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
|
package mill.define
import mill.discover.Discovered
import mill.eval.Evaluator
import mill.util.{DummyLogger, OSet, TestUtil}
import mill.T
import mill.eval.Result.Success
import utest._
import utest.framework.TestPath
object CacherTests extends TestSuite{
object Base extends Base
trait Base extends TestUtil.BaseModule{
def value = T{ 1 }
def result = T{ Success(1) }
}
object Middle extends Middle
trait Middle extends Base{
def value = T{ super.value() + 2}
def overriden = T{ super.value()}
}
object Terminal extends Terminal
trait Terminal extends Middle{
override def value = T{ super.value() + 4}
}
val tests = Tests{
def eval[V](mapping: Discovered.Mapping[_], v: Task[V])(implicit tp: TestPath) = {
val workspace = ammonite.ops.pwd / 'target / 'workspace / tp.value
val evaluator = new Evaluator(workspace, ammonite.ops.pwd, mapping, DummyLogger)
evaluator.evaluate(OSet(v)).values(0)
}
'simpleDefIsCached - assert(
Base.value eq Base.value,
eval(Discovered.mapping(Base), Base.value) == 1
)
'resultDefIsCached - assert(
Base.result eq Base.result,
eval(Discovered.mapping(Base), Base.result) == 1
)
val middleMapping = Discovered.mapping(Middle)
'overridingDefIsAlsoCached - assert(
eval(middleMapping, Middle.value) == 3,
Middle.value eq Middle.value
)
'overridenDefRemainsAvailable - assert(
eval(middleMapping, Middle.overriden) == 1
)
val terminalMapping = Discovered.mapping(Terminal)
'multipleOverridesWork- assert(
eval(terminalMapping, Terminal.value) == 7,
eval(terminalMapping, Terminal.overriden) == 1
)
// Doesn't fail, presumably compileError doesn't go far enough in the
// compilation pipeline to hit the override checks
//
// 'overrideOutsideModuleFails - {
// compileError("""
// trait Foo{
// def x = 1
// }
// object Bar extends Foo{
// def x = 2
// }
// """)
// }
}
}
|