reports/Builder__TestReport.st
author Jan Vrany <jan.vrany@fit.cvut.cz>
Fri, 24 Aug 2018 11:23:42 +0100
branchjv
changeset 528 67d1c7df7f90
parent 325 7a039308efa5
child 570 9c47ccc9e9b5
permissions -rw-r--r--
Refactor timeout scaling factor initialization In order to stabilize tests on (heavily loaded) CI infrastructure, reasses scaling factor every three minutes. Also include (simple) I/O benchmark to compensate for (overloaded) I/O subsystem of CI slaves. For details, see `Builder::TestReport::Result >> timeoutScale`
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
74
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
     1
"{ Package: 'stx:goodies/builder/reports' }"
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
     2
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
     3
"{ NameSpace: Builder }"
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
     4
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
     5
Report subclass:#TestReport
303
e217bb7aacf4 Backed out 4c26321be573.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 251
diff changeset
     6
	instanceVariableNames:'suite coverage instrument keepStdout keepBytecode'
241
9879c8960574 Added option --keep-stdout to TestReport to include stdout contents in reports.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 240
diff changeset
     7
	classVariableNames:''
9879c8960574 Added option --keep-stdout to TestReport to include stdout contents in reports.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 240
diff changeset
     8
	poolDictionaries:''
9879c8960574 Added option --keep-stdout to TestReport to include stdout contents in reports.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 240
diff changeset
     9
	category:'Builder-Reports'
74
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    10
!
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    11
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    12
TestResult subclass:#Result
528
67d1c7df7f90 Refactor timeout scaling factor initialization
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 325
diff changeset
    13
	instanceVariableNames:'format time timeoutScale timeoutScaleReassesmentTime npassed
67d1c7df7f90 Refactor timeout scaling factor initialization
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 325
diff changeset
    14
		nfailed nerror nskipped collector'
67d1c7df7f90 Refactor timeout scaling factor initialization
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 325
diff changeset
    15
	classVariableNames:''
241
9879c8960574 Added option --keep-stdout to TestReport to include stdout contents in reports.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 240
diff changeset
    16
	poolDictionaries:''
9879c8960574 Added option --keep-stdout to TestReport to include stdout contents in reports.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 240
diff changeset
    17
	privateIn:TestReport
74
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    18
!
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    19
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    20
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    21
!TestReport methodsFor:'accessing'!
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    22
303
e217bb7aacf4 Backed out 4c26321be573.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 251
diff changeset
    23
keepBytecode
e217bb7aacf4 Backed out 4c26321be573.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 251
diff changeset
    24
    ^ keepBytecode
e217bb7aacf4 Backed out 4c26321be573.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 251
diff changeset
    25
!
e217bb7aacf4 Backed out 4c26321be573.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 251
diff changeset
    26
e217bb7aacf4 Backed out 4c26321be573.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 251
diff changeset
    27
keepBytecode:aBoolean
e217bb7aacf4 Backed out 4c26321be573.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 251
diff changeset
    28
    keepBytecode := aBoolean.
e217bb7aacf4 Backed out 4c26321be573.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 251
diff changeset
    29
!
e217bb7aacf4 Backed out 4c26321be573.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 251
diff changeset
    30
241
9879c8960574 Added option --keep-stdout to TestReport to include stdout contents in reports.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 240
diff changeset
    31
keepStdout
9879c8960574 Added option --keep-stdout to TestReport to include stdout contents in reports.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 240
diff changeset
    32
    ^ keepStdout
9879c8960574 Added option --keep-stdout to TestReport to include stdout contents in reports.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 240
diff changeset
    33
!
9879c8960574 Added option --keep-stdout to TestReport to include stdout contents in reports.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 240
diff changeset
    34
9879c8960574 Added option --keep-stdout to TestReport to include stdout contents in reports.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 240
diff changeset
    35
keepStdout:aBoolean
9879c8960574 Added option --keep-stdout to TestReport to include stdout contents in reports.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 240
diff changeset
    36
    keepStdout := aBoolean.
9879c8960574 Added option --keep-stdout to TestReport to include stdout contents in reports.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 240
diff changeset
    37
!
9879c8960574 Added option --keep-stdout to TestReport to include stdout contents in reports.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 240
diff changeset
    38
74
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    39
suite
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    40
    ^ suite
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    41
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    42
    "Created: / 07-11-2011 / 09:41:21 / Jan Vrany <jan.vrany@fit.cvut.cz>"
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    43
! !
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    44
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    45
!TestReport methodsFor:'accessing - defaults'!
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    46
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    47
defaultFileSuffix
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    48
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    49
    ^'Test'
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    50
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    51
    "Created: / 04-08-2011 / 12:56:37 / Jan Vrany <jan.vrany@fit.cvut.cz>"
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    52
!
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    53
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    54
defaultFormat
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    55
    "superclass HDReport says that I am responsible to implement this method"
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    56
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    57
    ^ Builder::TestReportFormat::JUnit new
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    58
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    59
    "Created: / 04-08-2011 / 11:54:13 / Jan Vrany <jan.vrany@fit.cvut.cz>"
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    60
!
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    61
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    62
defaultName
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    63
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    64
    ^String streamContents:[:s|
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    65
        suite tests do:[:suite|
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    66
            s nextPutAll: suite name
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    67
        ] separatedBy:[
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    68
            s nextPut:$,;space
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    69
        ]
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    70
    ]
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    71
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    72
    "Created: / 07-11-2011 / 09:47:02 / Jan Vrany <jan.vrany@fit.cvut.cz>"
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    73
! !
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    74
164
707c2a3ef492 Initial version of code coverage report.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 111
diff changeset
    75
!TestReport methodsFor:'command line options'!
707c2a3ef492 Initial version of code coverage report.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 111
diff changeset
    76
707c2a3ef492 Initial version of code coverage report.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 111
diff changeset
    77
cmdlineOptionCoverage
707c2a3ef492 Initial version of code coverage report.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 111
diff changeset
    78
707c2a3ef492 Initial version of code coverage report.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 111
diff changeset
    79
    ^CmdLineOption new
707c2a3ef492 Initial version of code coverage report.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 111
diff changeset
    80
        short: $c;
707c2a3ef492 Initial version of code coverage report.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 111
diff changeset
    81
        long: 'coverage';
234
b48196ea5f68 Better command line help for standalone report runner.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 215
diff changeset
    82
        description: 'collect code coverage when running tests';
164
707c2a3ef492 Initial version of code coverage report.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 111
diff changeset
    83
        action:[
707c2a3ef492 Initial version of code coverage report.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 111
diff changeset
    84
            coverage := CoverageReport new.
707c2a3ef492 Initial version of code coverage report.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 111
diff changeset
    85
        ]
707c2a3ef492 Initial version of code coverage report.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 111
diff changeset
    86
707c2a3ef492 Initial version of code coverage report.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 111
diff changeset
    87
    "Created: / 25-06-2013 / 15:36:46 / Jan Vrany <jan.vrany@fit.cvut.cz>"
234
b48196ea5f68 Better command line help for standalone report runner.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 215
diff changeset
    88
    "Modified: / 27-05-2014 / 16:54:32 / Jan Vrany <jan.vrany@fit.cvut.cz>"
b48196ea5f68 Better command line help for standalone report runner.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 215
diff changeset
    89
!
b48196ea5f68 Better command line help for standalone report runner.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 215
diff changeset
    90
246
f0957ea6444a Builder::TestReport changed back to *keep* stdout by default. Pass --drop-stdout
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 241
diff changeset
    91
cmdlineOptionDropStdout
f0957ea6444a Builder::TestReport changed back to *keep* stdout by default. Pass --drop-stdout
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 241
diff changeset
    92
