GelfHandlerTest.php 4.0 KB

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