
1: #!/usr/local/bin/perl -w 2: # 3: # Run the test suite and generate a report 4: # 5: 6: if (! -f "Configure") { 7: print "Please run perl util/selftest.pl in the OpenSSL directory.\n"; 8: exit 1; 9: } 10: 11: my $report="testlog"; 12: my $os="??"; 13: my $version="??"; 14: my $platform0="??"; 15: my $platform="??"; 16: my $options="??"; 17: my $last="??"; 18: my $ok=0; 19: my $cc="cc"; 20: my $cversion="??"; 21: my $sep="-----------------------------------------------------------------------------\n"; 22: 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"; 23: 24: open(OUT,">$report") or die; 25: 26: print OUT "OpenSSL self-test report:\n\n"; 27: 28: $uname=`uname -a`; 29: $uname="??\n" if $uname eq ""; 30: 31: $c=`sh config -t`; 32: foreach $_ (split("\n",$c)) { 33: $os=$1 if (/Operating system: (.*)$/); 34: $platform0=$1 if (/Configuring for (.*)$/); 35: } 36: 37: system "sh config" if (! -f "Makefile"); 38: 39: if (open(IN,"<Makefile")) { 40: while (<IN>) { 41: $version=$1 if (/^VERSION=(.*)$/); 42: $platform=$1 if (/^PLATFORM=(.*)$/); 43: $options=$1 if (/^OPTIONS=(.*)$/); 44: $cc=$1 if (/^CC= *(.*)$/); 45: } 46: close(IN); 47: } else { 48: print OUT "Error running config!\n"; 49: } 50: 51: $cversion=`$cc -v 2>&1`; 52: $cversion=`$cc -V 2>&1` if $cversion =~ "[Uu]sage"; 53: $cversion=`$cc -V |head -1` if $cversion =~ "Error"; 54: $cversion=`$cc --version` if $cversion eq ""; 55: $cversion =~ s/Reading specs.*\n//; 56: $cversion =~ s/usage.*\n//; 57: chomp $cversion; 58: 59: if (open(IN,"<CHANGES")) { 60: while(<IN>) { 61: if (/\*\) (.{0,55})/ && !/applies to/) { 62: $last=$1; 63: last; 64: } 65: } 66: close(IN); 67: } 68: 69: print OUT "OpenSSL version: $version\n"; 70: print OUT "Last change: $last...\n"; 71: print OUT "Options: $options\n" if $options ne ""; 72: print OUT "OS (uname): $uname"; 73: print OUT "OS (config): $os\n"; 74: print OUT "Target (default): $platform0\n"; 75: print OUT "Target: $platform\n"; 76: print OUT "Compiler: $cversion\n"; 77: print OUT "\n"; 78: 79: print "Checking compiler...\n"; 80: if (open(TEST,">cctest.c")) { 81: print TEST "#include <stdio.h>\n#include <errno.h>\nmain(){printf(\"Hello world\\n\");}\n"; 82: close(TEST); 83: system("$cc -o cctest cctest.c"); 84: if (`./cctest` !~ /Hello world/) { 85: print OUT "Compiler doesn't work.\n"; 86: print OUT $not_our_fault; 87: goto err; 88: } 89: system("ar r cctest.a /dev/null"); 90: if (not -f "cctest.a") { 91: print OUT "Check your archive tool (ar).\n"; 92: print OUT $not_our_fault; 93: goto err; 94: } 95: } else { 96: print OUT "Can't create cctest.c\n"; 97: } 98: if (open(TEST,">cctest.c")) { 99: print TEST "#include <openssl/opensslv.h>\nmain(){printf(OPENSSL_VERSION_TEXT);}\n"; 100: close(TEST); 101: system("$cc -o cctest -Iinclude cctest.c"); 102: $cctest = `./cctest`; 103: if ($cctest !~ /OpenSSL $version/) { 104: if ($cctest =~ /OpenSSL/) { 105: print OUT "#include uses headers from different OpenSSL version!\n"; 106: } else { 107: print OUT "Can't compile test program!\n"; 108: } 109: print OUT $not_our_fault; 110: goto err; 111: } 112: } else { 113: print OUT "Can't create cctest.c\n"; 114: } 115: 116: print "Running make...\n"; 117: if (system("make 2>&1 | tee make.log") > 255) { 118: 119: print OUT "make failed!\n"; 120: if (open(IN,"<make.log")) { 121: print OUT $sep; 122: while (<IN>) { 123: print OUT; 124: } 125: close(IN); 126: print OUT $sep; 127: } else { 128: print OUT "make.log not found!\n"; 129: } 130: goto err; 131: } 132: 133: # Not sure why this is here. The tests themselves can detect if their 134: # particular feature isn't included, and should therefore skip themselves. 135: # To skip *all* tests just because one algorithm isn't included is like 136: # shooting mosquito with an elephant gun... 137: # -- Richard Levitte, inspired by problem report 1089 138: # 139: #$_=$options; 140: #s/no-asm//; 141: #s/no-shared//; 142: #s/no-krb5//; 143: #if (/no-/) 144: #{ 145: # print OUT "Test skipped.\n"; 146: # goto err; 147: #} 148: 149: print "Running make test...\n"; 150: if (system("make test 2>&1 | tee maketest.log") > 255) 151: { 152: print OUT "make test failed!\n"; 153: } else { 154: $ok=1; 155: } 156: 157: if ($ok and open(IN,"<maketest.log")) { 158: while (<IN>) { 159: $ok=2 if /^platform: $platform/; 160: } 161: close(IN); 162: } 163: 164: if ($ok != 2) { 165: print OUT "Failure!\n"; 166: if (open(IN,"<make.log")) { 167: print OUT $sep; 168: while (<IN>) { 169: print OUT; 170: } 171: close(IN); 172: print OUT $sep; 173: } else { 174: print OUT "make.log not found!\n"; 175: } 176: if (open(IN,"<maketest.log")) { 177: while (<IN>) { 178: print OUT; 179: } 180: close(IN); 181: print OUT $sep; 182: } else { 183: print OUT "maketest.log not found!\n"; 184: } 185: } else { 186: print OUT "Test passed.\n"; 187: } 188: err: 189: close(OUT); 190: 191: print "\n"; 192: open(IN,"<$report") or die; 193: while (<IN>) { 194: if (/$sep/) { 195: print "[...]\n"; 196: last; 197: } 198: print; 199: } 200: print "\nTest report in file $report\n"; 201: