From 52fef0db2af9b0f948d3c2f679a64d0b4d64f11d Mon Sep 17 00:00:00 2001 From: Stephan Lukasczyk Date: Sun, 24 Nov 2024 21:06:22 +0100 Subject: [PATCH] Provide tests for a selection of method The core algorithm is still not tested because I do not see how I could get the required objects in the necessary state. The unfortunate thing about the implemented selection algorithms is that they rely on an open editor for a normal execution, which seems to be hard to set up for a unit test. Any feedback and help on this is highly appreciated! --- .../actions/llm/LLMSampleSelectorBuilder.kt | 12 +- .../llm/LLMSampleSelectorBuilderTest.kt | 63 -------- .../actions/llm/LLMSampleSelectorTest.kt | 146 ++++++++++++++++++ 3 files changed, 152 insertions(+), 69 deletions(-) delete mode 100644 src/test/kotlin/org/jetbrains/research/testspark/actions/llm/LLMSampleSelectorBuilderTest.kt create mode 100644 src/test/kotlin/org/jetbrains/research/testspark/actions/llm/LLMSampleSelectorTest.kt diff --git a/src/main/kotlin/org/jetbrains/research/testspark/actions/llm/LLMSampleSelectorBuilder.kt b/src/main/kotlin/org/jetbrains/research/testspark/actions/llm/LLMSampleSelectorBuilder.kt index b29afc3e9..0b69316d7 100644 --- a/src/main/kotlin/org/jetbrains/research/testspark/actions/llm/LLMSampleSelectorBuilder.kt +++ b/src/main/kotlin/org/jetbrains/research/testspark/actions/llm/LLMSampleSelectorBuilder.kt @@ -195,7 +195,7 @@ class LLMSampleSelectorBuilder(private val project: Project, private val languag * A selector for samples for the LLM. */ class LLMSampleSelector { - private val defaultTestName = "provide manually = - IdeaTestFixtureFactory.getFixtureFactory().createFixtureBuilder("project") - - fixture = JavaTestFixtureFactory.getFixtureFactory() - .createCodeInsightFixture(projectBuilder.fixture) - fixture.setUp() - - addFilesFromJSONToFixture() - - project = fixture.project - IndexingTestUtil.waitUntilIndexesAreReady(project) - builder = LLMSampleSelectorBuilder(project, SupportedLanguage.Java) - } - - private fun addFilesFromJSONToFixture() { - val jsonFileContent = getResourceAsText("/llm/sampleSelectorTestFiles.json") - val type = object : TypeToken>() {}.type - val fileMap = Gson().fromJson(jsonFileContent, type) as Map - fileMap.forEach { (fileName, fileContent) -> - val psiFile = fixture.addFileToProject(fileName as String, fileContent as String) - if (fileName == "test/dummy/CarTest.java") { - openFile = psiFile - } - } - } - - private fun getResourceAsText(path: String): String? = - object {}.javaClass.getResource(path)?.readText() - -// @Test -// fun collectTestSampleForCurrentFile() { -// runReadAction { builder.collectTestSamplesForCurrentFile(openFile.virtualFile) } -// } - -// @Test -// fun collectTestSamples() { -// runReadAction { builder.collectTestSamples(project) } -// } -} diff --git a/src/test/kotlin/org/jetbrains/research/testspark/actions/llm/LLMSampleSelectorTest.kt b/src/test/kotlin/org/jetbrains/research/testspark/actions/llm/LLMSampleSelectorTest.kt new file mode 100644 index 000000000..718fe681f --- /dev/null +++ b/src/test/kotlin/org/jetbrains/research/testspark/actions/llm/LLMSampleSelectorTest.kt @@ -0,0 +1,146 @@ +package org.jetbrains.research.testspark.actions.llm + +import com.google.gson.Gson +import com.google.gson.reflect.TypeToken +import com.intellij.openapi.application.runReadAction +import com.intellij.psi.PsiClass +import com.intellij.psi.PsiJavaFile +import com.intellij.psi.PsiMethod +import com.intellij.testFramework.fixtures.CodeInsightTestFixture +import com.intellij.testFramework.fixtures.IdeaProjectTestFixture +import com.intellij.testFramework.fixtures.IdeaTestFixtureFactory +import com.intellij.testFramework.fixtures.JavaTestFixtureFactory +import com.intellij.testFramework.fixtures.TestFixtureBuilder +import com.intellij.util.containers.stream +import net.jqwik.api.ForAll +import net.jqwik.api.Property +import net.jqwik.api.lifecycle.BeforeTry +import org.junit.jupiter.api.Assertions.assertEquals +import org.junit.jupiter.api.BeforeEach +import org.junit.jupiter.api.Test +import kotlin.test.assertContentEquals + +class LLMSampleSelectorTest { + + private lateinit var selector: LLMSampleSelector + private lateinit var fixture: CodeInsightTestFixture + private lateinit var openFile: PsiJavaFile + + @BeforeEach + @BeforeTry + fun setUpSelector() { + selector = LLMSampleSelector() + } + + @BeforeEach + fun setUpProject() { + val projectBuilder: TestFixtureBuilder = + IdeaTestFixtureFactory.getFixtureFactory().createFixtureBuilder("project") + + fixture = JavaTestFixtureFactory.getFixtureFactory() + .createCodeInsightFixture(projectBuilder.fixture) + fixture.setUp() + + addFilesFromJSONToFixture() + } + + private fun classFromFile(psiJavaFile: PsiJavaFile): PsiClass { + return runReadAction { + psiJavaFile.classes[ + psiJavaFile.classes.stream().map { it.name }.toArray() + .indexOf(psiJavaFile.name.removeSuffix(".java")), + ] + } + } + + private fun methodsFromClass(psiClass: PsiClass): Array { + return psiClass.methods + } + + private fun addFilesFromJSONToFixture() { + val jsonFileContent = getResourceAsText("/llm/sampleSelectorTestFiles.json") + val type = object : TypeToken>() {}.type + val fileMap = Gson().fromJson(jsonFileContent, type) as Map + fileMap.forEach { (fileName, fileContent) -> + val psiFile = fixture.addFileToProject(fileName, fileContent) + if (fileName == "test/dummy/CarTest.java") { + openFile = psiFile as PsiJavaFile + } + } + } + + private fun getResourceAsText(path: String): String? = + object {}.javaClass.getResource(path)?.readText() + + @Test + fun `test the initial test names`() { + val expected = mutableListOf("provide manually") + val actual = selector.getTestNames() + assertContentEquals(expected, actual) + } + + @Test + fun `test the initial test code`() { + val initialCode = """ + public class TestSample { + // provide test method code here + } + """.trimIndent() + val expected = mutableListOf(initialCode) + val actual = selector.getInitialTestCodes() + assertContentEquals(expected, actual) + } + + @Property + fun `test the append of test sample code`(@ForAll index: Int, @ForAll code: String) { + selector.appendTestSampleCode(index, code) + val expected = "Test sample number ${index + 1}\n```\n$code\n```\n" + val actual = selector.getTestSamplesCode() + assertEquals(expected, actual) + } + + @Test + fun `test the class retrieval from a Java file`() { + val expectedName = "CarTest" + val actual = runReadAction { selector.retrievePsiClass(openFile as PsiJavaFile) } + assertEquals(expectedName, actual.name) + } + + @Test + fun `test the import-statement retrieval`() { + val expected = """ + import org.junit.jupiter.api.Test; + import static org.junit.jupiter.api.Assertions.assertEquals; + import dummy.*; + """.trimIndent() + val actual = runReadAction { + val file = openFile as PsiJavaFile + selector.retrieveImportStatements(file, classFromFile(file)) + } + assertEquals(expected, actual) + } + + @Test + fun `test the create test-sample class`() { + val expected = """ + import org.junit.jupiter.api.Test; + + public class TestSample { + // provide test method code here + } + """.trimIndent() + val actual = selector.createTestSampleClass( + "import org.junit.jupiter.api.Test;", + "// provide test method code here", + ) + assertEquals(expected, actual) + } + + @Test + fun `test the expected method name`() { + val expected = "dummy.CarTest#testCar" + val cls = classFromFile(openFile) + val actual = selector.createMethodName(cls, methodsFromClass(cls)[0]) + assertEquals(expected, actual) + } +}