mirror of
				https://github.com/Seldaek/monolog.git
				synced 2025-10-24 18:16:10 +02:00 
			
		
		
		
	
		
			
				
	
	
		
			66 lines
		
	
	
		
			2.0 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			66 lines
		
	
	
		
			2.0 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| <?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
 | |
| {
 | |
| }
 |