| 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465 |
- <?php declare(strict_types=1);
- /*
- * 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', [$handler = new TestHandler]);
- $errHandler = new ErrorHandler($logger);
- $errHandler->registerErrorHandler([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());
- }
- public function testHandleException()
- {
- $logger = new Logger('test', [$handler = new TestHandler]);
- $errHandler = new ErrorHandler($logger);
- $errHandler->registerExceptionHandler(['Monolog\CustomTestException' => Logger::ALERT, 'Throwable' => Logger::WARNING], false);
- try {
- throw new CustomCustomException();
- $this->assertCount(1, $handler->getRecords());
- $this->assertTrue($handler->hasAlertRecords());
- } catch (\Throwable $e) {
- }
- try {
- throw new CustomTestException();
- $this->assertCount(2, $handler->getRecords());
- $this->assertTrue($handler->hasAlertRecords());
- } catch (\Throwable $e) {
- }
- try {
- throw new RuntimeException();
- $this->assertCount(3, $handler->getRecords());
- $this->assertTrue($handler->hasWarningRecords());
- } catch (\Throwable $e) {
- }
- }
- }
- class CustomTestException extends \Exception
- {
- }
- class CustomCustomException extends CustomTestException
- {
- }
|