|
7 | 7 | use Monolog\Formatter\HtmlFormatter;
|
8 | 8 | use Monolog\Formatter\LineFormatter;
|
9 | 9 | use Monolog\Formatter\NormalizerFormatter;
|
| 10 | +use Monolog\Handler\FingersCrossedHandler; |
10 | 11 | use Monolog\Handler\LogEntriesHandler;
|
11 | 12 | use Monolog\Handler\NewRelicHandler;
|
12 | 13 | use Monolog\Handler\NullHandler;
|
@@ -432,4 +433,52 @@ public function __invoke()
|
432 | 433 |
|
433 | 434 | $this->assertSame(storage_path('logs/custom.log'), $url->getValue($handler));
|
434 | 435 | }
|
| 436 | + |
| 437 | + public function testWrappingHandlerInFingersCrossedWhenActionLevelIsUsed() |
| 438 | + { |
| 439 | + $config = $this->app['config']; |
| 440 | + |
| 441 | + $config->set('logging.channels.fingerscrossed', [ |
| 442 | + 'driver' => 'monolog', |
| 443 | + 'handler' => StreamHandler::class, |
| 444 | + 'level' => 'debug', |
| 445 | + 'action_level' => 'critical', |
| 446 | + 'with' => [ |
| 447 | + 'stream' => 'php://stderr', |
| 448 | + 'bubble' => false, |
| 449 | + ], |
| 450 | + ]); |
| 451 | + |
| 452 | + $manager = new LogManager($this->app); |
| 453 | + |
| 454 | + // create logger with handler specified from configuration |
| 455 | + $logger = $manager->channel('fingerscrossed'); |
| 456 | + $handlers = $logger->getLogger()->getHandlers(); |
| 457 | + |
| 458 | + $this->assertInstanceOf(Logger::class, $logger); |
| 459 | + $this->assertCount(1, $handlers); |
| 460 | + |
| 461 | + $expectedFingersCrossedHandler = $handlers[0]; |
| 462 | + $this->assertInstanceOf(FingersCrossedHandler::class, $expectedFingersCrossedHandler, ); |
| 463 | + |
| 464 | + $activationStrategyProp = new ReflectionProperty(get_class($expectedFingersCrossedHandler), 'activationStrategy'); |
| 465 | + $activationStrategyProp->setAccessible(true); |
| 466 | + $activationStrategyValue = $activationStrategyProp->getValue($expectedFingersCrossedHandler); |
| 467 | + |
| 468 | + $actionLevelProp = new ReflectionProperty(get_class($activationStrategyValue), 'actionLevel'); |
| 469 | + $actionLevelProp->setAccessible(true); |
| 470 | + $actionLevelValue = $actionLevelProp->getValue($activationStrategyValue); |
| 471 | + |
| 472 | + $this->assertEquals(Monolog::CRITICAL, $actionLevelValue); |
| 473 | + |
| 474 | + if (method_exists($expectedFingersCrossedHandler, 'getHandler')) { |
| 475 | + $expectedStreamHandler = $expectedFingersCrossedHandler->getHandler(); |
| 476 | + } else { |
| 477 | + $handlerProp = new ReflectionProperty(get_class($expectedFingersCrossedHandler), 'handler'); |
| 478 | + $handlerProp->setAccessible(true); |
| 479 | + $expectedStreamHandler = $handlerProp->getValue($expectedFingersCrossedHandler); |
| 480 | + } |
| 481 | + $this->assertInstanceOf(StreamHandler::class, $expectedStreamHandler); |
| 482 | + $this->assertEquals(Monolog::DEBUG, $expectedStreamHandler->getLevel()); |
| 483 | + } |
435 | 484 | }
|
0 commit comments