- added testgroup popularity report query
This commit is contained in:
ccooper%deadsquid.com 2006-09-13 17:45:50 +00:00
parent 42d7142b7b
commit 5ed2cd6ba4
5 changed files with 184 additions and 2 deletions

View File

@ -0,0 +1,83 @@
#!/usr/bin/perl -w
# -*- mode: cperl; c-basic-offset: 8; indent-tabs-mode: nil; -*-
# ***** BEGIN LICENSE BLOCK *****
# Version: MPL 1.1
#
# The contents of this file are subject to the Mozilla Public License Version
# 1.1 (the "License"); you may not use this file except in compliance with
# the License. You may obtain a copy of the License at
# http://www.mozilla.org/MPL/
#
# Software distributed under the License is distributed on an "AS IS" basis,
# WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License
# for the specific language governing rights and limitations under the
# License.
#
# The Original Code is Litmus.
#
# The Initial Developer of the Original Code is
# the Mozilla Corporation.
# Portions created by the Initial Developer are Copyright (C) 2006
# the Initial Developer. All Rights Reserved.
#
# Contributor(s):
# Chris Cooper <ccooper@deadsquid.com>
# Zach Lipton <zach@zachlipton.com>
#
# ***** END LICENSE BLOCK *****
use strict;
$|++;
use Litmus;
use Litmus::Auth;
use Litmus::Error;
use Litmus::DBI;
use CGI;
use Time::Piece::MySQL;
Litmus->init();
my $c = Litmus->cgi();
print $c->header();
my $template = "reporting/aggregate_results.tmpl";
my $title = "Test Results Submitted by Testgroup";
my $results;
my $dbh = Litmus::DBI->db_Main();
my $sql = "SELECT tg.name AS testgroup_name,pr.name AS product_name,b.name AS branch_name,count(tr.testresult_id) AS num_results
FROM testgroups tg, products pr, branches b, testgroup_branches tgb, subgroup_testgroups sgtg, testcase_subgroups tcsg, testcases tc, test_results tr
WHERE tg.testgroup_id=tgb.testgroup_id AND tgb.branch_id=b.branch_id AND tg.product_id=pr.product_id AND tg.enabled=1 AND tg.testgroup_id=sgtg.testgroup_id AND sgtg.subgroup_id=tcsg.subgroup_id AND tcsg.testcase_id=tc.testcase_id AND tc.testcase_id=tr.testcase_id AND tc.enabled=1 AND tr.branch_id=tgb.branch_id AND tc.product_id=tg.product_id
GROUP BY tg.name,pr.name,b.name
ORDER BY pr.name, b.name";
my $sth = $dbh->prepare($sql);
$sth->execute();
while (my $data = $sth->fetchrow_hashref) {
push @$results, $data;
}
$sth->finish();
my $vars = {
title => $title,
status => $c->param('status'),
};
# Only include results if we have them.
if ($results and scalar @$results > 0) {
$vars->{results} = $results;
}
$vars->{"defaultemail"} = Litmus::Auth::getCookie();
Litmus->template()->process($template, $vars) ||
internalError(Litmus->template()->error());
exit 0;

View File

@ -26,7 +26,7 @@
#%]
<div id="footer">
Search test results: <a href="search_results.cgi?order_by_created=DESC&amp;timespan=all&amp;result_status=fail&amp;limit=50">Recent Failures</a> | <a href="common_results.cgi?status=fail">Most Common Failures</a> | <a href="common_results.cgi?status=unclear">Testcases Most Frequently Marked As Unclear</a> | Test Runs In Progress<br/>Search testcases: <a href="show_test.cgi?recently=added">Recently Added</a> | <a href="show_test.cgi?recently=changed">Recently Changed</a>
Search test results: <a href="search_results.cgi?order_by_created=DESC&amp;timespan=all&amp;result_status=fail&amp;limit=50">Recent Failures</a> | <a href="search_results.cgi?order_by_created=DESC&amp;timespan=all&amp;result_status=unclear&amp;limit=50">Recently Unclear</a> | <a href="common_results.cgi?status=fail">Most Common Failures</a> | <a href="common_results.cgi?status=unclear">Testcases Most Frequently Marked As Unclear</a> | <a href="aggregate_results.cgi"> Testgroup Popularity</a><br/>Search testcases: <a href="show_test.cgi?recently=added">Recently Added</a> | <a href="show_test.cgi?recently=changed">Recently Changed</a>
</div>
</div>

