在说assert之前,先说一下assert的选项配置函数assert_options()。
mixed assert_options ( int $what [, mixed $value ] )
常量 INI设置 默认值 描述
ASSERT_ACTIVE assert.active 1 启用 assert() 断言
ASSERT_WARNING assert.warning 1 为每个失败的断言产生一个 PHP 警告(warning)
ASSERT_BAIL assert.bail 0 在断言失败时中止执行
ASSERT_QUIET_EVAL assert.quiet_eval 0 在断言表达式求值时禁用 error_reporting
ASSERT_CALLBACK assert.callback (NULL) 断言失败时调用回调函数
再说assert()
php官方手册对assert的描述是检查一个断言是否为false。
在php5中,assert的函数描述为
bool assert ( mixed $assertion [, string $description ] )
在php7中,assert的函数描述为
bool assert ( mixed $assertion [, Throwable $exception ] )
如果 assertion
是字符串,它将会被 assert() 当做 PHP 代码来执行。 assertion
是字符串的优势是当禁用断言时它的开销会更小,并且在断言失败时消息会包含 assertion
表达式。 这意味着如果你传入了 boolean 的条件作为assertion
,这个条件将不会显示为断言函数的参数;在调用你定义的assert_options()处理函数时,条件会转换为字符串,而布尔值 FALSE
会被转换成空字符串。
assert() 回调函数在构建自动测试套件的时候尤其有用,因为它们允许你简易地捕获传入断言的代码,并包含断言的位置信息。 当信息能够被其他方法捕获,使用断言可以让它更快更方便!
回调函数应该接受三个参数。 第一个参数包括了断言失败所在的文件。 第二个参数包含了断言失败所在的行号,第三个参数包含了失败的表达式(如有任意 — 字面值例如 1 或者 "two" 将不会传递到这个参数)。 PHP 5.4.8 及更高版本的用户也可以提供第四个可选参数,如果设置了,用于将 description
指定到 assert()。
对于对面对象来说,最小的单元是方法,assert在做单元测试的时候尤为有效。
下面简单模拟一个断言测试
<?php
function test($a,$b){
return $a+$b;
}
function my_assert_handler($file, $line, $code, $msg)
{
echo "<hr>Assertion Failed:File '$file'<br />Line '$line'<br />Code '$code'<br />Msg '$msg'<br /><hr />";
}
function testUnit($method,$arguments,$expect) {
assert_options(ASSERT_ACTIVE,1);
assert_options(ASSERT_WARNING,0);
assert_options(ASSERT_CALLBACK,'my_assert_handler');
$str = "$method(";
foreach($arguments as $v) {
$str .= $v .',';
}
$str = substr($str, 0,-1);
$str .= ')';
assert("$str == $expect","the result of $method is unexpecting");
}
testUnit('test',array(1,2),3);
testUnit('test',array(1,2),4);
testUnit('test',array(4,5),9);
testUnit('test',array(3,7),11);
?>
期望值与实际结果不同的,则会调用回调函数,就得知那些方法与预期不符