summaryrefslogtreecommitdiff
path: root/tests/test/Test.pm
diff options
context:
space:
mode:
Diffstat (limited to 'tests/test/Test.pm')
-rw-r--r--tests/test/Test.pm150
1 files changed, 150 insertions, 0 deletions
diff --git a/tests/test/Test.pm b/tests/test/Test.pm
new file mode 100644
index 0000000..865fc48
--- /dev/null
+++ b/tests/test/Test.pm
@@ -0,0 +1,150 @@
+# Test "test".
+
+# Copyright (C) 1998, 2003, 2005, 2006 Free Software Foundation, Inc.
+
+# This program is free software; you can redistribute it and/or modify
+# it under the terms of the GNU General Public License as published by
+# the Free Software Foundation; either version 2 of the License, or
+# (at your option) any later version.
+
+# This program is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+# GNU General Public License for more details.
+
+# You should have received a copy of the GNU General Public License
+# along with this program; if not, write to the Free Software
+# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
+# 02110-1301, USA.
+
+# -*-perl-*-
+package Test;
+require 5.002;
+use strict;
+
+sub test_vector
+{
+ my @tvec =
+ (
+ # test-name options input expected-output expected-return-code
+ #
+ ['1a', '', {}, '', 1],
+ ['1b', "-z ''", {}, '', 0],
+ ['1c', 'any-string', {}, '', 0],
+ ['1d', '-n any-string', {}, '', 0],
+ ['1e', "''", {}, '', 1],
+ ['1f', '-', {}, '', 0],
+ ['1g', '--', {}, '', 0],
+ ['1h', '-0', {}, '', 0],
+ ['1i', '-f', {}, '', 0],
+ ['1j', '--help', {}, '', 0],
+ ['1k', '--version', {}, '', 0],
+
+ ['streq-1', 't = t', {}, '', 0],
+ ['streq-2', 't = f', {}, '', 1],
+ ['streq-3', '! = !', {}, '', 0],
+ ['streq-4', '= = =', {}, '', 0],
+ ['streq-5', "'(' = '('", {}, '', 0],
+ ['streq-6', "'(' = ')'", {}, '', 1],
+ ['strne-1', 't != t', {}, '', 1],
+ ['strne-2', 't != f', {}, '', 0],
+ ['strne-3', '! != !', {}, '', 1],
+ ['strne-4', '= != =', {}, '', 1],
+ ['strne-5', "'(' != '('", {}, '', 1],
+ ['strne-6', "'(' != ')'", {}, '', 0],
+
+ ['and-1', 't -a t', {}, '', 0],
+ ['and-2', "'' -a t", {}, '', 1],
+ ['and-3', "t -a ''", {}, '', 1],
+ ['and-4', "'' -a ''", {}, '', 1],
+
+ ['or-1', 't -o t', {}, '', 0],
+ ['or-2', "'' -o t", {}, '', 0],
+ ['or-3', "t -o ''", {}, '', 0],
+ ['or-4', "'' -o ''", {}, '', 1],
+
+ ['eq-1', '9 -eq 9', {}, '', 0],
+ ['eq-2', '0 -eq 0', {}, '', 0],
+ ['eq-3', '0 -eq 00', {}, '', 0],
+ ['eq-4', '8 -eq 9', {}, '', 1],
+ ['eq-5', '1 -eq 0', {}, '', 1],
+ ['eq-6', '340282366920938463463374607431768211456 -eq 0', {}, '', 1],
+
+ ['gt-1', '5 -gt 5', {}, '', 1],
+ ['gt-2', '5 -gt 4', {}, '', 0],
+ ['gt-3', '4 -gt 5', {}, '', 1],
+ ['gt-4', '-1 -gt -2', {}, '', 0],
+ ['gt-5', '18446744073709551616 -gt -18446744073709551616', {}, '', 0],
+
+ ['lt-1', '5 -lt 5', {}, '', 1],
+ ['lt-2', '5 -lt 4', {}, '', 1],
+ ['lt-3', '4 -lt 5', {}, '', 0],
+ ['lt-4', '-1 -lt -2', {}, '', 1],
+ ['lt-5', '-18446744073709551616 -lt 18446744073709551616', {}, '', 0],
+
+ # This evokes `test: 0x0: integer expression expected'.
+ ['inv-1', '0x0 -eq 00', {}, '', 2],
+
+ ['t1', "-t", {}, '', 0],
+ ['t2', "-t 1", {}, '', 1],
+
+ ['paren-1', "'(' '' ')'", {}, '', 1],
+ ['paren-2', "'(' '(' ')'", {}, '', 0],
+ ['paren-3', "'(' ')' ')'", {}, '', 0],
+ ['paren-4', "'(' ! ')'", {}, '', 0],
+ ['paren-5', "'(' -a ')'", {}, '', 0],
+ );
+
+ my %inverse_op =
+ (
+ eq => 'ne',
+ lt => 'ge',
+ gt => 'le',
+ );
+
+ # Generate corresponding tests of inverse ops.
+ # E.g. generate tests of `-ge' from those of `-lt'.
+ my @tv;
+ my $t;
+ foreach $t (@tvec)
+ {
+ my ($test_name, $flags, $in, $exp, $ret) = @$t;
+
+ my $op;
+ for $op (qw(gt lt eq))
+ {
+ if ($test_name =~ /$op-/ && $flags =~ / -$op /)
+ {
+ my $inv = $inverse_op{$op};
+ $test_name =~ s/$op/$inv/;
+ $flags =~ s/-$op/-$inv/;
+ $ret = 1 - $ret;
+ push (@tv, [$test_name, $flags, $in, $exp, $ret]);
+ }
+ }
+ }
+
+ # Generate parenthesized and negated versions of each test.
+ # There are a few exceptions.
+ my %not_N = map {$_ => 1} qw (1a);
+ my %not_P = map {$_ => 1} qw (1a
+ streq-6 strne-6
+ paren-1 paren-2 paren-3 paren-4 paren-5);
+ foreach $t (@tvec)
+ {
+ my ($test_name, $flags, $in, $exp, $ret) = @$t;
+ next if $ret == 2;
+ push (@tv, ["N-$test_name", "! $flags", $in, $exp, 1 - $ret])
+ unless $not_N{$test_name};
+ push (@tv, ["P-$test_name", "'(' $flags ')'", $in, $exp, $ret])
+ unless $not_P{$test_name};
+ push (@tv, ["NP-$test_name", "! '(' $flags ')'", $in, $exp, 1 - $ret])
+ unless $not_P{$test_name};
+ push (@tv, ["NNP-$test_name", "! ! '(' $flags ')'", $in, $exp, $ret])
+ unless $not_P{$test_name};
+ }
+
+ return (@tv, @tvec);
+}
+
+1;