-
Notifications
You must be signed in to change notification settings - Fork 217
/
Copy pathCompilerTest.kt
98 lines (83 loc) · 3.89 KB
/
CompilerTest.kt
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
package org.javacs.kt
import org.hamcrest.Matchers.hasToString
import org.jetbrains.kotlin.psi.KtExpression
import org.jetbrains.kotlin.psi.KtNamedFunction
import org.jetbrains.kotlin.psi.KtReferenceExpression
import org.jetbrains.kotlin.psi.psiUtil.parentsWithSelf
import org.jetbrains.kotlin.resolve.BindingContext
import org.javacs.kt.compiler.Compiler
import org.junit.Assert.assertThat
import org.junit.Test
import org.junit.AfterClass
import org.junit.BeforeClass
import java.io.File
import java.nio.file.Files
class CompilerTest {
val myTestResources = testResourcesRoot().resolve("compiler")
val file = myTestResources.resolve("FileToEdit.kt")
val editedText = """
private class FileToEdit {
val someVal = 1
}"""
companion object {
lateinit var outputDirectory: File
lateinit var compiler: Compiler
@JvmStatic @BeforeClass fun setup() {
LOG.connectStdioBackend()
outputDirectory = Files.createTempDirectory("klsBuildOutput").toFile()
compiler = Compiler(
javaSourcePath = setOf(),
classPath = setOf(),
scriptsConfig = ScriptsConfiguration(),
codegenConfig = CodegenConfiguration(),
outputDirectory = outputDirectory
)
}
@JvmStatic @AfterClass
fun tearDown() {
compiler.close()
outputDirectory.delete()
}
}
@Test fun compileFile() {
val content = Files.readAllLines(file).joinToString("\n")
val original = compiler.createKtFile(content, file)
val (context, _) = compiler.compileKtFile(original, listOf(original))
val psi = original.findElementAt(45)!!
val kt = psi.parentsWithSelf.filterIsInstance<KtExpression>().first()
assertThat(context.getType(kt), hasToString("String"))
}
@Test fun newFile() {
val original = compiler.createKtFile(editedText, file)
val (context, _) = compiler.compileKtFile(original, listOf(original))
val psi = original.findElementAt(46)!!
val kt = psi.parentsWithSelf.filterIsInstance<KtExpression>().first()
assertThat(context.getType(kt), hasToString("Int"))
}
@Test fun editFile() {
val content = Files.readAllLines(file).joinToString("\n")
val original = compiler.createKtFile(content, file)
var (context, _) = compiler.compileKtFile(original, listOf(original))
var psi = original.findElementAt(46)!!
var kt = psi.parentsWithSelf.filterIsInstance<KtExpression>().first()
assertThat(context.getType(kt), hasToString("String"))
val edited = compiler.createKtFile(editedText, file)
context = compiler.compileKtFile(edited, listOf(edited)).first
psi = edited.findElementAt(46)!!
kt = psi.parentsWithSelf.filterIsInstance<KtExpression>().first()
assertThat(context.getType(kt), hasToString("Int"))
}
@Test fun editRef() {
val file1 = testResourcesRoot().resolve("hover/Recover.kt")
val content = Files.readAllLines(file1).joinToString("\n")
val original = compiler.createKtFile(content, file1)
val (context, _) = compiler.compileKtFile(original, listOf(original))
val function = original.findElementAt(49)!!.parentsWithSelf.filterIsInstance<KtNamedFunction>().first()
val scope = context.get(BindingContext.LEXICAL_SCOPE, function.bodyExpression)!!
val recompile = compiler.createKtDeclaration("""private fun singleExpressionFunction() = intFunction()""")
val (recompileContext, _) = compiler.compileKtExpression(recompile, scope, setOf(original))
val intFunctionRef = recompile.findElementAt(41)!!.parentsWithSelf.filterIsInstance<KtReferenceExpression>().first()
val target = recompileContext.get(BindingContext.REFERENCE_TARGET, intFunctionRef)!!
assertThat(target.name, hasToString("intFunction"))
}
}