# HG changeset patch # User lost@l-w.ca # Date 1315449920 21600 # Node ID 3413a88f4d09196b9904e1d205882bbbd946f9cc # Parent a88b04ba5ab81beb08c42470ab752a6c39bc1607 Added test framework diff -r a88b04ba5ab8 -r 3413a88f4d09 Makefile --- a/Makefile Mon Sep 05 18:10:21 2011 -0600 +++ b/Makefile Wed Sep 07 20:45:20 2011 -0600 @@ -70,9 +70,6 @@ @echo Linking $@ @$(CC) -o $@ $(lwar_objs) $(LDFLAGS) -test: test.c lwlib - $(CC) $(CPPFLAGS) $(CFLAGS) -o $@ test.c $(LDFLAGS) - #.PHONY: lwlib .INTERMEDIATE: lwlib lwlib: lwlib/liblw.a @@ -121,4 +118,8 @@ .PHONY: install install: cp $(MAIN_TARGETS) /usr/local/bin/ + +.PHONY: test +test: all test/runtests + @test/runtests \ No newline at end of file diff -r a88b04ba5ab8 -r 3413a88f4d09 test/runtests --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/test/runtests Wed Sep 07 20:45:20 2011 -0600 @@ -0,0 +1,92 @@ +#!/usr/bin/perl +# +# This program will execute all programs in the "tests" directory. Each +# program is expected to produce output as follows on stdout: +# +# each line begins with a test name followed by whitespace followed by +# PASS, FAIL, or SKIP. +# +# stderr is not redirected during testing. Any test that might spam stderr +# is encouraged to redirect it somewhere useful. +# +# After each test script exits, a report indicating number passed, failed, +# and skipped is presented, or if the script failed to run. +# +# Once all tests have been run, a report showing the grand total number of +# tests performed, passed, failed, and skipped. +# +# Each test can be in any programming language that is appropriate for +# the task. +# +# Each test can assume the current directory is the root of the source tree. + +use File::Basename; + +$testdir = dirname($0) . '/tests'; + +opendir DH, $testdir; +while ($fe = readdir DH) +{ + next if ($fe =~ /^\./); + next if ($fe =~ /~$/); + + $fn = $testdir . '/' . $fe; + + open P,"$fn|"; + while (
) + { + chomp; + ($tn, $ts) = split /\s+/; + $testresults{$fe}{$tn} = $ts; + if ($ts eq 'PASS') + { + $testspassed += 1; + $testresults{$fe}{'..passed'} += 1; + } + elsif ($ts eq 'FAIL') + { + $testsfailed += 1; + $testresults{$fe}{'..failed'} =+ 1; + } + elsif ($ts eq 'SKIP') + { + $testsskipped += 1; + $testresults{$fe}{'..skipped'} += 1; + } + else + { + $testsunknown += 1; + $testresults{$fe}{'..unknown'} += 1; + } + $teststotal += 1; + $testresults{$fe}{'..total'} += 1; + } + close P; + $fdn = $fe; + $fdn =~ s/\..+?$//; + $rline = sprintf("%-25.25s: %d/%d (%d skipped, %d unknown, %d failed)", $fdn, $testresults{$fe}{'..passed'}, $testresults{$fe}{'..total'}, $testresults{$fe}{'..skipped'}, $testresults{$fe}{'..unknown'}, $testresults{$fe}{'..failed'}); + print "$rline\n"; +} +closedir DH; + +print sprintf("\n===================\nTotal: %d/%d (%d skipped, %d unknown, %d failed)\n", $testspassed, $teststotal, $testsskipped, $testsunknown, $testsfailed); + +if ($testspassed < $teststotal) +{ + print "\nThe following tests either failed or were otherwise dubious:\n"; + foreach $i (keys %testresults) + { + $fdn = $i; + $fdn =~ s/\..+?$//; + foreach $j (keys %{ $testresults{$i} }) + { + next if $j =~ /^\./; + if ($testresults{$i}{$j} ne 'PASS') + { + print "$fdn/$j: $testresults{$i}{$j}\n"; + } + } + } + exit 1; +} +exit 0;