f0957ea6444a Builder::TestReport changed back to *keep* stdout by default. Pass --drop-stdout
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 241
diff changeset
    93
    ^CmdLineOption new
f0957ea6444a Builder::TestReport changed back to *keep* stdout by default. Pass --drop-stdout
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 241
diff changeset
    94
        long: 'drop-stdout';
f0957ea6444a Builder::TestReport changed back to *keep* stdout by default. Pass --drop-stdout
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 241
diff changeset
    95
        description: 'Do not include stdout in report';
f0957ea6444a Builder::TestReport changed back to *keep* stdout by default. Pass --drop-stdout
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 241
diff changeset
    96
        action:[
f0957ea6444a Builder::TestReport changed back to *keep* stdout by default. Pass --drop-stdout
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 241
diff changeset
    97
            keepStdout := false
f0957ea6444a Builder::TestReport changed back to *keep* stdout by default. Pass --drop-stdout
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 241
diff changeset
    98
        ]
f0957ea6444a Builder::TestReport changed back to *keep* stdout by default. Pass --drop-stdout
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 241
diff changeset
    99
f0957ea6444a Builder::TestReport changed back to *keep* stdout by default. Pass --drop-stdout
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 241
diff changeset
   100
    "Created: / 08-08-2014 / 11:48:32 / Jan Vrany <jan.vrany@fit.cvut.cz>"
f0957ea6444a Builder::TestReport changed back to *keep* stdout by default. Pass --drop-stdout
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 241
diff changeset
   101
!
f0957ea6444a Builder::TestReport changed back to *keep* stdout by default. Pass --drop-stdout
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 241
diff changeset
   102
234
b48196ea5f68 Better command line help for standalone report runner.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 215
diff changeset
   103
cmdlineOptionInstrument
b48196ea5f68 Better command line help for standalone report runner.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 215
diff changeset
   104
b48196ea5f68 Better command line help for standalone report runner.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 215
diff changeset
   105
    ^CmdLineOption new
b48196ea5f68 Better command line help for standalone report runner.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 215
diff changeset
   106
        short: $I;
b48196ea5f68 Better command line help for standalone report runner.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 215
diff changeset
   107
        long: 'instrument';
b48196ea5f68 Better command line help for standalone report runner.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 215
diff changeset
   108
        description: 'extra package to instrument for coverage (implies --coverage)';
b48196ea5f68 Better command line help for standalone report runner.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 215
diff changeset
   109
        action:[:package |
b48196ea5f68 Better command line help for standalone report runner.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 215
diff changeset
   110
            instrument isNil ifTrue:[ 
b48196ea5f68 Better command line help for standalone report runner.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 215
diff changeset
   111
                instrument := Set new.
b48196ea5f68 Better command line help for standalone report runner.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 215
diff changeset
   112
            ].
b48196ea5f68 Better command line help for standalone report runner.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 215
diff changeset
   113
            instrument add: package.
b48196ea5f68 Better command line help for standalone report runner.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 215
diff changeset
   114
            coverage isNil ifTrue:[ 
b48196ea5f68 Better command line help for standalone report runner.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 215
diff changeset
   115
                coverage := CoverageReport new.
b48196ea5f68 Better command line help for standalone report runner.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 215
diff changeset
   116
            ].
b48196ea5f68 Better command line help for standalone report runner.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 215
diff changeset
   117
b48196ea5f68 Better command line help for standalone report runner.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 215
diff changeset
   118
        ]
b48196ea5f68 Better command line help for standalone report runner.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 215
diff changeset
   119
b48196ea5f68 Better command line help for standalone report runner.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 215
diff changeset
   120
    "Created: / 27-05-2014 / 16:34:24 / Jan Vrany <jan.vrany@fit.cvut.cz>"
241
9879c8960574 Added option --keep-stdout to TestReport to include stdout contents in reports.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 240
diff changeset
   121
!
9879c8960574 Added option --keep-stdout to TestReport to include stdout contents in reports.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 240
diff changeset
   122
303
e217bb7aacf4 Backed out 4c26321be573.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 251
diff changeset
   123
cmdlineOptionKeepBytecode
e217bb7aacf4 Backed out 4c26321be573.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 251
diff changeset
   124
e217bb7aacf4 Backed out 4c26321be573.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 251
diff changeset
   125
    ^CmdLineOption new
e217bb7aacf4 Backed out 4c26321be573.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 251
diff changeset
   126
        long: 'keep-bytecode';
e217bb7aacf4 Backed out 4c26321be573.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 251
diff changeset
   127
        description: 'Keep and include method''s bytecode in reported stacktraces. May generate huge report!!';
e217bb7aacf4 Backed out 4c26321be573.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 251
diff changeset
   128
        action:[
e217bb7aacf4 Backed out 4c26321be573.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 251
diff changeset
   129
            keepBytecode := true
e217bb7aacf4 Backed out 4c26321be573.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 251
diff changeset
   130
        ]
e217bb7aacf4 Backed out 4c26321be573.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 251
diff changeset
   131
e217bb7aacf4 Backed out 4c26321be573.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 251
diff changeset
   132
    "Created: / 15-03-2016 / 14:32:16 / Jan Vrany <jan.vrany@fit.cvut.cz>"
e217bb7aacf4 Backed out 4c26321be573.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 251
diff changeset
   133
!
e217bb7aacf4 Backed out 4c26321be573.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 251
diff changeset
   134
241
9879c8960574 Added option --keep-stdout to TestReport to include stdout contents in reports.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 240
diff changeset
   135
cmdlineOptionKeepStdout
9879c8960574 Added option --keep-stdout to TestReport to include stdout contents in reports.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 240
diff changeset
   136
9879c8960574 Added option --keep-stdout to TestReport to include stdout contents in reports.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 240
diff changeset
   137
    ^CmdLineOption new
9879c8960574 Added option --keep-stdout to TestReport to include stdout contents in reports.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 240
diff changeset
   138
        long: 'keep-stdout';
9879c8960574 Added option --keep-stdout to TestReport to include stdout contents in reports.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 240
diff changeset
   139
        description: 'Keep stdout and include it in report (may generate huge report!!)';
9879c8960574 Added option --keep-stdout to TestReport to include stdout contents in reports.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 240
diff changeset
   140
        action:[
9879c8960574 Added option --keep-stdout to TestReport to include stdout contents in reports.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 240
diff changeset
   141
            keepStdout := true
9879c8960574 Added option --keep-stdout to TestReport to include stdout contents in reports.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 240
diff changeset
   142
        ]
9879c8960574 Added option --keep-stdout to TestReport to include stdout contents in reports.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 240
diff changeset
   143
9879c8960574 Added option --keep-stdout to TestReport to include stdout contents in reports.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 240
diff changeset
   144
    "Created: / 16-06-2014 / 10:42:00 / Jan Vrany <jan.vrany@fit.cvut.cz>"
164
707c2a3ef492 Initial version of code coverage report.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 111
diff changeset
   145
! !
707c2a3ef492 Initial version of code coverage report.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 111
diff changeset
   146
74
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   147
!TestReport methodsFor:'initialization'!
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   148
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   149
initialize
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   150
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   151
    suite := TestSuite new.
164
707c2a3ef492 Initial version of code coverage report.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 111
diff changeset
   152
    coverage := nil.
246
f0957ea6444a Builder::TestReport changed back to *keep* stdout by default. Pass --drop-stdout
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 241
diff changeset
   153
    keepStdout := true.
74
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   154
246
f0957ea6444a Builder::TestReport changed back to *keep* stdout by default. Pass --drop-stdout
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 241
diff changeset
   155
    "Modified: / 08-08-2014 / 11:45:36 / Jan Vrany <jan.vrany@fit.cvut.cz>"
74
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   156
!
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   157
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   158
setupForClasses:classes
90
995880ed753c comment/format in: #setupForClasses:
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 80
diff changeset
   159
    "Setup the report to run given classes"
74
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   160
90
995880ed753c comment/format in: #setupForClasses:
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 80
diff changeset
   161
    | suiteFromClasses |
74
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   162
90
995880ed753c comment/format in: #setupForClasses:
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 80
diff changeset
   163
    suiteFromClasses := TestSuite named:name.
74
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   164
    classes do:
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   165
            [:cls | 
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   166
            |tc|
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   167
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   168
            cls isTestCaseLike 
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   169
                ifTrue:
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   170
                    [ tc := cls asTestCase.
90
995880ed753c comment/format in: #setupForClasses:
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 80
diff changeset
   171
                    tc isAbstract ifFalse:[ suiteFromClasses addTest:tc suite ] ] ].
74
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   172
90
995880ed753c comment/format in: #setupForClasses:
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 80
diff changeset
   173
    self setupForSuite: suiteFromClasses.
74
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   174
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   175
    "Created: / 04-08-2011 / 14:34:50 / Jan Vrany <jan.vrany@fit.cvut.cz>"
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   176
!
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   177
164
707c2a3ef492 Initial version of code coverage report.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 111
diff changeset
   178
setupForPackages:pkgs 
74
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   179
164
707c2a3ef492 Initial version of code coverage report.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 111
diff changeset
   180
    pkgs do: [:pkg | 
74
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   181
        |def |
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   182
80
eb88d790573d Loads the package if not already loaded.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 74
diff changeset
   183
        self loadPackageIfNotAlready: pkg.
74
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   184
        def := ProjectDefinition definitionClassForPackage:pkg.
80
eb88d790573d Loads the package if not already loaded.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 74
diff changeset
   185
74
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   186
        (def respondsTo:#testSuite) ifTrue:[ 
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   187
            suite addTest:def testSuite 
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   188
        ] ifFalse:[ 
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   189
            | classes psuite |
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   190
            psuite := TestSuite named:pkg.
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   191
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   192
            classes := def notNil 
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   193
                        ifTrue:[ def classes ]
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   194
                        ifFalse:[ ProjectDefinition searchForClassesWithProject:pkg asSymbol ].
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   195
            classes do: [:cls | 
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   196
                |tc|
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   197
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   198
                cls isTestCaseLike ifTrue: [ 
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   199
                    tc := cls asTestCase.
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   200
                    tc isAbstract ifFalse:[ 
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   201
                        psuite addTest:tc suite
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   202
                    ]
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   203
                ]
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   204
            ].
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   205
            suite addTest: psuite.
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   206
        ]
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   207
    ].
164
707c2a3ef492 Initial version of code coverage report.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 111
diff changeset
   208
    coverage notNil ifTrue:[
707c2a3ef492 Initial version of code coverage report.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 111
diff changeset
   209
        coverage setupForPackages: packages.
234
b48196ea5f68 Better command line help for standalone report runner.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 215
diff changeset
   210
        instrument notNil ifTrue:[ 
b48196ea5f68 Better command line help for standalone report runner.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 215
diff changeset
   211
            coverage setupForPackages: instrument.
b48196ea5f68 Better command line help for standalone report runner.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 215
diff changeset
   212
        ].
164
707c2a3ef492 Initial version of code coverage report.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 111
diff changeset
   213
    ]
74
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   214
234
b48196ea5f68 Better command line help for standalone report runner.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 215
diff changeset
   215
    "Modified: / 27-05-2014 / 16:35:52 / Jan Vrany <jan.vrany@fit.cvut.cz>"
74
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   216
!
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   217
90
995880ed753c comment/format in: #setupForClasses:
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 80
diff changeset
   218
setupForSuite: suiteToAdd
74
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   219
90
995880ed753c comment/format in: #setupForClasses:
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 80
diff changeset
   220
    suite addTest: suiteToAdd.
74
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   221
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   222
    "Created: / 06-11-2011 / 18:27:04 / Jan Vrany <jan.vrany@fit.cvut.cz>"
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   223
! !
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   224
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   225
!TestReport methodsFor:'private'!
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   226
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   227
print: anObject on: aStream
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   228
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   229
    [ anObject printOn: aStream ]
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   230
        on: Error do:
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   231
            [aStream 
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   232
                nextPutAll: '** error when prining instance of ';
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   233
                nextPutAll: anObject class name;
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   234
                nextPutAll: '**']
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   235
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   236
    "Created: / 15-03-2011 / 22:09:13 / Jan Vrany <jan.vrany@fit.cvut.cz>"
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   237
! !
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   238
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   239
!TestReport methodsFor:'running'!
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   240
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   241
runReport
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   242
325
7a039308efa5 Test report: print test execution time in result summary
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 324
diff changeset
   243
    | result t0 t1 |
74
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   244
    result := Result new format:format.
325
7a039308efa5 Test report: print test execution time in result summary
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 324
diff changeset
   245
    t0 := Timestamp now.
164
707c2a3ef492 Initial version of code coverage report.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 111
diff changeset
   246
    coverage notNil ifTrue:[
707c2a3ef492 Initial version of code coverage report.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 111
diff changeset
   247
        InstrumentationContext  run:[
707c2a3ef492 Initial version of code coverage report.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 111
diff changeset
   248
            suite run:result.
707c2a3ef492 Initial version of code coverage report.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 111
diff changeset
   249
        ].
707c2a3ef492 Initial version of code coverage report.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 111
diff changeset
   250
        Transcript cr; cr.
707c2a3ef492 Initial version of code coverage report.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 111
diff changeset
   251
        Transcript show: 'COLLECTING COVERAGE...'.
707c2a3ef492 Initial version of code coverage report.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 111
diff changeset
   252
        coverage name: self name.
318
b7f0437a6d18 Pass ident string to coverage report when tests are run with `-c` option
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 303
diff changeset
   253
        coverage ident: self ident.
164
707c2a3ef492 Initial version of code coverage report.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 111
diff changeset
   254
        coverage run.
707c2a3ef492 Initial version of code coverage report.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 111
diff changeset
   255
    ] ifFalse:[
707c2a3ef492 Initial version of code coverage report.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 111
diff changeset
   256
        suite run:result.
707c2a3ef492 Initial version of code coverage report.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 111
diff changeset
   257
    ].
325
7a039308efa5 Test report: print test execution time in result summary
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 324
diff changeset
   258
    t1 := Timestamp now.
7a039308efa5 Test report: print test execution time in result summary
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 324
diff changeset
   259
111
d0fa0756222b class: Builder::TestReport
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 109
diff changeset
   260
    Transcript cr; cr.
215
b6e13772ac08 class: Builder::TestReport
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 189
diff changeset
   261
b6e13772ac08 class: Builder::TestReport
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 189
diff changeset
   262
    result failureOutcomes do:[:failureOutcome |
b6e13772ac08 class: Builder::TestReport
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 189
diff changeset
   263
        Transcript show: 'FAILED '.
b6e13772ac08 class: Builder::TestReport
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 189
diff changeset
   264
        failureOutcome testCase printOn: Transcript.
b6e13772ac08 class: Builder::TestReport
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 189
diff changeset
   265
        Transcript cr.
b6e13772ac08 class: Builder::TestReport
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 189
diff changeset
   266
    ].
