pjs/webtools/litmus/testlist.cgi

78 строки
2.1 KiB
Perl
Executable File

#!/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::DB::Product;
use CGI;
Litmus->init();
my $c = Litmus->cgi();
print $c->header();
# takes either param tests, a comma separated list of test ids to display,
# or if no param is given (for now), display a list of all failing tests
# (very slowly)
my @testlist;
my $tests = $c->param("tests");
if ($tests) {
my @tests = split("," => $tests);
foreach my $curtest (@tests) {
my $test = Litmus::DB::Test->retrieve($curtest);
push(@testlist, $test);
}
} else {
Litmus::DB::Test->set_sql('failing' => qq {
SELECT testcases.testcase_id
FROM testcases, test_results
WHERE
test_results.result_id != 1 AND
test_results.testcase_id = testcases.testcase_id
GROUP BY testcases.testcase_id
});
@testlist = Litmus::DB::Testcase->search_failing();
}
my $vars = {
testlist => \@testlist,
};
$vars->{"defaultemail"} = Litmus::Auth::getCookie();
Litmus->template()->process("list/list.html.tmpl", $vars) ||
internalError(Litmus->template()->error());