179 lines
5.8 KiB
179 lines
5.8 KiB
<?php
|
|
|
|
/*
|
|
* @copyright NetMonsters <team@netmonsters.ru>
|
|
* @link http://netmonsters.ru
|
|
* @package Majestic
|
|
* @subpackage UnitTests
|
|
* @since 2011-10-11
|
|
*
|
|
* Unit tests for ErrorHandler class
|
|
*/
|
|
|
|
require_once dirname(__FILE__) . '/../../classes/Env.class.php';
|
|
require_once dirname(__FILE__) . '/../../session/Session.php';
|
|
require_once dirname(__FILE__) . '/../../exception/ErrorHandler.php';
|
|
|
|
class ErrorHandlerTest extends PHPUnit_Framework_TestCase
|
|
{
|
|
public $old_eh = array('PHPUnit_Util_ErrorHandler', 'handleError');
|
|
|
|
protected $log_file_name = 'error_log_file';
|
|
|
|
public function setUp()
|
|
{
|
|
set_error_handler(array('ErrorHandler', 'error_handler'));
|
|
ob_start();
|
|
}
|
|
|
|
public function testErrorHandlerInit()
|
|
{
|
|
$my_eh = array('ErrorHandler', 'error_handler');
|
|
ErrorHandler::init();
|
|
$eh = set_error_handler($my_eh);
|
|
$this->assertInternalType('array', $eh);
|
|
$this->assertSame($eh, $my_eh);
|
|
}
|
|
|
|
public function testHandleError()
|
|
{
|
|
$this->setExpectedException('ErrorException', 'test error');
|
|
trigger_error("test error", E_USER_ERROR);
|
|
}
|
|
|
|
public function testHandleAt()
|
|
{
|
|
$my_eh = array('ErrorHandler', 'error_handler');
|
|
ErrorHandler::init();
|
|
set_error_handler($my_eh);
|
|
$var = '';
|
|
$ok = @$var['some'];
|
|
$this->assertSame('', $var);
|
|
ob_start();
|
|
$this->setExpectedException('ErrorException');
|
|
$ex = $var['some'];
|
|
}
|
|
|
|
/**
|
|
* @TODO: ErrorHandler->wrapTrace() not used
|
|
*/
|
|
public function testShowDebug()
|
|
{
|
|
try {
|
|
throw new ErrorException("test error", E_USER_ERROR);
|
|
}
|
|
catch (ErrorException $e) {
|
|
$_SESSION['some'] = 'value';
|
|
$result = ErrorHandler::showDebug($e);
|
|
$this->assertNotEmpty($result);
|
|
$this->assertStringStartsWith('<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">', $result);
|
|
$this->assertStringEndsWith('</html>', $result);
|
|
}
|
|
}
|
|
|
|
/**
|
|
* @TODO: ErrorHandler::wrapTrace not used
|
|
* @TODO: nl2br() adds html <br /> but leaves original linebreak line \n
|
|
*/
|
|
public function testWrapTrace()
|
|
{
|
|
$class = new ReflectionClass('ErrorHandler');
|
|
$method = $class->getMethod('WrapTrace');
|
|
$method->setAccessible(true);
|
|
$result = $method->invoke(null, "first line\nsecond line");
|
|
$this->assertSame("<code>first line<br />\nsecond line</code>", $result);
|
|
$result = $method->invoke(null, "first line\r\nsecond line");
|
|
$this->assertSame("<code>first line<br />\r\nsecond line</code>", $result);
|
|
$result = $method->invoke(null, "first line\r\n\r\nsecond line");
|
|
$this->assertSame("<code>first line<br />\r\n<br />\r\nsecond line</code>", $result);
|
|
}
|
|
|
|
/**
|
|
* @runInSeparateProcess
|
|
*/
|
|
public function testLogErrorDefaultException()
|
|
{
|
|
$ex = new Exception('message', 123);
|
|
ini_set('error_log', $this->log_file_name);
|
|
ErrorHandler::logError($ex);
|
|
$log = file_get_contents($this->log_file_name);
|
|
$this->assertContains('PHP Unknown Error: Exception: message in ', $log);
|
|
}
|
|
|
|
/**
|
|
* @runInSeparateProcess
|
|
*/
|
|
public function testLogErrorDefaultExceptionWithHTTP()
|
|
{
|
|
$_SERVER['REQUEST_METHOD'] = 'GET';
|
|
$_SERVER['REQUEST_URI'] = '/somelongurl';
|
|
$_SERVER['HTTP_REFERER'] = 'http://referrer/url';
|
|
$this->assertEquals('GET', ENV::Server('REQUEST_METHOD'));
|
|
$this->assertEquals('/somelongurl', ENV::Server('REQUEST_URI'));
|
|
$this->assertEquals('http://referrer/url', ENV::Server('HTTP_REFERER'));
|
|
|
|
$ex = new Exception('message', 123);
|
|
ini_set('error_log', $this->log_file_name);
|
|
ErrorHandler::logError($ex);
|
|
$log = file_get_contents($this->log_file_name);
|
|
$this->assertContains('PHP Unknown Error: Exception: message in ', $log);
|
|
$this->assertContains('URL: GET /somelongurl, referrer: http://referrer/url', $log);
|
|
}
|
|
|
|
/**
|
|
* @runInSeparateProcess
|
|
*/
|
|
public function testLogErrorCustomException()
|
|
{
|
|
$ex = new LogicException('Logic', 333);
|
|
ini_set('error_log', $this->log_file_name);
|
|
ErrorHandler::logError($ex);
|
|
$log = file_get_contents($this->log_file_name);
|
|
$this->assertContains('PHP Unknown Error: LogicException: Logic in ', $log);
|
|
}
|
|
|
|
/**
|
|
* @runInSeparateProcess
|
|
*/
|
|
public function testLogErrorErrorExceptionNotice()
|
|
{
|
|
$ex = new ErrorException('message', 321, E_NOTICE);
|
|
ini_set('error_log', $this->log_file_name);
|
|
ErrorHandler::logError($ex);
|
|
$log = file_get_contents($this->log_file_name);
|
|
$this->assertContains('PHP Notice: message in ', $log);
|
|
}
|
|
|
|
/**
|
|
* @runInSeparateProcess
|
|
*/
|
|
public function testLogErrorErrorExceptionWarning()
|
|
{
|
|
$ex = new ErrorException('message', 321, E_WARNING);
|
|
ini_set('error_log', $this->log_file_name);
|
|
ErrorHandler::logError($ex);
|
|
$log = file_get_contents($this->log_file_name);
|
|
$this->assertContains('PHP Warning: message in ', $log);
|
|
}
|
|
|
|
/**
|
|
* @runInSeparateProcess
|
|
*/
|
|
public function testLogErrorErrorExceptionFatal()
|
|
{
|
|
$ex = new ErrorException('message', 321, E_ERROR);
|
|
ini_set('error_log', $this->log_file_name);
|
|
ErrorHandler::logError($ex);
|
|
$log = file_get_contents($this->log_file_name);
|
|
$this->assertContains('PHP Fatal Error: message in ', $log);
|
|
}
|
|
|
|
public function tearDown()
|
|
{
|
|
if (file_exists($this->log_file_name) && is_writable($this->log_file_name)) {
|
|
unlink($this->log_file_name);
|
|
}
|
|
ini_set('error_log', 'php://stderr');
|
|
set_error_handler($this->old_eh);
|
|
}
|
|
}
|