# 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;
syntax highlighted by Code2HTML, v. 0.9.1