b6e13772ac08 class: Builder::TestReport
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 189
diff changeset
   267
    result errorOutcomes do:[:errorOutcome |
b6e13772ac08 class: Builder::TestReport
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 189
diff changeset
   268
        Transcript show: 'ERROR  '.
b6e13772ac08 class: Builder::TestReport
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 189
diff changeset
   269
        errorOutcome testCase printOn: Transcript.
b6e13772ac08 class: Builder::TestReport
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 189
diff changeset
   270
        Transcript cr.
b6e13772ac08 class: Builder::TestReport
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 189
diff changeset
   271
    ].
b6e13772ac08 class: Builder::TestReport
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 189
diff changeset
   272
    Transcript cr; cr.
111
d0fa0756222b class: Builder::TestReport
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 109
diff changeset
   273
    Transcript show: 'SUMMARY: '.
d0fa0756222b class: Builder::TestReport
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 109
diff changeset
   274
    result printOn: Transcript.
325
7a039308efa5 Test report: print test execution time in result summary
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 324
diff changeset
   275
    Transcript show: ', test execution time '.
7a039308efa5 Test report: print test execution time in result summary
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 324
diff changeset
   276
    (t1 - t0) printOn: Transcript.
111
d0fa0756222b class: Builder::TestReport
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 109
diff changeset
   277
    Transcript cr.
74
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   278
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   279
    "Created: / 04-08-2011 / 12:39:56 / Jan Vrany <jan.vrany@fit.cvut.cz>"
325
7a039308efa5 Test report: print test execution time in result summary
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 324
diff changeset
   280
    "Modified: / 23-02-2017 / 12:47:26 / Jan Vrany <jan.vrany@fit.cvut.cz>"
74
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   281
! !
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   282
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   283
!TestReport::Result methodsFor:'accessing'!
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   284
111
d0fa0756222b class: Builder::TestReport
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 109
diff changeset
   285
errorCount
d0fa0756222b class: Builder::TestReport
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 109
diff changeset
   286
d0fa0756222b class: Builder::TestReport
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 109
diff changeset
   287
    ^nerror
d0fa0756222b class: Builder::TestReport
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 109
diff changeset
   288
d0fa0756222b class: Builder::TestReport
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 109
diff changeset
   289
    "Created: / 31-01-2013 / 13:54:19 / Jan Vrany <jan.vrany@fit.cvut.cz>"
d0fa0756222b class: Builder::TestReport
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 109
diff changeset
   290
!
d0fa0756222b class: Builder::TestReport
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 109
diff changeset
   291
74
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   292
exceptions
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   293
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   294
    ^super exceptions , HaltInterrupt
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   295
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   296
    "Created: / 03-08-2011 / 14:59:31 / Jan Vrany <jan.vrany@fit.cvut.cz>"
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   297
!
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   298
111
d0fa0756222b class: Builder::TestReport
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 109
diff changeset
   299
failureCount
d0fa0756222b class: Builder::TestReport
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 109
diff changeset
   300
d0fa0756222b class: Builder::TestReport
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 109
diff changeset
   301
    ^nfailed
d0fa0756222b class: Builder::TestReport
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 109
diff changeset
   302
d0fa0756222b class: Builder::TestReport
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 109
diff changeset
   303
    "Created: / 31-01-2013 / 13:53:52 / Jan Vrany <jan.vrany@fit.cvut.cz>"
d0fa0756222b class: Builder::TestReport
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 109
diff changeset
   304
!
d0fa0756222b class: Builder::TestReport
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 109
diff changeset
   305
74
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   306
format
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   307
    ^ format
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   308
!
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   309
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   310
format:aFormat
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   311
    format := aFormat.
111
d0fa0756222b class: Builder::TestReport
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 109
diff changeset
   312
!
d0fa0756222b class: Builder::TestReport
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 109
diff changeset
   313
d0fa0756222b class: Builder::TestReport
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 109
diff changeset
   314
passedCount
d0fa0756222b class: Builder::TestReport
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 109
diff changeset
   315
d0fa0756222b class: Builder::TestReport
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 109
diff changeset
   316
    ^npassed
d0fa0756222b class: Builder::TestReport
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 109
diff changeset
   317
d0fa0756222b class: Builder::TestReport
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 109
diff changeset
   318
    "Created: / 31-01-2013 / 13:54:34 / Jan Vrany <jan.vrany@fit.cvut.cz>"
d0fa0756222b class: Builder::TestReport
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 109
diff changeset
   319
!
d0fa0756222b class: Builder::TestReport
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 109
diff changeset
   320
d0fa0756222b class: Builder::TestReport
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 109
diff changeset
   321
skippedCount
d0fa0756222b class: Builder::TestReport
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 109
diff changeset
   322
d0fa0756222b class: Builder::TestReport
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 109
diff changeset
   323
    ^nskipped
d0fa0756222b class: Builder::TestReport
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 109
diff changeset
   324
d0fa0756222b class: Builder::TestReport
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 109
diff changeset
   325
    "Created: / 31-01-2013 / 13:54:42 / Jan Vrany <jan.vrany@fit.cvut.cz>"
528
67d1c7df7f90 Refactor timeout scaling factor initialization
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 325
diff changeset
   326
!
67d1c7df7f90 Refactor timeout scaling factor initialization
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 325
diff changeset
   327
67d1c7df7f90 Refactor timeout scaling factor initialization
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 325
diff changeset
   328
timeoutScale
67d1c7df7f90 Refactor timeout scaling factor initialization
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 325
diff changeset
   329
    "Return a timeout scaling factor used to adjust test-case defined timeout.
67d1c7df7f90 Refactor timeout scaling factor initialization
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 325
diff changeset
   330
     This is required in order to stabilize tests on different computers and setups.
67d1c7df7f90 Refactor timeout scaling factor initialization
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 325
diff changeset
   331
     Slower machines may need higher timeout otherwise tests may fail."
67d1c7df7f90 Refactor timeout scaling factor initialization
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 325
diff changeset
   332
67d1c7df7f90 Refactor timeout scaling factor initialization
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 325
diff changeset
   333
    "/ This scaling factor is computed automatically by running a (not so) simple 
67d1c7df7f90 Refactor timeout scaling factor initialization
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 325
diff changeset
   334
    "/ benchmark. To make things more complicated, we have to re-asses the scaling
67d1c7df7f90 Refactor timeout scaling factor initialization
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 325
diff changeset
   335
    "/ factor time to time as machine performance may vary depending on a load - this
67d1c7df7f90 Refactor timeout scaling factor initialization
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 325
diff changeset
   336
    "/ happens specially on CI setups where CI slaves are virtualized and running on
67d1c7df7f90 Refactor timeout scaling factor initialization
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 325
diff changeset
   337
    "/ heavily-loaded systems.
67d1c7df7f90 Refactor timeout scaling factor initialization
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 325
diff changeset
   338
    "/ 
67d1c7df7f90 Refactor timeout scaling factor initialization
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 325
diff changeset
   339
    "/ The benchmark itself consists of:
67d1c7df7f90 Refactor timeout scaling factor initialization
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 325
diff changeset
   340
    "/ 
67d1c7df7f90 Refactor timeout scaling factor initialization
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 325
diff changeset
   341
    "/    * CPU benchmark - to handle systems with slow CPUs such as some
67d1c7df7f90 Refactor timeout scaling factor initialization
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 325
diff changeset
   342
    "/      low-end Celerons on RPi-kind of thing)
67d1c7df7f90 Refactor timeout scaling factor initialization
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 325
diff changeset
   343
    "/    * IO benchmark - to handle the case of slow IO on overloaded host
67d1c7df7f90 Refactor timeout scaling factor initialization
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 325
diff changeset
   344
    "/      running many tests in parallel.
67d1c7df7f90 Refactor timeout scaling factor initialization
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 325
diff changeset
   345
    "/ 
67d1c7df7f90 Refactor timeout scaling factor initialization
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 325
diff changeset
   346
