2017-08-03 75 views
0

管道Groovy中的錯誤,我有我的詹金斯2.0流水線庫和自定義步驟如下問題與自定義步驟和libary

Jenkinsfile從回購X包含:

@Library('[email protected]') 

import acme.jenkins.* 

node { 
    runGradle { 
     version = '3.3' 
     cmd = '--version' 
    } 
} 

在回購Y(流水線庫回購)我有vars/runGradle.groovy含有:

import acme.jenkins.* 

def call(body) { 
    def config = [:] 
    def utils = new Utils() 

    body.resolveStrategy = Closure.DELEGATE_FIRST 
    body.delegate = config 
    body() 

    sh "${utils.getGradleBinPath(config.version)} ${config.cmd}" 
} 

同樣在回購Y我有一個包含src/acme/jenkins/Utils.groovy

package acme.jenkins 

static String getGradleBinPath(String version = null) { 
    if (!version) { 
     throw new IllegalArgumentException('No Gradle version supplied') 
    } 
    tool(version).concat('/bin/gradle') 
} 

當我運行的管道,我收到以下錯誤:

Running on master in /var/lib/jenkins/workspace/Jenkins Library Development 
[Pipeline] { 
[Pipeline] } 
[Pipeline] // node 
[Pipeline] End of Pipeline 
hudson.remoting.ProxyException: groovy.lang.MissingMethodException: No signature of method: static softvision.jenkins.Utils.tool() is applicable for argument types: (java.lang.String) values: [3.3] 
Possible solutions: wait(), run(), run(), find(), grep(), any() 
    at groovy.lang.MetaClassImpl.invokeStaticMissingMethod(MetaClassImpl.java:1506) 
    at groovy.lang.MetaClassImpl.invokeStaticMethod(MetaClassImpl.java:1492) 
    at org.codehaus.groovy.runtime.callsite.StaticMetaClassSite.call(StaticMetaClassSite.java:53) 
    at org.codehaus.groovy.runtime.callsite.CallSiteArray.defaultCall(CallSiteArray.java:48) 
    at org.codehaus.groovy.runtime.callsite.AbstractCallSite.call(AbstractCallSite.java:113) 
    at com.cloudbees.groovy.cps.sandbox.DefaultInvoker.methodCall(DefaultInvoker.java:18) 
    at softvision.jenkins.Utils.getGradleBinPath(file:/var/lib/jenkins/jobs/Jenkins%20Library%20Development/builds/89/libs/softvision-pipelines/src/softvision/jenkins/Utils.groovy:7) 
    at runGradle.call(/var/lib/jenkins/jobs/Jenkins Library Development/builds/89/libs/softvision-pipelines/vars/runGradle.groovy:11) 
    at WorkflowScript.run(WorkflowScript:6) 
    at ___cps.transform___(Native Method) 
    at com.cloudbees.groovy.cps.impl.ContinuationGroup.methodCall(ContinuationGroup.java:57) 
    at com.cloudbees.groovy.cps.impl.FunctionCallBlock$ContinuationImpl.dispatchOrArg(FunctionCallBlock.java:109) 
    at com.cloudbees.groovy.cps.impl.FunctionCallBlock$ContinuationImpl.fixArg(FunctionCallBlock.java:82) 
    at sun.reflect.GeneratedMethodAccessor273.invoke(Unknown Source) 
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) 
    at java.lang.reflect.Method.invoke(Method.java:498) 
    at com.cloudbees.groovy.cps.impl.ContinuationPtr$ContinuationImpl.receive(ContinuationPtr.java:72) 
    at com.cloudbees.groovy.cps.impl.LocalVariableBlock$LocalVariable.get(LocalVariableBlock.java:39) 
    at com.cloudbees.groovy.cps.LValueBlock$GetAdapter.receive(LValueBlock.java:30) 
    at com.cloudbees.groovy.cps.impl.LocalVariableBlock.evalLValue(LocalVariableBlock.java:28) 
    at com.cloudbees.groovy.cps.LValueBlock$BlockImpl.eval(LValueBlock.java:55) 
    at com.cloudbees.groovy.cps.LValueBlock.eval(LValueBlock.java:16) 
    at com.cloudbees.groovy.cps.Next.step(Next.java:74) 
    at com.cloudbees.groovy.cps.Continuable.run0(Continuable.java:154) 
    at org.jenkinsci.plugins.workflow.cps.SandboxContinuable.access$001(SandboxContinuable.java:18) 
    at org.jenkinsci.plugins.workflow.cps.SandboxContinuable$1.call(SandboxContinuable.java:33) 
    at org.jenkinsci.plugins.workflow.cps.SandboxContinuable$1.call(SandboxContinuable.java:30) 
    at org.jenkinsci.plugins.scriptsecurity.sandbox.groovy.GroovySandbox.runInSandbox(GroovySandbox.java:108) 
    at org.jenkinsci.plugins.workflow.cps.SandboxContinuable.run0(SandboxContinuable.java:30) 
    at org.jenkinsci.plugins.workflow.cps.CpsThread.runNextChunk(CpsThread.java:165) 
    at org.jenkinsci.plugins.workflow.cps.CpsThreadGroup.run(CpsThreadGroup.java:330) 
    at org.jenkinsci.plugins.workflow.cps.CpsThreadGroup.access$100(CpsThreadGroup.java:82) 
    at org.jenkinsci.plugins.workflow.cps.CpsThreadGroup$2.call(CpsThreadGroup.java:242) 
    at org.jenkinsci.plugins.workflow.cps.CpsThreadGroup$2.call(CpsThreadGroup.java:230) 
    at org.jenkinsci.plugins.workflow.cps.CpsVmExecutorService$2.call(CpsVmExecutorService.java:64) 
    at java.util.concurrent.FutureTask.run(FutureTask.java:266) 
    at hudson.remoting.SingleLaneExecutorService$1.run(SingleLaneExecutorService.java:112) 
    at jenkins.util.ContextResettingExecutorService$1.run(ContextResettingExecutorService.java:28) 
    at java.util.concurrent.Executors$RunnableAdapter.call(Executors.java:511) 
    at java.util.concurrent.FutureTask.run(FutureTask.java:266) 
    at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1142) 
    at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:617) 
    at java.lang.Thread.run(Thread.java:745) 
