123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201 |
- #!/usr/local/bin/perl -w
- #
- # Run the test suite and generate a report
- #
- if (! -f "Configure") {
- print "Please run perl util/selftest.pl in the OpenSSL directory.\n";
- exit 1;
- }
- my $report="testlog";
- my $os="??";
- my $version="??";
- my $platform0="??";
- my $platform="??";
- my $options="??";
- my $last="??";
- my $ok=0;
- my $cc="cc";
- my $cversion="??";
- my $sep="-----------------------------------------------------------------------------\n";
- my $not_our_fault="\nPlease ask your system administrator/vendor for more information.\n[Problems with your operating system setup should not be reported\nto the OpenSSL project.]\n";
- open(OUT,">$report") or die;
- print OUT "OpenSSL self-test report:\n\n";
- $uname=`uname -a`;
- $uname="??\n" if $uname eq "";
- $c=`sh config -t`;
- foreach $_ (split("\n",$c)) {
- $os=$1 if (/Operating system: (.*)$/);
- $platform0=$1 if (/Configuring for (.*)$/);
- }
- system "sh config" if (! -f "Makefile");
- if (open(IN,"<Makefile")) {
- while (<IN>) {
- $version=$1 if (/^VERSION=(.*)$/);
- $platform=$1 if (/^PLATFORM=(.*)$/);
- $options=$1 if (/^OPTIONS=(.*)$/);
- $cc=$1 if (/^CC= *(.*)$/);
- }
- close(IN);
- } else {
- print OUT "Error running config!\n";
- }
- $cversion=`$cc -v 2>&1`;
- $cversion=`$cc -V 2>&1` if $cversion =~ "[Uu]sage";
- $cversion=`$cc -V |head -1` if $cversion =~ "Error";
- $cversion=`$cc --version` if $cversion eq "";
- $cversion =~ s/Reading specs.*\n//;
- $cversion =~ s/usage.*\n//;
- chomp $cversion;
- if (open(IN,"<CHANGES")) {
- while(<IN>) {
- if (/\*\) (.{0,55})/ && !/applies to/) {
- $last=$1;
- last;
- }
- }
- close(IN);
- }
- print OUT "OpenSSL version: $version\n";
- print OUT "Last change: $last...\n";
- print OUT "Options: $options\n" if $options ne "";
- print OUT "OS (uname): $uname";
- print OUT "OS (config): $os\n";
- print OUT "Target (default): $platform0\n";
- print OUT "Target: $platform\n";
- print OUT "Compiler: $cversion\n";
- print OUT "\n";
- print "Checking compiler...\n";
- if (open(TEST,">cctest.c")) {
- print TEST "#include <stdio.h>\n#include <errno.h>\nmain(){printf(\"Hello world\\n\");}\n";
- close(TEST);
- system("$cc -o cctest cctest.c");
- if (`./cctest` !~ /Hello world/) {
- print OUT "Compiler doesn't work.\n";
- print OUT $not_our_fault;
- goto err;
- }
- system("ar r cctest.a /dev/null");
- if (not -f "cctest.a") {
- print OUT "Check your archive tool (ar).\n";
- print OUT $not_our_fault;
- goto err;
- }
- } else {
- print OUT "Can't create cctest.c\n";
- }
- if (open(TEST,">cctest.c")) {
- print TEST "#include <openssl/opensslv.h>\nmain(){printf(OPENSSL_VERSION_TEXT);}\n";
- close(TEST);
- system("$cc -o cctest -Iinclude cctest.c");
- $cctest = `./cctest`;
- if ($cctest !~ /OpenSSL $version/) {
- if ($cctest =~ /OpenSSL/) {
- print OUT "#include uses headers from different OpenSSL version!\n";
- } else {
- print OUT "Can't compile test program!\n";
- }
- print OUT $not_our_fault;
- goto err;
- }
- } else {
- print OUT "Can't create cctest.c\n";
- }
- print "Running make...\n";
- if (system("make 2>&1 | tee make.log") > 255) {
- print OUT "make failed!\n";
- if (open(IN,"<make.log")) {
- print OUT $sep;
- while (<IN>) {
- print OUT;
- }
- close(IN);
- print OUT $sep;
- } else {
- print OUT "make.log not found!\n";
- }
- goto err;
- }
- # Not sure why this is here. The tests themselves can detect if their
- # particular feature isn't included, and should therefore skip themselves.
- # To skip *all* tests just because one algorithm isn't included is like
- # shooting mosquito with an elephant gun...
- # -- Richard Levitte, inspired by problem report 1089
- #
- #$_=$options;
- #s/no-asm//;
- #s/no-shared//;
- #s/no-krb5//;
- #if (/no-/)
- #{
- # print OUT "Test skipped.\n";
- # goto err;
- #}
- print "Running make test...\n";
- if (system("make test 2>&1 | tee maketest.log") > 255)
- {
- print OUT "make test failed!\n";
- } else {
- $ok=1;
- }
- if ($ok and open(IN,"<maketest.log")) {
- while (<IN>) {
- $ok=2 if /^platform: $platform/;
- }
- close(IN);
- }
- if ($ok != 2) {
- print OUT "Failure!\n";
- if (open(IN,"<make.log")) {
- print OUT $sep;
- while (<IN>) {
- print OUT;
- }
- close(IN);
- print OUT $sep;
- } else {
- print OUT "make.log not found!\n";
- }
- if (open(IN,"<maketest.log")) {
- while (<IN>) {
- print OUT;
- }
- close(IN);
- print OUT $sep;
- } else {
- print OUT "maketest.log not found!\n";
- }
- } else {
- print OUT "Test passed.\n";
- }
- err:
- close(OUT);
- print "\n";
- open(IN,"<$report") or die;
- while (<IN>) {
- if (/$sep/) {
- print "[...]\n";
- last;
- }
- print;
- }
- print "\nTest report in file $report\n";
|