67d1c7df7f90 Refactor timeout scaling factor initialization
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 325
diff changeset
   347
67d1c7df7f90 Refactor timeout scaling factor initialization
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 325
diff changeset
   348
    (timeoutScale isNil or: [timeoutScaleReassesmentTime < OperatingSystem getMillisecondTime ]) ifTrue:[ 
67d1c7df7f90 Refactor timeout scaling factor initialization
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 325
diff changeset
   349
        | time1 files time2 scale1 scale2 |
67d1c7df7f90 Refactor timeout scaling factor initialization
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 325
diff changeset
   350
67d1c7df7f90 Refactor timeout scaling factor initialization
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 325
diff changeset
   351
        "/ simple CPU benchmark
67d1c7df7f90 Refactor timeout scaling factor initialization
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 325
diff changeset
   352
        time1 := Time millisecondsToRun:[3000 timesRepeat: [ 2000 factorial ]].
67d1c7df7f90 Refactor timeout scaling factor initialization
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 325
diff changeset
   353
        scale1 := time1 / 2500"mean value of an i5 64bit".
67d1c7df7f90 Refactor timeout scaling factor initialization
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 325
diff changeset
   354
67d1c7df7f90 Refactor timeout scaling factor initialization
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 325
diff changeset
   355
        files := (Smalltalk getPackageDirectoryForPackage: self class package) recursiveDirectoryContentsAsFilenames 
67d1c7df7f90 Refactor timeout scaling factor initialization
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 325
diff changeset
   356
                    select: [:e | e isRegularFile and:[e suffix = 'st']].
67d1c7df7f90 Refactor timeout scaling factor initialization
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 325
diff changeset
   357
        time2 := Time millisecondsToRun:[ 10 timesRepeat: [ files shuffled do:[:e|e contents ] ] ].
67d1c7df7f90 Refactor timeout scaling factor initialization
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 325
diff changeset
   358
        scale2 := time2 / 2500"mean value of an 64bit linux ext4 on SATA SSD".
67d1c7df7f90 Refactor timeout scaling factor initialization
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 325
diff changeset
   359
67d1c7df7f90 Refactor timeout scaling factor initialization
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 325
diff changeset
   360
        timeoutScale := (scale1 max: scale2) max: 1.
67d1c7df7f90 Refactor timeout scaling factor initialization
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 325
diff changeset
   361
        timeoutScaleReassesmentTime := OperatingSystem getMillisecondTime + (1000*60*3) "/ reasses every three minutes
67d1c7df7f90 Refactor timeout scaling factor initialization
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 325
diff changeset
   362
    ].
67d1c7df7f90 Refactor timeout scaling factor initialization
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 325
diff changeset
   363
    ^ timeoutScale
67d1c7df7f90 Refactor timeout scaling factor initialization
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 325
diff changeset
   364
67d1c7df7f90 Refactor timeout scaling factor initialization
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 325
diff changeset
   365
    "
67d1c7df7f90 Refactor timeout scaling factor initialization
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 325
diff changeset
   366
    Builder::TestReport::Result new timeoutScale; timeoutScale
67d1c7df7f90 Refactor timeout scaling factor initialization
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 325
diff changeset
   367
    "
67d1c7df7f90 Refactor timeout scaling factor initialization
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 325
diff changeset
   368
67d1c7df7f90 Refactor timeout scaling factor initialization
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 325
diff changeset
   369
    "Created: / 24-08-2018 / 09:54:57 / Jan Vrany <jan.vrany@fit.cvut.cz>"
67d1c7df7f90 Refactor timeout scaling factor initialization
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 325
diff changeset
   370
    "Modified (comment): / 24-08-2018 / 11:20:15 / Jan Vrany <jan.vrany@fit.cvut.cz>"
74
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   371
! !
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   372
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   373
!TestReport::Result methodsFor:'adding'!
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   374
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   375
addError: testcase detail: exception
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   376
236
475480551293 When running SUnit tests, capture and log stdout, stderr and Transcript and include it in XML report.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 234
diff changeset
   377
    outcome result: (TestResult stateError).
247
7387f32855da Correctly capture and report stdout.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 246
diff changeset
   378
    outcome collectedOutput: collector contents. 
236
475480551293 When running SUnit tests, capture and log stdout, stderr and Transcript and include it in XML report.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 234
diff changeset
   379
    format writeTestCase: testcase outcome: outcome time: time exception: exception.
239
517a62e9f9ab Display one-char messages to make output shorter.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 237
diff changeset
   380
    Transcript show:'...ERROR'.
250
4392c84aaf1c Log start and end of individual tests.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 249
diff changeset
   381
    Logger trace: 'Finised %1>>%2, result ERROR' with: testcase nameForHDTestReport with: testcase selectorForHDTestReport.
215
b6e13772ac08 class: Builder::TestReport
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 189
diff changeset
   382
    self errorOutcomes add:outcome.      
111
d0fa0756222b class: Builder::TestReport
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 109
diff changeset
   383
    nerror := nerror + 1.
74
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   384
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   385
    "Created: / 03-08-2011 / 15:00:31 / Jan Vrany <jan.vrany@fit.cvut.cz>"
250
4392c84aaf1c Log start and end of individual tests.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 249
diff changeset
   386
    "Modified: / 29-10-2014 / 14:02:04 / Jan Vrany <jan.vrany@fit.cvut.cz>"
74
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   387
!
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   388
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   389
addFailure: testcase detail: exception
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   390
236
475480551293 When running SUnit tests, capture and log stdout, stderr and Transcript and include it in XML report.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 234
diff changeset
   391
    outcome result: (TestResult stateFail).
247
7387f32855da Correctly capture and report stdout.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 246
diff changeset
   392
    outcome collectedOutput: collector contents. 
236
475480551293 When running SUnit tests, capture and log stdout, stderr and Transcript and include it in XML report.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 234
diff changeset
   393
    format writeTestCase: testcase outcome: outcome time: time exception: exception.
239
517a62e9f9ab Display one-char messages to make output shorter.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 237
diff changeset
   394
    Transcript show:'...FAILED'.
250
4392c84aaf1c Log start and end of individual tests.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 249
diff changeset
   395
    Logger trace: 'Finised %1>>%2, result FAILED' with: testcase nameForHDTestReport with: testcase selectorForHDTestReport.
215
b6e13772ac08 class: Builder::TestReport
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 189
diff changeset
   396
    self failureOutcomes add: outcome.
111
d0fa0756222b class: Builder::TestReport
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 109
diff changeset
   397
    nfailed := nfailed + 1.
74
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   398
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   399
    "Created: / 03-08-2011 / 15:00:41 / Jan Vrany <jan.vrany@fit.cvut.cz>"
250
4392c84aaf1c Log start and end of individual tests.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 249
diff changeset
   400
    "Modified: / 29-10-2014 / 14:01:50 / Jan Vrany <jan.vrany@fit.cvut.cz>"
74
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   401
!
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   402
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   403
addPass: testcase
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   404
236
475480551293 When running SUnit tests, capture and log stdout, stderr and Transcript and include it in XML report.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 234
diff changeset
   405
    outcome result: TestResult statePass.
475480551293 When running SUnit tests, capture and log stdout, stderr and Transcript and include it in XML report.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 234
diff changeset
   406
    format writeTestCase: testcase outcome: outcome time: time exception: nil.
239
517a62e9f9ab Display one-char messages to make output shorter.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 237
diff changeset
   407
    Transcript show:'...OK'.
250
4392c84aaf1c Log start and end of individual tests.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 249
diff changeset
   408
    Logger trace: 'Finised %1>>%2, result PASSED' with: testcase nameForHDTestReport with: testcase selectorForHDTestReport.
