From 36ca27d2438317680c01571775102dbb4c185ea9 Mon Sep 17 00:00:00 2001 From: Olivier Lamy Date: Wed, 13 Sep 2023 16:06:26 +1000 Subject: [PATCH] JENKINS-71949 : restore Java 6/7/8 compatibility (#703) * restore 8 compilation Signed-off-by: Olivier Lamy * Add test to be sure it works with jdk8, build on a remote node using jdk8 Signed-off-by: Olivier Lamy * test for multiple jdks Signed-off-by: Olivier Lamy * add Issue annotation Signed-off-by: Olivier Lamy * add some debug for ci.jenkins.io Signed-off-by: Olivier Lamy * force file permission in the container Signed-off-by: Olivier Lamy * remove ls debug Signed-off-by: Olivier Lamy * back to 6 as it looks important to have different lines in a release notes saying the opposite.... Signed-off-by: Olivier Lamy --------- Signed-off-by: Olivier Lamy --- .../pipeline/maven/WithMavenStepTest.java | 51 ++++++++++++++++++- .../maven/docker/JavaGitContainer/Dockerfile | 3 ++ maven-spy/pom.xml | 3 +- 3 files changed, 54 insertions(+), 3 deletions(-) diff --git a/jenkins-plugin/src/test/java/org/jenkinsci/plugins/pipeline/maven/WithMavenStepTest.java b/jenkins-plugin/src/test/java/org/jenkinsci/plugins/pipeline/maven/WithMavenStepTest.java index 73864f0f..409bbf05 100644 --- a/jenkins-plugin/src/test/java/org/jenkinsci/plugins/pipeline/maven/WithMavenStepTest.java +++ b/jenkins-plugin/src/test/java/org/jenkinsci/plugins/pipeline/maven/WithMavenStepTest.java @@ -24,16 +24,25 @@ package org.jenkinsci.plugins.pipeline.maven; import static org.assertj.core.api.Assertions.assertThat; +import static org.junit.jupiter.params.provider.Arguments.arguments; import java.io.File; import java.nio.charset.StandardCharsets; +import java.util.Collection; import java.util.Collections; +import java.util.Objects; +import java.util.stream.Stream; +import hudson.model.JDK; +import hudson.tools.ToolLocationNodeProperty; import org.apache.commons.io.FileUtils; import org.jenkinsci.plugins.workflow.cps.CpsFlowDefinition; import org.jenkinsci.plugins.workflow.job.WorkflowJob; import org.jenkinsci.plugins.workflow.job.WorkflowRun; import org.junit.jupiter.api.Test; +import org.junit.jupiter.params.ParameterizedTest; +import org.junit.jupiter.params.provider.Arguments; +import org.junit.jupiter.params.provider.MethodSource; import org.jvnet.hudson.test.Issue; import org.testcontainers.containers.GenericContainer; @@ -49,6 +58,7 @@ import hudson.plugins.sshslaves.SSHLauncher; import hudson.slaves.DumbSlave; import hudson.slaves.RetentionStrategy; +import org.testcontainers.utility.MountableFile; public class WithMavenStepTest extends AbstractIntegrationTest { @@ -96,6 +106,46 @@ public void testDisableAllPublishers() throws Exception { assertFingerprintDoesNotExist(COMMONS_LANG3_FINGERPRINT); } + // the jdk path is configured in Dockerfile + private static Stream jdkMapProvider() { + return Stream.of( + arguments("jdk8", "/opt/java/jdk8"), + arguments("jdk11", "/opt/java/jdk11") + ); + } + + @ParameterizedTest + @MethodSource("jdkMapProvider") + @Issue("JENKINS-71949") + public void tesWithDifferentJavasForBuild(String jdkName, String jdkPath) throws Exception { + loadMonoDependencyMavenProjectInGitRepo(this.gitRepoRule); + String gitRepoPath = this.gitRepoRule.toString(); + javaGitContainerRule.copyFileToContainer(MountableFile.forHostPath(gitRepoPath), "/tmp/gitrepo"); + javaGitContainerRule.execInContainer("chmod", "-R", "777", "/tmp/gitrepo"); + registerAgentForContainer(javaGitContainerRule); + ToolLocationNodeProperty.ToolLocation toolLocation = + new ToolLocationNodeProperty.ToolLocation(new JDK.DescriptorImpl(), jdkName, jdkPath); + ToolLocationNodeProperty toolLocationNodeProperty = new ToolLocationNodeProperty(toolLocation); + Objects.requireNonNull(jenkinsRule.jenkins.getNode(AGENT_NAME)).getNodeProperties().add(toolLocationNodeProperty); + + jenkinsRule.jenkins.getJDKs().add(new JDK(jdkName, jdkPath)); + + //@formatter:off + WorkflowRun run = runPipeline(Result.SUCCESS, + "node('" + AGENT_NAME + "') {\n" + + " git('/tmp/gitrepo')\n" + + " withMaven(jdk: '" + jdkName + "') {\n" + + " sh 'mvn package'\n" + + " }\n" + + "}"); + //@formatter:on + jenkinsRule.assertLogContains("artifactsPublisher - Archive artifact target/mono-dependency-maven-project-0.1-SNAPSHOT.jar", run); + + Collection archives = run.pickArtifactManager().root().list("**/**.jar", "", true); + assertThat(archives).hasSize(1); + assertThat(archives.iterator().next().endsWith("mono-dependency-maven-project-0.1-SNAPSHOT.jar")).isTrue(); + } + private WorkflowRun runPipeline(Result expectedResult, String pipelineScript) throws Exception { WorkflowJob p = jenkinsRule.createProject(WorkflowJob.class, "project"); p.setDefinition(new CpsFlowDefinition(pipelineScript, true)); @@ -126,7 +176,6 @@ private void registerAgentForSlaveContainer(GenericContainer slaveContainer) DumbSlave agent = new DumbSlave(AGENT_NAME, SLAVE_BASE_PATH, sshLauncher); agent.setNumExecutors(1); agent.setRetentionStrategy(RetentionStrategy.INSTANCE); - jenkinsRule.jenkins.addNode(agent); } diff --git a/jenkins-plugin/src/test/resources/org/jenkinsci/plugins/pipeline/maven/docker/JavaGitContainer/Dockerfile b/jenkins-plugin/src/test/resources/org/jenkinsci/plugins/pipeline/maven/docker/JavaGitContainer/Dockerfile index 715d69f9..9629e69b 100644 --- a/jenkins-plugin/src/test/resources/org/jenkinsci/plugins/pipeline/maven/docker/JavaGitContainer/Dockerfile +++ b/jenkins-plugin/src/test/resources/org/jenkinsci/plugins/pipeline/maven/docker/JavaGitContainer/Dockerfile @@ -34,6 +34,9 @@ RUN sed -i -e 's/# en_US.UTF-8 UTF-8/en_US.UTF-8 UTF-8/' /etc/locale.gen && \ update-locale LANG=en_US.UTF-8 ENV LANG en_US.UTF-8 +COPY --from=eclipse-temurin:8u345-b01-jdk /opt/java/openjdk /opt/java/jdk8 +COPY --from=eclipse-temurin:11.0.16.1_1-jdk /opt/java/openjdk /opt/java/jdk11 + # run SSHD in the foreground with error messages to stderr ENTRYPOINT ["/usr/sbin/sshd", "-D", "-e"] diff --git a/maven-spy/pom.xml b/maven-spy/pom.xml index 5e4c11a4..2bce893c 100644 --- a/maven-spy/pom.xml +++ b/maven-spy/pom.xml @@ -67,8 +67,7 @@ org.apache.maven.plugins maven-compiler-plugin - 1.6 - 1.6 + 6