View File

@ -91,7 +91,7 @@
type="hidden"
value="[%valuelist FILTER html%]">
[% END %]
<select name="branch[%testidflag FILTER html%]" id="branch[%testidflag FILTER html%]"[% IF multiple %] multiple[% END %][% IF size %] size="[% size %]"[% END %][% IF onchange %] onchange="[% onchange %]"[% END %]
<select name="branch[%testidflag FILTER html%][% nameextra %]" id="branch[%testidflag FILTER html%][% nameextra %]"[% IF multiple %] multiple[% END %][% IF size %] size="[% size %]"[% END %][% IF onchange %] onchange="[% onchange %]"[% END %]
class="select_branch">
</select>
[% END %]

View File

@ -0,0 +1,45 @@
[%# ***** BEGIN LICENSE BLOCK *****
# Version: MPL 1.1
#
# The contents of this file are subject to the Mozilla Public License Version
# 1.1 (the "License"); you may not use this file except in compliance with
# the License. You may obtain a copy of the License at
# http://www.mozilla.org/MPL/
#
# Software distributed under the License is distributed on an "AS IS" basis,
# WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License
# for the specific language governing rights and limitations under the
# License.
#
# The Original Code is Litmus.
#
# The Initial Developer of the Original Code is
# The Mozilla Corporation.
# Portions created by the Initial Developer are Copyright (C) 2006
# the Initial Developer. All Rights Reserved.
#
# Contributor(s):
# Chris Cooper <ccooper@deadsquid.com>
# Zach Lipton <zach@zachlipton.com>
#
# ***** END LICENSE BLOCK *****
#%]
[% INCLUDE global/html_header.tmpl includeselects=1 %]
[% INCLUDE global/litmus_header.tmpl %]
<div id="page">
[% INCLUDE sidebar/sidebar.tmpl %]
<div id="content">
<h1 class="firstHeading">[% title | html %]</h1>
[% INCLUDE reporting/aggregate_results_table.tmpl %]
</div> <!--END content-->
</div> <!--END page-->
[% INCLUDE global/litmus_footer.tmpl %]
[% INCLUDE global/html_footer.tmpl %]

View File

@ -0,0 +1,54 @@
[%# ***** BEGIN LICENSE BLOCK *****
# Version: MPL 1.1
#
# The contents of this file are subject to the Mozilla Public License Version
# 1.1 (the "License"); you may not use this file except in compliance with
# the License. You may obtain a copy of the License at
# http://www.mozilla.org/MPL/
#
# Software distributed under the License is distributed on an "AS IS" basis,
# WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License
# for the specific language governing rights and limitations under the
# License.
#
# The Original Code is Litmus.
#
# The Initial Developer of the Original Code is
# The Mozilla Corporation.
# Portions created by the Initial Developer are Copyright (C) 2006
# the Initial Developer. All Rights Reserved.
#
# Contributor(s):
# Chris Cooper <ccooper@deadsquid.com>
# Zach Lipton <zach@zachlipton.com>
#
# ***** END LICENSE BLOCK *****
#%]
<table class="test-results">
<tr>
<td class="header">Product</td>
<td class="header">Branch</td>
<td class="header">Testgroup</td>
<td class="header"># Results</td>
</tr>
<tr>
[% IF results %]
[% FOREACH result=results %]
<tr [% IF not (loop.count % 2) %]class="odd"[% ELSE %]class="even"[% END %]>
<td align="center"><a href="search_results.cgi?product=[% result.product_name %]&branch=[% result.branch_name %]">[% result.product_name %]</a></td>
<td align="center"><a href="search_results.cgi?product=[% result.product_name %]&branch=[% result.branch_name | html %]">[% result.branch_name | html %]</a>
</td>
<td align="left">[% result.testgroup_name | html %]</td>
<td align="center">[% result.num_results | html %]</td>
</tr>
[% END %]
[% ELSE %]
<tr>
<td class="no-results" colspan="4">No test results match the search criteria.</td>
</tr>
[% END %]
</table>
</form>