From 5385a4c1cf943b82cf483c3acc994ba9312e7231 Mon Sep 17 00:00:00 2001 From: Tomas Hofman Date: Mon, 18 Mar 2024 15:23:56 +0100 Subject: [PATCH] Metadata resolution failure in one channel should not fail installation --- .../java/org/wildfly/channel/ChannelImpl.java | 27 ++++++++++++++----- 1 file changed, 21 insertions(+), 6 deletions(-) diff --git a/core/src/main/java/org/wildfly/channel/ChannelImpl.java b/core/src/main/java/org/wildfly/channel/ChannelImpl.java index 87a2a5d1..380ea581 100644 --- a/core/src/main/java/org/wildfly/channel/ChannelImpl.java +++ b/core/src/main/java/org/wildfly/channel/ChannelImpl.java @@ -30,6 +30,7 @@ import java.util.Set; import java.util.stream.Collectors; +import org.jboss.logging.Logger; import org.wildfly.channel.spi.MavenVersionsResolver; import org.wildfly.channel.version.VersionMatcher; @@ -38,6 +39,8 @@ */ class ChannelImpl implements AutoCloseable { + private static final Logger LOG = Logger.getLogger(ChannelImpl.class); + private Channel channelDefinition; private List requiredChannels = Collections.emptyList(); @@ -237,17 +240,29 @@ Optional resolveLatestVersion(String groupId, String return Optional.empty(); } case MAVEN_LATEST: - String latestMetadataVersion = resolver.getMetadataLatestVersion(groupId, artifactId); - if (blocklistedVersions.contains(latestMetadataVersion)) { + try { + String latestMetadataVersion = resolver.getMetadataLatestVersion(groupId, artifactId); + if (blocklistedVersions.contains(latestMetadataVersion)) { + return Optional.empty(); + } + return Optional.of(new ResolveLatestVersionResult(latestMetadataVersion, this)); + } catch (NoStreamFoundException e) { + LOG.debugf(e, "Metadata resolution for %s:%s failed in channel %s", + groupId, artifactId, this.getChannelDefinition().getName()); return Optional.empty(); } - return Optional.of(new ResolveLatestVersionResult(latestMetadataVersion, this)); case MAVEN_RELEASE: - String releaseMetadataVersion = resolver.getMetadataReleaseVersion(groupId, artifactId); - if (blocklistedVersions.contains(releaseMetadataVersion)) { + try { + String releaseMetadataVersion = resolver.getMetadataReleaseVersion(groupId, artifactId); + if (blocklistedVersions.contains(releaseMetadataVersion)) { + return Optional.empty(); + } + return Optional.of(new ResolveLatestVersionResult(releaseMetadataVersion, this)); + } catch (NoStreamFoundException e) { + LOG.debugf(e, "Metadata resolution for %s:%s failed in channel %s", + groupId, artifactId, this.getChannelDefinition().getName()); return Optional.empty(); } - return Optional.of(new ResolveLatestVersionResult(releaseMetadataVersion, this)); default: return Optional.empty(); }