1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
|
#!@PERL@
use strict;
use warnings;
use lib 'infrastructure';
use BoxPlatform;
my ($test_name,$test_mode) = @ARGV;
$test_mode = 'debug' if not defined $test_mode or $test_mode eq '';
if($test_name eq '' || ($test_mode ne 'debug' && $test_mode ne 'release'))
{
print <<__E;
Run Test utility -- bad usage.
runtest.pl (test|ALL) [release|debug]
Mode defaults to debug.
__E
exit(2);
}
my @results;
my $exit_code = 0;
if($test_name ne 'ALL')
{
# run one or more specified test
if ($test_name =~ m/,/)
{
foreach my $test (split m/,/, $test_name)
{
runtest($test);
}
}
else
{
runtest($test_name);
}
}
else
{
# run all tests
my @tests;
open MODULES,'modules.txt' or die "Can't open modules file";
while(<MODULES>)
{
# omit bits on some platforms?
next if m/\AEND-OMIT/;
if(m/\AOMIT:(.+)/)
{
if($1 eq $build_os or $1 eq $target_os)
{
while(<MODULES>)
{
last if m/\AEND-OMIT/;
}
}
next;
}
push @tests,$1 if m~\Atest/(\w+)\s~;
}
close MODULES;
runtest($_) for(@tests)
}
# report results
print "--------\n",join("\n",@results),"\n";
exit $exit_code;
sub runtest
{
my ($t) = @_;
# attempt to make this test
my $flag = ($test_mode eq 'release')?(BoxPlatform::make_flag('RELEASE')):'';
my $make_res = system("cd test/$t ; $make_command $flag");
if($make_res != 0)
{
push @results,"$t: make failed";
$exit_code = 2;
return;
}
my $logfile = "test-$t.log";
# run it
my $test_res = system("cd $test_mode/test/$t ; ./t 2>&1 " .
"| tee ../../../$logfile");
# open test results
if(open RESULTS, $logfile)
{
my $last;
while(<RESULTS>)
{
$last = $_ if m/\w/;
}
close RESULTS;
chomp $last;
push @results, "$t: $last";
if ($last ne "PASSED")
{
$exit_code = 1;
}
}
else
{
push @results,
"$t: failed to open test log file: $logfile: $!";
}
# delete test results
# unlink $logfile;
}
|