blob: 935cd39b7eea420a543255cfdbf9e13ab465c0d3 (
plain)
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
|
package com.google.devtools.ksp.test
import org.gradle.testkit.runner.BuildResult
import org.gradle.testkit.runner.GradleRunner
import org.gradle.testkit.runner.TaskOutcome
import org.junit.Assert
import org.junit.Rule
import org.junit.Test
import java.io.File
import java.util.jar.JarFile
class VerboseIT {
@Rule
@JvmField
val project: TemporaryTestProject = TemporaryTestProject("playground")
private fun GradleRunner.buildAndCheck(vararg args: String, extraCheck: (BuildResult) -> Unit = {}) =
buildAndCheckOutcome(*args, outcome = TaskOutcome.SUCCESS, extraCheck = extraCheck)
private fun GradleRunner.buildAndCheckOutcome(
vararg args: String,
outcome: TaskOutcome,
extraCheck: (BuildResult) -> Unit = {}
) {
val result = this.withArguments(*args).build()
Assert.assertEquals(outcome, result.task(":workload:build")?.outcome)
val artifact = File(project.root, "workload/build/libs/workload-1.0-SNAPSHOT.jar")
Assert.assertTrue(artifact.exists())
JarFile(artifact).use { jarFile ->
Assert.assertTrue(jarFile.getEntry("TestProcessor.log").size > 0)
Assert.assertTrue(jarFile.getEntry("hello/HELLO.class").size > 0)
Assert.assertTrue(jarFile.getEntry("g/G.class").size > 0)
Assert.assertTrue(jarFile.getEntry("com/example/AClassBuilder.class").size > 0)
}
extraCheck(result)
}
@Test
fun testNoProvider() {
val gradleRunner = GradleRunner.create().withProjectDir(project.root)
File(
project.root,
"test-processor/src/main/resources/META-INF/services/" +
"com.google.devtools.ksp.processing.SymbolProcessorProvider"
).delete()
gradleRunner.withArguments("build").buildAndFail().let { result ->
Assert.assertTrue(result.output.contains("No providers found in processor classpath."))
}
}
@Test
fun testProviderAndRoundLogging() {
val gradleRunner = GradleRunner.create().withProjectDir(project.root)
gradleRunner.buildAndCheck("--debug", "clean", "build") { result ->
Assert.assertTrue(
result.output.contains(
"i: [ksp] loaded provider(s): [TestProcessorProvider, TestProcessorProvider2]"
)
)
Assert.assertTrue(result.output.contains("v: [ksp] round 3 of processing"))
}
}
}
|