diff options
| author | Abigail <abigail@abigail.be> | 2020-11-02 12:48:25 +0100 |
|---|---|---|
| committer | Abigail <abigail@abigail.be> | 2020-11-02 12:48:25 +0100 |
| commit | 56f94eb269cf13e5871cd6316a853daa9dbad633 (patch) | |
| tree | 586ae742ce6afacd4b2e14fbcb91352645e1b504 | |
| parent | 6358c68fd8d05e51ee0c4d7777dbf5fef7c7cb18 (diff) | |
| download | perlweeklychallenge-club-56f94eb269cf13e5871cd6316a853daa9dbad633.tar.gz perlweeklychallenge-club-56f94eb269cf13e5871cd6316a853daa9dbad633.tar.bz2 perlweeklychallenge-club-56f94eb269cf13e5871cd6316a853daa9dbad633.zip | |
Copy test script from previous week
| -rwxr-xr-x | challenge-085/abigail/test.pl | 105 |
1 files changed, 105 insertions, 0 deletions
diff --git a/challenge-085/abigail/test.pl b/challenge-085/abigail/test.pl new file mode 100755 index 0000000000..6f26ad7159 --- /dev/null +++ b/challenge-085/abigail/test.pl @@ -0,0 +1,105 @@ +#!/opt/perl/bin/perl + +# +# Test the solutions. Either call it with the directory name you +# want to test in, or call it as "../test.pl" from within the directory. +# + +use 5.032; + +use strict; +use warnings; +no warnings 'syntax'; + +chdir ".." if -f "../test.pl"; + +use experimental 'signatures'; + +use Test::More; + + +my %languages = ( + Perl => { + exe => "/opt/perl/bin/perl", + ext => "pl", + }, + JavaScript => { + exe => "/usr/local/bin/node", + ext => "js", + dir => "node", + }, + bc => { + exe => "/usr/bin/bc", + ext => "bc", + filter => 's/.*/main($&)/', + }, + awk => { + exe => "/usr/bin/awk", + ext => "awk", + args => ["-f"], + }, + C => { + exe => "/usr/bin/cc", + ext => "c", + dir => "c", + } +); + +my $perl_exe = $languages {Perl} {exe}; + +foreach my $challenge (1, 2) { + my @inputs = <input-$challenge-*> or next; + subtest "Challenge $challenge" => sub { + foreach my $language (sort keys %languages) { + my $info = $languages {$language}; + my $exe = $$info {exe}; + my $ext = $$info {ext}; + my $dir = $$info {dir} // lc $language; + my @args = @{$$info {args} // []}; + my $filter = $$info {filter} // ''; + my $ext_out = $$info {ext_out} // "out"; + my $source = "$dir/ch-$challenge.$ext"; + my $compiled; + next unless -r $source; + + # + # C requires special handling. The source needs to be compiled. + # + if ($language eq "C") { + $compiled = $source =~ s/\.$ext$/.$ext_out/r; + system $exe, "-o", $compiled, $source; + } + + subtest $language => sub { + foreach my $input (@inputs) { + my $output_exp = ($input =~ s/input/output/r) . ".exp"; + my $exp = `cat $output_exp`; + + my $name = $input; + if ($exp =~ s/^\s*#\s*(.*)\n//) { + $name = $1; + } + + my $got; + if ($compiled) { + $got = `$perl_exe -ple '$filter' $input | ./$compiled`; + } + else { + $got = `$perl_exe -ple '$filter' $input |\ + $exe @args ./$source`; + } + + s/\h+$//gm for $exp, $got; + is $got, $exp, $name; + } + }; + + unlink $compiled if $compiled; + } + } +} + +done_testing; + + +__END__ |
