]> git.ipfire.org Git - thirdparty/bugzilla.git/commitdiff
Bug 601364: Make xt/search.t also test the normal field=value search params
authorMax Kanat-Alexander <mkanat@bugzilla.org>
Sat, 2 Oct 2010 15:52:56 +0000 (08:52 -0700)
committerMax Kanat-Alexander <mkanat@bugzilla.org>
Sat, 2 Oct 2010 15:52:56 +0000 (08:52 -0700)
r=mkanat, a=mkanat (module owner)

xt/lib/Bugzilla/Test/Search.pm
xt/lib/Bugzilla/Test/Search/FieldTest.pm
xt/lib/Bugzilla/Test/Search/FieldTestNormal.pm [new file with mode: 0644]
xt/lib/Bugzilla/Test/Search/OperatorTest.pm

index 0c14de8234cfdc336f0b814b50445b6f6a67259d..467615ba0784ee946d130246fb7ad8ea08feb103 100644 (file)
@@ -99,8 +99,8 @@ sub num_tests {
                      ? ($top_combinations * $all_combinations) : 0;
     # And AND tests, which means we run 2x $join_tests;
     $join_tests = $join_tests * 2;
-    # Also, because of NOT tests, we run 2x $top_combinations.
-    my $basic_tests = $top_combinations * 2;
+    # Also, because of NOT tests and Normal tests, we run 3x $top_combinations.
+    my $basic_tests = $top_combinations * 3;
     my $operator_field_tests = ($basic_tests + $join_tests) * TESTS_PER_RUN;
 
     # Then we test each field/operator combination for SQL injection.
index b5f6d23344e9db52a9b44e4a2f951ec78093544c..98f6275fe534cb3e9e91babded8d3be27719c39d 100644 (file)
@@ -279,7 +279,7 @@ sub join_broken {
 # Accessors: Bugzilla::Search Arguments #
 #########################################
 
-# The CGI object that will get passed to Bugzilla::Search as its arguments.
+# The data that will get passed to Bugzilla::Search as its arguments.
 sub search_params {
     my ($self) = @_;
     return $self->{search_params} if $self->{search_params};
diff --git a/xt/lib/Bugzilla/Test/Search/FieldTestNormal.pm b/xt/lib/Bugzilla/Test/Search/FieldTestNormal.pm
new file mode 100644 (file)
index 0000000..f0f8ed8
--- /dev/null
@@ -0,0 +1,58 @@
+# -*- Mode: perl; indent-tabs-mode: nil -*-
+#
+# 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 the Bugzilla Bug Tracking System.
+#
+# The Initial Developer of the Original Code is Everything Solved, Inc.
+# Portions created by the Initial Developer are Copyright (C) 2010 the
+# Initial Developer. All Rights Reserved.
+#
+# Contributor(s):
+#   Max Kanat-Alexander <mkanat@bugzilla.org>
+
+# This is the same as a FieldTest, except that it uses normal URL
+# parameters instead of Boolean Charts.
+package Bugzilla::Test::Search::FieldTestNormal;
+use strict;
+use warnings;
+use base qw(Bugzilla::Test::Search::FieldTest);
+
+# We just clone a FieldTest because that's the best for performance,
+# overall--that way we don't have to translate the value again.
+sub new {
+    my ($class, $field_test) = @_;
+    my $self = { %$field_test };
+    return bless $self, $class;
+}
+
+sub name {
+    my $self = shift;
+    my $name = $self->SUPER::name(@_);
+    return "$name (Normal Params)";
+}
+
+sub search_params {
+    my ($self) = @_;
+    return $self->{search_params} if $self->{search_params};
+
+    my $field = $self->field;
+    my $value = $self->translated_value;
+    my %params = (
+        $field => $value,
+        "${field}_type" => $self->operator,
+    );
+    
+    $self->{search_params} = \%params;
+    return $self->{search_params};
+}
+
+1;
\ No newline at end of file
index 5ebba00c4b8a1597662ea3f0034c59e370bf5597..f0880047122bd9e0defccd8b17753f91583e1fcd 100644 (file)
@@ -27,6 +27,7 @@ use strict;
 use warnings;
 use Bugzilla::Test::Search::Constants;
 use Bugzilla::Test::Search::FieldTest;
+use Bugzilla::Test::Search::FieldTestNormal;
 use Bugzilla::Test::Search::InjectionTest;
 use Bugzilla::Test::Search::OrTest;
 use Bugzilla::Test::Search::AndTest;
@@ -64,6 +65,9 @@ sub run {
             my $field_test =
                 new Bugzilla::Test::Search::FieldTest($self, $field, $test);
             $field_test->run();
+            my $normal_test =
+                new Bugzilla::Test::Search::FieldTestNormal($field_test);
+            $normal_test->run();
             my $not_test = new Bugzilla::Test::Search::NotTest($field_test);
             $not_test->run();