111
d0fa0756222b class: Builder::TestReport
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 109
diff changeset
   409
    npassed := npassed + 1.
74
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   410
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   411
    "Created: / 03-08-2011 / 15:19:54 / Jan Vrany <jan.vrany@fit.cvut.cz>"
250
4392c84aaf1c Log start and end of individual tests.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 249
diff changeset
   412
    "Modified: / 29-10-2014 / 14:01:06 / Jan Vrany <jan.vrany@fit.cvut.cz>"
105
15beda6b5f6e Added support for skipped/ignored tests
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 90
diff changeset
   413
!
15beda6b5f6e Added support for skipped/ignored tests
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 90
diff changeset
   414
15beda6b5f6e Added support for skipped/ignored tests
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 90
diff changeset
   415
addSkipped: testcase
15beda6b5f6e Added support for skipped/ignored tests
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 90
diff changeset
   416
240
d10369beab55 Oops, fix for skipped tests.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 239
diff changeset
   417
    outcome := self createOutcome.
d10369beab55 Oops, fix for skipped tests.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 239
diff changeset
   418
    outcome testCase: testcase.        
236
475480551293 When running SUnit tests, capture and log stdout, stderr and Transcript and include it in XML report.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 234
diff changeset
   419
    outcome result: TestResult stateSkip.
475480551293 When running SUnit tests, capture and log stdout, stderr and Transcript and include it in XML report.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 234
diff changeset
   420
    format writeTestCase: testcase outcome: outcome time: time exception: nil.
239
517a62e9f9ab Display one-char messages to make output shorter.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 237
diff changeset
   421
    Transcript show:'...SKIPPED'.
250
4392c84aaf1c Log start and end of individual tests.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 249
diff changeset
   422
    Logger trace: 'Finised %1>>%2, result SKIPPED' with: testcase nameForHDTestReport with: testcase selectorForHDTestReport.
111
d0fa0756222b class: Builder::TestReport
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 109
diff changeset
   423
    nskipped := nskipped + 1.
105
15beda6b5f6e Added support for skipped/ignored tests
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 90
diff changeset
   424
15beda6b5f6e Added support for skipped/ignored tests
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 90
diff changeset
   425
    "Created: / 21-11-2012 / 15:35:58 / Jan Vrany <jan.vrany@fit.cvut.cz>"
250
4392c84aaf1c Log start and end of individual tests.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 249
diff changeset
   426
    "Modified: / 29-10-2014 / 14:01:36 / Jan Vrany <jan.vrany@fit.cvut.cz>"
111
d0fa0756222b class: Builder::TestReport
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 109
diff changeset
   427
! !
d0fa0756222b class: Builder::TestReport
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 109
diff changeset
   428
d0fa0756222b class: Builder::TestReport
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 109
diff changeset
   429
!TestReport::Result methodsFor:'initialization'!
d0fa0756222b class: Builder::TestReport
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 109
diff changeset
   430
d0fa0756222b class: Builder::TestReport
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 109
diff changeset
   431
initialize
d0fa0756222b class: Builder::TestReport
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 109
diff changeset
   432
    super initialize.
d0fa0756222b class: Builder::TestReport
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 109
diff changeset
   433
322
9ec2abb1218e Autoscale testcase-provided timeout to compensate for slooow machines
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 318
diff changeset
   434
    npassed := nfailed := nerror := nskipped := 0.
528
67d1c7df7f90 Refactor timeout scaling factor initialization
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 325
diff changeset
   435
    timeoutScaleReassesmentTime := 0
111
d0fa0756222b class: Builder::TestReport
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 109
diff changeset
   436
d0fa0756222b class: Builder::TestReport
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 109
diff changeset
   437
    "Created: / 31-01-2013 / 13:52:33 / Jan Vrany <jan.vrany@fit.cvut.cz>"
528
67d1c7df7f90 Refactor timeout scaling factor initialization
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 325
diff changeset
   438
    "Modified: / 24-08-2018 / 10:58:55 / Jan Vrany <jan.vrany@fit.cvut.cz>"
74
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   439
! !
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   440
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   441
!TestReport::Result methodsFor:'running'!
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   442
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   443
performCase:aTestCase 
251
cb6ebbd8d1c0 Fixed setup of a SplittingStream when running tests - wrap Stdout / Stderr to an EncodedStream
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 250
diff changeset
   444
    | savedStdout savedStderr savedTranscript encoder |
74
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   445
236
475480551293 When running SUnit tests, capture and log stdout, stderr and Transcript and include it in XML report.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 234
diff changeset
   446
    savedStdout := Stdout.
475480551293 When running SUnit tests, capture and log stdout, stderr and Transcript and include it in XML report.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 234
diff changeset
   447
    savedStderr := Stdout.
475480551293 When running SUnit tests, capture and log stdout, stderr and Transcript and include it in XML report.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 234
diff changeset
   448
    savedTranscript := Transcript.
251
cb6ebbd8d1c0 Fixed setup of a SplittingStream when running tests - wrap Stdout / Stderr to an EncodedStream
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 250
diff changeset
   449
    encoder := OperatingSystem isMSWINDOWSlike 
cb6ebbd8d1c0 Fixed setup of a SplittingStream when running tests - wrap Stdout / Stderr to an EncodedStream
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 250
diff changeset
   450
                ifTrue:[ CharacterEncoder encoderForUTF8 ]
cb6ebbd8d1c0 Fixed setup of a SplittingStream when running tests - wrap Stdout / Stderr to an EncodedStream
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 250
diff changeset
   451
                ifFalse:[ CharacterEncoder encoderFor: OperatingSystem getCodeset ].
236
475480551293 When running SUnit tests, capture and log stdout, stderr and Transcript and include it in XML report.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 234
diff changeset
   452
    collector := WriteStream on:(String new:100).
475480551293 When running SUnit tests, capture and log stdout, stderr and Transcript and include it in XML report.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 234
diff changeset
   453
    [
251
cb6ebbd8d1c0 Fixed setup of a SplittingStream when running tests - wrap Stdout / Stderr to an EncodedStream
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 250
diff changeset
   454
        Stdout := SplittingWriteStream on:collector and: (EncodedStream stream: Stdout encoder: encoder).
cb6ebbd8d1c0 Fixed setup of a SplittingStream when running tests - wrap Stdout / Stderr to an EncodedStream
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 250
diff changeset
   455
        Stderr := SplittingWriteStream on:collector and: (EncodedStream stream: Stderr encoder: encoder).
236
475480551293 When running SUnit tests, capture and log stdout, stderr and Transcript and include it in XML report.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 234
diff changeset
   456
        Transcript := SplittingWriteStream on:collector and: Transcript.
475480551293 When running SUnit tests, capture and log stdout, stderr and Transcript and include it in XML report.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 234
diff changeset
   457
        time := Time millisecondsToRun: [ super performCase: aTestCase ]
475480551293 When running SUnit tests, capture and log stdout, stderr and Transcript and include it in XML report.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 234
diff changeset
   458
    ] ensure:[
475480551293 When running SUnit tests, capture and log stdout, stderr and Transcript and include it in XML report.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 234
diff changeset
   459
        Stdout := savedStdout.
475480551293 When running SUnit tests, capture and log stdout, stderr and Transcript and include it in XML report.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 234
diff changeset
   460
        Stderr := savedStderr.
475480551293 When running SUnit tests, capture and log stdout, stderr and Transcript and include it in XML report.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 234
diff changeset
   461
        Transcript := savedTranscript.
247
7387f32855da Correctly capture and report stdout.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 246
diff changeset
   462
        outcome collectedOutput: nil. "/ flush it, it has been written to output already
7387f32855da Correctly capture and report stdout.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 246
diff changeset
   463
        collector := nil.
236
475480551293 When running SUnit tests, capture and log stdout, stderr and Transcript and include it in XML report.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 234
diff changeset
   464
    ].
