From e2e6d861ce1e0c2d0e90af2ff426f86695f1bc6f Mon Sep 17 00:00:00 2001 From: Wesley Rogers Date: Tue, 10 Oct 2023 11:26:51 -0400 Subject: [PATCH] fix: use separate rewrite-polyglot version (#233) This commit fixes issue #233, where specifying a rewriteVersion inside the rewrite configuration block would result in rewrite-polyglot failing to resolve to a proper version. --- .../gradle/DefaultRewriteExtension.java | 5 +- .../gradle/RewriteResolveDependenciesTest.kt | 55 +++++++++++++++++++ 2 files changed, 58 insertions(+), 2 deletions(-) create mode 100644 plugin/src/test/kotlin/org/openrewrite/gradle/RewriteResolveDependenciesTest.kt diff --git a/plugin/src/main/java/org/openrewrite/gradle/DefaultRewriteExtension.java b/plugin/src/main/java/org/openrewrite/gradle/DefaultRewriteExtension.java index a8856d872..2ae0f78f5 100644 --- a/plugin/src/main/java/org/openrewrite/gradle/DefaultRewriteExtension.java +++ b/plugin/src/main/java/org/openrewrite/gradle/DefaultRewriteExtension.java @@ -217,12 +217,13 @@ public String getRewriteVersion() { return rewriteVersion; } + private String rewritePolyglotVersion; @Override public String getRewritePolyglotVersion() { - if (rewriteVersion == null) { + if (rewritePolyglotVersion == null) { return getVersionProps().getProperty("org.openrewrite:rewrite-polyglot"); } - return rewriteVersion; + return rewritePolyglotVersion; } private String rewriteGradleModelVersion; diff --git a/plugin/src/test/kotlin/org/openrewrite/gradle/RewriteResolveDependenciesTest.kt b/plugin/src/test/kotlin/org/openrewrite/gradle/RewriteResolveDependenciesTest.kt new file mode 100644 index 000000000..d18446ad3 --- /dev/null +++ b/plugin/src/test/kotlin/org/openrewrite/gradle/RewriteResolveDependenciesTest.kt @@ -0,0 +1,55 @@ +/* + * Copyright ${year} the original author or authors. + *

+ * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + *

+ * https://www.apache.org/licenses/LICENSE-2.0 + *

+ * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ +package org.openrewrite.gradle + +import org.assertj.core.api.Assertions.assertThat +import org.gradle.testkit.runner.TaskOutcome +import org.junit.jupiter.api.Test +import org.junit.jupiter.api.io.TempDir +import java.io.File + +class RewriteResolveDependenciesTest : RewritePluginTest { + @Test + fun `Specifying a rewriteVersion does not cause build failures`( + @TempDir projectDir: File + ) { + gradleProject(projectDir) { + buildGradle(""" + plugins { + id("java") + id("org.openrewrite.rewrite") + } + + repositories { + mavenLocal() + mavenCentral() + maven { + url = uri("https://oss.sonatype.org/content/repositories/snapshots") + } + } + + rewrite { + rewriteVersion = "8.6.1" + } + """) + } + + val result = runGradle(projectDir, "rewriteResolveDependencies") + val rewriteDryRunResult = result.task(":rewriteResolveDependencies")!! + assertThat(rewriteDryRunResult.outcome).isEqualTo(TaskOutcome.SUCCESS) + } + +}