Java embedded Elasticsearch for integration testing. Embedded Elasticsearch was deprecated in version 5.0 and above. This causes many issues especially when it comes to integration testing.
One possible remedy is to run Elasticsearch in a Docker container but unfortunately, that has its own problems. For instance, you cannot run the Elasticsearch in Docker in Docker. Besides that. you need to do extra configurations if you want to run the Elasticsearch when your tests are running.
An easier approach is to use community versions of embedded Elasticsearch.
Fortunately, in the Java world, some projects do exist to provide embedded Elasticsearch, especially for testing. So far the best of all is embedded-elasticsearch by Allegro. The project supports 1.x, 2.x, 5.x and 6.x versions of Elasticsearch. The only caveat of this project is that you cannot run it under root
user like any Elasticsearch cluster.
Setting it up is pretty easy. You just need to import the dependency to your project like this for Maven projects:
<dependency>
<groupId>pl.allegro.tech</groupId>
<artifactId>embedded-elasticsearch</artifactId>
<version>2.8.0</version>
<scope>test</scope>
</dependency>
After that, you can bootstrap and shut down the embedded Elasticsearch in your Java integration test like this:
public class EmbeddedElasticsearchTest {
private static EmbeddedElastic embeddedElastic;
@BeforeAll
public static void setup() {
try {
EmbeddedElastic.builder()
.withElasticVersion("5.0.0")
.withSetting(PopularProperties.TRANSPORT_TCP_PORT, 9350)
.withSetting(PopularProperties.CLUSTER_NAME, "my_cluster")
.withPlugin("analysis-stempel")
.withIndex("cars", IndexSettings.builder()
.withType("car", getSystemResourceAsStream("car-mapping.json"))
.build())
.withIndex("books", IndexSettings.builder()
.withType(PAPER_BOOK_INDEX_TYPE, getSystemResourceAsStream("paper-book-mapping.json"))
.withType("audio_book", getSystemResourceAsStream("audio-book-mapping.json"))
.withSettings(getSystemResourceAsStream("elastic-settings.json"))
.build())
.build()
.start()
} catch (IOException e) {
e.printStackTrace();
} catch (InterruptedException e) {
e.printStackTrace();
}
}
// Write your tests here
@AfterAll
public static void teardown() {
embeddedElastic.stop();
}
}
As you can see, we started the embedded Elasticsearch in setup
method which is annotated with @Beforeall
. This means that the embedded Elasticsearch will bootstrap before any tests start running.
Then after running all the test cases, we shut down the embedded Elasticsearch in teardown
method which is annotated with @Afterall
.
That’s all. Happy testing!
More reading on Java JUnit5, here.