From 0d8e92ae550c262c590abdabeb2817cab377393e Mon Sep 17 00:00:00 2001 From: Jesse Glick Date: Mon, 26 Aug 2024 18:40:02 -0400 Subject: [PATCH 1/4] Implement `IgnoredInternalClasses` --- pipeline-model-definition/pom.xml | 7 +- .../modeldefinition/parser/InternalCalls.java | 40 +++++++++++ .../parser/InternalCallsTest.java | 71 +++++++++++++++++++ pom.xml | 9 ++- 4 files changed, 124 insertions(+), 3 deletions(-) create mode 100644 pipeline-model-definition/src/main/java/org/jenkinsci/plugins/pipeline/modeldefinition/parser/InternalCalls.java create mode 100644 pipeline-model-definition/src/test/java/org/jenkinsci/plugins/pipeline/modeldefinition/parser/InternalCallsTest.java diff --git a/pipeline-model-definition/pom.xml b/pipeline-model-definition/pom.xml index 1ed740ba7..f7a8a5f9d 100644 --- a/pipeline-model-definition/pom.xml +++ b/pipeline-model-definition/pom.xml @@ -201,7 +201,11 @@ junit test - + + org.jenkins-ci.plugins + support-core + test + org.jenkins-ci.plugins ant @@ -241,5 +245,6 @@ false + true diff --git a/pipeline-model-definition/src/main/java/org/jenkinsci/plugins/pipeline/modeldefinition/parser/InternalCalls.java b/pipeline-model-definition/src/main/java/org/jenkinsci/plugins/pipeline/modeldefinition/parser/InternalCalls.java new file mode 100644 index 000000000..e0d17e0a2 --- /dev/null +++ b/pipeline-model-definition/src/main/java/org/jenkinsci/plugins/pipeline/modeldefinition/parser/InternalCalls.java @@ -0,0 +1,40 @@ +/* + * The MIT License + * + * Copyright 2024 CloudBees, Inc. + * + * Permission is hereby granted, free of charge, to any person obtaining a copy + * of this software and associated documentation files (the "Software"), to deal + * in the Software without restriction, including without limitation the rights + * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell + * copies of the Software, and to permit persons to whom the Software is + * furnished to do so, subject to the following conditions: + * + * The above copyright notice and this permission notice shall be included in + * all copies or substantial portions of the Software. + * + * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR + * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, + * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE + * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER + * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, + * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN + * THE SOFTWARE. + */ + +package org.jenkinsci.plugins.pipeline.modeldefinition.parser; + +import hudson.Extension; +import org.jenkinsci.plugins.pipeline.modeldefinition.model.CredentialsBindingHandler; +import org.jenkinsci.plugins.pipeline.modeldefinition.withscript.WithScriptDescribable; +import org.jenkinsci.plugins.workflow.cps.IgnoredInternalClasses; + +@Extension public final class InternalCalls implements IgnoredInternalClasses { + + @Override public boolean ignore(Class clazz) { + return WithScriptDescribable.class.isAssignableFrom(clazz) || + CredentialsBindingHandler.class.isAssignableFrom(clazz) || + clazz.getName().startsWith("org.jenkinsci.plugins.pipeline.modeldefinition."); + } + +} diff --git a/pipeline-model-definition/src/test/java/org/jenkinsci/plugins/pipeline/modeldefinition/parser/InternalCallsTest.java b/pipeline-model-definition/src/test/java/org/jenkinsci/plugins/pipeline/modeldefinition/parser/InternalCallsTest.java new file mode 100644 index 000000000..d617fe868 --- /dev/null +++ b/pipeline-model-definition/src/test/java/org/jenkinsci/plugins/pipeline/modeldefinition/parser/InternalCallsTest.java @@ -0,0 +1,71 @@ +/* + * The MIT License + * + * Copyright 2024 CloudBees, Inc. + * + * Permission is hereby granted, free of charge, to any person obtaining a copy + * of this software and associated documentation files (the "Software"), to deal + * in the Software without restriction, including without limitation the rights + * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell + * copies of the Software, and to permit persons to whom the Software is + * furnished to do so, subject to the following conditions: + * + * The above copyright notice and this permission notice shall be included in + * all copies or substantial portions of the Software. + * + * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR + * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, + * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE + * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER + * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, + * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN + * THE SOFTWARE. + */ + +package org.jenkinsci.plugins.pipeline.modeldefinition.parser; + +import com.cloudbees.jenkins.support.api.Container; +import com.cloudbees.jenkins.support.api.Content; +import java.io.ByteArrayOutputStream; +import java.io.IOException; +import static org.hamcrest.MatcherAssert.assertThat; +import static org.hamcrest.Matchers.allOf; +import static org.hamcrest.Matchers.containsString; +import static org.hamcrest.Matchers.not; +import org.jenkinsci.plugins.workflow.cps.CpsFlowDefinition; +import org.jenkinsci.plugins.workflow.cps.CpsFlowExecution; +import org.jenkinsci.plugins.workflow.job.WorkflowJob; +import org.junit.Rule; +import org.junit.Test; +import org.jvnet.hudson.test.JenkinsRule; +import org.jvnet.hudson.test.RealJenkinsRule; + +public final class InternalCallsTest { + + @Rule public final RealJenkinsRule rr = new RealJenkinsRule(); +// @ClassRule public static final BuildWatcher bw = new BuildWatcher(); + + @Test public void declarative() throws Throwable { + rr.then(InternalCallsTest::_declarative); + } + + private static void _declarative(JenkinsRule r) throws Throwable { + var p = r.createProject(WorkflowJob.class, "p"); + p.setDefinition(new CpsFlowDefinition("pipeline {options {quietPeriod 0}; agent any; stages {stage('x') {steps {echo(/constructing ${new hudson.EnvVars()}/)}}}}", true)); + r.assertLogContains("constructing [:]", r.buildAndAssertSuccess(p)); + var baos = new ByteArrayOutputStream(); + new CpsFlowExecution.PipelineInternalCalls().addContents(new Container() { + @Override public void add(Content content) { + try { + content.writeTo(baos); + } catch (IOException x) { + assert false : x; + } + } + }); + assertThat(baos.toString(), allOf( + containsString("hudson.EnvVars."), + not(containsString("org.jenkinsci.plugins.pipeline.modeldefinition")))); + } + +} diff --git a/pom.xml b/pom.xml index 254f43331..d85af6a30 100644 --- a/pom.xml +++ b/pom.xml @@ -75,10 +75,15 @@ io.jenkins.tools.bom bom-2.426.x - 2675.v1515e14da_7a_6 + 3023.v02a_987a_b_3ff9 import pom + + org.jenkins-ci.plugins.workflow + workflow-cps + 999999-SNAPSHOT + org.jenkins-ci.main jenkins-test-harness-tools @@ -133,7 +138,7 @@ 999999-SNAPSHOT jenkinsci/pipeline-model-definition-plugin - 2.426.1 + 2.426.3 From cfea011baacca0abfae62f8b7cc5e792a1643987 Mon Sep 17 00:00:00 2001 From: Jesse Glick Date: Mon, 26 Aug 2024 18:48:41 -0400 Subject: [PATCH 2/4] Did not wind up needing `RealJenkinsRule` here --- .../modeldefinition/parser/InternalCallsTest.java | 11 ++++------- 1 file changed, 4 insertions(+), 7 deletions(-) diff --git a/pipeline-model-definition/src/test/java/org/jenkinsci/plugins/pipeline/modeldefinition/parser/InternalCallsTest.java b/pipeline-model-definition/src/test/java/org/jenkinsci/plugins/pipeline/modeldefinition/parser/InternalCallsTest.java index d617fe868..1fdaaf1ce 100644 --- a/pipeline-model-definition/src/test/java/org/jenkinsci/plugins/pipeline/modeldefinition/parser/InternalCallsTest.java +++ b/pipeline-model-definition/src/test/java/org/jenkinsci/plugins/pipeline/modeldefinition/parser/InternalCallsTest.java @@ -35,21 +35,18 @@ import org.jenkinsci.plugins.workflow.cps.CpsFlowDefinition; import org.jenkinsci.plugins.workflow.cps.CpsFlowExecution; import org.jenkinsci.plugins.workflow.job.WorkflowJob; +import org.junit.ClassRule; import org.junit.Rule; import org.junit.Test; +import org.jvnet.hudson.test.BuildWatcher; import org.jvnet.hudson.test.JenkinsRule; -import org.jvnet.hudson.test.RealJenkinsRule; public final class InternalCallsTest { - @Rule public final RealJenkinsRule rr = new RealJenkinsRule(); -// @ClassRule public static final BuildWatcher bw = new BuildWatcher(); + @Rule public final JenkinsRule r = new JenkinsRule(); + @ClassRule public static final BuildWatcher bw = new BuildWatcher(); @Test public void declarative() throws Throwable { - rr.then(InternalCallsTest::_declarative); - } - - private static void _declarative(JenkinsRule r) throws Throwable { var p = r.createProject(WorkflowJob.class, "p"); p.setDefinition(new CpsFlowDefinition("pipeline {options {quietPeriod 0}; agent any; stages {stage('x') {steps {echo(/constructing ${new hudson.EnvVars()}/)}}}}", true)); r.assertLogContains("constructing [:]", r.buildAndAssertSuccess(p)); From 843cead6e679b7f4943ece9cfd72e62f63994ebe Mon Sep 17 00:00:00 2001 From: Jesse Glick Date: Mon, 26 Aug 2024 19:38:40 -0400 Subject: [PATCH 3/4] Incremental deployment --- pom.xml | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/pom.xml b/pom.xml index d85af6a30..ed130c321 100644 --- a/pom.xml +++ b/pom.xml @@ -79,10 +79,11 @@ import pom + org.jenkins-ci.plugins.workflow workflow-cps - 999999-SNAPSHOT + 3950.v9dfcb_0544a_5d org.jenkins-ci.main From f9c2c7789d10477e77ffdbb43c1b494e010b8b98 Mon Sep 17 00:00:00 2001 From: Jesse Glick Date: Tue, 27 Aug 2024 19:07:57 -0400 Subject: [PATCH 4/4] https://github.com/jenkinsci/workflow-cps-plugin/pull/929 released --- pom.xml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/pom.xml b/pom.xml index ed130c321..95451c8cf 100644 --- a/pom.xml +++ b/pom.xml @@ -83,7 +83,7 @@ org.jenkins-ci.plugins.workflow workflow-cps - 3950.v9dfcb_0544a_5d + 3953.v19f11da_8d2fa_ org.jenkins-ci.main