32499
|
1 |
#
|
|
2 |
# Author: Sascha Boehme
|
|
3 |
#
|
|
4 |
# Reports for Mirabelle
|
|
5 |
#
|
|
6 |
|
|
7 |
my $log_file = $ARGV[0];
|
|
8 |
|
|
9 |
open(FILE, "<$log_file") || die "Cannot open file '$log_file'";
|
|
10 |
my @lines = <FILE>;
|
|
11 |
close(FILE);
|
|
12 |
|
|
13 |
my $unhandled = 0;
|
|
14 |
|
|
15 |
my $sh_calls = 0;
|
|
16 |
my $sh_succeeded = 0;
|
|
17 |
my $sh_time = 0;
|
|
18 |
|
|
19 |
my $metis_calls = 0;
|
|
20 |
my $metis_succeeded = 0;
|
32517
|
21 |
my $metis_timeout = 0;
|
32499
|
22 |
my $metis_time = 0;
|
|
23 |
|
|
24 |
foreach (@lines) {
|
|
25 |
if (m/^unhandled exception/) {
|
|
26 |
$unhandled++;
|
|
27 |
}
|
|
28 |
if (m/^sledgehammer:/) {
|
|
29 |
$sh_calls++;
|
|
30 |
}
|
|
31 |
if (m/^sledgehammer: succeeded \(([0-9]+)\)/) {
|
|
32 |
$sh_succeeded++;
|
|
33 |
$sh_time += $1;
|
|
34 |
}
|
|
35 |
if (m/^metis \(sledgehammer\):/) {
|
|
36 |
$metis_calls++;
|
|
37 |
}
|
|
38 |
if (m/^metis \(sledgehammer\): succeeded \(([0-9]+)\)/) {
|
|
39 |
$metis_succeeded++;
|
|
40 |
$metis_time += $1;
|
|
41 |
}
|
32518
|
42 |
if (m/^metis \(sledgehammer\): timeout/) {
|
32517
|
43 |
$metis_timeout++;
|
32506
|
44 |
}
|
32499
|
45 |
}
|
|
46 |
|
|
47 |
open(FILE, ">>$log_file") || die "Cannot open file '$log_file'";
|
|
48 |
|
|
49 |
print FILE "\n\n\n";
|
|
50 |
|
|
51 |
if ($unhandled > 0) {
|
|
52 |
print FILE "Number of unhandled exceptions: $unhandled\n\n";
|
|
53 |
}
|
|
54 |
|
|
55 |
if ($sh_calls > 0) {
|
|
56 |
my $percent = $sh_succeeded / $sh_calls * 100;
|
|
57 |
my $time = $sh_time / 1000;
|
32508
|
58 |
my $avg_time = $time / $sh_succeeded;
|
32499
|
59 |
print FILE "Total number of sledgehammer calls: $sh_calls\n";
|
32517
|
60 |
print FILE "Number of successful sledgehammer calls: $sh_succeeded\n";
|
|
61 |
printf FILE "Success rate: %.0f%%\n", $percent;
|
32509
|
62 |
printf FILE "Total time for successful sledgehammer calls: %.3f seconds\n", $time;
|
|
63 |
printf FILE "Average time for successful sledgehammer calls: %.3f seconds\n\n", $avg_time;
|
32499
|
64 |
}
|
|
65 |
|
|
66 |
if ($metis_calls > 0) {
|
|
67 |
my $percent = $metis_succeeded / $metis_calls * 100;
|
|
68 |
my $time = $metis_time / 1000;
|
32506
|
69 |
my $avg_time = $time / $metis_succeeded;
|
32517
|
70 |
my $metis_exc = $sh_succeeded - $metis_succeeded - $metis_timeout;
|
32499
|
71 |
print FILE "Total number of metis calls: $metis_calls\n";
|
|
72 |
print FILE "Number of successful metis calls: $metis_succeeded\n";
|
32517
|
73 |
print FILE "Number of metis timeouts: $metis_timeout\n";
|
|
74 |
print FILE "Number of metis exceptions: $metis_exc\n";
|
|
75 |
printf FILE "Success rate: %.0f%%\n", $percent;
|
32509
|
76 |
printf FILE "Total time for successful metis calls: %.3f seconds\n", $time;
|
|
77 |
printf FILE "Average time for successful metis calls: %.3f seconds\n", $avg_time;
|
32499
|
78 |
}
|
|
79 |
|
|
80 |
close(FILE);
|