vel*_*sim 6 groovy hudson jenkins jenkins-workflow jenkins-pipeline
我有一个不同阶段的管道.我希望当前的作业检查前一个版本中已经传递了多少个阶段并将其记录在控制台中?
考虑这是我目前的管道
node(){
stage "1"
do something
stage "2"
do something else
}
Run Code Online (Sandbox Code Playgroud)
我想要一个时髦的脚本给我这样的东西
println currentBuild.previousBuild.getStage("1").result
Run Code Online (Sandbox Code Playgroud)
我的代码的目的是跟踪我的构建中不同阶段的成功与失败.这种方法有其他替代方案吗?
您可以迭代构建的所有阶段并执行您需要的操作:
WorkflowRun run = Jenkins.instance.getItemByFullName("####YOUR_JOB_NAME####")._getRuns()[0]
FlowExecution exec = run.getExecution()
PipelineNodeGraphVisitor visitor = new PipelineNodeGraphVisitor(run)
def flowNodes = visitor.getPipelineNodes()
for (Iterator iterator = flowNodes.iterator(); iterator.hasNext();)
{
def node = iterator.next()
if (node.getType() == FlowNodeWrapper.NodeType.STAGE)
{
String stageName = node.getDisplayName()
def stageResult = node.getStatus().getResult()
println "Result of stage ${stageName} is ${stageResult}"
}
}
Run Code Online (Sandbox Code Playgroud)
你肯定可以使用Pipeline REST API插件,对我来说它是开箱即用的Jenkins 2.13.
通过解析生成的JSON,您可以获得与您期望的类似的舞台状态.对于api调用,我个人使用http_request插件.
从文档GET/job /:job-name /:run-id/wfapi/describe返回:
{
"_links": {
"self": {
"href": "/jenkins/job/Test%20Workflow/16/wfapi/describe"
},
"pendingInputActions": {
"href": "/jenkins/job/Test%20Workflow/16/wfapi/pendingInputActions"
}
},
"id": "2014-10-16_13-07-52",
"name": "#16",
"status": "PAUSED_PENDING_INPUT",
"startTimeMillis": 1413461275770,
"endTimeMillis": 1413461285999,
"durationMillis": 10229,
"stages": [
{
"_links": {
"self": {
"href": "/jenkins/job/Test%20Workflow/16/execution/node/5/wfapi/describe"
}
},
"id": "5",
"name": "Build",
"status": "SUCCESS",
"startTimeMillis": 1413461275770,
"durationMillis": 5228
},
{
"_links": {
"self": {
"href": "/jenkins/job/Test%20Workflow/16/execution/node/8/wfapi/describe"
}
},
"id": "8",
"name": "Test",
"status": "SUCCESS",
"startTimeMillis": 1413461280998,
"durationMillis": 4994
},
{
"_links": {
"self": {
"href": "/jenkins/job/Test%20Workflow/16/execution/node/10/wfapi/describe"
}
},
"id": "10",
"name": "Deploy",
"status": "PAUSED_PENDING_INPUT",
"startTimeMillis": 1413461285992,
"durationMillis": 7
}
]
}
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
5185 次 |
| 最近记录: |