blob: 5c93dd7574ac2ca9fc9c71b0932a3bc10e93e479 (
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
|
import scala.reflect.{ClassTag, classTag}
object Test {
def main(args: Array[String]): Unit = {
ConcurrentMapSpec.test()
IteratorSpec.test()
LNodeSpec.test()
SnapshotSpec.test()
}
}
trait Spec {
implicit def implicitously: languageFeature.implicitConversions = scala.language.implicitConversions
implicit def reflectively : languageFeature.reflectiveCalls = scala.language.reflectiveCalls
implicit def str2ops(s: String): AnyRef{def in[U](body: => U): Unit} = new {
def in[U](body: =>U): Unit = {
// just execute body
body
}
}
implicit def any2ops(a: Any): AnyRef{def shouldEqual(other: Any): Unit} = new {
def shouldEqual(other: Any) = assert(a == other)
}
def evaluating[U](body: =>U) = new {
def shouldProduce[T <: Throwable: ClassTag]() = {
var produced = false
try body
catch {
case e: Throwable => if (e.getClass == implicitly[ClassTag[T]].runtimeClass) produced = true
} finally {
assert(produced, "Did not produce exception of type: " + implicitly[ClassTag[T]])
}
}
}
}
|