2
0

RollbarHandlerTest.php 2.3 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485
  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 Exception;
  12. use Monolog\Level;
  13. use PHPUnit\Framework\MockObject\MockObject;
  14. use Rollbar\RollbarLogger;
  15. /**
  16. * @author Erik Johansson <erik.pm.johansson@gmail.com>
  17. * @see https://rollbar.com/docs/notifier/rollbar-php/
  18. *
  19. * @coversDefaultClass Monolog\Handler\RollbarHandler
  20. *
  21. * @requires function \Rollbar\RollbarLogger::__construct
  22. */
  23. class RollbarHandlerTest extends \Monolog\Test\MonologTestCase
  24. {
  25. private RollbarLogger&MockObject $rollbarLogger;
  26. private array $reportedExceptionArguments;
  27. protected function setUp(): void
  28. {
  29. parent::setUp();
  30. $this->setupRollbarLoggerMock();
  31. }
  32. public function tearDown(): void
  33. {
  34. parent::tearDown();
  35. unset($this->rollbarLogger, $this->reportedExceptionArguments);
  36. }
  37. /**
  38. * When reporting exceptions to Rollbar the
  39. * level has to be set in the payload data
  40. */
  41. public function testExceptionLogLevel()
  42. {
  43. $handler = $this->createHandler();
  44. $handler->handle($this->getRecord(Level::Debug, context: ['exception' => $e = new Exception()]));
  45. $this->assertEquals('debug', $this->reportedExceptionArguments['payload']['level']);
  46. $this->assertSame($e, $this->reportedExceptionArguments['context']);
  47. }
  48. private function setupRollbarLoggerMock()
  49. {
  50. $config = [
  51. 'access_token' => 'ad865e76e7fb496fab096ac07b1dbabb',
  52. 'environment' => 'test',
  53. ];
  54. $this->rollbarLogger = $this->getMockBuilder(RollbarLogger::class)
  55. ->setConstructorArgs([$config])
  56. ->onlyMethods(['log'])
  57. ->getMock();
  58. $this->rollbarLogger
  59. ->expects($this->any())
  60. ->method('log')
  61. ->willReturnCallback(function ($exception, $context, $payload) {
  62. $this->reportedExceptionArguments = compact('exception', 'context', 'payload');
  63. });
  64. }
  65. private function createHandler(): RollbarHandler
  66. {
  67. return new RollbarHandler($this->rollbarLogger, Level::Debug);
  68. }
  69. }