From d09fc969570cdf8833e3a6492a47f8b82dc33aa0 Mon Sep 17 00:00:00 2001 From: Aubrey Chipman Date: Thu, 11 Apr 2024 14:49:32 -0500 Subject: [PATCH] Gracefully create a copy configuration --- .../ExtendRecommenderConfigurationAction.java | 15 +++++++++------ 1 file changed, 9 insertions(+), 6 deletions(-) diff --git a/src/main/groovy/netflix/nebula/dependency/recommender/ExtendRecommenderConfigurationAction.java b/src/main/groovy/netflix/nebula/dependency/recommender/ExtendRecommenderConfigurationAction.java index 0b36cbd..e7ed5b6 100644 --- a/src/main/groovy/netflix/nebula/dependency/recommender/ExtendRecommenderConfigurationAction.java +++ b/src/main/groovy/netflix/nebula/dependency/recommender/ExtendRecommenderConfigurationAction.java @@ -67,12 +67,15 @@ public void execute(Configuration configuration) { * will be not only a different instance, but also may return different deprecation values. */ private DefaultConfiguration createCopy(Set dependencies, Set dependencyConstraints) { - DefaultConfiguration copiedConfiguration = (DefaultConfiguration) project.getConfigurations().create(getNameWithCopySuffix()); - copiedConfiguration.setVisible(false); - copiedConfiguration.setCanBeResolved(false); - copiedConfiguration.setCanBeConsumed(bom.isCanBeConsumed()); - copiedConfiguration.setTransitive(bom.isTransitive()); - copiedConfiguration.setDescription(bom.getDescription()); + DefaultConfiguration copiedConfiguration = (DefaultConfiguration) project.getConfigurations().findByName(getNameWithCopySuffix()); + if (copiedConfiguration == null) { + copiedConfiguration = (DefaultConfiguration) project.getConfigurations().create(getNameWithCopySuffix()); + copiedConfiguration.setVisible(false); + copiedConfiguration.setCanBeResolved(false); + copiedConfiguration.setCanBeConsumed(bom.isCanBeConsumed()); + copiedConfiguration.setTransitive(bom.isTransitive()); + copiedConfiguration.setDescription(bom.getDescription()); + } copiedConfiguration.getArtifacts().addAll(bom.getAllArtifacts()); for (ExcludeRule excludeRule : bom.getExcludeRules()) { copiedConfiguration.getExcludeRules().add(new DefaultExcludeRule(excludeRule.getGroup(), excludeRule.getModule()));