GelfHandlerTest.php 3.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122
  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 Gelf\Message;
  12. use Monolog\Level;
  13. use Monolog\Formatter\GelfMessageFormatter;
  14. class GelfHandlerTest extends \Monolog\Test\MonologTestCase
  15. {
  16. public function setUp(): void
  17. {
  18. if (!class_exists('Gelf\Publisher') || !class_exists('Gelf\Message')) {
  19. $this->markTestSkipped("graylog2/gelf-php not installed");
  20. }
  21. }
  22. /**
  23. * @covers Monolog\Handler\GelfHandler::__construct
  24. */
  25. public function testConstruct()
  26. {
  27. $handler = new GelfHandler($this->getMessagePublisher());
  28. $this->assertInstanceOf('Monolog\Handler\GelfHandler', $handler);
  29. }
  30. protected function getHandler($messagePublisher)
  31. {
  32. $handler = new GelfHandler($messagePublisher);
  33. return $handler;
  34. }
  35. protected function getMessagePublisher()
  36. {
  37. return $this->getMockBuilder('Gelf\Publisher')
  38. ->onlyMethods(['publish'])
  39. ->disableOriginalConstructor()
  40. ->getMock();
  41. }
  42. public function testDebug()
  43. {
  44. $record = $this->getRecord(Level::Debug, "A test debug message");
  45. $expectedMessage = new Message();
  46. $expectedMessage
  47. ->setLevel(7)
  48. ->setAdditional('facility', 'test')
  49. ->setShortMessage($record->message)
  50. ->setTimestamp($record->datetime)
  51. ;
  52. $messagePublisher = $this->getMessagePublisher();
  53. $messagePublisher->expects($this->once())
  54. ->method('publish')
  55. ->with($expectedMessage);
  56. $handler = $this->getHandler($messagePublisher);
  57. $handler->handle($record);
  58. }
  59. public function testWarning()
  60. {
  61. $record = $this->getRecord(Level::Warning, "A test warning message");
  62. $expectedMessage = new Message();
  63. $expectedMessage
  64. ->setLevel(4)
  65. ->setAdditional('facility', 'test')
  66. ->setShortMessage($record->message)
  67. ->setTimestamp($record->datetime)
  68. ;
  69. $messagePublisher = $this->getMessagePublisher();
  70. $messagePublisher->expects($this->once())
  71. ->method('publish')
  72. ->with($expectedMessage);
  73. $handler = $this->getHandler($messagePublisher);
  74. $handler->handle($record);
  75. }
  76. public function testInjectedGelfMessageFormatter()
  77. {
  78. $record = $this->getRecord(
  79. Level::Warning,
  80. "A test warning message",
  81. extra: ['blarg' => 'yep'],
  82. context: ['from' => 'logger'],
  83. );
  84. $expectedMessage = new Message();
  85. $expectedMessage
  86. ->setLevel(4)
  87. ->setAdditional('facility', 'test')
  88. ->setHost("mysystem")
  89. ->setShortMessage($record->message)
  90. ->setTimestamp($record->datetime)
  91. ->setAdditional("EXTblarg", 'yep')
  92. ->setAdditional("CTXfrom", 'logger')
  93. ;
  94. $messagePublisher = $this->getMessagePublisher();
  95. $messagePublisher->expects($this->once())
  96. ->method('publish')
  97. ->with($expectedMessage);
  98. $handler = $this->getHandler($messagePublisher);
  99. $handler->setFormatter(new GelfMessageFormatter('mysystem', 'EXT', 'CTX'));
  100. $handler->handle($record);
  101. }
  102. }