我的函数prepare()具有以下定义:
私有函数prepare(&$data,$conditions=null,$conditionsRequired=false)
当我测试它时,这个
/**
* @covers /data/DB_Service::prepare
* @uses /inc/config
*/
public function testNoExceptionIsRaisedForValidPrepareWithConditionsAndConditionsRequiredArguments() {
$method = new ReflectionMethod('DB_Service', 'prepare');
$method->setAccessible(TRUE);
$dbs = new DB_Service(new Config(), array('admin', 'etl'));
$data = array('message' => '', 'sql' => array('full_query' => ""));
$method->invoke($dbs, $data, array('conditionKey' => 'conditionValue'), TRUE);
}
提高(并打破我的测试)
ReflectionException:调用方法DB_Service::prepare()失败
然而,这个
/**
* @covers /data/DB_Service::prepare
* @uses /inc/config
*/
public function testNoExceptionIsRaisedForValidPrepareWithConditionsAndConditionsRequiredArguments() {
$method = new ReflectionMethod('DB_Service', 'prepare');
$method->setAccessible(TRUE);
$dbs = new DB_Service(new Config(), array('admin', 'etl'));
//$data is no longer declared - the array is directly in the call below
$method->invoke($dbs, array('message' => '', 'sql' => array('full_query' => "")), array('conditionKey' => 'conditionValue'), TRUE);
}
运行良好,测试成功。
为什么声明变量然后传递不起作用,而只是在方法调用中创建它起作用?我认为这与invoke()的工作方式有关,但我似乎不知道是什么。
从invoke:的文档
注意:如果函数有需要引用的参数,那么它们必须是传递参数列表中的引用。
因此,如果您将其更改为:,那么您的第一个示例应该有效
$method->invoke($dbs, &$data, array('conditionKey' => 'conditionValue'), TRUE);
EDIT:为了避免不推荐的调用时间通过引用,您可以使用数组和invokeArgs:
$method->invokeArgs($dbs, array(&$data, array('conditionKey' => 'conditionValue'), TRUE));