#!/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";