Skip to content

Commit

Permalink
#45 Build step
Browse files Browse the repository at this point in the history
  • Loading branch information
dcoraboeuf committed May 12, 2018
1 parent 7f84369 commit b3c96b1
Show file tree
Hide file tree
Showing 2 changed files with 52 additions and 1 deletion.
1 change: 0 additions & 1 deletion pom.xml
Expand Up @@ -106,7 +106,6 @@
<groupId>org.jenkins-ci.plugins.workflow</groupId>
<artifactId>workflow-cps</artifactId>
<version>2.19</version>
<scope>test</scope>
</dependency>
<dependency>
<groupId>org.jenkins-ci.plugins.workflow</groupId>
Expand Down
Expand Up @@ -9,11 +9,17 @@
import net.nemerosa.ontrack.dsl.Ontrack;
import net.nemerosa.ontrack.jenkins.dsl.OntrackDSLConnector;
import org.apache.commons.lang.StringUtils;
import org.jenkinsci.plugins.workflow.actions.TimingAction;
import org.jenkinsci.plugins.workflow.cps.nodes.StepStartNode;
import org.jenkinsci.plugins.workflow.graph.FlowNode;
import org.jenkinsci.plugins.workflow.steps.*;
import org.kohsuke.stapler.DataBoundConstructor;
import org.kohsuke.stapler.DataBoundSetter;

import javax.annotation.Nonnull;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
import java.util.Set;

/**
Expand Down Expand Up @@ -90,12 +96,58 @@ protected Void run() throws Exception {
if (StringUtils.isNotBlank(gitCommit)) {
ontrackBuild.getConfig().gitCommit(gitCommit);
}
// Collecting run info
Map<String, Object> runInfo = new HashMap<>();
// Gets the (current) duration of the stage
FlowNode flowNode = context.get(FlowNode.class);
if (flowNode != null) {
Long durationSeconds = getTiming(flowNode);
// TODO Cause
// TODO URL
if (durationSeconds != null) {
runInfo.put("runTime", durationSeconds);
}
}
// If not empty, send the runtime
if (!runInfo.isEmpty()) {
ontrackBuild.setRunInfo(runInfo);
}
// Done
return null;
}
};
}

// org.jenkinsci.plugins.workflow.support.steps.StageStep
protected Long getTiming(FlowNode node) {
if (node instanceof StepStartNode) {
StepStartNode stepNode = (StepStartNode) node;
StepDescriptor stepDescriptor = stepNode.getDescriptor();
if (stepDescriptor != null) {
String stepDescriptorId = stepDescriptor.getId();
if ("org.jenkinsci.plugins.workflow.support.steps.StageStep".equals(stepDescriptorId)) {
TimingAction timingAction = node.getAction(TimingAction.class);
if (timingAction != null) {
long startTime = timingAction.getStartTime();
return (System.currentTimeMillis() - startTime) / 1000;
}
}
}
}
return getTiming(node.getParents());
}

private Long getTiming(List<FlowNode> nodes) {
for (FlowNode node : nodes) {
Long durationSeconds = getTiming(node);
if (durationSeconds != null) {
return durationSeconds;
}
}
return null;
}


@Extension
public static class DescriptorImpl extends StepDescriptor {

Expand Down

0 comments on commit b3c96b1

Please sign in to comment.