1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
|
package mill
package scalalib
import mill.api.Result
import mill.util.{TestEvaluator, TestUtil}
import utest._
import utest.framework.TestPath
object HelloJavaTests extends TestSuite {
object HelloJava extends TestUtil.BaseModule{
def millSourcePath = TestUtil.getSrcPathBase() / millOuterCtx.enclosing.split('.')
trait JUnitTests extends TestModule{
def testFrameworks = Seq("com.novocode.junit.JUnitFramework")
def ivyDeps = Agg(ivy"com.novocode:junit-interface:0.11")
}
object core extends JavaModule{
object test extends Tests with JUnitTests
}
object app extends JavaModule{
def moduleDeps = Seq(core)
object test extends Tests with JUnitTests
}
}
val resourcePath = os.pwd / 'scalalib / 'test / 'resources / "hello-java"
def init()(implicit tp: TestPath) = {
val eval = new TestEvaluator(HelloJava)
os.remove.all(HelloJava.millSourcePath)
os.remove.all(eval.outPath)
os.makeDir.all(HelloJava.millSourcePath / os.up)
os.copy(resourcePath, HelloJava.millSourcePath)
eval
}
def tests: Tests = Tests {
'compile - {
val eval = init()
val Right((res1, n1)) = eval.apply(HelloJava.core.compile)
val Right((res2, 0)) = eval.apply(HelloJava.core.compile)
val Right((res3, n2)) = eval.apply(HelloJava.app.compile)
assert(
res1 == res2,
n1 != 0,
n2 != 0,
os.walk(res1.classes.path).exists(_.last == "Core.class"),
!os.walk(res1.classes.path).exists(_.last == "Main.class"),
os.walk(res3.classes.path).exists(_.last == "Main.class"),
!os.walk(res3.classes.path).exists(_.last == "Core.class")
)
}
'docJar - {
val eval = init()
val Right((ref1, _)) = eval.apply(HelloJava.core.docJar)
val Right((ref2, _)) = eval.apply(HelloJava.app.docJar)
assert(
os.proc("jar", "tf", ref1.path).call().out.lines.contains("hello/Core.html"),
os.proc("jar", "tf", ref2.path).call().out.lines.contains("hello/Main.html")
)
}
'test - {
val eval = init()
val Left(Result.Failure(ref1, Some(v1))) = eval.apply(HelloJava.core.test.test())
assert(
v1._2(0).fullyQualifiedName == "hello.MyCoreTests.lengthTest",
v1._2(0).status == "Success",
v1._2(1).fullyQualifiedName == "hello.MyCoreTests.msgTest",
v1._2(1).status == "Failure"
)
val Right((v2, _)) = eval.apply(HelloJava.app.test.test())
assert(
v2._2(0).fullyQualifiedName == "hello.MyAppTests.appTest",
v2._2(0).status == "Success",
v2._2(1).fullyQualifiedName == "hello.MyAppTests.coreTest",
v2._2(1).status == "Success"
)
}
'failures - {
val eval = init()
val mainJava = HelloJava.millSourcePath / 'app / 'src / "Main.java"
val coreJava = HelloJava.millSourcePath / 'core / 'src / "Core.java"
val Right(_) = eval.apply(HelloJava.core.compile)
val Right(_) = eval.apply(HelloJava.app.compile)
ammonite.ops.write.over(mainJava, ammonite.ops.read(mainJava) + "}")
val Right(_) = eval.apply(HelloJava.core.compile)
val Left(_) = eval.apply(HelloJava.app.compile)
ammonite.ops.write.over(coreJava, ammonite.ops.read(coreJava) + "}")
val Left(_) = eval.apply(HelloJava.core.compile)
val Left(_) = eval.apply(HelloJava.app.compile)
ammonite.ops.write.over(mainJava, ammonite.ops.read(mainJava).dropRight(1))
ammonite.ops.write.over(coreJava, ammonite.ops.read(coreJava).dropRight(1))
val Right(_) = eval.apply(HelloJava.core.compile)
val Right(_) = eval.apply(HelloJava.app.compile)
}
}
}
|