* adjust the export feature of bug.
This commit is contained in:
@@ -73,5 +73,17 @@ $config->bug->list->allFields = 'id, module, project, story, task,
|
||||
lastEditedDate';
|
||||
$config->bug->list->defaultFields = 'id,severity,pri,title,openedBy,assignedTo,resolvedBy,resolution';
|
||||
|
||||
$config->bug->list->exportFields = 'id, product, module, project, story, task,
|
||||
title, keywords, severity, pri, type, os, browser,
|
||||
steps, status, mailto,
|
||||
openedBy, openedDate, openedBuild,
|
||||
assignedTo, assignedDate,
|
||||
resolvedBy, resolution, resolvedBuild, resolvedDate,
|
||||
closedBy, closedDate,
|
||||
duplicateBug, linkBug,
|
||||
case,
|
||||
lastEditedBy,
|
||||
lastEditedDate, files';
|
||||
|
||||
$config->bug->editor->create = array('id' => 'steps', 'tools' => 'bugTools');
|
||||
$config->bug->editor->edit = array('id' => 'steps', 'tools' => 'bugTools');
|
||||
|
||||
@@ -165,12 +165,6 @@ class bug extends control
|
||||
->orderBy($orderBy)->page($pager)->fetchAll();
|
||||
}
|
||||
|
||||
/* save session .*/
|
||||
$sql = $this->dao->get();
|
||||
$sql = explode('WHERE', $sql);
|
||||
$sql = explode('ORDER', $sql[1]);
|
||||
$this->session->set('bugReport', $sql[0]);
|
||||
|
||||
/* Process the sql, get the conditon partion, save it to session. Thus the report page can use the same condition. */
|
||||
if($browseType != 'needconfirm')
|
||||
{
|
||||
@@ -760,125 +754,169 @@ class bug extends control
|
||||
*/
|
||||
public function export($productID, $orderBy)
|
||||
{
|
||||
$fields = array();
|
||||
$users = $this->loadModel('user')->getPairs('noletter');
|
||||
$products = $this->loadModel('product')->getPairs();
|
||||
$projects = $this->loadModel('project')->getPairs();
|
||||
$relatedStories = $this->dao->select('id,title')->from(TABLE_STORY)->fetchPairs();
|
||||
$relatedModule = $this->dao->select('id, name')->from(TABLE_MODULE)->fetchPairs();
|
||||
$relatedTasks = $this->dao->select('id, name')->from(TABLE_TASK)->fetchPairs();
|
||||
$relatedBugs = $this->dao->select('id, title')->from(TABLE_BUG)->fetchPairs();
|
||||
$relatedCases = $this->dao->select('id, title')->from(TABLE_CASE)->fetchPairs();
|
||||
|
||||
/* get the fields of bug module from lang. */
|
||||
$fields = array(
|
||||
'id' => $this->lang->bug->id,
|
||||
'product' => $this->lang->bug->product,
|
||||
'module' => $this->lang->bug->module,
|
||||
'project' => $this->lang->bug->project,
|
||||
'story' => $this->lang->bug->story,
|
||||
'storyVersion' => $this->lang->bug->storyVersion,
|
||||
'task' => $this->lang->bug->task,
|
||||
'title' => $this->lang->bug->title,
|
||||
'keywords' => $this->lang->bug->keywords,
|
||||
'severity' => $this->lang->bug->severity,
|
||||
'pri' => $this->lang->bug->pri,
|
||||
'type' => $this->lang->bug->type,
|
||||
'os' => $this->lang->bug->os,
|
||||
'browser' => $this->lang->bug->browser,
|
||||
'hardware' => $this->lang->bug->hardware,
|
||||
'found' => $this->lang->bug->found,
|
||||
'steps' => $this->lang->bug->steps,
|
||||
'status' => $this->lang->bug->status,
|
||||
'mailto' => $this->lang->bug->mailto,
|
||||
'openedBy' => $this->lang->bug->openedBy,
|
||||
'openedDate' => $this->lang->bug->openedDate,
|
||||
'openedBuild' => $this->lang->bug->openedBuild,
|
||||
'assignedTo' => $this->lang->bug->assignedTo,
|
||||
'assignedDate' => $this->lang->bug->assignedDate,
|
||||
'resolvedBy' => $this->lang->bug->resolvedBy,
|
||||
'resolution' => $this->lang->bug->resolution,
|
||||
'resolvedBuild' => $this->lang->bug->resolvedBuild,
|
||||
'resolvedDate' => $this->lang->bug->resolvedDate,
|
||||
'colsedBy' => $this->lang->bug->closedBy,
|
||||
'closedDate' => $this->lang->bug->closedDate,
|
||||
'duplicateBug' => $this->lang->bug->duplicateBug,
|
||||
'linkBug' => $this->lang->bug->linkBug,
|
||||
'case' => $this->lang->bug->case,
|
||||
'lastEditedBy' => $this->lang->bug->lastEditedBy,
|
||||
'lastEditedDate' => $this->lang->bug->lastEditedDate,
|
||||
);
|
||||
|
||||
if($_POST)
|
||||
{
|
||||
$bugs = $this->bug->getByQuery($productID, $this->session->bugReport, $orderBy);
|
||||
$bugLang = $this->lang->bug;
|
||||
$bugConfig = $this->config->bug;
|
||||
|
||||
/* Create field lists. */
|
||||
$fields = explode(',', $bugConfig->list->exportFields);
|
||||
foreach($fields as $key => $fieldName)
|
||||
{
|
||||
$fieldName = trim($fieldName);
|
||||
$fields[$fieldName] = isset($bugLang->$fieldName) ? $bugLang->$fieldName : $fieldName;
|
||||
unset($fields[$key]);
|
||||
}
|
||||
|
||||
/* Get bugs. */
|
||||
$bugs = $this->dao->select('*')->from(TABLE_BUG)->alias('t1')->where($this->session->bugReportCondition)->orderBy($orderBy)->fetchAll('id');
|
||||
|
||||
/* Get users, products and projects. */
|
||||
$users = $this->loadModel('user')->getPairs('noletter');
|
||||
$products = $this->loadModel('product')->getPairs();
|
||||
$projects = $this->loadModel('project')->getPairs('all');
|
||||
|
||||
/* Get related objects id lists. */
|
||||
$relatedModuleIdList = array();
|
||||
$relatedStoryIdList = array();
|
||||
$relatedTaskIdList = array();
|
||||
$relatedBugIdList = array();
|
||||
$relatedCaseIdList = array();
|
||||
$relatedBuildIdList = array();
|
||||
|
||||
foreach($bugs as $bug)
|
||||
{
|
||||
if($_POST['fileType'] == 'csv')
|
||||
$relatedModuleIdList[$bug->module] = $bug->module;
|
||||
$relatedStoryIdList[$bug->story] = $bug->story;
|
||||
$relatedTaskIdList[$bug->task] = $bug->task;
|
||||
$relatedCaseIdList[$bug->case] = $bug->case;
|
||||
$relatedBugIdList[$bug->duplicateBug] = $bug->duplicateBug;
|
||||
|
||||
/* Process link bugs. */
|
||||
$linkBugs = explode(',', $bug->linkBug);
|
||||
foreach($linkBugs as $linkBugID)
|
||||
{
|
||||
$bug->steps = str_replace("<br />", "\n", $bug->steps);
|
||||
if($linkBugID) $relatedBugIdList[$linkBugID] = trim($linkBugID);
|
||||
}
|
||||
|
||||
/* Process builds. */
|
||||
$builds = $bug->openedBuild . ',' . $bug->resolvedBuild;
|
||||
$builds = explode(',', $builds);
|
||||
foreach($builds as $buildID)
|
||||
{
|
||||
if($buildID) $relatedBuildIdList[$buildID] = trim($buildID);
|
||||
}
|
||||
}
|
||||
|
||||
/* Get related objects title or names. */
|
||||
$relatedModules = $this->dao->select('id, name')->from(TABLE_MODULE)->where('id')->in($relatedModuleIdList)->fetchPairs();
|
||||
$relatedStories = $this->dao->select('id,title')->from(TABLE_STORY) ->where('id')->in($relatedStoryIdList)->fetchPairs();
|
||||
$relatedTasks = $this->dao->select('id, name')->from(TABLE_TASK)->where('id')->in($relatedTaskIdList)->fetchPairs();
|
||||
$relatedBugs = $this->dao->select('id, title')->from(TABLE_BUG)->where('id')->in($relatedBugIdList)->fetchPairs();
|
||||
$relatedCases = $this->dao->select('id, title')->from(TABLE_CASE)->where('id')->in($relatedCaseIdList)->fetchPairs();
|
||||
$relatedBuilds = $this->dao->select('id, name')->from(TABLE_BUILD)->where('id')->in($relatedBuildIdList)->fetchPairs();
|
||||
$relatedFiles = $this->dao->select('id, objectID, pathname, title')->from(TABLE_FILE)->where('objectType')->eq('bug')->andWhere('objectID')->in(@array_keys($bugs))->fetchGroup('objectID');
|
||||
|
||||
foreach($bugs as $bug)
|
||||
{
|
||||
if($this->post->fileType == 'csv')
|
||||
{
|
||||
$bug->steps = htmlspecialchars_decode($bug->steps);
|
||||
$bug->steps = str_replace("<br />", "\n", $bug->steps);
|
||||
$bug->steps = str_replace(" ", " ", $bug->steps);
|
||||
$bug->steps = str_replace('"', '""', $bug->steps);
|
||||
}
|
||||
else if($_POST['fileType'] == 'html')
|
||||
|
||||
/* fill some field with useful value. */
|
||||
if(isset($products[$bug->product])) $bug->product = $products[$bug->product];
|
||||
if(isset($projects[$bug->project])) $bug->project = $projects[$bug->project];
|
||||
if(isset($relatedModules[$bug->module])) $bug->module = $relatedModules[$bug->module];
|
||||
if(isset($relatedStories[$bug->story])) $bug->story = $relatedStories[$bug->story];
|
||||
if(isset($relatedTasks[$bug->task])) $bug->task = $relatedTasks[$bug->task];
|
||||
if(isset($relatedBugs[$bug->duplicateBug])) $bug->duplicateBug = $relatedBugs[$bug->duplicateBug];
|
||||
if(isset($relatedCases[$bug->case])) $bug->case = $relatedCases[$bug->case];
|
||||
|
||||
$bug->pri = $bugLang->priList[$bug->pri];
|
||||
$bug->type = $bugLang->typeList[$bug->type];
|
||||
$bug->status = $bugLang->statusList[$bug->status];
|
||||
$bug->resolution = $bugLang->resolutionList[$bug->resolution];
|
||||
|
||||
if(isset($users[$bug->openedBy])) $bug->openedBy = $users[$bug->openedBy];
|
||||
if(isset($users[$bug->assignedTo])) $bug->assignedTo = $users[$bug->assignedTo];
|
||||
if(isset($users[$bug->resolvedBy])) $bug->resolvedBy = $users[$bug->resolvedBy];
|
||||
if(isset($users[$bug->lastEditedBy])) $bug->lastEditedBy = $users[$bug->lastEditedBy];
|
||||
if(isset($users[$bug->closedBy])) $bug->closedBy = $users[$bug->closedBy];
|
||||
|
||||
$bug->openedDate = substr($bug->openedDate, 0, 10);
|
||||
$bug->assignedDate = substr($bug->assignedDate, 0, 10);
|
||||
$bug->closedDate = substr($bug->closedDate, 0, 10);
|
||||
$bug->resolvedDate = substr($bug->resolvedDate, 0, 10);
|
||||
$bug->lastEditedDate = substr($bug->lastEditedDate, 0, 10);
|
||||
|
||||
if($bug->linkBug)
|
||||
{
|
||||
$legendAttatchs = $this->dao->select('pathname, title')->from(TABLE_FILE)->where('objectType')->eq('task')->andWhere('objectID')->eq($bug->id)->fetchAll();
|
||||
if($legendAttatchs)
|
||||
$tmpLinkBugs = array();
|
||||
$linkBugIdList = explode(',', $bug->linkBug);
|
||||
foreach($linkBugIdList as $linkBugID)
|
||||
{
|
||||
foreach($legendAttatchs as $legendAttatch)
|
||||
{
|
||||
$legendAttatch->pathname = "http://" . $_SERVER['HTTP_HOST'] . $this->config->webRoot . "data/upload/$bug->company/" . $legendAttatch->pathname;
|
||||
$task->legendAttatchs .= "<a href=$legendAttatch->pathname>" . $legendAttatch->title . "</a><br />";
|
||||
}
|
||||
$linkBugID = trim($linkBugID);
|
||||
$tmpLinkBugs[] = isset($relatedBugs[$linkBugID]) ? $relatedBugs[$linkBugID] : $linkBugID;
|
||||
}
|
||||
$bug->linkBug = join("; \n", $tmpLinkBugs);
|
||||
}
|
||||
|
||||
if($bug->openedBuild)
|
||||
{
|
||||
$tmpOpenedBuilds = array();
|
||||
$tmpResolvedBuilds = array();
|
||||
$buildIdList = explode(',', $bug->openedBuild);
|
||||
foreach($buildIdList as $buildID)
|
||||
{
|
||||
$buildID = trim($buildID);
|
||||
$tmpOpenedBuilds[] = isset($relatedBuilds[$buildID]) ? $relatedBuilds[$buildID] : $buildID;
|
||||
}
|
||||
$bug->openedBuild = join("; \n", $tmpOpenedBuilds);
|
||||
}
|
||||
|
||||
if($bug->resolvedBuild)
|
||||
{
|
||||
$buildIdList = explode(',', $bug->resolvedBuild);
|
||||
foreach($buildIdList as $buildID)
|
||||
{
|
||||
$buildID = trim($buildID);
|
||||
$tmpResolvedBuilds[] = isset($relatedBuilds[$buildID]) ? $relatedBuilds[$buildID] : $buildID;
|
||||
}
|
||||
$bug->resolvedBuild = join("; \n", $tmpResolvedBuilds);
|
||||
}
|
||||
|
||||
/* Set related files. */
|
||||
if(isset($relatedFiles[$bug->id]))
|
||||
{
|
||||
foreach($relatedFiles[$bug->id] as $file)
|
||||
{
|
||||
$fileURL = 'http://' . $this->server->http_host . $this->config->webRoot . "data/upload/$bug->company/" . $file->pathname;
|
||||
$bug->files .= html::a($fileURL, $file->title, '_blank') . '<br />';
|
||||
}
|
||||
}
|
||||
|
||||
$bug->mailto = trim(trim($bug->mailto), ',');
|
||||
$mailtos = explode(',', $bug->mailto);
|
||||
$bug->mailto = '';
|
||||
foreach($mailtos as $mailto)
|
||||
{
|
||||
$mailto = trim($mailto);
|
||||
if(isset($users[$mailto])) $bug->mailto .= $users[$mailto] . ',';
|
||||
}
|
||||
|
||||
/* drop some field that is not needed. */
|
||||
unset($bug->company);
|
||||
unset($bug->caseVersion);
|
||||
unset($bug->result);
|
||||
|
||||
/* fill some field with useful value. */
|
||||
$bug->story = isset($relatedStories[$bug->story]) ? $relatedStories[$bug->story] : '';
|
||||
$bug->module = isset($relatedModules[$bug->module]) ? $relatedModules[$bug->module] : '';
|
||||
$bug->task = isset($relatedTasks[$bug->task]) ? $relatedTasks[$bug->task] : '';
|
||||
$bug->duplicateBug = isset($relatedBugs[$bug->duplicateBug]) ? $relatedBugs[$bug->duplicateBug] : '';
|
||||
$bug->linkBug = isset($relatedBugs[$bug->linkBug]) ? $relatedBugs[$bug->linkBug] : '';
|
||||
$bug->case = isset($relatedCases[$bug->case]) ? $relatedCases[$bug->case] : '';
|
||||
$bug->project = isset($projects[$bug->project]) ? $projects[$bug->project] : '';
|
||||
|
||||
$bug->product = $products[$bug->product];
|
||||
$bug->pri = $this->lang->bug->priList[$bug->pri];
|
||||
$bug->type = $this->lang->bug->typeList[$bug->type];
|
||||
$bug->status = $this->lang->bug->statusList[$bug->status];
|
||||
|
||||
$bug->mailto = trim(trim($bug->mailto), ',');
|
||||
$mailtos = explode(',', $bug->mailto);
|
||||
$bug->mailto = '';
|
||||
foreach($mailtos as $mailto)
|
||||
{
|
||||
if(isset($users[$mailto])) $bug->mailto .= $users[$mailto] . ',';
|
||||
}
|
||||
$bug->openedBy = $users[$bug->openedBy];
|
||||
$bug->openedDate = substr($bug->openedDate, 0, 10);
|
||||
if(isset($users[$bug->assignedTo]))$bug->assignedTo = $users[$bug->assignedTo];
|
||||
$bug->assignedDate = substr($bug->assignedDate, 0, 10);
|
||||
if(isset($users[$bug->resolvedBy])) $bug->resolvedBy = $users[$bug->resolvedBy];
|
||||
$bug->resolution = $this->lang->bug->resolutionList[$bug->resolution];
|
||||
$bug->resolvedDate = substr($bug->resolvedDate, 0, 10);
|
||||
$bug->closedBy = $users[$bug->closedBy];
|
||||
$bug->closedDate = substr($bug->closedDate, 0, 10);
|
||||
$bug->lastEditedBy = $users[$bug->lastEditedBy];
|
||||
$bug->lastEditedDate = substr($bug->lastEditedDate, 0, 10);
|
||||
unset($bug->deleted);
|
||||
}
|
||||
|
||||
$this->post->set('fields', $fields);
|
||||
$this->post->set('rows', $bugs);
|
||||
if($this->post->fileType == 'csv') $this->fetch('file', 'export2CSV', $_POST);
|
||||
if($this->post->fileType == 'xml') $this->fetch('file', 'export2XML', $_POST);
|
||||
if($this->post->fileType == 'html') $this->fetch('file', 'export2HTML', $_POST);
|
||||
$this->fetch('file', 'export2' . $this->post->fileType, $_POST);
|
||||
}
|
||||
|
||||
$this->display();
|
||||
|
||||
@@ -112,25 +112,6 @@ class bugModel extends model
|
||||
return $bug;
|
||||
}
|
||||
|
||||
/**
|
||||
* getByQuery
|
||||
*
|
||||
* @param string $productID
|
||||
* @param string $query
|
||||
* @param string $orderBy
|
||||
* @access public
|
||||
* @return void
|
||||
*/
|
||||
public function getByQuery($productID, $query, $orderBy)
|
||||
{
|
||||
$tmpBugs = $this->dao->select('*')->from(TABLE_BUG)->alias('t1')->where($query)
|
||||
->andWhere('product')->eq((int)$productID)
|
||||
->andWhere('deleted')->eq(0)
|
||||
->orderBy($orderBy)
|
||||
->fetchAll();
|
||||
return $tmpBugs;
|
||||
}
|
||||
|
||||
/**
|
||||
* Update a bug.
|
||||
*
|
||||
|
||||
Reference in New Issue
Block a user