74
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   465
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   466
    "Created: / 03-08-2011 / 18:40:18 / Jan Vrany <jan.vrany@fit.cvut.cz>"
251
cb6ebbd8d1c0 Fixed setup of a SplittingStream when running tests - wrap Stdout / Stderr to an EncodedStream
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 250
diff changeset
   467
    "Modified: / 07-12-2014 / 01:12:08 / Jan Vrany <jan.vrany@fit.cvut.cz>"
74
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   468
!
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   469
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   470
runCase:aTestCase debugged: debugged 
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   471
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   472
    | timeout |
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   473
    timeout := aTestCase timeout.
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   474
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   475
    self runCase: aTestCase debugged: debugged 
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   476
         fork:  (aTestCase shouldFork or:[timeout notNil])
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   477
         timeout: timeout ? 60"sec"
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   478
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   479
    "Created: / 22-08-2011 / 14:37:14 / Jan Vrany <jan.vrany@fit.cvut.cz>"
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   480
!
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   481
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   482
runCase:aTestCase debugged: debugged fork:doFork
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   483
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   484
    ^self runCase:aTestCase debugged: debugged 
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   485
          fork:doFork timeout: aTestCase timeout ? 60"sec"
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   486
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   487
    "Created: / 22-08-2011 / 14:38:11 / Jan Vrany <jan.vrany@fit.cvut.cz>"
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   488
!
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   489
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   490
runCase:aTestCase debugged: debugged fork:doFork timeout: tout
109
7a93688e5642 Make use of TestCase>>shouldSkip
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 105
diff changeset
   491
    | nm sel |
105
15beda6b5f6e Added support for skipped/ignored tests
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 90
diff changeset
   492
189
bd2bed33aba7 Fixes to make it running on Smalltalk/X 6.2.2 released in July 2012
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 164
diff changeset
   493
    (aTestCase perform: #shouldSkip ifNotUnderstood:[false]) ifTrue:[
105
15beda6b5f6e Added support for skipped/ignored tests
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 90
diff changeset
   494
        self addSkipped: aTestCase.
15beda6b5f6e Added support for skipped/ignored tests
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 90
diff changeset
   495
        ^self.
15beda6b5f6e Added support for skipped/ignored tests
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 90
diff changeset
   496
    ].
74
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   497
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   498
    nm := aTestCase nameForHDTestReport.
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   499
    nm size > 20 ifTrue:[
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   500
        nm := (nm copyTo: 17) , '...'
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   501
    ].
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   502
    sel := aTestCase selectorForHDTestReport.
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   503
    sel size > 20 ifTrue:[
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   504
        sel := '...' , (sel copyFrom: sel size - 16 to: sel size)
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   505
    ].
234
b48196ea5f68 Better command line help for standalone report runner.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 215
diff changeset
   506
    Transcript showCR:('%1 >> #%2' bindWith: aTestCase nameForHDTestReport with: aTestCase selectorForHDTestReport).
250
4392c84aaf1c Log start and end of individual tests.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 249
diff changeset
   507
    Transcript show:('%-20s >> %-20s : ' printfWith: nm with: sel).
234
b48196ea5f68 Better command line help for standalone report runner.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 215
diff changeset
   508
74
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   509
    outcome := self createOutcome.
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   510
    outcome testCase: aTestCase.
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   511
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   512
    doFork ifFalse:[ 
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   513
        super runCase:aTestCase debugged: debugged.
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   514
        Transcript cr.
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   515
        ^self.
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   516
    ].
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   517
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   518
    OperatingSystem isUNIXlike ifTrue:[
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   519
"/        self unixForkCase: aTestCase debugged: debugged.
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   520
"/      Use lightweight forking
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   521
        self lightForkCase: aTestCase debugged: debugged timeout: tout.
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   522
        ^ self.
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   523
    ].
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   524
    OperatingSystem isMSWINDOWSlike ifTrue:[
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   525
        self lightForkCase: aTestCase debugged: debugged timeout: tout.
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   526
        ^ self.
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   527
    ].
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   528
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   529
    self error:'Unssuported platform'
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   530
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   531
    "Created: / 12-01-2012 / 17:52:22 / Jan Vrany <jan.vrany@fit.cvut.cz>"
250
4392c84aaf1c Log start and end of individual tests.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 249
diff changeset
   532
    "Modified: / 29-10-2014 / 13:57:47 / Jan Vrany <jan.vrany@fit.cvut.cz>"
74
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   533
! !
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   534
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   535
!TestReport::Result methodsFor:'running-private'!
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   536
322
9ec2abb1218e Autoscale testcase-provided timeout to compensate for slooow machines
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 318
diff changeset
   537
lightForkCase:aTestCase debugged: debugged timeout: timeoutBase
9ec2abb1218e Autoscale testcase-provided timeout to compensate for slooow machines
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 318
diff changeset
   538
    | timeout thread sema stime etime timeouted error stack log logPos |
74
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   539
250
4392c84aaf1c Log start and end of individual tests.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 249
diff changeset
   540
    Logger trace: 'Running %1>>%2' with: aTestCase nameForHDTestReport with: aTestCase selectorForHDTestReport.
239
517a62e9f9ab Display one-char messages to make output shorter.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 237
diff changeset
   541
    Transcript show:'F'.
528
67d1c7df7f90 Refactor timeout scaling factor initialization
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 325
diff changeset
   542
    timeout := (timeoutBase * self timeoutScale) rounded. 
74
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   543
    sema := Semaphore new.
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   544
    stime := OperatingSystem getMillisecondTime.
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   545
    log := false.
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   546
    logPos := format stream stream position.
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   547
    timeouted := false.
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   548
    thread := [ super runCase:aTestCase debugged: debugged ] newProcess.
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   549
    thread addExitAction:[sema signal].
237
8229efa1f621 Dump all threads when testcase times out.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 236
diff changeset
   550
    thread name: ('Testcase execution thread (%1)' bindWith: aTestCase).
74
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   551
    thread resume.
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   552
239
517a62e9f9ab Display one-char messages to make output shorter.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 237
diff changeset
   553
    Transcript show: 'W'.
74
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   554
    (sema waitWithTimeout:timeout) isNil ifTrue: [
239
517a62e9f9ab Display one-char messages to make output shorter.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 237
diff changeset
   555
        Transcript show: 'T'.
237
8229efa1f621 Dump all threads when testcase times out.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 236
diff changeset
   556
        stack := String streamContents:[:s |  ReportRunner dumpProcessesOn:s ].
74
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   557
        thread terminate.
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   558
        timeouted := true.
239
517a62e9f9ab Display one-char messages to make output shorter.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 237
diff changeset
   559
        Transcript show: 'K'.
74
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   560
    ].
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   561
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   562
    etime := OperatingSystem getMillisecondTime.
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   563
    timeouted ifTrue:[
528
67d1c7df7f90 Refactor timeout scaling factor initialization
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 325
diff changeset
   564
        error := TimeoutError new messageText: ('Timed out (effective %1ms, base %2ms, scale %3)' bindWith: timeout with: timeoutBase with: timeoutScale asFloat) .
67d1c7df7f90 Refactor timeout scaling factor initialization
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 325
diff changeset
   565
        outcome isNil ifTrue:[ outcome := self createOutcome ].
236
475480551293 When running SUnit tests, capture and log stdout, stderr and Transcript and include it in XML report.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 234
diff changeset
   566
        outcome result: TestResult stateError.
74
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   567
        format 
236
475480551293 When running SUnit tests, capture and log stdout, stderr and Transcript and include it in XML report.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 234
diff changeset
   568
            writeTestCase: aTestCase outcome: outcome 
74
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   569
                     time: etime - stime
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   570
                exception: error
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   571
               stacktrace: stack.
250
4392c84aaf1c Log start and end of individual tests.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 249
diff changeset
   572
         Transcript show:'...ERROR'.
4392c84aaf1c Log start and end of individual tests.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 249
diff changeset
   573
         Logger trace: 'Finised %1>>%2, result ERROR (timeout)' with: aTestCase nameForHDTestReport with: aTestCase selectorForHDTestReport.
74
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   574
    ].
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   575
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   576
    outcome := nil.
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   577
    Transcript cr.
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   578
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   579
    "Created: / 12-01-2012 / 17:42:12 / Jan Vrany <jan.vrany@fit.cvut.cz>"
