-
Notifications
You must be signed in to change notification settings - Fork 65
/
SMarkReporter.class.st
106 lines (88 loc) · 2.27 KB
/
SMarkReporter.class.st
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
"
SMarkReporter is a simple formatter of benchmark results.
Subclass such as SMarkSimpleStatisticsReporter might implement more advanced reporting functionality, e.g., including a statistical evaluation of the results.
Example:
| f |
f := TextStream on: String new.
SMarkSimpleStatisticsReporter reportFor: (SMarkTestRunnerSuiteForAutosizing run: 10) on: f.
f contents
"
Class {
#name : #SMarkReporter,
#superclass : #Object,
#instVars : [
'runner',
'stream'
],
#category : #'CogBenchmarks-SMark'
}
{ #category : #defaults }
SMarkReporter class >> defaultOutputDestination [
^ ScriptConsole
]
{ #category : #defaults }
SMarkReporter class >> defaultReporter [
^ SMarkSimpleStatisticsReporter
]
{ #category : #reporting }
SMarkReporter class >> reportFor: aRunner [
self reportFor: aRunner on: self defaultOutputDestination.
]
{ #category : #reporting }
SMarkReporter class >> reportFor: aRunner on: aStream [
| reporter |
reporter := self new.
reporter runner: aRunner.
reporter outputStream: aStream.
reporter report.
^ reporter.
]
{ #category : #reporting }
SMarkReporter >> benchmarkFooter: aName [
stream cr.
]
{ #category : #reporting }
SMarkReporter >> benchmarkHeader: aName [
stream << 'Benchmark ' << (aName asString); cr.
]
{ #category : #reporting }
SMarkReporter >> footer [
"No output at the moment"
^ self
]
{ #category : #reporting }
SMarkReporter >> header [
| suiteName |
suiteName := runner suite class name asString.
stream << 'Report for: ' << suiteName; cr.
]
{ #category : #initialization }
SMarkReporter >> initialize [
super initialize.
stream := self class defaultOutputDestination.
]
{ #category : #accessing }
SMarkReporter >> outputStream: aStream [
stream := aStream
]
{ #category : #accessing }
SMarkReporter >> report [
self header.
runner results keysAndValuesDo: [:key :value |
self benchmarkHeader: key.
self reportAllRuns: value of: key.
self benchmarkFooter: key.
].
self footer.
^ self
]
{ #category : #reporting }
SMarkReporter >> reportAllRuns: aListOfResults of: benchmark [
aListOfResults do: [:result |
result criteria keysAndValuesDo: [:benchName :timer |
stream << benchName << ': ' << (timer totalTime asString, 'ms'); cr.]]
]
{ #category : #accessing }
SMarkReporter >> runner: aRunner [
runner := aRunner.
]