Groundwork for a perl based testing framework
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>
2015-04-17 17:44:48 +00:00
|
|
|
#! /usr/bin/perl
|
|
|
|
|
|
|
|
use strict;
|
|
|
|
|
|
|
|
use File::Spec::Functions;
|
2015-04-30 17:38:47 +00:00
|
|
|
use File::Basename;
|
Groundwork for a perl based testing framework
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>
2015-04-17 17:44:48 +00:00
|
|
|
use OpenSSL::Test qw/:DEFAULT top_file/;
|
|
|
|
|
|
|
|
setup("check_testexes");
|
|
|
|
|
2015-08-09 04:52:50 +00:00
|
|
|
my $OpenSSL_ver = "";
|
|
|
|
my $Makefile = top_file("Makefile");
|
|
|
|
if (open(FH, $Makefile)) {
|
|
|
|
$OpenSSL_ver =
|
|
|
|
(map { chomp; s/^VERSION=([^\s]*)\s*$//; $1 } grep { /^VERSION=/ } <FH>)[0];
|
|
|
|
close FH;
|
|
|
|
}
|
|
|
|
|
Groundwork for a perl based testing framework
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>
2015-04-17 17:44:48 +00:00
|
|
|
my $MINFO = top_file("MINFO");
|
|
|
|
|
2015-08-09 03:35:57 +00:00
|
|
|
plan skip_all => "because MINFO not found. If you want this test to run, please do 'perl util/mkfiles.pl > MINFO'"
|
|
|
|
unless open(FH,$MINFO);
|
|
|
|
|
2015-08-09 04:52:50 +00:00
|
|
|
my $MINFO_ver = "";
|
|
|
|
|
2015-08-09 03:35:57 +00:00
|
|
|
while(<FH>) {
|
|
|
|
chomp;
|
2015-08-09 04:52:50 +00:00
|
|
|
if (/^VERSION=([^\s]*)\s*$/) {
|
|
|
|
$MINFO_ver = $1;
|
|
|
|
}
|
2015-08-09 03:35:57 +00:00
|
|
|
last if /^RELATIVE_DIRECTORY=test$/;
|
|
|
|
}
|
|
|
|
while(<FH>) {
|
|
|
|
chomp;
|
|
|
|
last if /^EXE=/;
|
|
|
|
}
|
|
|
|
close FH;
|
|
|
|
|
2015-08-09 04:52:50 +00:00
|
|
|
plan skip_all => "because MINFO is not from this OpenSSL version. If you want this test to run, please do 'perl util/mkfiles.pl > MINFO'"
|
|
|
|
unless $OpenSSL_ver eq $MINFO_ver;
|
|
|
|
|
2015-08-09 03:35:57 +00:00
|
|
|
s/^EXE=\s*//;
|
|
|
|
s/\s*$//;
|
|
|
|
my @expected_tests =
|
|
|
|
map { s/\..*$//; # Remove extension
|
|
|
|
s/_?test$//; # Remove 'test', possibly prefixed with '_'
|
|
|
|
s/(sha\d+)t/$1/; # sha comes with no t at the end
|
|
|
|
$_; } split(/\s+/, $_);
|
|
|
|
|
|
|
|
plan tests => scalar @expected_tests;
|
|
|
|
|
|
|
|
my @found_tests =
|
|
|
|
map { basename($_) } glob(top_file("test", "recipes", "*.t"));
|
|
|
|
|
|
|
|
foreach my $test (sort @expected_tests) {
|
|
|
|
ok(scalar(grep(/^[0-9][0-9]-test_$test\.t$/, @found_tests)),
|
|
|
|
"check that a test for $test exists")
|
|
|
|
|| diag("Expected to find something matching '[0-9][0-9]-test_$test.t'");
|
Groundwork for a perl based testing framework
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>
2015-04-17 17:44:48 +00:00
|
|
|
}
|