AbstractProcessingHandlerTest.php 4.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135
  1. <?php declare(strict_types=1);
  2. /*
  3. * This file is part of the Monolog package.
  4. *
  5. * (c) Jordi Boggiano <j.boggiano@seld.be>
  6. *
  7. * For the full copyright and license information, please view the LICENSE
  8. * file that was distributed with this source code.
  9. */
  10. namespace Monolog\Handler;
  11. use Monolog\Test\TestCase;
  12. use Monolog\Level;
  13. use Monolog\Processor\WebProcessor;
  14. use Monolog\Formatter\LineFormatter;
  15. class AbstractProcessingHandlerTest extends TestCase
  16. {
  17. /**
  18. * @covers Monolog\Handler\FormattableHandlerTrait::getFormatter
  19. * @covers Monolog\Handler\FormattableHandlerTrait::setFormatter
  20. */
  21. public function testConstructAndGetSet()
  22. {
  23. $handler = $this->getMockForAbstractClass('Monolog\Handler\AbstractProcessingHandler', [Level::Warning, false]);
  24. $handler->setFormatter($formatter = new LineFormatter);
  25. $this->assertSame($formatter, $handler->getFormatter());
  26. }
  27. /**
  28. * @covers Monolog\Handler\AbstractProcessingHandler::handle
  29. */
  30. public function testHandleLowerLevelMessage()
  31. {
  32. $handler = $this->getMockForAbstractClass('Monolog\Handler\AbstractProcessingHandler', [Level::Warning, true]);
  33. $this->assertFalse($handler->handle($this->getRecord(Level::Debug)));
  34. }
  35. /**
  36. * @covers Monolog\Handler\AbstractProcessingHandler::handle
  37. */
  38. public function testHandleBubbling()
  39. {
  40. $handler = $this->getMockForAbstractClass('Monolog\Handler\AbstractProcessingHandler', [Level::Debug, true]);
  41. $this->assertFalse($handler->handle($this->getRecord()));
  42. }
  43. /**
  44. * @covers Monolog\Handler\AbstractProcessingHandler::handle
  45. */
  46. public function testHandleNotBubbling()
  47. {
  48. $handler = $this->getMockForAbstractClass('Monolog\Handler\AbstractProcessingHandler', [Level::Debug, false]);
  49. $this->assertTrue($handler->handle($this->getRecord()));
  50. }
  51. /**
  52. * @covers Monolog\Handler\AbstractProcessingHandler::handle
  53. */
  54. public function testHandleIsFalseWhenNotHandled()
  55. {
  56. $handler = $this->getMockForAbstractClass('Monolog\Handler\AbstractProcessingHandler', [Level::Warning, false]);
  57. $this->assertTrue($handler->handle($this->getRecord()));
  58. $this->assertFalse($handler->handle($this->getRecord(Level::Debug)));
  59. }
  60. /**
  61. * @covers Monolog\Handler\AbstractProcessingHandler::processRecord
  62. */
  63. public function testProcessRecord()
  64. {
  65. $handler = $this->getMockForAbstractClass('Monolog\Handler\AbstractProcessingHandler');
  66. $handler->pushProcessor(new WebProcessor([
  67. 'REQUEST_URI' => '',
  68. 'REQUEST_METHOD' => '',
  69. 'REMOTE_ADDR' => '',
  70. 'SERVER_NAME' => '',
  71. 'UNIQUE_ID' => '',
  72. ]));
  73. $handledRecord = null;
  74. $handler->expects($this->once())
  75. ->method('write')
  76. ->will($this->returnCallback(function ($record) use (&$handledRecord) {
  77. $handledRecord = $record;
  78. }))
  79. ;
  80. $handler->handle($this->getRecord());
  81. $this->assertEquals(6, count($handledRecord['extra']));
  82. }
  83. /**
  84. * @covers Monolog\Handler\ProcessableHandlerTrait::pushProcessor
  85. * @covers Monolog\Handler\ProcessableHandlerTrait::popProcessor
  86. */
  87. public function testPushPopProcessor()
  88. {
  89. $logger = $this->getMockForAbstractClass('Monolog\Handler\AbstractProcessingHandler');
  90. $processor1 = new WebProcessor;
  91. $processor2 = new WebProcessor;
  92. $logger->pushProcessor($processor1);
  93. $logger->pushProcessor($processor2);
  94. $this->assertEquals($processor2, $logger->popProcessor());
  95. $this->assertEquals($processor1, $logger->popProcessor());
  96. $this->expectException(\LogicException::class);
  97. $logger->popProcessor();
  98. }
  99. /**
  100. * @covers Monolog\Handler\ProcessableHandlerTrait::pushProcessor
  101. */
  102. public function testPushProcessorWithNonCallable()
  103. {
  104. $handler = $this->getMockForAbstractClass('Monolog\Handler\AbstractProcessingHandler');
  105. $this->expectException(\TypeError::class);
  106. $handler->pushProcessor(new \stdClass());
  107. }
  108. /**
  109. * @covers Monolog\Handler\FormattableHandlerTrait::getFormatter
  110. * @covers Monolog\Handler\FormattableHandlerTrait::getDefaultFormatter
  111. */
  112. public function testGetFormatterInitializesDefault()
  113. {
  114. $handler = $this->getMockForAbstractClass('Monolog\Handler\AbstractProcessingHandler');
  115. $this->assertInstanceOf(LineFormatter::class, $handler->getFormatter());
  116. }
  117. }