RollbarHandlerTest.php 2.3 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889
  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 as 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. class RollbarHandlerTest extends TestCase
  23. {
  24. /**
  25. * @var MockObject
  26. */
  27. private $rollbarLogger;
  28. /**
  29. * @var array
  30. */
  31. private $reportedExceptionArguments = null;
  32. protected function setUp()
  33. {
  34. parent::setUp();
  35. $this->setupRollbarLoggerMock();
  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->createExceptionRecord(Logger::DEBUG));
  45. $this->assertEquals('debug', $this->reportedExceptionArguments['payload']['level']);
  46. }
  47. private function setupRollbarLoggerMock()
  48. {
  49. $config = array(
  50. 'access_token' => 'ad865e76e7fb496fab096ac07b1dbabb',
  51. 'environment' => 'test',
  52. );
  53. $this->rollbarLogger = $this->getMockBuilder(RollbarLogger::class)
  54. ->setConstructorArgs(array($config))
  55. ->setMethods(array('log'))
  56. ->getMock();
  57. $this->rollbarLogger
  58. ->expects($this->any())
  59. ->method('log')
  60. ->willReturnCallback(function ($exception, $context, $payload) {
  61. $this->reportedExceptionArguments = compact('exception', 'context', 'payload');
  62. });
  63. }
  64. private function createHandler(): RollbarHandler
  65. {
  66. return new RollbarHandler($this->rollbarLogger, Logger::DEBUG);
  67. }
  68. private function createExceptionRecord($level = Logger::DEBUG, $message = 'test', $exception = null): array
  69. {
  70. return $this->getRecord($level, $message, [
  71. 'exception' => $exception ?: new Exception(),
  72. ]);
  73. }
  74. }