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:
committed by
Jordi Boggiano
parent
7ef89ec7c6
commit
c2d1d22b71
@@ -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",
|
||||||
|
@@ -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,27 +90,22 @@ 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;
|
||||||
}
|
}
|
||||||
|
|
||||||
public function flush()
|
public function flush()
|
||||||
{
|
{
|
||||||
if ($this->hasRecords) {
|
if ($this->hasRecords) {
|
||||||
$this->rollbarNotifier->flush();
|
$this->rollbarLogger->flush();
|
||||||
$this->hasRecords = false;
|
$this->hasRecords = false;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@@ -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
|
||||||
|
Reference in New Issue
Block a user