528
67d1c7df7f90 Refactor timeout scaling factor initialization
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 325
diff changeset
   580
    "Modified: / 24-08-2018 / 11:19:24 / Jan Vrany <jan.vrany@fit.cvut.cz>"
74
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   581
!
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   582
322
9ec2abb1218e Autoscale testcase-provided timeout to compensate for slooow machines
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 318
diff changeset
   583
unixForkCase:aTestCase debugged: debugged timeout: timeoutBase
9ec2abb1218e Autoscale testcase-provided timeout to compensate for slooow machines
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 318
diff changeset
   584
    | timeout pid status sema stime etime error stack suiteFailuresBefore suiteErrorsBefore log logPos |
74
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   585
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   586
    Transcript show:'forking...'.
528
67d1c7df7f90 Refactor timeout scaling factor initialization
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 325
diff changeset
   587
    timeout := (timeoutBase * self timeoutScale) rounded.   
74
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   588
    sema := Semaphore new.
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   589
    stime := OperatingSystem getMillisecondTime.
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   590
    log := false.
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   591
    logPos := format stream stream position.
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   592
    Processor monitor:
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   593
            [ pid := OperatingSystem fork.
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   594
            pid == 0 ifTrue:[ nil ] ifFalse:[ pid ] ]
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   595
        action:
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   596
            [:s | 
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   597
            Transcript show:'child finished...'.
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   598
            status := s.
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   599
            sema signal ].
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   600
    pid == 0 
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   601
        ifTrue:
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   602
            [ "Child, exit codes:
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   603
             0...PASSED
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   604
             1...FAILED
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   605
             2...ERROR
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   606
           >64...got signal <code>-64"
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   607
            
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   608
            [ suiteFailuresBefore := failures.
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   609
            suiteErrorsBefore := errors.
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   610
            super runCase:aTestCase debugged: debugged.
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   611
            suiteErrorsBefore ~~ errors ifTrue:[ Smalltalk exit:2 ].
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   612
            suiteFailuresBefore ~~ failures ifTrue:[ Smalltalk exit:1 ].
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   613
            format streamClose.
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   614
            Smalltalk exit:0. ] on:OSSignalInterrupt
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   615
                    do:[:ex | format streamClose. Smalltalk exit:64 + ex parameter ] ]
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   616
        ifFalse:
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   617
            [ "Parent"
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   618
            format streamClose.
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   619
            Transcript show: 'waiting for child...'.
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   620
            (sema waitWithTimeout:timeout) isNil 
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   621
                ifTrue:
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   622
                    [Transcript show: 'timeout...'.
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   623
                    OperatingSystem terminateProcess:pid.
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   624
                    OperatingSystem childProcessWait:true pid:pid.
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   625
                    Transcript show: 'killed...'.
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   626
                    ].
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   627
            etime := OperatingSystem getMillisecondTime.
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   628
            (status isNil or:[ status success not ]) 
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   629
                ifFalse:[
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   630
                    "/child finished, result is pass. However, it is not in my passed collection
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   631
                    "/since addPass: has been called in child process
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   632
                   super addPass: aTestCase.
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   633
                ] ifTrue:
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   634
                    [ log := true.
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   635
                    status isNil 
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   636
                        ifTrue:
528
67d1c7df7f90 Refactor timeout scaling factor initialization
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 325
diff changeset
   637
                            [ error := TimeoutError new messageText: ('Timed out (effective %1ms, base %2ms, scale %3)' bindWith: timeout with: timeoutBase with:timeoutScale asFloat) .
74
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   638
                            stack := 'Oops, timed out!! (timeout was ' , timeout printString , ' sec)'. ]
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   639
                        ifFalse:
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   640
                            [ status status == #signal 
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   641
                                ifTrue:
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   642
                                    [ error := OSSignalInterrupt new parameter:status code.
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   643
                                    stack := 'Oops, VM terminated on signal ' , status code printString, ' (stactrace not awailable)' ].
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   644
                            status status == #exit 
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   645
                                ifTrue:
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   646
                                    [ status code == 1 
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   647
                                        ifTrue:
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   648
                                            [super addFailure: aTestCase detail: nil.
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   649
                                            log := false ].
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   650
                                    status code == 2 
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   651
                                        ifTrue:
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   652
                                            [super addError: aTestCase detail: nil.
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   653
                                            log := false ].
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   654
                                    status code > 64 
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   655
                                        ifTrue:
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   656
                                            [ error := OSSignalInterrupt new parameter:status code - 64.
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   657
                                            stack := 'Oops, VM terminated on signal ' , status code p ] ] ]. ].
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   658
            format streamOpenForAppend.
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   659
            log ifTrue:[
236
475480551293 When running SUnit tests, capture and log stdout, stderr and Transcript and include it in XML report.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 234
diff changeset
   660
                     outcome result: TestResult stateError.
74
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   661
                     format stream stream position: logPos.
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   662
                     format 
236
475480551293 When running SUnit tests, capture and log stdout, stderr and Transcript and include it in XML report.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 234
diff changeset
   663
                        writeTestCase: aTestCase outcome: outcome 
74
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   664
                                 time: etime - stime
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   665
                            exception: error
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   666
                           stacktrace: stack.
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   667
                     Transcript show:'ERROR'
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   668
            ]
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   669
    ].
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   670
    outcome := nil.
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   671
    Transcript cr.
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   672
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   673
    "Created: / 12-01-2012 / 17:43:07 / Jan Vrany <jan.vrany@fit.cvut.cz>"
528
67d1c7df7f90 Refactor timeout scaling factor initialization
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 325
diff changeset
   674
    "Modified: / 24-08-2018 / 11:19:44 / Jan Vrany <jan.vrany@fit.cvut.cz>"
74
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   675
! !
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   676
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   677
!TestReport class methodsFor:'documentation'!
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   678
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   679
version
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   680
    ^ '$Header$'
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   681
!
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   682
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   683
version_CVS
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   684
    ^ '$Header$'
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   685
!
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   686
318
b7f0437a6d18 Pass ident string to coverage report when tests are run with `-c` option
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 303
diff changeset
   687
version_HG
b7f0437a6d18 Pass ident string to coverage report when tests are run with `-c` option
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 303
diff changeset
   688
b7f0437a6d18 Pass ident string to coverage report when tests are run with `-c` option
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 303
diff changeset
   689
    ^ '$Changeset: <not expanded> $'
b7f0437a6d18 Pass ident string to coverage report when tests are run with `-c` option
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 303
diff changeset
   690
!
b7f0437a6d18 Pass ident string to coverage report when tests are run with `-c` option
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 303
diff changeset
   691
74
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   692
version_SVN
164
707c2a3ef492 Initial version of code coverage report.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 111
diff changeset
   693
    ^ '$Id$'
74
d67d39f7b54e initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   694
! !
111
d0fa0756222b class: Builder::TestReport
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 109
diff changeset
   695