setAccessible(true); $reflectionProperty->setValue(null, null); $factory = new LoggerManager( $this->createStub(IManageConfigValues::class), $this->createStub(LoggerFactory::class) ); $this->assertInstanceOf(LoggerInterface::class, $factory->getLogger()); } public function testGetLoggerReturnsSameObject(): void { $reflectionProperty = new \ReflectionProperty(LoggerManager::class, 'logger'); $reflectionProperty->setAccessible(true); $reflectionProperty->setValue(null, null); $factory = new LoggerManager( $this->createStub(IManageConfigValues::class), $this->createStub(LoggerFactory::class) ); $this->assertSame($factory->getLogger(), $factory->getLogger()); } public function testGetLoggerWithDebugDisabledReturnsNullLogger(): void { $config = $this->createStub(IManageConfigValues::class); $config->method('get')->willReturnMap([ ['system', 'debugging', null, false], ]); $reflectionProperty = new \ReflectionProperty(LoggerManager::class, 'logger'); $reflectionProperty->setAccessible(true); $reflectionProperty->setValue(null, null); $factory = new LoggerManager( $config, $this->createStub(LoggerFactory::class) ); $this->assertInstanceOf(NullLogger::class, $factory->getLogger()); } public function testGetLoggerWithProfilerEnabledReturnsProfilerLogger(): void { $config = $this->createStub(IManageConfigValues::class); $config->method('get')->willReturnMap([ ['system', 'debugging', null, false], ['system', 'profiling', null, true], ]); $reflectionProperty = new \ReflectionProperty(LoggerManager::class, 'logger'); $reflectionProperty->setAccessible(true); $reflectionProperty->setValue(null, null); $factory = new LoggerManager( $config, $this->createStub(LoggerFactory::class) ); $this->assertInstanceOf(ProfilerLogger::class, $factory->getLogger()); } public function testChangeChannelReturnsDifferentLogger(): void { $config = $this->createStub(IManageConfigValues::class); $config->method('get')->willReturnMap([ ['system', 'debugging', null, false], ['system', 'profiling', null, true], ]); $reflectionProperty = new \ReflectionProperty(LoggerManager::class, 'logger'); $reflectionProperty->setAccessible(true); $reflectionProperty->setValue(null, null); $factory = new LoggerManager( $config, $this->createStub(LoggerFactory::class) ); $logger1 = $factory->getLogger(); $factory->changeLogChannel(LogChannel::CONSOLE); $this->assertNotSame($logger1, $factory->getLogger()); } }