Blame tests/run-unit-tests.pl.in

Packit 284210
#!@PERL@
Packit 284210
#
Packit 284210
# Run unit tests.
Packit 284210
#
Packit 284210
# Syntax:
Packit 284210
#          All: run-tests.pl
Packit 284210
#     All in file: run-tests.pl file
Packit 284210
#     Nth in file: run-tests.pl file N
Packit 284210
#
Packit 284210
use strict;
Packit 284210
use POSIX qw(WIFEXITED WEXITSTATUS WIFSIGNALED WTERMSIG);
Packit 284210
use File::Basename qw(basename dirname);
Packit 284210
use FileHandle;
Packit 284210
use IPC::Open2 qw(open2);
Packit 284210
Packit 284210
my @TYPES = qw(tfn op action);
Packit 284210
my $TEST = "./msc_test";
Packit 284210
my $SCRIPT = basename($0);
Packit 284210
my $SCRIPTDIR = dirname($0);
Packit 284210
my $PASSED = 0;
Packit 284210
my $TOTAL = 0;
Packit 284210
my $DEBUG = $ENV{MSC_TEST_DEBUG} || 0;
Packit 284210
Packit 284210
if (defined $ARGV[0]) {
Packit 284210
    runfile(dirname($ARGV[0]), basename($ARGV[0]), $ARGV[1]);
Packit 284210
    done();
Packit 284210
}
Packit 284210
Packit 284210
for my $type (sort @TYPES) {
Packit 284210
    my $dir = "$SCRIPTDIR/$type";
Packit 284210
    my @cfg = ();
Packit 284210
Packit 284210
    # Get test names
Packit 284210
    opendir(DIR, "$dir") or quit(1, "Failed to open \"$dir\": $!");
Packit 284210
    @cfg = grep { /\.t$/ && -f "$dir/$_" } readdir(DIR);
Packit 284210
    closedir(DIR);
Packit 284210
Packit 284210
    for my $cfg (sort @cfg) {
Packit 284210
        runfile($dir, $cfg);
Packit 284210
    }
Packit 284210
Packit 284210
}
Packit 284210
done();
Packit 284210
Packit 284210
Packit 284210
sub runfile {
Packit 284210
    my($dir, $cfg, $testnum) = @_;
Packit 284210
    my $fn = "$dir/$cfg";
Packit 284210
    my @data = ();
Packit 284210
    my $edata;
Packit 284210
    my @C = ();
Packit 284210
    my @test = ();
Packit 284210
    my $teststr;
Packit 284210
    my $n = 0;
Packit 284210
    my $pass = 0;
Packit 284210
Packit 284210
    open(CFG, "<$fn") or quit(1, "Failed to open \"$fn\": $!");
Packit 284210
    @data = <CFG>;
Packit 284210
    
Packit 284210
    $edata = q/@C = (/ . join("", @data) . q/)/;
Packit 284210
    eval $edata;
Packit 284210
    quit(1, "Failed to read test data \"$cfg\": $@") if ($@);
Packit 284210
Packit 284210
    unless (@C) {
Packit 284210
        msg("\nNo tests defined for $fn");
Packit 284210
        return;
Packit 284210
    }
Packit 284210
Packit 284210
    msg("\nLoaded ".@C." tests from $fn");
Packit 284210
    for my $t (@C) {
Packit 284210
        $n++;
Packit 284210
        next if (defined $testnum and $n != $testnum);
Packit 284210
Packit 284210
        my %t = %{$t || {}};
Packit 284210
        my $id = sprintf("%6d", $n);
Packit 284210
        my $in = (exists($t{input}) and defined($t{input})) ? $t{input} : "";
Packit 284210
        my $out;
Packit 284210
        my $test_in = new FileHandle();
Packit 284210
        my $test_out = new FileHandle();
Packit 284210
        my $test_pid;
Packit 284210
        my $rc = 0;
Packit 284210
        my $param;
Packit 284210
Packit 284210
        if ($t{type} eq "tfn") {
Packit 284210
            $param = escape($t{output});
Packit 284210
        }
Packit 284210
        elsif ($t{type} eq "op") {
Packit 284210
            $param = escape($t{param});
Packit 284210
        }
Packit 284210
        elsif ($t{type} eq "action") {
Packit 284210
            $param = escape($t{param});
Packit 284210
        }
Packit 284210
        else {
Packit 284210
            quit(1, "Unknown type \"$t{type}\" - should be one of: " . join(",",@TYPES));
Packit 284210
        }
Packit 284210
Packit 284210
        @test = ("-t", $t{type}, "-n", $t{name}, "-p", $param, "-D", "$DEBUG", (exists($t{ret}) ? ("-r", $t{ret}) : ()), (exists($t{iterations}) ? ("-I", $t{iterations}) : ()), (exists($t{prerun}) ? ("-P", $t{prerun}) : ()));
Packit 284210
        $teststr = "$TEST " . join(" ", map { "\"$_\"" } @test);
Packit 284210
        $test_pid = open2($test_out, $test_in, $TEST, @test) or quit(1, "Failed to execute test: $teststr\": $!");
Packit 284210
        print $test_in "$in";
Packit 284210
        close $test_in;
Packit 284210
        $out = join("\\n", split(/\n/, <$test_out>));
Packit 284210
        close $test_out;
Packit 284210
        waitpid($test_pid, 0);
Packit 284210
Packit 284210
        $rc = $?;
Packit 284210
        if ( WIFEXITED($rc) ) {
Packit 284210
            $rc = WEXITSTATUS($rc);
Packit 284210
        }
Packit 284210
        elsif( WIFSIGNALED($rc) ) {
Packit 284210
            msg("Test exited with signal " . WTERMSIG($rc) . ".");
Packit 284210
            msg("Executed: $teststr");
Packit 284210
            $rc = -1;
Packit 284210
        }
Packit 284210
        else {
Packit 284210
            msg("Test exited with unknown error.");
Packit 284210
            $rc = -1;
Packit 284210
        }
Packit 284210
Packit 284210
        if ($rc == 0) {
Packit 284210
            $pass++;
Packit 284210
        }
Packit 284210
Packit 284210
        msg(sprintf("%s) %s \"%s\"%s: %s%s", $id, $t{type}, $t{name}, (exists($t{comment}) ? " $t{comment}" : ""), ($rc ? "failed" : "passed"), ((defined($out) && $out ne "")? " ($out)" : "")));
Packit 284210
        
Packit 284210
    }
Packit 284210
Packit 284210
    $TOTAL += $testnum ? 1 : $n;
Packit 284210
    $PASSED += $pass;
Packit 284210
Packit 284210
    msg(sprintf("Passed: %2d; Failed: %2d", $pass, $testnum ? (1 - $pass) : ($n - $pass)));
Packit 284210
}
Packit 284210
Packit 284210
sub escape {
Packit 284210
    my @new = ();
Packit 284210
    for my $c (split(//, $_[0])) {
Packit 284210
        push @new, ((ord($c) >= 0x20 and ord($c) <= 0x7e) ? $c : sprintf("\\x%02x", ord($c)));
Packit 284210
    }
Packit 284210
    join('', @new);
Packit 284210
}
Packit 284210
Packit 284210
sub msg {
Packit 284210
    print STDOUT "@_\n" if (@_);
Packit 284210
}
Packit 284210
Packit 284210
sub quit {
Packit 284210
    my($ec,$msg) = @_;
Packit 284210
    $ec = 0 unless (defined $_[0]);
Packit 284210
Packit 284210
    msg("$msg") if (defined $msg);
Packit 284210
Packit 284210
    exit $ec;
Packit 284210
}
Packit 284210
Packit 284210
sub done {
Packit 284210
    if ($PASSED != $TOTAL) {
Packit 284210
        quit(1, "\n$PASSED/$TOTAL tests passed.");
Packit 284210
    }
Packit 284210
Packit 284210
    quit(0, "\nAll tests passed ($TOTAL).");
Packit 284210
}