* @package testtask * @version $Id: control.php 5114 2013-07-12 06:02:59Z chencongzhi520@gmail.com $ * @link http://www.zentao.net */ class testtask extends control { public $products = array(); /** * Construct function, load product module, assign products to view auto. * * @access public * @return void */ public function __construct() { parent::__construct(); $this->loadModel('product'); $this->view->products = $this->products = $this->product->getPairs('nocode'); } /** * Index page, header to browse. * * @access public * @return void */ public function index() { $this->locate($this->createLink('testtask', 'browse')); } /** * Browse test tasks. * * @param int $productID * @param string $type * @param string $orderBy * @param int $recTotal * @param int $recPerPage * @param int $pageID * @access public * @return void */ public function browse($productID = 0, $branch = 0, $type = 'wait', $orderBy = 'id_desc', $recTotal = 0, $recPerPage = 20, $pageID = 1) { /* Save session. */ $this->session->set('testtaskList', $this->app->getURI(true)); /* Set menu. */ $productID = $this->product->saveState($productID, $this->products); $this->testtask->setMenu($this->products, $productID, $branch); /* Load pager. */ $this->app->loadClass('pager', $static = true); $pager = pager::init($recTotal, $recPerPage, $pageID); /* Append id for secend sort. */ $sort = $this->loadModel('common')->appendOrder($orderBy); $this->view->title = $this->products[$productID] . $this->lang->colon . $this->lang->testtask->common; $this->view->position[] = html::a($this->createLink('testtask', 'browse', "productID=$productID"), $this->products[$productID]); $this->view->position[] = $this->lang->testtask->common; $this->view->productID = $productID; $this->view->productName = $this->products[$productID]; $this->view->orderBy = $orderBy; $this->view->tasks = $this->testtask->getProductTasks($productID, $branch, $sort, $pager, $type); $this->view->users = $this->loadModel('user')->getPairs('noclosed|noletter'); $this->view->pager = $pager; $this->view->type = $type; $this->view->branch = $branch; $this->display(); } /** * Create a test task. * * @param int $productID * @access public * @return void */ public function create($productID, $projectID = 0, $build = 0) { if(!empty($_POST)) { $taskID = $this->testtask->create(); if(dao::isError()) die(js::error(dao::getError())); $actionID = $this->loadModel('action')->create('testtask', $taskID, 'opened'); if($this->post->owner) { $this->sendmail($taskID, $actionID, 'opened'); } die(js::locate($this->createLink('testtask', 'browse', "productID=$productID"), 'parent')); } /* Create testtask from build of project.*/ if($projectID != 0 and $build != 0) { $products = $this->dao->select('t2.id, t2.name')->from(TABLE_PROJECTPRODUCT)->alias('t1') ->leftJoin(TABLE_PRODUCT)->alias('t2')->on('t1.product = t2.id') ->where('t1.project')->eq($projectID) ->andWhere('t2.deleted')->eq(0) ->fetchPairs('id'); $productID = $productID ? $productID : key($products); $projects = $this->dao->select('id, name')->from(TABLE_PROJECT)->where('id')->eq($projectID)->andWhere('deleted')->eq(0)->fetchPairs('id'); $builds = $this->dao->select('id, name')->from(TABLE_BUILD)->where('id')->eq($build)->andWhere('deleted')->eq(0)->fetchPairs('id'); } /* Create testtask from testtask of project.*/ if($projectID != 0 and $build == 0) { $products = $this->dao->select('t2.id, t2.name')->from(TABLE_PROJECTPRODUCT)->alias('t1') ->leftJoin(TABLE_PRODUCT)->alias('t2')->on('t1.product = t2.id') ->where('t1.project')->eq($projectID) ->andWhere('t2.deleted')->eq(0) ->fetchPairs('id'); $productID = $productID ? $productID : key($products); $projects = $this->dao->select('id, name')->from(TABLE_PROJECT)->where('id')->eq($projectID)->andWhere('deleted')->eq(0)->fetchPairs('id'); $builds = $this->dao->select('id, name')->from(TABLE_BUILD)->where('project')->eq($projectID)->andWhere('deleted')->eq(0)->fetchPairs('id'); $builds = array('trunk' => 'Trunk') + $builds; } /* Create testtask from testtask of test.*/ if($projectID == 0) { $projects = $this->product->getProjectPairs($productID, $branch = 0, $params = 'nodeleted'); $builds = $this->loadModel('build')->getProductBuildPairs($productID); } /* Set menu. */ $productID = $this->product->saveState($productID, $this->products); $this->testtask->setMenu($this->products, $productID); $this->view->title = $this->products[$productID] . $this->lang->colon . $this->lang->testtask->create; $this->view->position[] = html::a($this->createLink('testtask', 'browse', "productID=$productID"), $this->products[$productID]); $this->view->position[] = $this->lang->testtask->common; $this->view->position[] = $this->lang->testtask->create; if($projectID != 0) { $this->view->products = $products; $this->view->projectID = $projectID; } $this->view->projects = $projects; $this->view->productID = $productID; $this->view->builds = $builds; $this->view->users = $this->loadModel('user')->getPairs('noclosed|nodeleted|qdfirst'); $this->display(); } /** * View a test task. * * @param int $taskID * @access public * @return void */ public function view($taskID) { /* Get test task, and set menu. */ $task = $this->testtask->getById($taskID, true); if(!$task) die(js::error($this->lang->notFound) . js::locate('back')); $productID = $task->product; $buildID = $task->build; $build = $this->loadModel('build')->getByID($buildID); $stories = array(); $bugs = array(); if($build) { $stories = $this->dao->select('*')->from(TABLE_STORY)->where('id')->in($build->stories)->fetchAll(); $this->loadModel('common')->saveQueryCondition($this->dao->get(), 'story'); $bugs = $this->dao->select('*')->from(TABLE_BUG)->where('id')->in($build->bugs)->fetchAll(); $this->loadModel('common')->saveQueryCondition($this->dao->get(), 'bug'); } $this->testtask->setMenu($this->products, $productID, $task->branch); $this->view->title = "TASK #$task->id $task->name/" . $this->products[$productID]; $this->view->position[] = html::a($this->createLink('testtask', 'browse', "productID=$productID"), $this->products[$productID]); $this->view->position[] = $this->lang->testtask->common; $this->view->position[] = $this->lang->testtask->view; $this->view->productID = $productID; $this->view->task = $task; $this->view->users = $this->loadModel('user')->getPairs('noclosed|noletter'); $this->view->actions = $this->loadModel('action')->getList('testtask', $taskID); $this->view->build = $build; $this->view->stories = $stories; $this->view->bugs = $bugs; $this->display(); } /** * Browse cases of a test task. * * @param string $taskID * @param string $browseType bymodule|all|assignedtome * @param int $param * @param int $recTotal * @param int $recPerPage * @param int $pageID * @access public * @return void */ public function cases($taskID, $browseType = 'all', $param = 0, $orderBy = 'id_desc', $recTotal = 0, $recPerPage = 20, $pageID = 1) { /* Save the session. */ $this->app->loadLang('testcase'); $this->session->set('caseList', $this->app->getURI(true)); /* Load pager. */ $this->app->loadClass('pager', $static = true); $pager = pager::init($recTotal, $recPerPage, $pageID); /* Set the browseType and moduleID. */ $browseType = strtolower($browseType); $moduleID = ($browseType == 'bymodule') ? (int)$param : 0; $queryID = ($browseType == 'bysearch') ? (int)$param : 0; /* Append id for secend sort. */ $sort = $this->loadModel('common')->appendOrder($orderBy, 't2.id'); /* Get task and product info, set menu. */ $task = $this->testtask->getById($taskID); if(!$task) die(js::error($this->lang->notFound) . js::locate('back')); $productID = $task->product; $this->testtask->setMenu($this->products, $productID, $task->branch); if($browseType == 'bymodule' or $browseType == 'all') { $modules = ''; if($moduleID) $modules = $this->loadModel('tree')->getAllChildID($moduleID); $this->view->runs = $this->testtask->getRuns($taskID, $modules, $sort, $pager); } elseif($browseType == 'assignedtome') { $this->view->runs = $this->testtask->getUserRuns($taskID, $this->session->user->account, $sort, $pager); } /* By search. */ elseif($browseType == 'bysearch') { if($queryID) { $query = $this->loadModel('search')->getQuery($queryID); if($query) { $this->session->set('testcaseQuery', $query->sql); $this->session->set('testcaseForm', $query->form); } else { $this->session->set('testcaseQuery', ' 1 = 1'); } } else { if($this->session->testcaseQuery == false) $this->session->set('testcaseQuery', ' 1 = 1'); } $queryProductID = $productID; $allProduct = "`product` = 'all'"; $caseQuery = $this->session->testcaseQuery; if(strpos($this->session->testcaseQuery, $allProduct) !== false) { $products = array_keys($this->loadModel('product')->getPrivProducts()); $caseQuery = str_replace($allProduct, '1', $this->session->testcaseQuery); $caseQuery = $caseQuery . ' AND `product`' . helper::dbIN(array_keys($products)); $queryProductID = 'all'; } $caseQuery = preg_replace('/`(\w+)`/', 't2.`$1`', $caseQuery); $this->view->runs = $this->dao->select('t2.*,t1.*, t2.version as caseVersion')->from(TABLE_TESTRUN)->alias('t1') ->leftJoin(TABLE_CASE)->alias('t2')->on('t1.case = t2.id') ->where($caseQuery) ->andWhere('t1.task')->eq($taskID) ->beginIF($task->branch)->andWhere('t2.branch')->in("0,{$task->branch}")->fi() ->orderBy(strpos($sort, 'assignedTo') !== false ? ('t1.' . $sort) : ('t2.' . $sort)) ->page($pager) ->fetchAll(); } $this->loadModel('common')->saveQueryCondition($this->dao->get(), 'testcase', false); /* Save testcaseIDs session for get the pre and next testcase. */ $testcaseIDs = ''; foreach($this->view->runs as $run) $testcaseIDs .= ',' . $run->case; $this->session->set('testcaseIDs', $testcaseIDs . ','); /* Build the search form. */ $this->loadModel('testcase'); $this->config->testcase->search['params']['product']['values']= array($productID => $this->products[$productID], 'all' => $this->lang->testcase->allProduct); $this->config->testcase->search['params']['module']['values'] = $this->loadModel('tree')->getOptionMenu($productID, $viewType = 'case'); $this->config->testcase->search['actionURL'] = inlink('cases', "taskID=$taskID&browseType=bySearch&queryID=myQueryID"); unset($this->config->testcase->search['fields']['branch']); unset($this->config->testcase->search['params']['branch']); $this->loadModel('search')->setSearchParams($this->config->testcase->search); $this->view->title = $this->products[$productID] . $this->lang->colon . $this->lang->testtask->cases; $this->view->position[] = html::a($this->createLink('testtask', 'browse', "productID=$productID"), $this->products[$productID]); $this->view->position[] = $this->lang->testtask->common; $this->view->position[] = $this->lang->testtask->cases; $this->view->productID = $productID; $this->view->productName = $this->products[$productID]; $this->view->task = $task; $this->view->users = $this->loadModel('user')->getPairs('noclosed,nodeleted,qafirst'); $this->view->moduleTree = $this->loadModel('tree')->getTreeMenu($productID, $viewType = 'case', $startModuleID = 0, array('treeModel', 'createTestTaskLink'), $extra = $taskID, $task->branch); $this->view->browseType = $browseType; $this->view->param = $param; $this->view->orderBy = $orderBy; $this->view->taskID = $taskID; $this->view->moduleID = $moduleID; $this->view->treeClass = $browseType == 'bymodule' ? '' : 'hidden'; $this->view->pager = $pager; $this->display(); } /** * Group case. * * @param int $taskID * @param string $groupBy * @access public * @return void */ public function groupCase($taskID, $groupBy = 'story') { /* Save the session. */ $this->app->loadLang('testcase'); $this->session->set('caseList', $this->app->getURI(true)); /* Get task and product info, set menu. */ $groupBy = empty($groupBy) ? 'story' : $groupBy; $task = $this->testtask->getById($taskID); if(!$task) die(js::error($this->lang->notFound) . js::locate('back')); $productID = $task->product; $this->testtask->setMenu($this->products, $productID, $task->branch); $runs = $this->testtask->getRuns($taskID, 0, $groupBy); $this->loadModel('common')->saveQueryCondition($this->dao->get(), 'testcase', false); $groupCases = array(); $groupByList = array(); foreach($runs as $run) { if($groupBy == 'story') { $groupCases[$run->story][] = $run; $groupByList[$run->story] = $run->storyTitle; } } $this->view->title = $this->products[$productID] . $this->lang->colon . $this->lang->testtask->cases; $this->view->position[] = html::a($this->createLink('testtask', 'browse', "productID=$productID"), $this->products[$productID]); $this->view->position[] = $this->lang->testtask->common; $this->view->position[] = $this->lang->testtask->cases; $this->view->users = $this->loadModel('user')->getPairs('noletter'); $this->view->productID = $productID; $this->view->task = $task; $this->view->taskID = $taskID; $this->view->browseType = 'group'; $this->view->groupBy = $groupBy; $this->view->groupByList = $groupByList; $this->view->cases = $groupCases; $this->display(); } /** * Edit a test task. * * @param int $taskID * @access public * @return void */ public function edit($taskID) { if(!empty($_POST)) { $changes = $this->testtask->update($taskID); if(dao::isError()) die(js::error(dao::getError())); if($changes) { $actionID = $this->loadModel('action')->create('testtask', $taskID, 'edited'); $this->action->logHistory($actionID, $changes); /* send mail.*/ $this->sendmail($taskID, $actionID, 'edited'); } die(js::locate(inlink('view', "taskID=$taskID"), 'parent')); } /* Get task info. */ $task = $this->testtask->getById($taskID); $productID = $this->product->saveState($task->product, $this->products); /* Set menu. */ $this->testtask->setMenu($this->products, $productID, $task->branch); $this->view->title = $this->products[$productID] . $this->lang->colon . $this->lang->testtask->edit; $this->view->position[] = html::a($this->createLink('testtask', 'browse', "productID=$productID"), $this->products[$productID]); $this->view->position[] = $this->lang->testtask->common; $this->view->position[] = $this->lang->testtask->edit; $this->view->task = $task; $this->view->projects = $this->product->getProjectPairs($productID); $this->view->builds = $this->loadModel('build')->getProductBuildPairs($productID); $this->view->users = $this->loadModel('user')->getPairs('nodeleted', $task->owner); $this->display(); } /** * Start testtask. * * @param int $taskID * @access public * @return void */ public function start($taskID) { $actions = $this->loadModel('action')->getList('testtask', $taskID); if(!empty($_POST)) { $changes = $this->testtask->start($taskID); if(dao::isError()) die(js::error(dao::getError())); if($this->post->comment != '' or !empty($changes)) { $actionID = $this->action->create('testtask', $taskID, 'Started', $this->post->comment); $this->action->logHistory($actionID, $changes); } if(isonlybody()) die(js::reload('parent.parent')); die(js::locate($this->createLink('testtask', 'view', "taskID=$taskID"), 'parent')); } /* Get task info. */ $testtask = $this->testtask->getById($taskID); $productID = $this->product->saveState($testtask->product, $this->products); /* Set menu. */ $this->testtask->setMenu($this->products, $productID, $testtask->branch); $this->view->testtask = $testtask; $this->view->title = $testtask->name . $this->lang->colon . $this->lang->testtask->start; $this->view->position[] = $this->lang->testtask->common; $this->view->position[] = $this->lang->testtask->start; $this->view->actions = $actions; $this->display(); } /** * Close testtask. * * @param int $taskID * @access public * @return void */ public function close($taskID) { $actions = $this->loadModel('action')->getList('testtask', $taskID); if(!empty($_POST)) { $changes = $this->testtask->close($taskID); if(dao::isError()) die(js::error(dao::getError())); if($this->post->comment != '' or !empty($changes)) { $actionID = $this->action->create('testtask', $taskID, 'Closed', $this->post->comment); $this->action->logHistory($actionID, $changes); } if(isonlybody()) die(js::reload('parent.parent')); die(js::locate($this->createLink('testtask', 'view', "taskID=$taskID"), 'parent')); } /* Get task info. */ $testtask = $this->testtask->getById($taskID); $productID = $this->product->saveState($testtask->product, $this->products); /* Set menu. */ $this->testtask->setMenu($this->products, $productID, $testtask->branch); $this->view->testtask = $this->testtask->getById($taskID); $this->view->title = $testtask->name . $this->lang->colon . $this->lang->close; $this->view->position[] = $this->lang->testtask->common; $this->view->position[] = $this->lang->close; $this->view->actions = $actions; $this->display(); } /** * Delete a test task. * * @param int $taskID * @param string $confirm yes|no * @access public * @return void */ public function delete($taskID, $confirm = 'no') { if($confirm == 'no') { die(js::confirm($this->lang->testtask->confirmDelete, inlink('delete', "taskID=$taskID&confirm=yes"))); } else { $task = $this->testtask->getByID($taskID); $this->testtask->delete(TABLE_TESTTASK, $taskID); /* if ajax request, send result. */ if($this->server->ajax) { if(dao::isError()) { $response['result'] = 'fail'; $response['message'] = dao::getError(); } else { $response['result'] = 'success'; $response['message'] = ''; } $this->send($response); } die(js::locate(inlink('browse', "product=$task->product"), 'parent')); } } /** * Link cases to a test task. * * @param int $taskID * @access public * @return void */ public function linkCase($taskID, $param = 'all', $recTotal = 0, $recPerPage = 20, $pageID = 1) { if(!empty($_POST)) { $this->testtask->linkCase($taskID); $this->locate(inlink('cases', "taskID=$taskID")); } /* Save session. */ $this->session->set('caseList', $this->app->getURI(true)); /* Get task and product id. */ $task = $this->testtask->getById($taskID); $productID = $this->product->saveState($task->product, $this->products); /* Load pager. */ $this->app->loadClass('pager', $static = true); $pager = pager::init($recTotal, $recPerPage, $pageID); /* Build the search form. */ $this->loadModel('testcase'); $this->config->testcase->search['params']['product']['values']= array($productID => $this->products[$productID], 'all' => $this->lang->testcase->allProduct); $this->config->testcase->search['params']['module']['values'] = $this->loadModel('tree')->getOptionMenu($productID, $viewType = 'case'); $this->config->testcase->search['actionURL'] = inlink('linkcase', "taskID=$taskID"); unset($this->config->testcase->search['fields']['branch']); unset($this->config->testcase->search['params']['branch']); $this->loadModel('search')->setSearchParams($this->config->testcase->search); /* Save session. */ $this->testtask->setMenu($this->products, $productID, $task->branch); $this->view->title = $task->name . $this->lang->colon . $this->lang->testtask->linkCase; $this->view->position[] = html::a($this->createLink('testtask', 'browse', "productID=$productID"), $this->products[$productID]); $this->view->position[] = $this->lang->testtask->common; $this->view->position[] = $this->lang->testtask->linkCase; /* Get cases. */ if($this->session->testcaseQuery == false) $this->session->set('testcaseQuery', ' 1 = 1'); $query = str_replace("`product` = 'all'", '1', $this->session->testcaseQuery); // If search all product, replace product = all to 1=1 $linkedCases = $this->dao->select('`case`')->from(TABLE_TESTRUN)->where('task')->eq($taskID)->fetchPairs('case'); if($param == 'all') { $cases = $this->dao->select('*')->from(TABLE_CASE)->where($query) ->andWhere('product')->eq($productID) ->andWhere('id')->notIN($linkedCases) ->beginIF($task->branch)->andWhere('branch')->in("0,$task->branch")->fi() ->andWhere('deleted')->eq(0) ->orderBy('id desc') ->page($pager) ->fetchAll(); } if($param == 'bystory') { $stories = $this->dao->select('stories')->from(TABLE_BUILD)->where('id')->eq($task->build)->fetch('stories'); $cases = array(); if($stories) { $cases = $this->dao->select('*')->from(TABLE_CASE)->where($query) ->andWhere('product')->eq($productID) ->beginIF($linkedCases)->andWhere('id')->notIN($linkedCases)->fi() ->andWhere('story')->in($stories) ->andWhere('deleted')->eq(0) ->orderBy('id desc') ->page($pager) ->fetchAll(); } } if($param == 'bybug') { $bugs = $this->dao->select('bugs')->from(TABLE_BUILD)->where('id')->eq($task->build)->fetch('bugs'); $cases = array(); if($bugs) { $cases = empty($bugs) ? array() : $this->dao->select('*')->from(TABLE_CASE)->where($query) ->andWhere('product')->eq($productID) ->beginIF($linkedCases)->andWhere('id')->notIN($linkedCases)->fi() ->andWhere('fromBug')->in($bugs) ->andWhere('deleted')->eq(0) ->orderBy('id desc') ->page($pager) ->fetchAll(); } } $this->view->users = $this->loadModel('user')->getPairs('noletter'); $this->view->cases = $cases; $this->view->taskID = $taskID; $this->view->pager = $pager; $this->view->task = $task; $this->display(); } /** * Remove a case from test task. * * @param int $rowID * @access public * @return void */ public function unlinkCase($rowID, $confirm = 'no') { if($confirm == 'no') { die(js::confirm($this->lang->testtask->confirmUnlinkCase, $this->createLink('testtask', 'unlinkCase', "rowID=$rowID&confirm=yes"))); } else { $response['result'] = 'success'; $response['message'] = ''; $this->dao->delete()->from(TABLE_TESTRUN)->where('id')->eq((int)$rowID)->exec(); if(dao::isError()) { $response['result'] = 'fail'; $response['message'] = dao::getError(); } $this->send($response); } } /** * Run case. * * @param int $runID * @param String $extras others params, forexample, caseID=10, version=3 * @access public * @return void */ public function runCase($runID, $caseID = 0, $version = 0) { if($caseID) { $run = new stdclass(); $run->case = $this->loadModel('testcase')->getById($caseID, $version); } else { $run = $this->testtask->getRunById($runID); } $caseID = $caseID ? $caseID : $run->case->id; $preAndNext = $this->loadModel('common')->getPreAndNextObject('testcase', $caseID); if(!empty($_POST)) { $this->testtask->createResult($runID); if(dao::isError()) die(js::error(dao::getError())); /* set cookie for ajax load caselist when close colorbox. */ setcookie('selfClose', 1); if($preAndNext->next) { $nextRunID = $runID ? $preAndNext->next->id : 0; $nextCaseID = $runID ? $preAndNext->next->case : $preAndNext->next->id; $nextVersion = $preAndNext->next->version; die(js::locate(inlink('runCase', "runID=$nextRunID&caseID=$nextCaseID&version=$nextVersion"))); } else { die(js::closeModal('parent')); } } $preCase = ''; $nextCase = ''; if($preAndNext->pre) { $preCase['runID'] = $runID ? $preAndNext->pre->id : 0; $preCase['caseID'] = $runID ? $preAndNext->pre->case : $preAndNext->pre->id; $preCase['version'] = $preAndNext->pre->version; } if($preAndNext->next) { $nextCase['runID'] = $runID ? $preAndNext->next->id : 0; $nextCase['caseID'] = $runID ? $preAndNext->next->case : $preAndNext->next->id; $nextCase['version'] = $preAndNext->next->version; } $this->view->run = $run; $this->view->preCase = $preCase; $this->view->nextCase = $nextCase; $this->view->results = $this->testtask->getResults($runID, $caseID); $this->view->users = $this->loadModel('user')->getPairs('noclosed, noletter'); $this->view->caseID = $caseID; $this->view->version = $version; die($this->display()); } /** * Batch run case. * * @param int $productID * @param string $orderBy * @param string $from * @access public * @return void */ public function batchRun($productID, $orderBy = 'id_desc', $from = 'testcase') { $url = $this->session->caseList ? $this->session->caseList : $this->createLink('testcase', 'browse', "productID=$productID"); if($this->post->results) { $this->testtask->batchRun($from); die(js::locate($url, 'parent')); } $caseIDList = $this->post->caseIDList ? $this->post->caseIDList : die(js::locate($url, 'parent')); /* The case of tasks of qa. */ if($productID) { $this->testtask->setMenu($this->products, $productID); $this->view->moduleOptionMenu = $this->loadModel('tree')->getOptionMenu($productID, $viewType = 'case', $startModuleID = 0); } /* The case of my. */ else { $this->lang->testtask->menu = $this->lang->my->menu; $this->lang->set('menugroup.testtask', 'my'); $this->lang->testtask->menuOrder = $this->lang->my->menuOrder; $this->loadModel('my')->setMenu(); $this->view->title = $this->lang->testtask->batchRun; } $this->view->cases = $this->dao->select('*')->from(TABLE_CASE)->where('id')->in($caseIDList)->fetchAll('id'); $this->view->steps = $this->dao->select('t1.*')->from(TABLE_CASESTEP)->alias('t1') ->leftJoin(TABLE_CASE)->alias('t2')->on('t1.case=t2.id') ->where('t2.id')->in($caseIDList) ->andWhere('t1.version=t2.version') ->fetchGroup('case', 'id'); $this->view->caseIDList = $caseIDList; $this->view->productID = $productID; $this->view->title = $this->lang->testtask->batchRun; $this->view->position[] = $this->lang->testtask->common; $this->view->position[] = $this->lang->testtask->batchRun; $this->display(); } /** * View test results of a test run. * * @param int $runID * @param int $caseID * @access public * @return void */ public function results($runID, $caseID = 0, $version = 0) { if($caseID) { $case = $this->loadModel('testcase')->getByID($caseID, $version); $results = $this->testtask->getResults(0, $caseID); } else { $case = $this->testtask->getRunById($runID)->case; $results = $this->testtask->getResults($runID); $testtaskID = $this->dao->select('task')->from(TABLE_TESTRUN)->where('id')->eq($runID)->fetch('task'); $testtask = $this->dao->select('build, product')->from(TABLE_TESTTASK)->where('id')->eq($testtaskID)->fetch(); $this->view->build = isset($builds[$testtask->build]) ? $builds[$testtask->build] : ''; } $this->view->case = $case; $this->view->results = $results; $this->view->builds = $this->loadModel('build')->getProductBuildPairs($case->product); $this->view->users = $this->loadModel('user')->getPairs('noclosed, noletter'); die($this->display()); } /** * Batch assign cases. * * @param int $taskID * @access public * @return void */ public function batchAssign($taskID) { $this->dao->update(TABLE_TESTRUN) ->set('assignedTo')->eq($this->post->assignedTo) ->where('task')->eq((int)$taskID) ->andWhere('`case`')->in($this->post->caseIDList) ->exec(); die(js::locate($this->session->caseList)); } /** * Send mail. * * @param int $testtaskID * @param int $actionID * @param string $action * @access public * @return void */ public function sendmail($testtaskID, $actionID, $actionType) { /* Reset $this->output. */ $this->clear(); $testtask = $this->testtask->getByID($testtaskID); $action = $this->action->getById($actionID); $users = $this->loadModel('user')->getPairs('noletter'); $this->view->testtask = $testtask; $this->view->action = $action; $this->view->users = $users; $mailContent = $this->parse($this->moduleName, 'sendmail'); if($actionType == 'opened') { $mailTitle = sprintf($this->lang->testtask->mail->create->title, $this->app->user->realname, $testtaskID, $this->post->name); } else { $mailTitle = sprintf($this->lang->testtask->mail->edit->title, $this->app->user->realname, $testtaskID, $this->post->name); } $this->loadModel('mail')->send($this->post->owner, $mailTitle, $mailContent); if($this->mail->isError()) trigger_error(join("\n", $this->mail->getError())); } }