set(EnvironmentChecker::class, 'log_results_warning', true); Config::modify()->set(EnvironmentChecker::class, 'log_results_error', true); EnvironmentCheckSuite::register('test suite', new EnvironmentCheckerTest\CheckNoErrors()); $logger = $this->getMockBuilder(Logger::class) ->disableOriginalConstructor() ->onlyMethods(['log']) ->getMock(); $logger->expects($this->never())->method('log'); Injector::inst()->registerService($logger, LoggerInterface::class); (new EnvironmentChecker('test suite', 'test'))->index(); } public function testLogsWithWarnings() { Config::modify()->set(EnvironmentChecker::class, 'log_results_warning', true); Config::modify()->set(EnvironmentChecker::class, 'log_results_error', false); EnvironmentCheckSuite::register('test suite', new EnvironmentCheckerTest\CheckWarnings()); EnvironmentCheckSuite::register('test suite', new EnvironmentCheckerTest\CheckErrors()); $logger = $this->getMockBuilder(Logger::class) ->disableOriginalConstructor() ->onlyMethods(['log']) ->getMock(); $matcher = $this->once(); $logger->expects($matcher) ->method('log') ->willReturnCallback(function (mixed $level) use ($matcher) { match ($matcher->numberOfInvocations()) { 1 => $this->assertSame(LogLevel::WARNING, $level), }; }); Injector::inst()->registerService($logger, LoggerInterface::class); (new EnvironmentChecker('test suite', 'test'))->index(); } public function testLogsWithErrors() { Config::modify()->set(EnvironmentChecker::class, 'log_results_error', false); Config::modify()->set(EnvironmentChecker::class, 'log_results_error', true); EnvironmentCheckSuite::register('test suite', new EnvironmentCheckerTest\CheckWarnings()); EnvironmentCheckSuite::register('test suite', new EnvironmentCheckerTest\CheckErrors()); $logger = $this->getMockBuilder(Logger::class) ->disableOriginalConstructor() ->onlyMethods(['log']) ->getMock(); $matcher = $this->once(); $logger->expects($matcher) ->method('log') ->willReturnCallback(function (mixed $level) use ($matcher) { match ($matcher->numberOfInvocations()) { 1 => $this->assertSame(LogLevel::ALERT, $level), }; }); Injector::inst()->registerService($logger, LoggerInterface::class); (new EnvironmentChecker('test suite', 'test'))->index(); } }