我有4个groovy脚本(其中2个是dsl.groovy脚本):
JobConfig.groovy :
class JobConfig {
final name
JobConfig(map) {
name = map['name']
}
}
topLevel.groovy :
import JobConfig.*
def doSmthWithJobConfig(final JobConfig config) {
println(config.name);
}
sublevel1.dsl.groovy :
GroovyShell shell = new GroovyShell()
def topLevelScript = shell.parse(new File("topLevel.groovy"))
def jobConfigs = [
new JobConfig(name: 'JenkinsTestDSLs'),
new JobConfig(name: 'JenkinsTestDSLs2')
]
jobConfigs.each {
topLevelScript.doSmthWithJobConfig(it);
}
sublevel2.dsl.groovy :
GroovyShell shell = new GroovyShell()
def topLevelScript = shell.parse(new File("topLevel.groovy"))
def jobConfigs = [
new JobConfig(name: 'JenkinsTestDSLs3'),
new JobConfig(name: 'JenkinsTestDSLs4')
]
jobConfigs.each {
topLevelScript.doSmthWithJobConfig(it);
}
现在,如果在本地,我会执行以下操作:
groovyc JobConfig.groovy
,我在本地运行脚本没有任何问题。
但是在jenkins上,即使我在这些脚本所在的相同位置提供JobConfig.class,也无法使其运行。我读了here,只要JobConfig.groovy在CLASSPATH上就不需要做任何编译。我如何与 Jenkins 做到这一点?还是有其他解决方案?
最佳答案
如果您不想编译groovy类,然后将已编译的类添加到类路径中,则可以在groovy脚本中使用此类,如下所示:
给定一个普通的类(class)
class GroovyClass {
def GroovyClass(someParameter) {}
def aMethod() {}
}
您可以像这样在groovy脚本中使用该类
import hudson.model.*
import java.io.File;
import jenkins.model.Jenkins;
def jenkinsRootDir = build.getEnvVars()["JENKINS_HOME"];
def parent = getClass().getClassLoader()
def loader = new GroovyClassLoader(parent)
def someParameterValue = "abc"
def groovyClass = loader.parseClass(new File(jenkinsRootDir + "/userContent/GroovyScripts/GroovyClass.groovy")).newInstance(someParameterValue)
groovyClass.aMethod()
关于jenkins - 在其他Jenkins groovy脚本中使用groovy类,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/17804812/