Finished: FAILURE 

這是相同的錯誤,如果我包在一個名爲UtilsgetGradleBinPath方法,用或沒有該方法的關鍵字前綴static,我在使用類版本時也試過implement Serializable,但我得到相同的錯誤。

如果我刪除腳本版本中的static關鍵字,它可以正常工作,所有示例代碼方案和上面提到的產生相同的錯誤。

我對Groovy很新,所以請原諒我,如果這與詹金斯無關,或者非常微不足道。

回答

1

無法直接在src目錄下的classes \ scripts中訪問管道標準步驟。您應該將這些步驟傳遞給構造函數/設置器或作爲方法參數。
類似的東西應該工作
src/acme/jenkins/Utils.groovy

package acme.jenkins 
class Utils implements Serializable { 

    def steps 

    Utils(steps) { 
     this.steps = steps 
    } 

    String getGradleBinPath(String version = null) { 
     if (!version) { 
      throw new IllegalArgumentException('No Gradle version supplied') 
     } 
     steps.tool(version).concat('/bin/gradle') 
    } 
} 

,然後在vars/runGradle.groovy

//.. 
def utils = new Utils(steps) 
//... 

Accessing steps

請注意steps是一個標準的全局變量,用於保存流水線步驟。

+0

不知何故,我在文檔中忽略了這一點。你的實現工作,但一個小的編輯,我還需要實現'Serializable'接口,否則我會''acme.jenkins.Utils''上的java.io.NotSerializableException異常,你可以請編輯你的答案,所以我可以將其標記爲例外? – Nicolae

+0

@Nicolae你是對的。我糾正了答案。 –

+0

作爲一個方面說明,如果有人能夠介入並解釋爲什麼沒有實現'Serializable'接口就無法工作。 – Nicolae