仅当另一个作业(jobA)在上次成功后失败 n 次时,我才想触发/启动作业(jobB)。我看到了这个参数化的触发器插件——但是对于触发器,你只能说“失败”,但你不能定义它是否应该在计数器失败后触发。
谢谢克里斯
仅当另一个作业(jobA)在上次成功后失败 n 次时,我才想触发/启动作业(jobB)。我看到了这个参数化的触发器插件——但是对于触发器,你只能说“失败”,但你不能定义它是否应该在计数器失败后触发。
谢谢克里斯
在这里,我的 groovy 脚本解决了这个问题。使用 g roovy-postbuild 插件在 jobA 上执行脚本。感谢伊恩 W 的意见。
import hudson.model.*
import jenkins.model.Jenkins
job_name = "jobA"
job_name_to_run = "jobB"
triggerThreshold = 2
last_succ_num = 0
last_job_num = 0
def currentBuild = Thread.currentThread().executable
def job = Hudson.instance.getJob(job_name)
def job_data = Jenkins.instance.getItemByFullName(job.fullName)
println 'Job: ' + job_data.fullName
if (job_data.getLastBuild()) {
last_job_num = job_data.getLastBuild().getNumber()
}
println 'last_job_num: ' + last_job_num
if (job_data.getLastSuccessfulBuild()) {
last_succ_num = job_data.getLastSuccessfulBuild().getNumber()
}
println 'last_succ_num: ' + last_succ_num
doRunJob =(last_job_num - last_succ_num >= triggerThreshold)
println 'do run job? ' + doRunJob
if (doRunJob){
def jobToRun = Hudson.instance.getJob(job_name_to_run)
def cause = new Cause.UpstreamCause(currentBuild)
def causeAction = new hudson.model.CauseAction(cause)
Hudson.instance.queue.schedule(jobToRun, 0, causeAction)
}