From 8794c292e7b41a27d18871b7760f280065dbb593 Mon Sep 17 00:00:00 2001 From: Jim Meyering Date: Sat, 28 Dec 1996 05:30:46 +0000 Subject: Fix a couple of thinkos and typos. Now it works with pr's tests, too. --- tests/cut/mk-script.pl | 23 +++++++++++++++-------- tests/head/mk-script.pl | 23 +++++++++++++++-------- tests/join/mk-script.pl | 23 +++++++++++++++-------- tests/ls/mk-script.pl | 23 +++++++++++++++-------- 4 files changed, 60 insertions(+), 32 deletions(-) (limited to 'tests') diff --git a/tests/cut/mk-script.pl b/tests/cut/mk-script.pl index 20d617cb7..60a90d5b0 100644 --- a/tests/cut/mk-script.pl +++ b/tests/cut/mk-script.pl @@ -17,13 +17,10 @@ sub validate { my ($test_name, $flags, $in_spec, $expected, $e_ret_code, $rest) = @$test_vector; - if (!defined $e_ret_code || defined $rest) - { - die "wrong number of elements in test $test_name\n"; - } + die "wrong number of elements in test $test_name\n" + if (!defined $e_ret_code || defined $rest); assert (!ref $test_name); assert (!ref $flags); - assert (!ref $expected); assert (!ref $e_ret_code); die "$0: $.: duplicate test name \`$test_name'\n" @@ -75,7 +72,9 @@ sub spec_to_list ($$$) # file. if (ref $file_spec) { - assert (ref $file_spec eq 'SCALAR'); + my $r = ref $file_spec; + die "bad test: $test_name is $r\n" + if ref $file_spec ne 'SCALAR'; my $existing_file = $$file_spec; # FIXME: make sure $existing_file exists somewhere. push (@explicit_file, $existing_file); @@ -169,6 +168,11 @@ sub wrap push (@maint, @{$e->{MAINT_GEN}}); } + # The list of explicitly mentioned files may contain duplicates. + # Eliminated any duplicates. + my %e = map {$_ => 1} @exp; + @exp = sort keys %e; + my $len = 77; print join (" \\\n", wrap ($len, 'explicit =', @exp)), "\n"; print join (" \\\n", wrap ($len, 'maint_gen =', @maint)), "\n"; @@ -219,7 +223,9 @@ foreach $test_vector (Test::test_vector ()) && defined $Test::input_via_stdin && $Test::input_via_stdin) ? '< ' : ''); - my $cmd = "\$xx $flags $redirect_stdin" . join (' ', @srcdir_rel_in_file) + my $z = $Test::common_option_prefix if defined $Test::common_option_prefix; + $z ||= ''; + my $cmd = "\$xx $z$flags $redirect_stdin" . join (' ', @srcdir_rel_in_file) . " > $out 2> $err_output"; print <&2 + \$echo Passed all $n_tests tests. 1>&2 else \$echo Failed \$errors tests. 1>&2 fi diff --git a/tests/head/mk-script.pl b/tests/head/mk-script.pl index 20d617cb7..60a90d5b0 100644 --- a/tests/head/mk-script.pl +++ b/tests/head/mk-script.pl @@ -17,13 +17,10 @@ sub validate { my ($test_name, $flags, $in_spec, $expected, $e_ret_code, $rest) = @$test_vector; - if (!defined $e_ret_code || defined $rest) - { - die "wrong number of elements in test $test_name\n"; - } + die "wrong number of elements in test $test_name\n" + if (!defined $e_ret_code || defined $rest); assert (!ref $test_name); assert (!ref $flags); - assert (!ref $expected); assert (!ref $e_ret_code); die "$0: $.: duplicate test name \`$test_name'\n" @@ -75,7 +72,9 @@ sub spec_to_list ($$$) # file. if (ref $file_spec) { - assert (ref $file_spec eq 'SCALAR'); + my $r = ref $file_spec; + die "bad test: $test_name is $r\n" + if ref $file_spec ne 'SCALAR'; my $existing_file = $$file_spec; # FIXME: make sure $existing_file exists somewhere. push (@explicit_file, $existing_file); @@ -169,6 +168,11 @@ sub wrap push (@maint, @{$e->{MAINT_GEN}}); } + # The list of explicitly mentioned files may contain duplicates. + # Eliminated any duplicates. + my %e = map {$_ => 1} @exp; + @exp = sort keys %e; + my $len = 77; print join (" \\\n", wrap ($len, 'explicit =', @exp)), "\n"; print join (" \\\n", wrap ($len, 'maint_gen =', @maint)), "\n"; @@ -219,7 +223,9 @@ foreach $test_vector (Test::test_vector ()) && defined $Test::input_via_stdin && $Test::input_via_stdin) ? '< ' : ''); - my $cmd = "\$xx $flags $redirect_stdin" . join (' ', @srcdir_rel_in_file) + my $z = $Test::common_option_prefix if defined $Test::common_option_prefix; + $z ||= ''; + my $cmd = "\$xx $z$flags $redirect_stdin" . join (' ', @srcdir_rel_in_file) . " > $out 2> $err_output"; print <&2 + \$echo Passed all $n_tests tests. 1>&2 else \$echo Failed \$errors tests. 1>&2 fi diff --git a/tests/join/mk-script.pl b/tests/join/mk-script.pl index 20d617cb7..60a90d5b0 100644 --- a/tests/join/mk-script.pl +++ b/tests/join/mk-script.pl @@ -17,13 +17,10 @@ sub validate { my ($test_name, $flags, $in_spec, $expected, $e_ret_code, $rest) = @$test_vector; - if (!defined $e_ret_code || defined $rest) - { - die "wrong number of elements in test $test_name\n"; - } + die "wrong number of elements in test $test_name\n" + if (!defined $e_ret_code || defined $rest); assert (!ref $test_name); assert (!ref $flags); - assert (!ref $expected); assert (!ref $e_ret_code); die "$0: $.: duplicate test name \`$test_name'\n" @@ -75,7 +72,9 @@ sub spec_to_list ($$$) # file. if (ref $file_spec) { - assert (ref $file_spec eq 'SCALAR'); + my $r = ref $file_spec; + die "bad test: $test_name is $r\n" + if ref $file_spec ne 'SCALAR'; my $existing_file = $$file_spec; # FIXME: make sure $existing_file exists somewhere. push (@explicit_file, $existing_file); @@ -169,6 +168,11 @@ sub wrap push (@maint, @{$e->{MAINT_GEN}}); } + # The list of explicitly mentioned files may contain duplicates. + # Eliminated any duplicates. + my %e = map {$_ => 1} @exp; + @exp = sort keys %e; + my $len = 77; print join (" \\\n", wrap ($len, 'explicit =', @exp)), "\n"; print join (" \\\n", wrap ($len, 'maint_gen =', @maint)), "\n"; @@ -219,7 +223,9 @@ foreach $test_vector (Test::test_vector ()) && defined $Test::input_via_stdin && $Test::input_via_stdin) ? '< ' : ''); - my $cmd = "\$xx $flags $redirect_stdin" . join (' ', @srcdir_rel_in_file) + my $z = $Test::common_option_prefix if defined $Test::common_option_prefix; + $z ||= ''; + my $cmd = "\$xx $z$flags $redirect_stdin" . join (' ', @srcdir_rel_in_file) . " > $out 2> $err_output"; print <&2 + \$echo Passed all $n_tests tests. 1>&2 else \$echo Failed \$errors tests. 1>&2 fi diff --git a/tests/ls/mk-script.pl b/tests/ls/mk-script.pl index 20d617cb7..60a90d5b0 100644 --- a/tests/ls/mk-script.pl +++ b/tests/ls/mk-script.pl @@ -17,13 +17,10 @@ sub validate { my ($test_name, $flags, $in_spec, $expected, $e_ret_code, $rest) = @$test_vector; - if (!defined $e_ret_code || defined $rest) - { - die "wrong number of elements in test $test_name\n"; - } + die "wrong number of elements in test $test_name\n" + if (!defined $e_ret_code || defined $rest); assert (!ref $test_name); assert (!ref $flags); - assert (!ref $expected); assert (!ref $e_ret_code); die "$0: $.: duplicate test name \`$test_name'\n" @@ -75,7 +72,9 @@ sub spec_to_list ($$$) # file. if (ref $file_spec) { - assert (ref $file_spec eq 'SCALAR'); + my $r = ref $file_spec; + die "bad test: $test_name is $r\n" + if ref $file_spec ne 'SCALAR'; my $existing_file = $$file_spec; # FIXME: make sure $existing_file exists somewhere. push (@explicit_file, $existing_file); @@ -169,6 +168,11 @@ sub wrap push (@maint, @{$e->{MAINT_GEN}}); } + # The list of explicitly mentioned files may contain duplicates. + # Eliminated any duplicates. + my %e = map {$_ => 1} @exp; + @exp = sort keys %e; + my $len = 77; print join (" \\\n", wrap ($len, 'explicit =', @exp)), "\n"; print join (" \\\n", wrap ($len, 'maint_gen =', @maint)), "\n"; @@ -219,7 +223,9 @@ foreach $test_vector (Test::test_vector ()) && defined $Test::input_via_stdin && $Test::input_via_stdin) ? '< ' : ''); - my $cmd = "\$xx $flags $redirect_stdin" . join (' ', @srcdir_rel_in_file) + my $z = $Test::common_option_prefix if defined $Test::common_option_prefix; + $z ||= ''; + my $cmd = "\$xx $z$flags $redirect_stdin" . join (' ', @srcdir_rel_in_file) . " > $out 2> $err_output"; print <&2 + \$echo Passed all $n_tests tests. 1>&2 else \$echo Failed \$errors tests. 1>&2 fi -- cgit v1.2.3-70-g09d2