RollbarHandlerTest.php 2.4 KB

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