mirror of
https://github.com/kamilwylegala/cakephp2-php8.git
synced 2024-11-15 03:18:26 +00:00
Fixing incorrect exit codes on console exceptions.
Uncaught exceptions on the console would result in exit code 0. This is not helpful in *nix scripting. - Update the ConsoleErrorHandler to not inherit from the web error handler. - Make ErrorHandler::_mapErrorCode() public as it isn't overly private. - Make ConsoleErrorHandler methods instance methods so mocking can be done. - Add a _stop method to correctly exit. - Update tests.
This commit is contained in:
parent
bab131b8fd
commit
aa7448e3ed
4 changed files with 43 additions and 14 deletions
|
@ -25,7 +25,7 @@ App::uses('CakeLog', 'Log');
|
||||||
*
|
*
|
||||||
* @package Cake.Console
|
* @package Cake.Console
|
||||||
*/
|
*/
|
||||||
class ConsoleErrorHandler extends ErrorHandler {
|
class ConsoleErrorHandler {
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Standard error stream.
|
* Standard error stream.
|
||||||
|
@ -52,12 +52,13 @@ class ConsoleErrorHandler extends ErrorHandler {
|
||||||
* @param Exception $exception The exception to handle
|
* @param Exception $exception The exception to handle
|
||||||
* @return void
|
* @return void
|
||||||
*/
|
*/
|
||||||
public static function handleException(Exception $exception) {
|
public function handleException(Exception $exception) {
|
||||||
$stderr = self::getStderr();
|
$stderr = self::getStderr();
|
||||||
$stderr->write(__d('cake_console', "<error>Error:</error> %s\n%s",
|
$stderr->write(__d('cake_console', "<error>Error:</error> %s\n%s",
|
||||||
$exception->getMessage(),
|
$exception->getMessage(),
|
||||||
$exception->getTraceAsString()
|
$exception->getTraceAsString()
|
||||||
));
|
));
|
||||||
|
$this->_stop($exception->getCode() ? $exception->getCode() : 1);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -71,12 +72,12 @@ class ConsoleErrorHandler extends ErrorHandler {
|
||||||
* @param array $context The backtrace of the error.
|
* @param array $context The backtrace of the error.
|
||||||
* @return void
|
* @return void
|
||||||
*/
|
*/
|
||||||
public static function handleError($code, $description, $file = null, $line = null, $context = null) {
|
public function handleError($code, $description, $file = null, $line = null, $context = null) {
|
||||||
if (error_reporting() === 0) {
|
if (error_reporting() === 0) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
$stderr = self::getStderr();
|
$stderr = self::getStderr();
|
||||||
list($name, $log) = self::_mapErrorCode($code);
|
list($name, $log) = ErrorHandler::mapErrorCode($code);
|
||||||
$message = __d('cake_console', '%s in [%s, line %s]', $description, $file, $line);
|
$message = __d('cake_console', '%s in [%s, line %s]', $description, $file, $line);
|
||||||
$stderr->write(__d('cake_console', "<error>%s Error:</error> %s\n", $name, $message));
|
$stderr->write(__d('cake_console', "<error>%s Error:</error> %s\n", $name, $message));
|
||||||
|
|
||||||
|
@ -85,4 +86,13 @@ class ConsoleErrorHandler extends ErrorHandler {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Wrapper for exit(), used for testing.
|
||||||
|
*
|
||||||
|
* @param $code int The exit code.
|
||||||
|
*/
|
||||||
|
protected function _stop($code = 0) {
|
||||||
|
exit($code);
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -135,8 +135,9 @@ class ShellDispatcher {
|
||||||
App::build();
|
App::build();
|
||||||
}
|
}
|
||||||
require_once CAKE . 'Console' . DS . 'ConsoleErrorHandler.php';
|
require_once CAKE . 'Console' . DS . 'ConsoleErrorHandler.php';
|
||||||
set_exception_handler(array('ConsoleErrorHandler', 'handleException'));
|
$ErrorHandler = new ConsoleErrorHandler();
|
||||||
set_error_handler(array('ConsoleErrorHandler', 'handleError'), Configure::read('Error.level'));
|
set_exception_handler(array($ErrorHandler, 'handleException'));
|
||||||
|
set_error_handler(array($ErrorHandler, 'handleError'), Configure::read('Error.level'));
|
||||||
|
|
||||||
if (!defined('FULL_BASE_URL')) {
|
if (!defined('FULL_BASE_URL')) {
|
||||||
define('FULL_BASE_URL', 'http://localhost');
|
define('FULL_BASE_URL', 'http://localhost');
|
||||||
|
|
|
@ -157,7 +157,7 @@ class ErrorHandler {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
$errorConfig = Configure::read('Error');
|
$errorConfig = Configure::read('Error');
|
||||||
list($error, $log) = self::_mapErrorCode($code);
|
list($error, $log) = self::mapErrorCode($code);
|
||||||
|
|
||||||
$debug = Configure::read('debug');
|
$debug = Configure::read('debug');
|
||||||
if ($debug) {
|
if ($debug) {
|
||||||
|
@ -189,7 +189,7 @@ class ErrorHandler {
|
||||||
* @param integer $code Error code to map
|
* @param integer $code Error code to map
|
||||||
* @return array Array of error word, and log location.
|
* @return array Array of error word, and log location.
|
||||||
*/
|
*/
|
||||||
protected static function _mapErrorCode($code) {
|
public static function mapErrorCode($code) {
|
||||||
$error = $log = null;
|
$error = $log = null;
|
||||||
switch ($code) {
|
switch ($code) {
|
||||||
case E_PARSE:
|
case E_PARSE:
|
||||||
|
|
|
@ -33,6 +33,7 @@ class ConsoleErrorHandlerTest extends CakeTestCase {
|
||||||
*/
|
*/
|
||||||
public function setUp() {
|
public function setUp() {
|
||||||
parent::setUp();
|
parent::setUp();
|
||||||
|
$this->Error = $this->getMock('ConsoleErrorHandler', array('_stop'));
|
||||||
ConsoleErrorHandler::$stderr = $this->getMock('ConsoleOutput', array(), array(), '', false);
|
ConsoleErrorHandler::$stderr = $this->getMock('ConsoleOutput', array(), array(), '', false);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -42,6 +43,7 @@ class ConsoleErrorHandlerTest extends CakeTestCase {
|
||||||
* @return void
|
* @return void
|
||||||
*/
|
*/
|
||||||
public function tearDown() {
|
public function tearDown() {
|
||||||
|
unset($this->Error);
|
||||||
parent::tearDown();
|
parent::tearDown();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -55,7 +57,7 @@ class ConsoleErrorHandlerTest extends CakeTestCase {
|
||||||
ConsoleErrorHandler::$stderr->expects($this->once())->method('write')
|
ConsoleErrorHandler::$stderr->expects($this->once())->method('write')
|
||||||
->with($content);
|
->with($content);
|
||||||
|
|
||||||
ConsoleErrorHandler::handleError(E_NOTICE, 'This is a notice error', '/some/file', 275);
|
$this->Error->handleError(E_NOTICE, 'This is a notice error', '/some/file', 275);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -68,7 +70,11 @@ class ConsoleErrorHandlerTest extends CakeTestCase {
|
||||||
ConsoleErrorHandler::$stderr->expects($this->once())->method('write')
|
ConsoleErrorHandler::$stderr->expects($this->once())->method('write')
|
||||||
->with($this->stringContains('Missing action'));
|
->with($this->stringContains('Missing action'));
|
||||||
|
|
||||||
ConsoleErrorHandler::handleException($exception);
|
$this->Error->expects($this->once())
|
||||||
|
->method('_stop')
|
||||||
|
->with(404);
|
||||||
|
|
||||||
|
$this->Error->handleException($exception);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -82,7 +88,11 @@ class ConsoleErrorHandlerTest extends CakeTestCase {
|
||||||
ConsoleErrorHandler::$stderr->expects($this->once())->method('write')
|
ConsoleErrorHandler::$stderr->expects($this->once())->method('write')
|
||||||
->with($this->stringContains('Too many parameters.'));
|
->with($this->stringContains('Too many parameters.'));
|
||||||
|
|
||||||
ConsoleErrorHandler::handleException($exception);
|
$this->Error->expects($this->once())
|
||||||
|
->method('_stop')
|
||||||
|
->with(1);
|
||||||
|
|
||||||
|
$this->Error->handleException($exception);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -96,7 +106,11 @@ class ConsoleErrorHandlerTest extends CakeTestCase {
|
||||||
ConsoleErrorHandler::$stderr->expects($this->once())->method('write')
|
ConsoleErrorHandler::$stderr->expects($this->once())->method('write')
|
||||||
->with($this->stringContains('dont use me in cli.'));
|
->with($this->stringContains('dont use me in cli.'));
|
||||||
|
|
||||||
ConsoleErrorHandler::handleException($exception);
|
$this->Error->expects($this->once())
|
||||||
|
->method('_stop')
|
||||||
|
->with(404);
|
||||||
|
|
||||||
|
$this->Error->handleException($exception);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -110,7 +124,11 @@ class ConsoleErrorHandlerTest extends CakeTestCase {
|
||||||
ConsoleErrorHandler::$stderr->expects($this->once())->method('write')
|
ConsoleErrorHandler::$stderr->expects($this->once())->method('write')
|
||||||
->with($this->stringContains('dont use me in cli.'));
|
->with($this->stringContains('dont use me in cli.'));
|
||||||
|
|
||||||
ConsoleErrorHandler::handleException($exception);
|
$this->Error->expects($this->once())
|
||||||
|
->method('_stop')
|
||||||
|
->with(500);
|
||||||
|
|
||||||
|
$this->Error->handleException($exception);
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue