AbstractProcessingHandlerTest.php 4.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134
  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\Level;
  12. use Monolog\Processor\WebProcessor;
  13. use Monolog\Formatter\LineFormatter;
  14. class AbstractProcessingHandlerTest extends \Monolog\Test\MonologTestCase
  15. {
  16. /**
  17. * @covers Monolog\Handler\FormattableHandlerTrait::getFormatter
  18. * @covers Monolog\Handler\FormattableHandlerTrait::setFormatter
  19. */
  20. public function testConstructAndGetSet()
  21. {
  22. $handler = $this->getMockBuilder('Monolog\Handler\AbstractProcessingHandler')->setConstructorArgs([Level::Warning, false])->onlyMethods(['write'])->getMock();
  23. $handler->setFormatter($formatter = new LineFormatter);
  24. $this->assertSame($formatter, $handler->getFormatter());
  25. }
  26. /**
  27. * @covers Monolog\Handler\AbstractProcessingHandler::handle
  28. */
  29. public function testHandleLowerLevelMessage()
  30. {
  31. $handler = $this->getMockBuilder('Monolog\Handler\AbstractProcessingHandler')->setConstructorArgs([Level::Warning, true])->onlyMethods(['write'])->getMock();
  32. $this->assertFalse($handler->handle($this->getRecord(Level::Debug)));
  33. }
  34. /**
  35. * @covers Monolog\Handler\AbstractProcessingHandler::handle
  36. */
  37. public function testHandleBubbling()
  38. {
  39. $handler = $this->getMockBuilder('Monolog\Handler\AbstractProcessingHandler')->setConstructorArgs([Level::Debug, true])->onlyMethods(['write'])->getMock();
  40. $this->assertFalse($handler->handle($this->getRecord()));
  41. }
  42. /**
  43. * @covers Monolog\Handler\AbstractProcessingHandler::handle
  44. */
  45. public function testHandleNotBubbling()
  46. {
  47. $handler = $this->getMockBuilder('Monolog\Handler\AbstractProcessingHandler')->setConstructorArgs([Level::Debug, false])->onlyMethods(['write'])->getMock();
  48. $this->assertTrue($handler->handle($this->getRecord()));
  49. }
  50. /**
  51. * @covers Monolog\Handler\AbstractProcessingHandler::handle
  52. */
  53. public function testHandleIsFalseWhenNotHandled()
  54. {
  55. $handler = $this->getMockBuilder('Monolog\Handler\AbstractProcessingHandler')->setConstructorArgs([Level::Warning, false])->onlyMethods(['write'])->getMock();
  56. $this->assertTrue($handler->handle($this->getRecord()));
  57. $this->assertFalse($handler->handle($this->getRecord(Level::Debug)));
  58. }
  59. /**
  60. * @covers Monolog\Handler\AbstractProcessingHandler::processRecord
  61. */
  62. public function testProcessRecord()
  63. {
  64. $handler = $this->createPartialMock('Monolog\Handler\AbstractProcessingHandler', ['write']);
  65. $handler->pushProcessor(new WebProcessor([
  66. 'REQUEST_URI' => '',
  67. 'REQUEST_METHOD' => '',
  68. 'REMOTE_ADDR' => '',
  69. 'SERVER_NAME' => '',
  70. 'UNIQUE_ID' => '',
  71. ]));
  72. $handledRecord = null;
  73. $handler->expects($this->once())
  74. ->method('write')
  75. ->willReturnCallback(function ($record) use (&$handledRecord) {
  76. $handledRecord = $record;
  77. })
  78. ;
  79. $handler->handle($this->getRecord());
  80. $this->assertEquals(6, \count($handledRecord['extra']));
  81. }
  82. /**
  83. * @covers Monolog\Handler\ProcessableHandlerTrait::pushProcessor
  84. * @covers Monolog\Handler\ProcessableHandlerTrait::popProcessor
  85. */
  86. public function testPushPopProcessor()
  87. {
  88. $logger = $this->createPartialMock('Monolog\Handler\AbstractProcessingHandler', ['write']);
  89. $processor1 = new WebProcessor;
  90. $processor2 = new WebProcessor;
  91. $logger->pushProcessor($processor1);
  92. $logger->pushProcessor($processor2);
  93. $this->assertEquals($processor2, $logger->popProcessor());
  94. $this->assertEquals($processor1, $logger->popProcessor());
  95. $this->expectException(\LogicException::class);
  96. $logger->popProcessor();
  97. }
  98. /**
  99. * @covers Monolog\Handler\ProcessableHandlerTrait::pushProcessor
  100. */
  101. public function testPushProcessorWithNonCallable()
  102. {
  103. $handler = $this->createPartialMock('Monolog\Handler\AbstractProcessingHandler', ['write']);
  104. $this->expectException(\TypeError::class);
  105. $handler->pushProcessor(new \stdClass());
  106. }
  107. /**
  108. * @covers Monolog\Handler\FormattableHandlerTrait::getFormatter
  109. * @covers Monolog\Handler\FormattableHandlerTrait::getDefaultFormatter
  110. */
  111. public function testGetFormatterInitializesDefault()
  112. {
  113. $handler = $this->createPartialMock('Monolog\Handler\AbstractProcessingHandler', ['write']);
  114. $this->assertInstanceOf(LineFormatter::class, $handler->getFormatter());
  115. }
  116. }