From 2e064f611cb40b58cceef2d7438445a6962443e6 Mon Sep 17 00:00:00 2001 From: Laura Trotta Date: Wed, 13 Nov 2024 15:49:22 +0100 Subject: [PATCH 1/4] unit test container version latest --- .../elasticsearch/ElasticsearchTestServer.java | 12 +++++++++--- 1 file changed, 9 insertions(+), 3 deletions(-) diff --git a/java-client/src/test/java/co/elastic/clients/elasticsearch/ElasticsearchTestServer.java b/java-client/src/test/java/co/elastic/clients/elasticsearch/ElasticsearchTestServer.java index 498bce9ae..02e4a0833 100644 --- a/java-client/src/test/java/co/elastic/clients/elasticsearch/ElasticsearchTestServer.java +++ b/java-client/src/test/java/co/elastic/clients/elasticsearch/ElasticsearchTestServer.java @@ -117,11 +117,17 @@ public synchronized ElasticsearchTestServer start() { return this; } - Version version = Version.VERSION.major() < 8 ? new Version(7,17,5,false) : new Version(8,12,0,false); + // using latest snapshot version for generic tests + Version version = Version.VERSION.major() < 8 ? new Version(7, 17, 25, false) : + Version.parse(Version.VERSION.major() + "." + Version.VERSION.minor() + ".0-SNAPSHOT"); - // Note we could use version.major() + "." + version.minor() + "-SNAPSHOT" but plugins won't install on a snapshot version - String esImage = "docker.elastic.co/elasticsearch/elasticsearch:" + version; + // using specific stable version for tests with plugins + if (plugins.length > 0) { + version = Version.VERSION.major() < 8 ? new Version(7, 17, 25, false) : new Version(8, 16, 0, false); + } + String esImage = "docker.elastic.co/elasticsearch/elasticsearch:" + version; + DockerImageName image; if (plugins.length == 0) { image = DockerImageName.parse(esImage); From 6d037ac1c4ea0d3226ac5cb0d41aeb26ba52c505 Mon Sep 17 00:00:00 2001 From: Laura Trotta Date: Thu, 14 Nov 2024 16:15:33 +0100 Subject: [PATCH 2/4] fetching version info from artifacts api --- .../ElasticsearchTestServer.java | 73 +++++++++++++++++-- 1 file changed, 66 insertions(+), 7 deletions(-) diff --git a/java-client/src/test/java/co/elastic/clients/elasticsearch/ElasticsearchTestServer.java b/java-client/src/test/java/co/elastic/clients/elasticsearch/ElasticsearchTestServer.java index 02e4a0833..03990faae 100644 --- a/java-client/src/test/java/co/elastic/clients/elasticsearch/ElasticsearchTestServer.java +++ b/java-client/src/test/java/co/elastic/clients/elasticsearch/ElasticsearchTestServer.java @@ -29,6 +29,7 @@ import co.elastic.clients.transport.Version; import co.elastic.clients.transport.endpoints.DelegatingJsonEndpoint; import co.elastic.clients.transport.rest_client.RestClientTransport; +import org.apache.commons.io.FileUtils; import org.apache.http.HttpHost; import org.apache.http.auth.AuthScope; import org.apache.http.auth.UsernamePasswordCredentials; @@ -40,12 +41,16 @@ import org.testcontainers.utility.DockerImageName; import javax.net.ssl.SSLContext; +import java.io.File; +import java.io.FileWriter; import java.io.IOException; import java.io.InputStream; import java.net.HttpURLConnection; import java.net.URL; import java.nio.charset.StandardCharsets; import java.time.Duration; +import java.time.Instant; +import java.time.temporal.ChronoUnit; import java.util.Base64; public class ElasticsearchTestServer implements AutoCloseable { @@ -112,22 +117,75 @@ AuthScope.ANY, new UsernamePasswordCredentials("elastic", "changeme") client = new ElasticsearchClient(transport); } + private Version selectLatestVersion(Version version, String info) { + if (info.contains(version.toString())) { + return version; + } + // if no version X.Y.0 was found, we give up + if (version.maintenance() == 0) { + throw new RuntimeException("Elasticsearch server container version: " + version + " not yet " + + "available"); + } + return selectLatestVersion(new Version(version.major(), version.minor(), version.maintenance() - 1, + false), info); + } + + private String fetchAndWriteVersionInfo(File file) throws IOException { + String versionInfo = IOUtils.toString(new URL("https://artifacts-api.elastic" + + ".co/v1/versions/"), StandardCharsets.UTF_8); + try (FileWriter fw = new FileWriter(file, false)) { + fw.write(versionInfo); + } + return versionInfo; + } + + private Version getLatestAvailableServerVersion(Version version) { + try { + // check if there's cached information + ClassLoader classLoader = getClass().getClassLoader(); + URL location = classLoader.getResource("./co/elastic/clients/version.json"); + + // writing the info on file before returning + if (location == null) { + File file = new File(classLoader.getResource("./co/elastic/clients").getFile() + "/version" + + ".json"); + String versionInfo = fetchAndWriteVersionInfo(file); + return selectLatestVersion(version, versionInfo); + } + + File file = new File(location.getFile()); + + // info file was found, but it's expired + if (Instant.ofEpochMilli(file.lastModified()).isBefore(Instant.now().minus(24, + ChronoUnit.HOURS))) { + String versionInfo = fetchAndWriteVersionInfo(file); + return selectLatestVersion(version, versionInfo); + } + + // info file exists and it has new info + String versionInfo = FileUtils.readFileToString(file, StandardCharsets.UTF_8); + return selectLatestVersion(version, versionInfo); + + } catch (IOException e) { + throw new RuntimeException(e); + } + } + public synchronized ElasticsearchTestServer start() { if (this.client != null) { return this; } - // using latest snapshot version for generic tests - Version version = Version.VERSION.major() < 8 ? new Version(7, 17, 25, false) : - Version.parse(Version.VERSION.major() + "." + Version.VERSION.minor() + ".0-SNAPSHOT"); + Version version = getLatestAvailableServerVersion(Version.VERSION); // using specific stable version for tests with plugins if (plugins.length > 0) { - version = Version.VERSION.major() < 8 ? new Version(7, 17, 25, false) : new Version(8, 16, 0, false); + version = Version.VERSION.major() < 8 ? new Version(7, 17, 25, false) : new Version(8, 16, 0, + false); } String esImage = "docker.elastic.co/elasticsearch/elasticsearch:" + version; - + DockerImageName image; if (plugins.length == 0) { image = DockerImageName.parse(esImage); @@ -172,10 +230,11 @@ public static JsonData getJsonResponse(ElasticsearchClient client, Req req try { @SuppressWarnings("unchecked") - JsonEndpoint endpoint0 = (JsonEndpoint) request.getClass() + JsonEndpoint endpoint0 = (JsonEndpoint) request.getClass() .getDeclaredField("_ENDPOINT").get(null); endpoint = endpoint0; - } catch (IllegalAccessException|NoSuchFieldException e) { + } catch (IllegalAccessException | NoSuchFieldException e) { throw new RuntimeException(e); } From 3f0d1f1880c70242708f7fde1cf9e988c5e91162 Mon Sep 17 00:00:00 2001 From: Laura Trotta Date: Thu, 14 Nov 2024 16:51:15 +0100 Subject: [PATCH 3/4] using io utils also for writing --- .../clients/elasticsearch/ElasticsearchTestServer.java | 8 +++----- 1 file changed, 3 insertions(+), 5 deletions(-) diff --git a/java-client/src/test/java/co/elastic/clients/elasticsearch/ElasticsearchTestServer.java b/java-client/src/test/java/co/elastic/clients/elasticsearch/ElasticsearchTestServer.java index 03990faae..9da83f8ba 100644 --- a/java-client/src/test/java/co/elastic/clients/elasticsearch/ElasticsearchTestServer.java +++ b/java-client/src/test/java/co/elastic/clients/elasticsearch/ElasticsearchTestServer.java @@ -63,6 +63,7 @@ public class ElasticsearchTestServer implements AutoCloseable { private ElasticsearchClient client; private static ElasticsearchTestServer global; + private static final String artifactsApiUrl = "https://artifacts-api.elastic.co/v1/versions/"; public static synchronized ElasticsearchTestServer global() { if (global == null) { @@ -131,11 +132,8 @@ private Version selectLatestVersion(Version version, String info) { } private String fetchAndWriteVersionInfo(File file) throws IOException { - String versionInfo = IOUtils.toString(new URL("https://artifacts-api.elastic" + - ".co/v1/versions/"), StandardCharsets.UTF_8); - try (FileWriter fw = new FileWriter(file, false)) { - fw.write(versionInfo); - } + String versionInfo = IOUtils.toString(new URL(artifactsApiUrl), StandardCharsets.UTF_8); + FileUtils.writeStringToFile(file, versionInfo, StandardCharsets.UTF_8); return versionInfo; } From c169396be58d166e2374746cd449634b45c1acc2 Mon Sep 17 00:00:00 2001 From: Laura Trotta Date: Thu, 14 Nov 2024 17:53:27 +0100 Subject: [PATCH 4/4] checkstyle --- .../elastic/clients/elasticsearch/ElasticsearchTestServer.java | 1 - 1 file changed, 1 deletion(-) diff --git a/java-client/src/test/java/co/elastic/clients/elasticsearch/ElasticsearchTestServer.java b/java-client/src/test/java/co/elastic/clients/elasticsearch/ElasticsearchTestServer.java index 9da83f8ba..9fca54c03 100644 --- a/java-client/src/test/java/co/elastic/clients/elasticsearch/ElasticsearchTestServer.java +++ b/java-client/src/test/java/co/elastic/clients/elasticsearch/ElasticsearchTestServer.java @@ -42,7 +42,6 @@ import javax.net.ssl.SSLContext; import java.io.File; -import java.io.FileWriter; import java.io.IOException; import java.io.InputStream; import java.net.HttpURLConnection;