我对phpunit有点陌生,经过数小时的研究,我还没有找到办法。如何使用 phpunit 测试函数 getResults。
函数 getResults 和 getResultsDetails 属于 Result 类。函数 searchUser 属于 User 类。要通过登录,我可以使用用户名和密码在登录对象中调用 doLogin,它将保留在 $_SESSION
class Result {
public function __construct()
{
if(!isset($_SESSION)){
session_start();
}
$this->loginObject = new Login();
}
public function getResults($fName, $lName)
{
$result = searchUser($fName, $lName);
while ($row = mysql_fetch_assoc($results)) {
$userIDs = $result['id'] . ',';
}
return
array(
'userIDs' => $userIDs,
'count' => getResultDetails($userIDs),
'results' => getResultDetails($userIDs, 0, 500),
)
}
如果传入限制和偏移量,则返回结果,否则返回所有内容的计数
public function getResultDetails($userIDs, $limit = null, $offset =null)
{
if(!$this->beforeFilter()) return "logout";
//open db connection
$sql = '';
if(!$limit && !$offset)
{
$sql .= 'SELECT count(*) ';
} else {
$sql .= 'SELECT a.info, b.info, d.info ';
}
$sql .= 'FROM a ';
$sql .= 'inner join b on blah blah';
$sql .= 'inner join d blah blah';
$sql .= "where d.userID in ($userIDs)";
if($limit && $offset)
$sql .= "LIMIT $limit, $offset";
return mysql_query($sql);
}
}
这是根据 firName 和 lastName 搜索用户。searchUser 属于 User 类 class Patient{ public function __construct() { if(!isset($_SESSION)){ session_start(); } $this->loginObject = new Login(); }
public function searchUser($fName, $lName)
{
if(!$this->beforeFilter()) return "logout";
// logic to do search user and return user result mysq_query($sql)
return userIDs;
}
}