Jenkins 詹金斯DSL管道问题
因此,我有一个groovy脚本,它应该是我DSL工作的种子,但我不确定在获取凭据并将它们分配给env vars时我做错了什么:Jenkins 詹金斯DSL管道问题,jenkins,jenkins-pipeline,jenkins-job-dsl,Jenkins,Jenkins Pipeline,Jenkins Job Dsl,因此,我有一个groovy脚本,它应该是我DSL工作的种子,但我不确定在获取凭据并将它们分配给env vars时我做错了什么: for(job in product_base_jobs) { pipelineJob("${job}") { definition{ cpsScm { scm { git { branches('staging')
for(job in product_base_jobs) {
pipelineJob("${job}") {
definition{
cpsScm {
scm {
git {
branches('staging')
remote {
credentials('jenkins-git')
url("git@gitty.local/${job}.git")
}
}
}
scriptPath("./Jenkinsfile")
}
triggers {
}
}
wrappers{
colorizeOutput()
timestamps()
credentialsBinding{
usernamePassword('ARTIFACTORY_USER','ARTIFACTORY_PASS','JenkinsArtifactoryCredentials')
usernamePassword('ACCESS_KEY','SECRET_KEY','Jenkins_S3')
}
}
environmentVariables{
env('ARTIFACTORY_USER',"${ARTIFACTORY_USER}")
env('ARTIFACTORY_PASS',"${ARTIFACTORY_PASS}")
env('ACCESS_KEY',"${ACCESS_KEY}")
env('SECRET_KEY',"${SECRET_KEY}")
}
}
}
我还尝试使用另一种方法,但没有成功:
credentialsBinding{
usernamePassword{
usernameVariable('ARTIFACTORY_USER')
passwordVariable('ARTIFACTORY_PASS')
credentialsId('JenkinsArtifactoryCredentials')
}
usernamePassword{
usernameVariable('ACCESS_KEY')
passwordVariable('SECRET_KEY')
credentialsId('Jenkins_S3')
}
}
environmentVariables{
env('ARTIFACTORY_USER',"${ARTIFACTORY_USER}")
env('ARTIFACTORY_PASS',"${ARTIFACTORY_PASS}")
env('ACCESS_KEY',"${ACCESS_KEY}")
env('SECRET_KEY',"${SECRET_KEY}")
}
}
以下是我得到的错误:
Processing DSL script jobs.groovy
Warning: (jobs.groovy, line 30) acceptMergeRequestOnSuccess is deprecated
Warning: (jobs.groovy, line 34) addNoteOnMergeRequest is deprecated
Warning: (jobs.groovy, line 35) addVoteOnMergeRequest is deprecated
Warning: (jobs.groovy, line 36) acceptMergeRequestOnSuccess is deprecated
ERROR: (jobs.groovy, line 50) No such property: ARTIFACTORY_USER for class: javaposse.jobdsl.dsl.helpers.toplevel.EnvironmentVariableContext
Finished: FAILURE
我正在处理的是一个bug还是一个错误的方法。通常情况下,我会使用WitchCredentials作为脚本化方式的一部分,但我希望合并许多具有许多共同点的作业。管道作业类型不支持
包装器
和环境变量
。这些方法是否可用是作业DSL中的一个问题,请参阅
不要使用作业DSL来添加凭据,而是使用jenkins文件中的管道代码来访问任何凭据。见:
node {
withCredentials([usernameColonPassword(credentialsId: 'mylogin', variable: 'USERPASS')]) {
sh '''
set +x
curl -u $USERPASS https://private.server/ > output
'''
}
}