3. Completion Test
Edit pageLast modified: 14 November 2024Tested Functionality: 10. Reference Contributor
tip
This page is part of multistep Testing a Custom Language Plugin tutorial.
Define Test Data
Create the DefaultTestData.simple file in the testData directory. This file contains test Simple language properties that will be completed in a test Java file (see the Test
class later in this section).
# You are reading the ".properties" entry.
! The exclamation mark can also mark text as comments.
website = https://en.wikipedia.org/
language = English
# The backslash below tells the application to continue reading
# the value onto the next line.
message = Welcome to \
Wikipedia!
# Add spaces to the key
key\ with\ spaces = This is the value that could be looked up with the key "key with spaces".
# Unicode
tab : \u0009
Create a test input Java file CompleteTestData.java in the testData directory. This file contains a Simple Language reference within the Java code at <caret>
special marker, which denotes the caret position to use in the test.
public class Test {
public static void main(String[] args) {
System.out.println("simple:<caret>");
}
}
Define a Test
Subclass LightJavaCodeInsightFixtureTestCase
to create SimpleCodeInsightTest
. Override getTestDataPath()
, and return the path from the root of this plugin module to the testData directory.
/**
* @return path to test data file directory relative to working directory in the run configuration for this test.
*/
@Override
protected String getTestDataPath() {
return "src/test/testData";
}
At this point, only one test is defined in SimpleCodeInsightTest
: testCompletion()
. This method:
Configures the test using the two input files.
Calls the basic completion functionality. Behind the scenes, this method call creates a list of possible elements to complete the embedded Simple Language reference.
Checks the list of returned lookup strings to ensure it matches the completion variants provided by the reference.
public void testCompletion() {
myFixture.configureByFiles("CompleteTestData.java", "DefaultTestData.simple");
myFixture.complete(CompletionType.BASIC);
List<String> lookupElementStrings = myFixture.getLookupElementStrings();
assertNotNull(lookupElementStrings);
assertSameElements(lookupElementStrings, "key with spaces", "language", "message", "tab", "website");
}
A number of related methods exist in CodeInsightTestFixture
for testing completion and lookup elements, e.g., when testing completion variants and requiring only one testdata file CodeInsightTestFixture.testCompletionVariants()
.
Run the Test
Run the test and make sure it's successful.
Open the Gradle Tool Window.
Select the simple_language_plugin node. You may need to reimport it as a Gradle project.
Drill down under simple_language_plugin to Tasks, verification, test task.
Run the test task.
The results are displayed in the Run Tool Window, and also written to the simple_language_plugin
If the Run Tool Window displays the error Test events were not received, do the following:
In the Gradle Tool Window, drill down under simple_language_plugin to Tasks, build, clean task.
Run the clean task, which deletes the simple_language_plugin/build directory.
Restart the test.