1
0
mirror of https://github.com/Seldaek/monolog.git synced 2025-08-04 12:17:35 +02:00

Sync RollbarHandler with the latest changes rollbar/rollbar package (#1042)

* Sync RollbarHandler and RollbarHandlerTest with the latest changes in the rollbar/rollbar package (1.0+)
This commit is contained in:
Artur Moczulski
2018-06-17 07:16:39 -07:00
committed by Jordi Boggiano
parent 7ef89ec7c6
commit c2d1d22b71
3 changed files with 29 additions and 33 deletions

View File

@@ -28,7 +28,8 @@
"php-console/php-console": "^3.1.3", "php-console/php-console": "^3.1.3",
"jakub-onderka/php-parallel-lint": "^0.9", "jakub-onderka/php-parallel-lint": "^0.9",
"predis/predis": "^1.1", "predis/predis": "^1.1",
"phpspec/prophecy": "^1.6.1" "phpspec/prophecy": "^1.6.1",
"rollbar/rollbar": "^1.3"
}, },
"suggest": { "suggest": {
"graylog2/gelf-php": "Allow sending log messages to a GrayLog2 server", "graylog2/gelf-php": "Allow sending log messages to a GrayLog2 server",

View File

@@ -11,7 +11,7 @@
namespace Monolog\Handler; namespace Monolog\Handler;
use RollbarNotifier; use Rollbar\RollbarLogger;
use Throwable; use Throwable;
use Monolog\Logger; use Monolog\Logger;
@@ -19,7 +19,7 @@ use Monolog\Logger;
* Sends errors to Rollbar * Sends errors to Rollbar
* *
* If the context data contains a `payload` key, that is used as an array * If the context data contains a `payload` key, that is used as an array
* of payload options to RollbarNotifier's report_message/report_exception methods. * of payload options to RollbarLogger's log method.
* *
* Rollbar's context info will contain the context + extra keys from the log record * Rollbar's context info will contain the context + extra keys from the log record
* merged, and then on top of that a few keys: * merged, and then on top of that a few keys:
@@ -34,11 +34,9 @@ use Monolog\Logger;
class RollbarHandler extends AbstractProcessingHandler class RollbarHandler extends AbstractProcessingHandler
{ {
/** /**
* Rollbar notifier * @var RollbarLogger
*
* @var RollbarNotifier
*/ */
protected $rollbarNotifier; protected $rollbarLogger;
protected $levelMap = [ protected $levelMap = [
Logger::DEBUG => 'debug', Logger::DEBUG => 'debug',
@@ -61,13 +59,13 @@ class RollbarHandler extends AbstractProcessingHandler
protected $initialized = false; protected $initialized = false;
/** /**
* @param RollbarNotifier $rollbarNotifier RollbarNotifier object constructed with valid token * @param RollbarLogger $rollbarLogger RollbarLogger object constructed with valid token
* @param int $level The minimum logging level at which this handler will be triggered * @param int $level The minimum logging level at which this handler will be triggered
* @param bool $bubble Whether the messages that are handled can bubble up the stack or not * @param bool $bubble Whether the messages that are handled can bubble up the stack or not
*/ */
public function __construct(RollbarNotifier $rollbarNotifier, $level = Logger::ERROR, $bubble = true) public function __construct(RollbarLogger $rollbarLogger, $level = Logger::ERROR, $bubble = true)
{ {
$this->rollbarNotifier = $rollbarNotifier; $this->rollbarLogger = $rollbarLogger;
parent::__construct($level, $bubble); parent::__construct($level, $bubble);
} }
@@ -84,11 +82,6 @@ class RollbarHandler extends AbstractProcessingHandler
} }
$context = $record['context']; $context = $record['context'];
$payload = [];
if (isset($context['payload'])) {
$payload = $context['payload'];
unset($context['payload']);
}
$context = array_merge($context, $record['extra'], [ $context = array_merge($context, $record['extra'], [
'level' => $this->levelMap[$record['level']], 'level' => $this->levelMap[$record['level']],
'monolog_level' => $record['level_name'], 'monolog_level' => $record['level_name'],
@@ -97,19 +90,14 @@ class RollbarHandler extends AbstractProcessingHandler
]); ]);
if (isset($context['exception']) && $context['exception'] instanceof Throwable) { if (isset($context['exception']) && $context['exception'] instanceof Throwable) {
$payload['level'] = $context['level'];
$exception = $context['exception']; $exception = $context['exception'];
unset($context['exception']); unset($context['exception']);
$toLog = $exception;
$this->rollbarNotifier->report_exception($exception, $context, $payload);
} else { } else {
$this->rollbarNotifier->report_message( $toLog = $record['message'];
$record['message'],
$context['level'],
$context,
$payload
);
} }
$this->rollbarLogger->log($context['level'], $toLog, $context);
$this->hasRecords = true; $this->hasRecords = true;
} }
@@ -117,7 +105,7 @@ class RollbarHandler extends AbstractProcessingHandler
public function flush() public function flush()
{ {
if ($this->hasRecords) { if ($this->hasRecords) {
$this->rollbarNotifier->flush(); $this->rollbarLogger->flush();
$this->hasRecords = false; $this->hasRecords = false;
} }
} }

View File

@@ -15,6 +15,7 @@ use Exception;
use Monolog\Test\TestCase; use Monolog\Test\TestCase;
use Monolog\Logger; use Monolog\Logger;
use PHPUnit_Framework_MockObject_MockObject as MockObject; use PHPUnit_Framework_MockObject_MockObject as MockObject;
use Rollbar\RollbarLogger;
/** /**
* @author Erik Johansson <erik.pm.johansson@gmail.com> * @author Erik Johansson <erik.pm.johansson@gmail.com>
@@ -27,7 +28,7 @@ class RollbarHandlerTest extends TestCase
/** /**
* @var MockObject * @var MockObject
*/ */
private $rollbarNotifier; private $rollbarLogger;
/** /**
* @var array * @var array
@@ -38,7 +39,7 @@ class RollbarHandlerTest extends TestCase
{ {
parent::setUp(); parent::setUp();
$this->setupRollbarNotifierMock(); $this->setupRollbarLoggerMock();
} }
/** /**
@@ -54,15 +55,21 @@ class RollbarHandlerTest extends TestCase
$this->assertEquals('debug', $this->reportedExceptionArguments['payload']['level']); $this->assertEquals('debug', $this->reportedExceptionArguments['payload']['level']);
} }
private function setupRollbarNotifierMock() private function setupRollbarLoggerMock()
{ {
$this->rollbarNotifier = $this->getMockBuilder('RollbarNotifier') $config = array(
->setMethods(array('report_message', 'report_exception', 'flush')) 'access_token' => 'ad865e76e7fb496fab096ac07b1dbabb',
'environment' => 'test'
);
$this->rollbarLogger = $this->getMockBuilder(RollbarLogger::class)
->setConstructorArgs(array($config))
->setMethods(array('log'))
->getMock(); ->getMock();
$this->rollbarNotifier $this->rollbarLogger
->expects($this->any()) ->expects($this->any())
->method('report_exception') ->method('log')
->willReturnCallback(function ($exception, $context, $payload) { ->willReturnCallback(function ($exception, $context, $payload) {
$this->reportedExceptionArguments = compact('exception', 'context', 'payload'); $this->reportedExceptionArguments = compact('exception', 'context', 'payload');
}); });
@@ -70,7 +77,7 @@ class RollbarHandlerTest extends TestCase
private function createHandler(): RollbarHandler private function createHandler(): RollbarHandler
{ {
return new RollbarHandler($this->rollbarNotifier, Logger::DEBUG); return new RollbarHandler($this->rollbarLogger, Logger::DEBUG);
} }
private function createExceptionRecord($level = Logger::DEBUG, $message = 'test', $exception = null): array private function createExceptionRecord($level = Logger::DEBUG, $message = 'test', $exception = null): array