2005-10-11 22:44:16 +04:00
|
|
|
#!/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) 2005
|
|
|
|
# the Initial Developer. All Rights Reserved.
|
|
|
|
#
|
|
|
|
# Contributor(s):
|
|
|
|
# Chris Cooper <ccooper@deadsquid.com>
|
|
|
|
# Zach Lipton <zach@zachlipton.com>
|
|
|
|
#
|
|
|
|
# ***** END LICENSE BLOCK *****
|
|
|
|
|
|
|
|
use strict;
|
|
|
|
|
|
|
|
# Litmus homepage
|
|
|
|
|
|
|
|
use Litmus;
|
|
|
|
use Litmus::Auth;
|
|
|
|
use Litmus::Error;
|
|
|
|
use Litmus::DB::Testresult;
|
|
|
|
use Litmus::FormWidget;
|
|
|
|
|
|
|
|
use CGI;
|
|
|
|
use Time::Piece::MySQL;
|
|
|
|
|
|
|
|
my $c = new CGI;
|
|
|
|
print $c->header();
|
|
|
|
|
|
|
|
use diagnostics;
|
|
|
|
|
|
|
|
my $criteria = "Custom<br/>";
|
|
|
|
my $results;
|
|
|
|
my @where;
|
|
|
|
my @order_by;
|
|
|
|
my $limit;
|
|
|
|
my $where_criteria = "";
|
|
|
|
my $order_by_criteria = "";
|
|
|
|
my $limit_criteria = "";
|
|
|
|
if ($c->param) {
|
|
|
|
foreach my $param ($c->param) {
|
|
|
|
next if ($c->param($param) eq '');
|
|
|
|
if ($param =~ /^order_by_(.*)$/) {
|
|
|
|
my $order_by_proto = quotemeta($1);
|
|
|
|
next if ($c->param($param) ne 'ASC' and
|
|
|
|
$c->param($param) ne 'DESC');
|
|
|
|
my $order_by_direction = $c->param($param);
|
|
|
|
push @order_by, {field => $order_by_proto,
|
|
|
|
direction => $order_by_direction};
|
|
|
|
$order_by_criteria .= "Order by $order_by_proto $order_by_direction<br/>";
|
|
|
|
} elsif ($param eq 'branch') {
|
|
|
|
my $value = quotemeta($c->param($param));
|
|
|
|
push @where, {field => $param,
|
|
|
|
value => $value};
|
|
|
|
$where_criteria .= "Branch is \'".$c->param($param)."\'<br/>";
|
2005-12-13 07:26:15 +03:00
|
|
|
} elsif ($param eq 'locale') {
|
|
|
|
my $value = quotemeta($c->param($param));
|
2005-12-22 21:25:16 +03:00
|
|
|
push @where, {field => 'locale',
|
2005-12-13 07:26:15 +03:00
|
|
|
value => $value};
|
2005-12-22 21:25:16 +03:00
|
|
|
$where_criteria .= "Locale is \'".$c->param($param)."\'<br/>";
|
2005-10-11 22:44:16 +04:00
|
|
|
} elsif ($param eq 'product') {
|
|
|
|
my $value = quotemeta($c->param($param));
|
|
|
|
push @where, {field => $param,
|
|
|
|
value => $value};
|
|
|
|
$where_criteria .= "Product is \'".$c->param($param)."\'<br/>";
|
|
|
|
} elsif ($param eq 'platform') {
|
|
|
|
my $value = quotemeta($c->param($param));
|
|
|
|
push @where, {field => $param,
|
|
|
|
value => $value};
|
|
|
|
$where_criteria .= "Platform is \'".$c->param($param)."\'<br/>";
|
|
|
|
} elsif ($param eq 'test_group') {
|
|
|
|
my $value = quotemeta($c->param($param));
|
|
|
|
push @where, {field => $param,
|
|
|
|
value => $value};
|
|
|
|
$where_criteria .= "Test group is \'".$c->param($param)."\'<br/>";
|
|
|
|
} elsif ($param eq 'test_id') {
|
|
|
|
my $value = quotemeta($c->param($param));
|
|
|
|
push @where, {field => $param,
|
|
|
|
value => $value};
|
|
|
|
$where_criteria .= "Testcase ID# is \'".$c->param($param)."\'<br/>";
|
|
|
|
} elsif ($param eq 'summary') {
|
|
|
|
my $value = quotemeta($c->param($param));
|
|
|
|
push @where, {field => $param,
|
|
|
|
value => $value};
|
|
|
|
$where_criteria .= "Summary like \'".$c->param($param)."\'<br/>";
|
|
|
|
} elsif ($param eq 'result_status') {
|
|
|
|
my $value = quotemeta($c->param($param));
|
|
|
|
push @where, {field => $param,
|
|
|
|
value => $value};
|
|
|
|
$where_criteria .= "Status is \'".$c->param($param)."\'<br/>";
|
|
|
|
} elsif ($param eq 'timespan') {
|
|
|
|
my $value = $c->param($param);
|
|
|
|
if ($value ne 'all') {
|
|
|
|
$value =~ s/[^\-0-9]//g;
|
|
|
|
push @where, {field => $param,
|
|
|
|
value => $value};
|
|
|
|
$value =~ s/\-//g;
|
|
|
|
if ($value == 1) {
|
|
|
|
$where_criteria .= "Submitted in the last day<br/>";
|
|
|
|
} else {
|
|
|
|
$where_criteria .= "Submitted in the last $value days<br/>";
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
$where_criteria .= "All Results<br/>";
|
|
|
|
}
|
|
|
|
} elsif ($param eq "limit") {
|
|
|
|
$limit = quotemeta($c->param($param));
|
|
|
|
next if ($limit == $Litmus::DB::Testresult::_num_results_default);
|
|
|
|
$limit_criteria .= "Limit to $limit results";
|
|
|
|
} else {
|
|
|
|
# Skip unknown field
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if ($where_criteria eq '' and
|
|
|
|
$order_by_criteria eq '' and
|
|
|
|
$limit_criteria eq '') {
|
|
|
|
($criteria,$results) =
|
|
|
|
Litmus::DB::Testresult->getDefaultTestResults;
|
|
|
|
} else {
|
|
|
|
$criteria .= $where_criteria . $order_by_criteria . $limit_criteria;
|
|
|
|
$criteria =~ s/_/ /g;
|
|
|
|
$results = Litmus::DB::Testresult->getTestResults(\@where,
|
|
|
|
\@order_by,
|
|
|
|
$limit);
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
($criteria,$results) =
|
|
|
|
Litmus::DB::Testresult->getDefaultTestResults;
|
|
|
|
}
|
|
|
|
|
|
|
|
# Populate each of our form widgets for select/input.
|
|
|
|
# Set a default value as appropriate.
|
|
|
|
my $products = Litmus::FormWidget->getProducts;
|
2005-12-22 21:25:16 +03:00
|
|
|
my $platforms = Litmus::FormWidget->getUniquePlatforms;
|
2005-10-11 22:44:16 +04:00
|
|
|
my $test_groups = Litmus::FormWidget->getTestGroups;
|
|
|
|
my $result_statuses = Litmus::FormWidget->getResultStatuses;
|
|
|
|
my $branches = Litmus::FormWidget->getBranches;
|
2005-12-22 21:25:16 +03:00
|
|
|
my $locales = Litmus::FormWidget->getLocales;
|
2005-10-11 22:44:16 +04:00
|
|
|
|
|
|
|
my $title = 'Search Test Results';
|
|
|
|
|
|
|
|
my $vars = {
|
|
|
|
title => $title,
|
|
|
|
criteria => $criteria,
|
|
|
|
products => $products,
|
|
|
|
platforms => $platforms,
|
|
|
|
test_groups => $test_groups,
|
|
|
|
result_statuses => $result_statuses,
|
|
|
|
branches => $branches,
|
2005-12-22 21:25:16 +03:00
|
|
|
locales => $locales,
|
2005-10-11 22:44:16 +04:00
|
|
|
limit => $limit,
|
|
|
|
};
|
|
|
|
|
|
|
|
# Only include results if we have them.
|
|
|
|
if ($results and scalar @$results > 0) {
|
|
|
|
$vars->{results} = $results;
|
|
|
|
}
|
|
|
|
|
|
|
|
my $cookie = Litmus::Auth::getCookie();
|
|
|
|
$vars->{"defaultemail"} = $cookie;
|
|
|
|
$vars->{"show_admin"} = Litmus::Auth::istrusted($cookie);
|
|
|
|
|
|
|
|
Litmus->template()->process("reporting/search_results.tmpl", $vars) ||
|
|
|
|
internalError(Litmus->template()->error());
|
|
|
|
|
|
|
|
exit 0;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|