mirror of
https://github.com/openssl/openssl.git
synced 2025-01-18 13:44:20 +08:00
aec27d4d52
The idea with this perl based testing framework is to make use of what's delivered with perl and exists on all sorts of platforms. The choice came to using Test::More and Test::Harness, as that seems to be the most widely spread foundation, even if perl is aged. The main runner of the show is run_tests.pl. As it currently stands, it's designed to run from inside Makefile, but it's absolutely possible to run it from the command line as well, like so: cd test OPENSSL_SRCDIR=.. perl run_tests.pl The tester scripts themselves are stored in the subdirectory recipes/, and initially, we have two such scripts, recipes/00-check_testalltests.t and recipes/00-check_testexes.t. recipes/00-check_testalltests.t will pick out the dependencies of "alltests" in test/Makefile, and check if it can find recipes with corresponding names. recipes/00-check_testexes.t does something similar, but bases it on existing compiled test binaries. They make it easy to figure out what's to be added, and will be removed when this effort is finished. Individual recipes can be run as well, of course, as they are perl scripts in themselves. For example, you can run only recipes/00-check_testexes.t like so: cd test OPENSSL_SRCDIR=.. perl recipes/00-check_testexes.t To make coding easier, there's a routine library OpenSSL::Test, which is reachable in a perl script like so: use lib 'testlib'; use OpenSSL::Test; Reviewed-by: Rich Salz <rsalz@openssl.org>
54 lines
1.1 KiB
Perl
54 lines
1.1 KiB
Perl
#! /usr/bin/perl
|
|
|
|
use strict;
|
|
|
|
use File::Spec::Functions;
|
|
use Test::More;
|
|
|
|
use OpenSSL::Test qw/:DEFAULT top_file/;
|
|
|
|
setup("check_testexes");
|
|
|
|
my $MINFO = top_file("MINFO");
|
|
|
|
plan tests => 2;
|
|
if (ok(open(FH,$MINFO), "MINFO exists")) {
|
|
subtest 'Finding test scripts for the compiled test binaries' => sub {
|
|
find_tests(\*FH); close FH;
|
|
};
|
|
} else {
|
|
diag("Expected to find $MINFO, please run 'make files' in the top directory");
|
|
}
|
|
|
|
#-------------
|
|
# test script finder
|
|
sub find_tests {
|
|
my $fh = shift;
|
|
while(<$fh>) {
|
|
chomp;
|
|
last if /^RELATIVE_DIRECTORY=test$/;
|
|
}
|
|
while(<$fh>) {
|
|
chomp;
|
|
last if /^EXE=/;
|
|
}
|
|
|
|
s/^EXE=\s*//;
|
|
s/\s*$//;
|
|
my %foundfiles =
|
|
map {
|
|
my $key = $_;
|
|
s/_?test$//;
|
|
s/(sha\d+)t/$1/;
|
|
$key => top_file("test",
|
|
"recipes/[0-9][0-9]-test_$_.t"); } split(/\s+/, $_);
|
|
|
|
plan tests => scalar (keys %foundfiles);
|
|
|
|
foreach (sort keys %foundfiles) {
|
|
my @check = glob($foundfiles{$_});
|
|
ok(scalar @check, "check that a test for $_ exists")
|
|
|| diag("Expected to find something matching $foundfiles{$_}");
|
|
}
|
|
}
|