- add proper unique keys to users table - check for empty username and/or passwords - compare the entered password against the db version instead of itself <- !!! - check form submissions in JS prior to submission - require a unique IRC nickname if it is provided, but allow users not to enter one if they so choose - display mailto: links for admins only - display account created page when updating accounts - make login look-and-feel consistent with the rest of the site b=321265 - add getDisplayName function to User.pm -> returns IRC nickname, real name, or email depending on what is available. Used wherever user information is displayed. b=324022 - add scrollbars to testcase display (css -> overflow: auto) b=324648 - use quotemeta in Testresults.pm to avoid SQL injection when searching results Misc: - update copyrights to 2006 - fix log_text db schema regression - remove validity_lookup and vetting_status_lookup tables and assoicated perl classes. Replaced by per-test-result fields. - remove out-of-date formats/ directory and contents - add functions to DBTools.pm to manipulate keys and drop tables - display error/success/info messages in a transient popup div - update version to 0.6. Make version string part of sidebar title. - allow re-testing of completed subgroups by same tester, i.e. don't disable subgroups with 100% testing coverage - remove 'next' regression on run_tests testcase display - comment out user table on stats page - whitespace fixes git-svn-id: svn://10.0.0.236/trunk@188156 18797224-902f-48f8-a5cc-f745e15eee43
101 lines
3.2 KiB
Perl
Executable File
101 lines
3.2 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::Error;
|
|
use Litmus::DB::Test;
|
|
use Litmus::UserAgentDetect;
|
|
use Litmus::SysConfig;
|
|
use Litmus::Auth;
|
|
|
|
use CGI;
|
|
use Time::Piece::MySQL;
|
|
|
|
my $c = Litmus->cgi();
|
|
|
|
# how old of a build do we want to allow? default is 10 days
|
|
my $maxbuildage = 10;
|
|
# what branch do we accept? default is the trunk or the 1.8 branch
|
|
my $branch = Litmus::DB::Branch->retrieve(1);
|
|
my $branch2 = Litmus::DB::Branch->retrieve(2);
|
|
|
|
showTest();
|
|
|
|
sub showTest {
|
|
print $c->header();
|
|
|
|
# if they don't have a buildid or it's old, then just don't display
|
|
# any tests:
|
|
my $ua = Litmus::UserAgentDetect->new();
|
|
my $time = localtime;
|
|
$time->date_separator("");
|
|
my $curbuildtime = $time->ymd;
|
|
my $prod = Litmus::DB::Product->search(name => "Firefox")->next();
|
|
my @detectbranch = $ua->branch($prod);
|
|
if ((! $ua->buildid()) || (! $detectbranch[0]) ||
|
|
$curbuildtime - $ua->buildid() > $maxbuildage ||
|
|
($detectbranch[0]->branchid() != $branch->branchid() &&
|
|
$detectbranch[0]->branchid() != $branch2->branchid())) {
|
|
Litmus->template()->process("simpletest/simpletest.html.tmpl") ||
|
|
internalError(Litmus->template()->error());
|
|
exit;
|
|
}
|
|
|
|
my $pid = $prod->productid();
|
|
# get a random test to display:
|
|
Litmus::DB::Test->set_sql(random_test => qq {
|
|
SELECT tests.test_id, tests.subgroup_id, tests.summary, tests.details, tests.status_id, tests.community_enabled, tests.format_id, tests.regression_bug_id
|
|
FROM __TABLE__, products,test_groups,subgroups
|
|
WHERE
|
|
products.product_id=? AND
|
|
community_enabled = 1 AND
|
|
products.product_id=test_groups.product_id AND
|
|
subgroups.testgroup_id=test_groups.testgroup_id AND
|
|
tests.subgroup_id=subgroups.subgroup_id
|
|
ORDER BY RAND()
|
|
LIMIT 1
|
|
});
|
|
|
|
my $test = Litmus::DB::Test->search_random_test($pid)->next();
|
|
|
|
my @results = Litmus::DB::Result->retrieve_all();
|
|
|
|
my $vars = {
|
|
test => $test,
|
|
results => \@results,
|
|
};
|
|
|
|
$vars->{"defaultemail"} = Litmus::Auth::getCookie();
|
|
|
|
Litmus->template()->process("simpletest/simpletest.html.tmpl", $vars) ||
|
|
internalError(Litmus->template()->error());
|
|
}
|