diff --git a/initializr-web/src/main/java/io/spring/initializr/web/mapper/InitializrMetadataV2JsonMapper.java b/initializr-web/src/main/java/io/spring/initializr/web/mapper/InitializrMetadataV2JsonMapper.java index 4d99813b..4777274f 100644 --- a/initializr-web/src/main/java/io/spring/initializr/web/mapper/InitializrMetadataV2JsonMapper.java +++ b/initializr-web/src/main/java/io/spring/initializr/web/mapper/InitializrMetadataV2JsonMapper.java @@ -48,6 +48,7 @@ import org.springframework.util.StringUtils; * A {@link InitializrMetadataJsonMapper} handling the metadata format for v2. * * @author Stephane Nicoll + * @author Guillaume Gerbaud */ public class InitializrMetadataV2JsonMapper implements InitializrMetadataJsonMapper { @@ -83,7 +84,7 @@ public class InitializrMetadataV2JsonMapper implements InitializrMetadataJsonMap singleSelect(delegate, metadata.getPackagings()); singleSelect(delegate, metadata.getJavaVersions()); singleSelect(delegate, metadata.getLanguages()); - singleSelect(delegate, metadata.getBootVersions(), this::mapVersionMetadata); + singleSelect(delegate, metadata.getBootVersions(), this::mapVersionMetadata, this::formatVersion); text(delegate, metadata.getGroupId()); text(delegate, metadata.getArtifactId()); text(delegate, metadata.getVersion()); @@ -137,16 +138,30 @@ public class InitializrMetadataV2JsonMapper implements InitializrMetadataJsonMap } protected void singleSelect(ObjectNode parent, SingleSelectCapability capability) { - singleSelect(parent, capability, this::mapValue); + singleSelect(parent, capability, this::mapValue, (id) -> id); + } + + /** + * Map a {@link SingleSelectCapability} invoking the specified {@code valueMapper}. + * @param parent the parent node + * @param capability the capability to map + * @param valueMapper the function to invoke to transform one value of the capability + * @deprecated in favor of + * {@link #singleSelect(ObjectNode, SingleSelectCapability, Function, Function)} + */ + @Deprecated + protected void singleSelect(ObjectNode parent, SingleSelectCapability capability, + Function valueMapper) { + singleSelect(parent, capability, valueMapper, (id) -> id); } protected void singleSelect(ObjectNode parent, SingleSelectCapability capability, - Function valueMapper) { + Function valueMapper, Function defaultMapper) { ObjectNode single = nodeFactory.objectNode(); single.put("type", capability.getType().getName()); DefaultMetadataElement defaultType = capability.getDefault(); if (defaultType != null) { - single.put("default", defaultType.getId()); + single.put("default", defaultMapper.apply(defaultType.getId())); } ArrayNode values = nodeFactory.arrayNode(); values.addAll(capability.getContent().stream().map(valueMapper).collect(Collectors.toList())); diff --git a/initializr-web/src/test/java/io/spring/initializr/web/mapper/InitializrMetadataV21JsonMapperTests.java b/initializr-web/src/test/java/io/spring/initializr/web/mapper/InitializrMetadataV21JsonMapperTests.java index 3e508b5d..15c95d32 100755 --- a/initializr-web/src/test/java/io/spring/initializr/web/mapper/InitializrMetadataV21JsonMapperTests.java +++ b/initializr-web/src/test/java/io/spring/initializr/web/mapper/InitializrMetadataV21JsonMapperTests.java @@ -102,7 +102,9 @@ class InitializrMetadataV21JsonMapperTests { .addBootVersion("2.5.0-M2", false).addBootVersion("2.4.2", true).build(); String json = this.jsonMapper.write(metadata, null); JsonNode result = objectMapper.readTree(json); - JsonNode versions = result.get("bootVersion").get("values"); + JsonNode platformVersions = result.get("bootVersion"); + assertThat(platformVersions.get("default").textValue()).isEqualTo("2.4.2.RELEASE"); + JsonNode versions = platformVersions.get("values"); assertThat(versions).hasSize(3); assertVersionMetadata(versions.get(0), "2.5.0.BUILD-SNAPSHOT", "2.5.0-SNAPSHOT"); assertVersionMetadata(versions.get(1), "2.5.0.M2", "2.5.0-M2"); diff --git a/initializr-web/src/test/java/io/spring/initializr/web/mapper/InitializrMetadataV22JsonMapperTests.java b/initializr-web/src/test/java/io/spring/initializr/web/mapper/InitializrMetadataV22JsonMapperTests.java index 0c5b64fb..df291a12 100755 --- a/initializr-web/src/test/java/io/spring/initializr/web/mapper/InitializrMetadataV22JsonMapperTests.java +++ b/initializr-web/src/test/java/io/spring/initializr/web/mapper/InitializrMetadataV22JsonMapperTests.java @@ -62,7 +62,9 @@ class InitializrMetadataV22JsonMapperTests { .addBootVersion("2.5.0-M2", false).addBootVersion("2.4.2", true).build(); String json = this.jsonMapper.write(metadata, null); JsonNode result = objectMapper.readTree(json); - JsonNode versions = result.get("bootVersion").get("values"); + JsonNode platformVersions = result.get("bootVersion"); + assertThat(platformVersions.get("default").textValue()).isEqualTo("2.4.2"); + JsonNode versions = platformVersions.get("values"); assertThat(versions).hasSize(3); assertVersionMetadata(versions.get(0), "2.5.0-SNAPSHOT", "2.5.0-SNAPSHOT"); assertVersionMetadata(versions.get(1), "2.5.0-M2", "2.5.0-M2");