From 1feb0d4e3af58eb1f3ffe49e11a32d6eb2211166 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?S=C3=A9bastien=20Deleuze?= Date: Fri, 28 Apr 2023 18:41:58 +0200 Subject: [PATCH] Add support for `default-for` attribute This new index.json attribute is design to allow more flexible version matching to avoid breakage due to switch on latest version for untested ones. It should have a `default-for` key and a regexp as a string value, for example "1\\.0\\..*" which should match versions like "1.0.0", "1.0.1", "1.0.2", etc. See oracle/graalvm-reachability-metadata#62 See oracle/graalvm-reachability-metadata#275 --- .../internal/index/artifacts/Artifact.java | 10 ++++++- ...duleJsonVersionToConfigDirectoryIndex.java | 8 +++-- ...JsonVersionToConfigDirectoryIndexTest.java | 30 +++++++++++++++++++ .../test/resources/json/artifact-2/index.json | 5 ++++ 4 files changed, 49 insertions(+), 4 deletions(-) create mode 100644 common/graalvm-reachability-metadata/src/test/resources/json/artifact-2/index.json diff --git a/common/graalvm-reachability-metadata/src/main/java/org/graalvm/reachability/internal/index/artifacts/Artifact.java b/common/graalvm-reachability-metadata/src/main/java/org/graalvm/reachability/internal/index/artifacts/Artifact.java index 248f11f9e..aaf6abbd3 100644 --- a/common/graalvm-reachability-metadata/src/main/java/org/graalvm/reachability/internal/index/artifacts/Artifact.java +++ b/common/graalvm-reachability-metadata/src/main/java/org/graalvm/reachability/internal/index/artifacts/Artifact.java @@ -45,6 +45,7 @@ import com.fasterxml.jackson.annotation.JsonProperty; import java.util.Set; +import java.util.regex.Pattern; @JsonIgnoreProperties(ignoreUnknown = true) public class Artifact { @@ -53,18 +54,21 @@ public class Artifact { private final String directory; private final boolean latest; private final boolean override; + private final Pattern defaultForPattern; @JsonCreator public Artifact(@JsonProperty("module") String module, @JsonProperty("tested-versions") Set versions, @JsonProperty("metadata-version") String directory, @JsonProperty(value = "latest", defaultValue = "false") boolean latest, - @JsonProperty(value = "override", defaultValue = "false") boolean override) { + @JsonProperty(value = "override", defaultValue = "false") boolean override, + @JsonProperty(value = "default-for") String defaultFor) { this.module = module; this.versions = versions; this.directory = directory; this.latest = latest; this.override = override; + this.defaultForPattern = (defaultFor == null ? null : Pattern.compile(defaultFor)); } public String getModule() { @@ -86,4 +90,8 @@ public boolean isLatest() { public boolean isOverride() { return override; } + + public boolean isDefaultFor(String version) { + return defaultForPattern != null && defaultForPattern.matcher(version).matches(); + } } diff --git a/common/graalvm-reachability-metadata/src/main/java/org/graalvm/reachability/internal/index/artifacts/SingleModuleJsonVersionToConfigDirectoryIndex.java b/common/graalvm-reachability-metadata/src/main/java/org/graalvm/reachability/internal/index/artifacts/SingleModuleJsonVersionToConfigDirectoryIndex.java index 0f1edbb89..d518e6bbd 100644 --- a/common/graalvm-reachability-metadata/src/main/java/org/graalvm/reachability/internal/index/artifacts/SingleModuleJsonVersionToConfigDirectoryIndex.java +++ b/common/graalvm-reachability-metadata/src/main/java/org/graalvm/reachability/internal/index/artifacts/SingleModuleJsonVersionToConfigDirectoryIndex.java @@ -91,7 +91,8 @@ private Map> parseIndexFile(Path rootPath) { */ @Override public Optional findConfiguration(String groupId, String artifactId, String version) { - return findConfigurationFor(groupId, artifactId, version, artifact -> artifact.getVersions().contains(version)); + return findConfigurationFor(groupId, artifactId, version, + artifact -> artifact.getVersions().contains(version) || artifact.isDefaultFor(version)); } @Override @@ -101,15 +102,16 @@ public Optional findLatestConfigurationFor(String groupI } /** - * Returns the latest configuration directory for the requested artifact. + * Returns the matching configuration directory for the requested artifact. * * @param groupId the group ID of the artifact * @param artifactId the artifact ID of the artifact + * @param version the version of the artifact * @return a configuration directory, or empty if no configuration directory is available */ @Override public Optional findLatestConfigurationFor(String groupId, String artifactId, String version) { - return findConfigurationFor(groupId, artifactId, version, Artifact::isLatest); + return findConfigurationFor(groupId, artifactId, version, artifact -> artifact.isDefaultFor(version) || artifact.isLatest()); } private Optional findConfigurationFor(String groupId, String artifactId, String version, diff --git a/common/graalvm-reachability-metadata/src/test/java/org/graalvm/reachability/internal/index/artifacts/SingleModuleJsonVersionToConfigDirectoryIndexTest.java b/common/graalvm-reachability-metadata/src/test/java/org/graalvm/reachability/internal/index/artifacts/SingleModuleJsonVersionToConfigDirectoryIndexTest.java index 42a046d46..7abc08f96 100644 --- a/common/graalvm-reachability-metadata/src/test/java/org/graalvm/reachability/internal/index/artifacts/SingleModuleJsonVersionToConfigDirectoryIndexTest.java +++ b/common/graalvm-reachability-metadata/src/test/java/org/graalvm/reachability/internal/index/artifacts/SingleModuleJsonVersionToConfigDirectoryIndexTest.java @@ -95,6 +95,36 @@ void checkIndex() throws URISyntaxException { } + @Test + void checkIndexWithDefaultFor() throws URISyntaxException { + withIndex("artifact-2"); + + Optional config = index.findConfiguration("com.foo", "bar", "1.0"); + assertTrue(config.isPresent()); + assertEquals(repoPath.resolve("1.0"), config.get().getDirectory()); + + config = index.findConfiguration("com.foo", "bar", "1.1"); + assertTrue(config.isPresent()); + assertEquals(repoPath.resolve("1.0"), config.get().getDirectory()); + + config = index.findConfiguration("com.foo", "bar", "2.0"); + assertTrue(config.isPresent()); + assertEquals(repoPath.resolve("2.0"), config.get().getDirectory()); + + config = index.findConfiguration("com.foo", "bar", "2.1"); + assertTrue(config.isPresent()); + assertEquals(repoPath.resolve("2.0"), config.get().getDirectory()); + + Optional latest = index.findLatestConfigurationFor("com.foo", "bar", "123"); + assertTrue(latest.isPresent()); + assertEquals(repoPath.resolve("2.0"), latest.get().getDirectory()); + + config = index.findConfiguration("com.foo", "baz", "1.1"); + assertTrue(config.isPresent()); + assertEquals(repoPath.resolve("1.0"), config.get().getDirectory()); + + } + private void withIndex(String json) throws URISyntaxException { repoPath = new File(SingleModuleJsonVersionToConfigDirectoryIndexTest.class.getResource("/json/" + json).toURI()).toPath(); index = new SingleModuleJsonVersionToConfigDirectoryIndex(repoPath); diff --git a/common/graalvm-reachability-metadata/src/test/resources/json/artifact-2/index.json b/common/graalvm-reachability-metadata/src/test/resources/json/artifact-2/index.json new file mode 100644 index 000000000..53b35b5cc --- /dev/null +++ b/common/graalvm-reachability-metadata/src/test/resources/json/artifact-2/index.json @@ -0,0 +1,5 @@ +[ + { "module": "com.foo:bar", "tested-versions": ["1.0"], "metadata-version": "1.0", "default-for": "1\\..*" }, + { "module": "com.foo:bar", "tested-versions": ["2.0", "2.1"], "metadata-version": "2.0", "latest": true }, + { "module": "com.foo:baz", "tested-versions": ["1.0"], "metadata-version": "1.0", "default-for": "1.*" } +]