mirror of
https://github.com/Seldaek/monolog.git
synced 2025-08-11 15:44:34 +02:00
Add tests and fix issue with array_merge
This commit is contained in:
@@ -78,7 +78,12 @@ class ErrorHandler
|
|||||||
public function registerErrorHandler(array $levelMap = array(), $callPrevious = true, $errorTypes = -1)
|
public function registerErrorHandler(array $levelMap = array(), $callPrevious = true, $errorTypes = -1)
|
||||||
{
|
{
|
||||||
$prev = set_error_handler(array($this, 'handleError'), $errorTypes);
|
$prev = set_error_handler(array($this, 'handleError'), $errorTypes);
|
||||||
$this->errorLevelMap = array_merge($this->defaultErrorLevelMap(), $levelMap);
|
$this->errorLevelMap = $this->defaultErrorLevelMap();
|
||||||
|
// merging the map into the defaults by hand because array_merge
|
||||||
|
// trips up on numeric keys
|
||||||
|
foreach ($levelMap as $key => $val) {
|
||||||
|
$this->errorLevelMap[$key] = $val;
|
||||||
|
}
|
||||||
if ($callPrevious) {
|
if ($callPrevious) {
|
||||||
$this->previousErrorHandler = $prev ?: true;
|
$this->previousErrorHandler = $prev ?: true;
|
||||||
}
|
}
|
||||||
|
31
tests/Monolog/ErrorHandlerTest.php
Normal file
31
tests/Monolog/ErrorHandlerTest.php
Normal file
@@ -0,0 +1,31 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
/*
|
||||||
|
* This file is part of the Monolog package.
|
||||||
|
*
|
||||||
|
* (c) Jordi Boggiano <j.boggiano@seld.be>
|
||||||
|
*
|
||||||
|
* For the full copyright and license information, please view the LICENSE
|
||||||
|
* file that was distributed with this source code.
|
||||||
|
*/
|
||||||
|
|
||||||
|
namespace Monolog;
|
||||||
|
|
||||||
|
use Monolog\Handler\TestHandler;
|
||||||
|
|
||||||
|
class ErrorHandlerTest extends \PHPUnit_Framework_TestCase
|
||||||
|
{
|
||||||
|
public function testHandleError()
|
||||||
|
{
|
||||||
|
$logger = new Logger('test', array($handler = new TestHandler));
|
||||||
|
$errHandler = new ErrorHandler($logger);
|
||||||
|
|
||||||
|
$errHandler->registerErrorHandler(array(E_USER_NOTICE => Logger::EMERGENCY), false);
|
||||||
|
trigger_error('Foo', E_USER_ERROR);
|
||||||
|
$this->assertCount(1, $handler->getRecords());
|
||||||
|
$this->assertTrue($handler->hasErrorRecords());
|
||||||
|
trigger_error('Foo', E_USER_NOTICE);
|
||||||
|
$this->assertCount(2, $handler->getRecords());
|
||||||
|
$this->assertTrue($handler->hasEmergencyRecords());
|
||||||
|
}
|
||||||
|
}
|
Reference in New Issue
Block a user