blob: 53b0942ceeca81f4fcfd0790af258be0bbbd2d55 (
plain) (
blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
|
package dotty
package tools
package vulpix
import scala.collection.mutable
import dotc.reporting.TestReporter
trait SummaryReporting {
def reportFailed(): Unit
def reportPassed(): Unit
def addFailedTest(msg: String): Unit
def addReproduceInstruction(instr: String): Unit
def addStartingMessage(msg: String): Unit
def addCleanup(f: () => Unit): Unit
def echoSummary(): Unit
}
final class NoSummaryReport extends SummaryReporting {
def reportFailed(): Unit = ()
def reportPassed(): Unit = ()
def addFailedTest(msg: String): Unit = ()
def addReproduceInstruction(instr: String): Unit = ()
def addStartingMessage(msg: String): Unit = ()
def addCleanup(f: () => Unit): Unit = ()
def echoSummary(): Unit = ()
}
final class SummaryReport extends SummaryReporting {
private val startingMessages = mutable.ArrayBuffer.empty[String]
private val failedTests = mutable.ArrayBuffer.empty[String]
private val reproduceInstructions = mutable.ArrayBuffer.empty[String]
private val cleanUps = mutable.ArrayBuffer.empty[() => Unit]
private[this] var passed = 0
private[this] var failed = 0
def reportFailed(): Unit =
failed += 1
def reportPassed(): Unit =
passed += 1
def addFailedTest(msg: String): Unit =
failedTests.append(msg)
def addReproduceInstruction(instr: String): Unit =
reproduceInstructions.append(instr)
def addStartingMessage(msg: String): Unit =
startingMessages.append(msg)
def addCleanup(f: () => Unit): Unit =
cleanUps.append(f)
/** Both echoes the summary to stdout and prints to file */
def echoSummary(): Unit = {
import SummaryReport._
val rep = new StringBuilder
rep.append(
s"""|
|================================================================================
|Test Report
|================================================================================
|
|$passed passed, $failed failed, ${passed + failed} total
|""".stripMargin
)
startingMessages.foreach(rep.append)
failedTests.map(x => " " + x).foreach(rep.append)
// If we're compiling locally, we don't need instructions on how to
// reproduce failures
if (isInteractive) {
println(rep.toString)
if (failed > 0) println {
"""|
|----------------------------------------------------------
|Note: reproduction instructed have been dumped to log file
|----------------------------------------------------------""".stripMargin
}
}
rep += '\n'
reproduceInstructions.foreach(rep.append)
// If we're on the CI, we want everything
if (!isInteractive) println(rep.toString)
TestReporter.writeToLog(rep.toString)
// Perform cleanup callback:
if (cleanUps.nonEmpty) cleanUps.foreach(_.apply())
}
}
object SummaryReport {
val isInteractive = Properties.testsInteractive && !Properties.isRunByDrone
}
|