1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43
|
--TEST--
PEAR_ErrorStack->push() message callback set in setMsgCallback()
--SKIPIF--
<?php
if (!getenv('PHP_PEAR_RUNTESTS')) {
echo 'skip';
}
?>
--FILE--
<?php
require_once dirname(__FILE__) . DIRECTORY_SEPARATOR . 'setup.php.inc';
function messagecallback(&$stack, $err)
{
global $wasCalled, $phpunit;
$phpunit->assertEquals(4, $err['code'], 'wrong message code');
$phpunit->assertEquals(array('hello' => 6), $err['params'], 'wrong message params');
$phpunit->assertEquals('test', $err['package'], 'wrong error stack');
$wasCalled = true;
return 'my silly message';
}
$stack->setMessageCallback('messagecallback');
$wasCalled = false;
$stack->push(4, 'error', array('hello' => 6));
$phpunit->assertTrue($wasCalled, 'message callback was not called!');
$err = $stack->pop();
unset($err['time']);
unset($err['context']);
$phpunit->assertEquals(
array(
'code' => 4,
'params' => array('hello' => 6),
'package' => 'test',
'level' => 'error',
'message' => 'my silly message',
),
$err, 'popped something else'
);
$err = $stack->pop();
$phpunit->assertNull($err, 'stack not empty!');
echo 'tests done';
?>
--EXPECT--
tests done
|