From ed36c678b30285b135d80d73ecfca11d602cf3cf Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?G=C3=BCnther=20Grill?= Date: Wed, 28 Sep 2016 09:27:20 +0200 Subject: [PATCH] Create the correct name for images (#70) * Fix tag replacement -> too much of the name is replaces when a port is contained in the image name * Upgrade gradle to latest 2.x release --- gradle/wrapper/gradle-wrapper.properties | 2 +- .../gradle/docker/PalantirDockerPlugin.groovy | 17 ++++++++++++++--- .../docker/PalantirDockerPluginTests.groovy | 14 ++++++++++++++ 3 files changed, 29 insertions(+), 4 deletions(-) diff --git a/gradle/wrapper/gradle-wrapper.properties b/gradle/wrapper/gradle-wrapper.properties index d8ecefbc..fe28dce1 100644 --- a/gradle/wrapper/gradle-wrapper.properties +++ b/gradle/wrapper/gradle-wrapper.properties @@ -2,4 +2,4 @@ distributionBase=GRADLE_USER_HOME distributionPath=wrapper/dists zipStoreBase=GRADLE_USER_HOME zipStorePath=wrapper/dists -distributionUrl=https\://services.gradle.org/distributions/gradle-2.12-bin.zip +distributionUrl=https\://services.gradle.org/distributions/gradle-2.14.1-bin.zip diff --git a/src/main/groovy/com/palantir/gradle/docker/PalantirDockerPlugin.groovy b/src/main/groovy/com/palantir/gradle/docker/PalantirDockerPlugin.groovy index 1b46c754..f335acb1 100644 --- a/src/main/groovy/com/palantir/gradle/docker/PalantirDockerPlugin.groovy +++ b/src/main/groovy/com/palantir/gradle/docker/PalantirDockerPlugin.groovy @@ -145,11 +145,22 @@ class PalantirDockerPlugin implements Plugin { } } - private String computeName(String name, String tag) { - return name.replaceAll(":.*", "") + ":" + tag + private static String computeName(String name, String tag) { + int lastColon = name.lastIndexOf(':') + int lastSlash = name.lastIndexOf('/') + + int endIndex; + + // image_name -> this should remain + // host:port/image_name -> this should remain. + // host:port/image_name:v1 -> v1 should be replaced + if (lastColon > lastSlash) endIndex = lastColon + else endIndex = name.length() + + return name.substring(0, endIndex) + ":" + tag } - private String ucfirst(String str) { + private static String ucfirst(String str) { StringBuffer sb = new StringBuffer(str); sb.replace(0, 1, str.substring(0, 1).toUpperCase()); return sb.toString(); diff --git a/src/test/groovy/com/palantir/gradle/docker/PalantirDockerPluginTests.groovy b/src/test/groovy/com/palantir/gradle/docker/PalantirDockerPluginTests.groovy index ab9a844f..cce724e0 100644 --- a/src/test/groovy/com/palantir/gradle/docker/PalantirDockerPluginTests.groovy +++ b/src/test/groovy/com/palantir/gradle/docker/PalantirDockerPluginTests.groovy @@ -20,6 +20,7 @@ import org.gradle.api.internal.artifacts.mvnsettings.DefaultMavenFileLocations import org.gradle.api.internal.artifacts.mvnsettings.DefaultMavenSettingsProvider import org.gradle.testkit.runner.BuildResult import org.gradle.testkit.runner.TaskOutcome +import spock.lang.Unroll class PalantirDockerPluginTests extends AbstractPluginTest { @@ -417,5 +418,18 @@ class PalantirDockerPluginTests extends AbstractPluginTest { execCond("docker rmi -f ${id}") || true } + def 'check if compute name replaces the name correctly'() { + expect: + PalantirDockerPlugin.computeName(name, tag) == result + + where: + name | tag | result + "v1" | "latest" | "v1:latest" + "v1:1" | "latest" | "v1:latest" + "host/v1" | "latest" | "host/v1:latest" + "host/v1:1" | "latest" | "host/v1:latest" + "host:port/v1" | "latest" | "host:port/v1:latest" + "host:port/v1:1" | "latest" | "host:port/v1:latest" + } }