From 52317866bae96374605be4f4686a864da8875b22 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?St=C3=A9phane=20Nicoll?= Date: Mon, 29 Jul 2024 15:36:57 +0200 Subject: [PATCH] Hacking --- .../boot/maven/BuildImageMojo.java | 4 +- .../springframework/boot/maven/Docker.java | 10 +++-- .../boot/maven/DockerTests.java | 44 +++++++++++++------ 3 files changed, 40 insertions(+), 18 deletions(-) diff --git a/spring-boot-project/spring-boot-tools/spring-boot-maven-plugin/src/main/java/org/springframework/boot/maven/BuildImageMojo.java b/spring-boot-project/spring-boot-tools/spring-boot-maven-plugin/src/main/java/org/springframework/boot/maven/BuildImageMojo.java index 79b62bf53030..223b2c76a0e6 100644 --- a/spring-boot-project/spring-boot-tools/spring-boot-maven-plugin/src/main/java/org/springframework/boot/maven/BuildImageMojo.java +++ b/spring-boot-project/spring-boot-tools/spring-boot-maven-plugin/src/main/java/org/springframework/boot/maven/BuildImageMojo.java @@ -246,9 +246,9 @@ public void execute() throws MojoExecutionException { private void buildImage() throws MojoExecutionException { Libraries libraries = getLibraries(Collections.emptySet()); try { - DockerConfiguration dockerConfiguration = (this.docker != null) ? this.docker.asDockerConfiguration() - : new Docker().asDockerConfiguration(); BuildRequest request = getBuildRequest(libraries); + DockerConfiguration dockerConfiguration = (this.docker != null) ? this.docker.asDockerConfiguration(request.isPublish()) + : new Docker().asDockerConfiguration(request.isPublish()); Builder builder = new Builder(new MojoBuildLog(this::getLog), dockerConfiguration); builder.build(request); } diff --git a/spring-boot-project/spring-boot-tools/spring-boot-maven-plugin/src/main/java/org/springframework/boot/maven/Docker.java b/spring-boot-project/spring-boot-tools/spring-boot-maven-plugin/src/main/java/org/springframework/boot/maven/Docker.java index 53618609d4d7..437812bf51db 100644 --- a/spring-boot-project/spring-boot-tools/spring-boot-maven-plugin/src/main/java/org/springframework/boot/maven/Docker.java +++ b/spring-boot-project/spring-boot-tools/spring-boot-maven-plugin/src/main/java/org/springframework/boot/maven/Docker.java @@ -140,14 +140,15 @@ void setPublishRegistry(DockerRegistry builderRegistry) { * Returns this configuration as a {@link DockerConfiguration} instance. This method * should only be called when the configuration is complete and will no longer be * changed. + * @param publish whether the image should be published * @return the Docker configuration */ - DockerConfiguration asDockerConfiguration() { + DockerConfiguration asDockerConfiguration(boolean publish) { DockerConfiguration dockerConfiguration = new DockerConfiguration(); dockerConfiguration = customizeHost(dockerConfiguration); dockerConfiguration = dockerConfiguration.withBindHostToBuilder(this.bindHostToBuilder); dockerConfiguration = customizeBuilderAuthentication(dockerConfiguration); - dockerConfiguration = customizePublishAuthentication(dockerConfiguration); + dockerConfiguration = customizePublishAuthentication(dockerConfiguration, publish); return dockerConfiguration; } @@ -180,7 +181,10 @@ private DockerConfiguration customizeBuilderAuthentication(DockerConfiguration d "Invalid Docker builder registry configuration, either token or username/password must be provided"); } - private DockerConfiguration customizePublishAuthentication(DockerConfiguration dockerConfiguration) { + private DockerConfiguration customizePublishAuthentication(DockerConfiguration dockerConfiguration, boolean publish) { + if (!publish) { + return dockerConfiguration; + } if (this.publishRegistry == null || this.publishRegistry.isEmpty()) { return dockerConfiguration.withEmptyPublishRegistryAuthentication(); } diff --git a/spring-boot-project/spring-boot-tools/spring-boot-maven-plugin/src/test/java/org/springframework/boot/maven/DockerTests.java b/spring-boot-project/spring-boot-tools/spring-boot-maven-plugin/src/test/java/org/springframework/boot/maven/DockerTests.java index f2258b915dc3..00a96126b603 100644 --- a/spring-boot-project/spring-boot-tools/spring-boot-maven-plugin/src/test/java/org/springframework/boot/maven/DockerTests.java +++ b/spring-boot-project/spring-boot-tools/spring-boot-maven-plugin/src/test/java/org/springframework/boot/maven/DockerTests.java @@ -25,6 +25,7 @@ import static org.assertj.core.api.Assertions.assertThat; import static org.assertj.core.api.Assertions.assertThatIllegalArgumentException; +import static org.assertj.core.api.Assertions.assertThatNoException; /** * Tests for {@link Docker}. @@ -37,7 +38,7 @@ class DockerTests { @Test void asDockerConfigurationWithDefaults() { Docker docker = new Docker(); - DockerConfiguration dockerConfiguration = docker.asDockerConfiguration(); + DockerConfiguration dockerConfiguration = createDockerConfiguration(docker); assertThat(dockerConfiguration.getHost()).isNull(); assertThat(dockerConfiguration.getBuilderRegistryAuthentication()).isNull(); assertThat(decoded(dockerConfiguration.getPublishRegistryAuthentication().getAuthHeader())) @@ -53,14 +54,14 @@ void asDockerConfigurationWithHostConfiguration() { docker.setHost("docker.example.com"); docker.setTlsVerify(true); docker.setCertPath("/tmp/ca-cert"); - DockerConfiguration dockerConfiguration = docker.asDockerConfiguration(); + DockerConfiguration dockerConfiguration = createDockerConfiguration(docker); DockerHostConfiguration host = dockerConfiguration.getHost(); assertThat(host.getAddress()).isEqualTo("docker.example.com"); assertThat(host.isSecure()).isTrue(); assertThat(host.getCertificatePath()).isEqualTo("/tmp/ca-cert"); assertThat(host.getContext()).isNull(); assertThat(dockerConfiguration.isBindHostToBuilder()).isFalse(); - assertThat(docker.asDockerConfiguration().getBuilderRegistryAuthentication()).isNull(); + assertThat(createDockerConfiguration(docker).getBuilderRegistryAuthentication()).isNull(); assertThat(decoded(dockerConfiguration.getPublishRegistryAuthentication().getAuthHeader())) .contains("\"username\" : \"\"") .contains("\"password\" : \"\"") @@ -72,14 +73,14 @@ void asDockerConfigurationWithHostConfiguration() { void asDockerConfigurationWithContextConfiguration() { Docker docker = new Docker(); docker.setContext("test-context"); - DockerConfiguration dockerConfiguration = docker.asDockerConfiguration(); + DockerConfiguration dockerConfiguration = createDockerConfiguration(docker); DockerHostConfiguration host = dockerConfiguration.getHost(); assertThat(host.getContext()).isEqualTo("test-context"); assertThat(host.getAddress()).isNull(); assertThat(host.isSecure()).isFalse(); assertThat(host.getCertificatePath()).isNull(); assertThat(dockerConfiguration.isBindHostToBuilder()).isFalse(); - assertThat(docker.asDockerConfiguration().getBuilderRegistryAuthentication()).isNull(); + assertThat(createDockerConfiguration(docker).getBuilderRegistryAuthentication()).isNull(); assertThat(decoded(dockerConfiguration.getPublishRegistryAuthentication().getAuthHeader())) .contains("\"username\" : \"\"") .contains("\"password\" : \"\"") @@ -92,7 +93,7 @@ void asDockerConfigurationWithHostAndContextFails() { Docker docker = new Docker(); docker.setContext("test-context"); docker.setHost("docker.example.com"); - assertThatIllegalArgumentException().isThrownBy(docker::asDockerConfiguration) + assertThatIllegalArgumentException().isThrownBy(() -> createDockerConfiguration(docker)) .withMessageContaining("Invalid Docker configuration"); } @@ -103,13 +104,13 @@ void asDockerConfigurationWithBindHostToBuilder() { docker.setTlsVerify(true); docker.setCertPath("/tmp/ca-cert"); docker.setBindHostToBuilder(true); - DockerConfiguration dockerConfiguration = docker.asDockerConfiguration(); + DockerConfiguration dockerConfiguration = createDockerConfiguration(docker); DockerHostConfiguration host = dockerConfiguration.getHost(); assertThat(host.getAddress()).isEqualTo("docker.example.com"); assertThat(host.isSecure()).isTrue(); assertThat(host.getCertificatePath()).isEqualTo("/tmp/ca-cert"); assertThat(dockerConfiguration.isBindHostToBuilder()).isTrue(); - assertThat(docker.asDockerConfiguration().getBuilderRegistryAuthentication()).isNull(); + assertThat(createDockerConfiguration(docker).getBuilderRegistryAuthentication()).isNull(); assertThat(decoded(dockerConfiguration.getPublishRegistryAuthentication().getAuthHeader())) .contains("\"username\" : \"\"") .contains("\"password\" : \"\"") @@ -124,7 +125,7 @@ void asDockerConfigurationWithUserAuth() { new Docker.DockerRegistry("user1", "secret1", "https://docker1.example.com", "docker1@example.com")); docker.setPublishRegistry( new Docker.DockerRegistry("user2", "secret2", "https://docker2.example.com", "docker2@example.com")); - DockerConfiguration dockerConfiguration = docker.asDockerConfiguration(); + DockerConfiguration dockerConfiguration = createDockerConfiguration(docker); assertThat(decoded(dockerConfiguration.getBuilderRegistryAuthentication().getAuthHeader())) .contains("\"username\" : \"user1\"") .contains("\"password\" : \"secret1\"") @@ -142,7 +143,7 @@ void asDockerConfigurationWithIncompleteBuilderUserAuthFails() { Docker docker = new Docker(); docker.setBuilderRegistry( new Docker.DockerRegistry("user", null, "https://docker.example.com", "docker@example.com")); - assertThatIllegalArgumentException().isThrownBy(docker::asDockerConfiguration) + assertThatIllegalArgumentException().isThrownBy(() -> createDockerConfiguration(docker)) .withMessageContaining("Invalid Docker builder registry configuration"); } @@ -151,7 +152,7 @@ void asDockerConfigurationWithIncompletePublishUserAuthFails() { Docker docker = new Docker(); docker.setPublishRegistry( new Docker.DockerRegistry("user", null, "https://docker.example.com", "docker@example.com")); - assertThatIllegalArgumentException().isThrownBy(docker::asDockerConfiguration) + assertThatIllegalArgumentException().isThrownBy(() -> createDockerConfiguration(docker)) .withMessageContaining("Invalid Docker publish registry configuration"); } @@ -160,7 +161,7 @@ void asDockerConfigurationWithTokenAuth() { Docker docker = new Docker(); docker.setBuilderRegistry(new Docker.DockerRegistry("token1")); docker.setPublishRegistry(new Docker.DockerRegistry("token2")); - DockerConfiguration dockerConfiguration = docker.asDockerConfiguration(); + DockerConfiguration dockerConfiguration = createDockerConfiguration(docker); assertThat(decoded(dockerConfiguration.getBuilderRegistryAuthentication().getAuthHeader())) .contains("\"identitytoken\" : \"token1\""); assertThat(decoded(dockerConfiguration.getPublishRegistryAuthentication().getAuthHeader())) @@ -175,10 +176,27 @@ void asDockerConfigurationWithUserAndTokenAuthFails() { dockerRegistry.setToken("token"); Docker docker = new Docker(); docker.setBuilderRegistry(dockerRegistry); - assertThatIllegalArgumentException().isThrownBy(docker::asDockerConfiguration) + assertThatIllegalArgumentException().isThrownBy(() -> createDockerConfiguration(docker)) .withMessageContaining("Invalid Docker builder registry configuration"); } + @Test + void asDockerConfigurationWithUserAndTokenAuthDoesNotFailIfPublishingIsDisabled() { + Docker.DockerRegistry dockerRegistry = new Docker.DockerRegistry(); + dockerRegistry.setUsername("user"); + dockerRegistry.setPassword("secret"); + dockerRegistry.setToken("token"); + Docker docker = new Docker(); + docker.setPublishRegistry(dockerRegistry); + DockerConfiguration dockerConfiguration = docker.asDockerConfiguration(false); + assertThat(dockerConfiguration.getPublishRegistryAuthentication()).isNull(); + } + + private DockerConfiguration createDockerConfiguration(Docker docker) { + return docker.asDockerConfiguration(true); + + } + String decoded(String value) { return new String(Base64.getDecoder().decode(value)); }