1 <?xml version="1.0" encoding="utf-8"?>
5 <description><!-- Managed by Jenkins Job Builder --></description>
6 <keepDependencies>false</keepDependencies>
7 <blockBuildWhenDownstreamBuilding>false</blockBuildWhenDownstreamBuilding>
8 <blockBuildWhenUpstreamBuilding>false</blockBuildWhenUpstreamBuilding>
9 <concurrentBuild>false</concurrentBuild>
10 <assignedNode>build-vm</assignedNode>
11 <canRoam>false</canRoam>
13 <com.coravy.hudson.plugins.github.GithubProjectProperty>
14 <projectUrl>$GIT_URL/$PROJECT/example-org/releng/ciman</projectUrl>
15 </com.coravy.hudson.plugins.github.GithubProjectProperty>
16 <hudson.model.ParametersDefinitionProperty>
17 <parameterDefinitions>
18 <hudson.model.StringParameterDefinition>
20 <description>Parameter to identify a Gerrit project. This is typically the
21 project repo path as exists in Gerrit.
22 For example: ofextensions/circuitsw
24 <defaultValue>releng/ciman</defaultValue>
25 </hudson.model.StringParameterDefinition>
26 <hudson.model.StringParameterDefinition>
28 <description>Stream is often set to the same name as 'branch' but can
29 sometimes be used as a name representing a project's release code
32 <defaultValue>master</defaultValue>
33 </hudson.model.StringParameterDefinition>
34 <hudson.model.StringParameterDefinition>
35 <name>GERRIT_PROJECT</name>
36 <description>Parameter to identify Gerrit project. This is typically the
37 project repo path as exists in Gerrit.
38 For example: ofextensions/circuitsw
40 Note that Gerrit will override this parameter automatically if a
41 job is triggered by Gerrit.
43 <defaultValue>releng/ciman</defaultValue>
44 </hudson.model.StringParameterDefinition>
45 <hudson.model.StringParameterDefinition>
46 <name>GERRIT_BRANCH</name>
47 <description>Parameter to identify a Gerrit branch.
49 Note that Gerrit will override this parameter automatically if a
50 job is triggered by Gerrit.
52 <defaultValue>master</defaultValue>
53 </hudson.model.StringParameterDefinition>
54 <hudson.model.StringParameterDefinition>
55 <name>GERRIT_REFSPEC</name>
56 <description>Parameter to identify a refspec when pulling from Gerrit.
58 Note that Gerrit will override this parameter automatically if a
59 job is triggered by Gerrit.
62 </hudson.model.StringParameterDefinition>
63 <hudson.model.StringParameterDefinition>
64 <name>MAVEN_OPTS</name>
65 <description>Maven Java opts. Example: -Xmx1024m -XX:MaxPermSize=256m
68 </hudson.model.StringParameterDefinition>
69 <hudson.model.StringParameterDefinition>
70 <name>MAVEN_PARAMS</name>
71 <description>Maven parameters to pass to the mvn command.
74 </hudson.model.StringParameterDefinition>
75 <hudson.model.StringParameterDefinition>
77 <description>Maven selector to be used by shell scripts</description>
78 <defaultValue>/w/tools/hudson.tasks.Maven_MavenInstallation/mvn33/bin/mvn</defaultValue>
79 </hudson.model.StringParameterDefinition>
80 <hudson.model.StringParameterDefinition>
81 <name>STAGING_PROFILE_ID</name>
82 <description>Nexus staging profile ID.
84 <defaultValue>uuddlrlrba</defaultValue>
85 </hudson.model.StringParameterDefinition>
86 </parameterDefinitions>
87 </hudson.model.ParametersDefinitionProperty>
89 <scm class="hudson.plugins.git.GitSCM">
90 <configVersion>2</configVersion>
92 <hudson.plugins.git.UserRemoteConfig>
94 <refspec>+refs/pull/*:refs/remotes/origin/pr/*</refspec>
95 <url>git@github.com:example-org/releng/ciman</url>
96 <credentialsId>test-credential</credentialsId>
97 </hudson.plugins.git.UserRemoteConfig>
100 <hudson.plugins.git.BranchSpec>
102 </hudson.plugins.git.BranchSpec>
105 <buildChooser class="hudson.plugins.git.util.DefaultBuildChooser"/>
106 <doGenerateSubmoduleConfigurations>false</doGenerateSubmoduleConfigurations>
107 <authorOrCommitter>false</authorOrCommitter>
108 <wipeOutWorkspace>true</wipeOutWorkspace>
109 <pruneBranches>false</pruneBranches>
110 <remotePoll>false</remotePoll>
111 <gitTool>Default</gitTool>
112 <submoduleCfg class="list"/>
117 <skipTag>true</skipTag>
119 <useShallowClone>false</useShallowClone>
120 <ignoreNotifyCommit>false</ignoreNotifyCommit>
122 <hudson.plugins.git.extensions.impl.SubmoduleOption>
123 <disableSubmodules>false</disableSubmodules>
124 <recursiveSubmodules>true</recursiveSubmodules>
125 <trackingSubmodules>false</trackingSubmodules>
127 <timeout>10</timeout>
128 </hudson.plugins.git.extensions.impl.SubmoduleOption>
129 <hudson.plugins.git.extensions.impl.WipeWorkspace/>
134 <command>mkdir -p $WORKSPACE/target/classes $WORKSPACE/jacoco/classes</command>
135 </hudson.tasks.Shell>
137 <command>echo "quiet=on" > "$HOME/.wgetrc"</command>
138 </hudson.tasks.Shell>
140 <targets>--version</targets>
142 <mavenName>mvn33</mavenName>
143 <usePrivateRepository>false</usePrivateRepository>
144 <settings class="jenkins.mvn.DefaultSettingsProvider"/>
145 <globalSettings class="jenkins.mvn.DefaultGlobalSettingsProvider"/>
146 </hudson.tasks.Maven>
148 <command>rm "$HOME/.wgetrc"</command>
149 </hudson.tasks.Shell>
150 <org.jenkinsci.plugins.configfiles.builder.ConfigFileBuildStep plugin="config-file-provider">
152 <org.jenkinsci.plugins.configfiles.buildwrapper.ManagedFile>
153 <fileId>global-settings</fileId>
155 <variable>GLOBAL_SETTINGS_FILE</variable>
156 </org.jenkinsci.plugins.configfiles.buildwrapper.ManagedFile>
157 <org.jenkinsci.plugins.configfiles.buildwrapper.ManagedFile>
158 <fileId>aproject-settings</fileId>
160 <variable>SETTINGS_FILE</variable>
161 </org.jenkinsci.plugins.configfiles.buildwrapper.ManagedFile>
163 </org.jenkinsci.plugins.configfiles.builder.ConfigFileBuildStep>
166 <propertiesContent>SERVER_ID=opendaylight-staging</propertiesContent>
171 # SPDX-License-Identifier: EPL-1.0
172 ##############################################################################
173 # Copyright (c) 2017 The Linux Foundation and others.
175 # All rights reserved. This program and the accompanying materials
176 # are made available under the terms of the Eclipse Public License v1.0
177 # which accompanies this distribution, and is available at
178 # http://www.eclipse.org/legal/epl-v10.html
179 ##############################################################################
180 echo "---> create-netrc.sh"
182 # Ensure we fail the job if any steps fail.
185 NEXUS_URL="${NEXUS_URL:-$NEXUSPROXY}"
186 CREDENTIAL=$(xmlstarlet sel -N "x=http://maven.apache.org/SETTINGS/1.0.0" \
187 -t -m "/x:settings/x:servers/x:server[x:id='${SERVER_ID}']" \
188 -v x:username -o ":" -v x:password \
189 "$SETTINGS_FILE")
191 machine=$(echo "$NEXUS_URL" | awk -F/ '{print $3}')
192 user=$(echo "$CREDENTIAL" | cut -f1 -d:)
193 pass=$(echo "$CREDENTIAL" | cut -f2 -d:)
195 echo "machine $machine login $user password $pass" > ~/.netrc
197 </hudson.tasks.Shell>
200 # SPDX-License-Identifier: EPL-1.0
201 ##############################################################################
202 # Copyright (c) 2017 The Linux Foundation and others.
204 # All rights reserved. This program and the accompanying materials
205 # are made available under the terms of the Eclipse Public License v1.0
206 # which accompanies this distribution, and is available at
207 # http://www.eclipse.org/legal/epl-v10.html
208 ##############################################################################
209 echo "---> lftools-install.sh"
211 # By default a released version of lftools should always be used.
212 # The purpose of the 2 variables below is so that lftools devs can test
213 # unreleased versions of lftools. There are 2 methods to install a dev version
216 # 1) gerrit patch: Used to test a patch that has not yet been merged.
217 # To do this set something like this:
218 # LFTOOLS_MODE=gerrit
219 # LFTOOLS_REFSPEC=refs/changes/96/5296/7
221 # 2) git branch: Used to install an lftools version from a specific branch.
222 # To use this set the variables as follows:
224 # LFTOOLS_REFSPEC=master
226 # 3) release : The intended use case and default setting.
227 # Set LFTOOLS_MODE=release, in this case LFTOOLS_REFSPEC is unused.
229 LFTOOLS_MODE=release # release | git | gerrit
230 LFTOOLS_REFSPEC=master
232 # Ensure we fail the job if any steps fail.
233 # DO NOT set -u as virtualenv's activate script has unbound variables
236 virtualenv --quiet "/tmp/v/lftools"
237 # shellcheck source=/tmp/v/lftools/bin/activate disable=SC1091
238 source "/tmp/v/lftools/bin/activate"
239 pip install --quiet --upgrade pip
241 case $LFTOOLS_MODE in
243 git clone https://gerrit.linuxfoundation.org/infra/releng/lftools.git /tmp/lftools
245 git fetch origin "$LFTOOLS_REFSPEC"
246 git checkout FETCH_HEAD
247 pip install --quiet --upgrade -r requirements.txt
248 pip install --quiet --upgrade -e .
253 pip install --quiet --upgrade git+https://gerrit.linuxfoundation.org/infra/releng/lftools.git@"$BRANCH"
257 pip install --quiet --upgrade "lftools<1.0.0"
261 # pipdeptree prints out a lot of information because lftools pulls in many
262 # dependencies. Let's only print it if we want to debug.
263 # echo "----> Pip Dependency Tree"
264 # pip install --quiet --upgrade pipdeptree
268 # SPDX-License-Identifier: EPL-1.0
269 ##############################################################################
270 # Copyright (c) 2017 The Linux Foundation and others.
272 # All rights reserved. This program and the accompanying materials
273 # are made available under the terms of the Eclipse Public License v1.0
274 # which accompanies this distribution, and is available at
275 # http://www.eclipse.org/legal/epl-v10.html
276 ##############################################################################
278 # This file contains a list of variables that are generally useful in many
279 # scripts. It is meant to be sourced in other scripts so that the variables can
282 MAVEN_OPTIONS="$(echo --show-version \
285 -Dorg.slf4j.simpleLogger.log.org.apache.maven.cli.transfer.Slf4jMavenTransferListener=warn \
286 -Dmaven.repo.local=/tmp/r \
287 -Dorg.ops4j.pax.url.mvn.localRepository=/tmp/r)"
288 echo "$MAVEN_OPTIONS"
291 # SPDX-License-Identifier: EPL-1.0
292 ##############################################################################
293 # Copyright (c) 2017 The Linux Foundation and others.
295 # All rights reserved. This program and the accompanying materials
296 # are made available under the terms of the Eclipse Public License v1.0
297 # which accompanies this distribution, and is available at
298 # http://www.eclipse.org/legal/epl-v10.html
299 ##############################################################################
301 # This script removes the -SNAPSHOT from a project to prepare it for release.
303 PATCH_DIR="$WORKSPACE/archives/patches"
304 mkdir -p "$PATCH_DIR"
306 # Ensure we fail the job if any steps fail.
309 echo "$PROJECT" "$(git rev-parse --verify HEAD)" | tee -a "$PATCH_DIR/taglist.log"
311 # Strip -SNAPSHOT from version to prepare release.
312 find . -name "*.xml" -print0 | xargs -0 sed -i 's/-SNAPSHOT//g'
314 git commit -am "Release $PROJECT"
315 git format-patch --stdout "origin/$GERRIT_BRANCH" > "$PATCH_DIR/${PROJECT//\//-}.patch"
316 git bundle create "$PATCH_DIR/${PROJECT//\//-}.bundle" "origin/${GERRIT_BRANCH}..HEAD"
319 # SPDX-License-Identifier: EPL-1.0
320 ##############################################################################
321 # Copyright (c) 2017 The Linux Foundation and others.
323 # All rights reserved. This program and the accompanying materials
324 # are made available under the terms of the Eclipse Public License v1.0
325 # which accompanies this distribution, and is available at
326 # http://www.eclipse.org/legal/epl-v10.html
327 ##############################################################################
329 # This script builds a Maven project and deploys it into a staging repo which
330 # can be used to deploy elsewhere later eg. Nexus staging / snapshot repos.
332 # DO NOT enable -u because $MAVEN_PARAMS and $MAVEN_OPTIONS could be unbound.
333 # Ensure we fail the job if any steps fail.
339 # Disable SC2086 because we want to allow word splitting for $MAVEN_* parameters.
340 # shellcheck disable=SC2086
342 --global-settings "$GLOBAL_SETTINGS_FILE" \
343 --settings "$SETTINGS_FILE" \
344 -DaltDeploymentRepository=staging::default::file:"$WORKSPACE"/m2repo \
345 $MAVEN_PARAMS $MAVEN_OPTIONS
348 # SPDX-License-Identifier: EPL-1.0
349 ##############################################################################
350 # Copyright (c) 2017 The Linux Foundation and others.
352 # All rights reserved. This program and the accompanying materials
353 # are made available under the terms of the Eclipse Public License v1.0
354 # which accompanies this distribution, and is available at
355 # http://www.eclipse.org/legal/epl-v10.html
356 ##############################################################################
358 # This script publishes artifacts to a staging repo in Nexus.
360 # $WORKSPACE/m2repo : Exists and used to deploy the staging repository.
361 # $NEXUS_URL : Jenkins global variable should be defined.
362 # $STAGING_PROFILE_ID : Provided by a job parameter.
364 # Ensure we fail the job if any steps fail.
367 TMP_FILE="$(mktemp)"
368 lftools deploy nexus-stage "$NEXUS_URL" "$STAGING_PROFILE_ID" "$WORKSPACE/m2repo" | tee "$TMP_FILE"
369 staging_repo=$(sed -n -e 's/Staging repository \(.*\) created\./\1/p' "$TMP_FILE")
371 # Store repo info to a file in archives
372 mkdir -p "$WORKSPACE/archives"
373 echo "$staging_repo" > "$WORKSPACE/archives/staging-repo.txt"
376 rm "$TMP_FILE"
378 </hudson.tasks.Shell>
381 set +e # DO NOT cause build failure if any of the rm calls fail.
383 rm "$GLOBAL_SETTINGS_FILE" "$SETTINGS_FILE"
385 # In some cases we use the lf-provide-maven-settings macro to produce
386 # a "$HOME/.netrc" file containing credentials. Remove that file here
388 rm "$HOME/.netrc"
390 # DO NOT fail build if any of the above lines fail.
393 </hudson.tasks.Shell>
396 <org.jenkinsci.plugins.postbuildscript.PostBuildScript>
400 # SPDX-License-Identifier: EPL-1.0
401 ##############################################################################
402 # Copyright (c) 2017 The Linux Foundation and others.
404 # All rights reserved. This program and the accompanying materials
405 # are made available under the terms of the Eclipse Public License v1.0
406 # which accompanies this distribution, and is available at
407 # http://www.eclipse.org/legal/epl-v10.html
408 ##############################################################################
409 echo "---> sysstat.sh"
410 set +e # DON'T fail build if script fails.
412 OS=$(facter operatingsystem)
413 case "$OS" in
415 SYSSTAT_PATH="/var/log/sysstat"
417 # Dont run the script when systat is not enabled by default
418 if ! grep --quiet 'ENABLED="true"' "/etc/default/sysstat"; then
423 SYSSTAT_PATH="/var/log/sa"
431 SAR_DIR="$WORKSPACE/archives/sar-reports"
432 mkdir -p "$SAR_DIR"
433 cp "$SYSSTAT_PATH/"* "$_"
434 # convert sar data to ascii format
435 while IFS="" read -r s
437 [ -f "$s" ] && LC_TIME=POSIX sar -A -f "$s" > "$SAR_DIR/sar${s//[!0-9]/}"
438 done < <(find "$SYSSTAT_PATH" -name "sa[0-9]*" || true)
440 # DON'T fail build if script fails.
443 </hudson.tasks.Shell>
444 <org.jenkinsci.plugins.configfiles.builder.ConfigFileBuildStep plugin="config-file-provider">
446 <org.jenkinsci.plugins.configfiles.buildwrapper.ManagedFile>
447 <fileId>jenkins-log-archives-settings</fileId>
449 <variable>SETTINGS_FILE</variable>
450 </org.jenkinsci.plugins.configfiles.buildwrapper.ManagedFile>
452 </org.jenkinsci.plugins.configfiles.builder.ConfigFileBuildStep>
455 <propertiesContent>SERVER_ID=logs</propertiesContent>
460 # SPDX-License-Identifier: EPL-1.0
461 ##############################################################################
462 # Copyright (c) 2017 The Linux Foundation and others.
464 # All rights reserved. This program and the accompanying materials
465 # are made available under the terms of the Eclipse Public License v1.0
466 # which accompanies this distribution, and is available at
467 # http://www.eclipse.org/legal/epl-v10.html
468 ##############################################################################
469 echo "---> create-netrc.sh"
471 # Ensure we fail the job if any steps fail.
474 NEXUS_URL="${NEXUS_URL:-$NEXUSPROXY}"
475 CREDENTIAL=$(xmlstarlet sel -N "x=http://maven.apache.org/SETTINGS/1.0.0" \
476 -t -m "/x:settings/x:servers/x:server[x:id='${SERVER_ID}']" \
477 -v x:username -o ":" -v x:password \
478 "$SETTINGS_FILE")
480 machine=$(echo "$NEXUS_URL" | awk -F/ '{print $3}')
481 user=$(echo "$CREDENTIAL" | cut -f1 -d:)
482 pass=$(echo "$CREDENTIAL" | cut -f2 -d:)
484 echo "machine $machine login $user password $pass" > ~/.netrc
486 </hudson.tasks.Shell>
489 # SPDX-License-Identifier: EPL-1.0
490 ##############################################################################
491 # Copyright (c) 2017 The Linux Foundation and others.
493 # All rights reserved. This program and the accompanying materials
494 # are made available under the terms of the Eclipse Public License v1.0
495 # which accompanies this distribution, and is available at
496 # http://www.eclipse.org/legal/epl-v10.html
497 ##############################################################################
498 echo "---> lftools-install.sh"
500 # By default a released version of lftools should always be used.
501 # The purpose of the 2 variables below is so that lftools devs can test
502 # unreleased versions of lftools. There are 2 methods to install a dev version
505 # 1) gerrit patch: Used to test a patch that has not yet been merged.
506 # To do this set something like this:
507 # LFTOOLS_MODE=gerrit
508 # LFTOOLS_REFSPEC=refs/changes/96/5296/7
510 # 2) git branch: Used to install an lftools version from a specific branch.
511 # To use this set the variables as follows:
513 # LFTOOLS_REFSPEC=master
515 # 3) release : The intended use case and default setting.
516 # Set LFTOOLS_MODE=release, in this case LFTOOLS_REFSPEC is unused.
518 LFTOOLS_MODE=release # release | git | gerrit
519 LFTOOLS_REFSPEC=master
521 # Ensure we fail the job if any steps fail.
522 # DO NOT set -u as virtualenv's activate script has unbound variables
525 virtualenv --quiet "/tmp/v/lftools"
526 # shellcheck source=/tmp/v/lftools/bin/activate disable=SC1091
527 source "/tmp/v/lftools/bin/activate"
528 pip install --quiet --upgrade pip
530 case $LFTOOLS_MODE in
532 git clone https://gerrit.linuxfoundation.org/infra/releng/lftools.git /tmp/lftools
534 git fetch origin "$LFTOOLS_REFSPEC"
535 git checkout FETCH_HEAD
536 pip install --quiet --upgrade -r requirements.txt
537 pip install --quiet --upgrade -e .
542 pip install --quiet --upgrade git+https://gerrit.linuxfoundation.org/infra/releng/lftools.git@"$BRANCH"
546 pip install --quiet --upgrade "lftools<1.0.0"
550 # pipdeptree prints out a lot of information because lftools pulls in many
551 # dependencies. Let's only print it if we want to debug.
552 # echo "----> Pip Dependency Tree"
553 # pip install --quiet --upgrade pipdeptree
557 # SPDX-License-Identifier: EPL-1.0
558 ##############################################################################
559 # Copyright (c) 2017 The Linux Foundation and others.
561 # All rights reserved. This program and the accompanying materials
562 # are made available under the terms of the Eclipse Public License v1.0
563 # which accompanies this distribution, and is available at
564 # http://www.eclipse.org/legal/epl-v10.html
565 ##############################################################################
566 echo "---> logs-deploy.sh"
568 # Ensure we fail the job if any steps fail.
571 set -x # Trace commands for this script to make debugging easier.
573 ARCHIVE_ARTIFACTS="${ARCHIVE_ARTIFACTS:-}"
574 LOGS_SERVER="${LOGS_SERVER:-None}"
576 if [ "${LOGS_SERVER}" == 'None' ]
578 set +x # Disable trace since we no longer need it
580 echo "WARNING: Logging server not set"
582 NEXUS_URL="${NEXUS_URL:-$NEXUSPROXY}"
583 NEXUS_PATH="${SILO}/${JENKINS_HOSTNAME}/${JOB_NAME}/${BUILD_NUMBER}"
584 BUILD_URL="${BUILD_URL}"
586 lftools deploy archives -p "$ARCHIVE_ARTIFACTS" "$NEXUS_URL" "$NEXUS_PATH" "$WORKSPACE"
587 lftools deploy logs "$NEXUS_URL" "$NEXUS_PATH" "$BUILD_URL"
589 set +x # Disable trace since we no longer need it.
591 echo "Build logs: <a href=\"$LOGS_SERVER/$NEXUS_PATH\">$LOGS_SERVER/$NEXUS_PATH</a>"
594 </hudson.tasks.Shell>
597 # SPDX-License-Identifier: EPL-1.0
598 ##############################################################################
599 # Copyright (c) 2017 The Linux Foundation and others.
601 # All rights reserved. This program and the accompanying materials
602 # are made available under the terms of the Eclipse Public License v1.0
603 # which accompanies this distribution, and is available at
604 # http://www.eclipse.org/legal/epl-v10.html
605 ##############################################################################
607 # Clear log credential files
608 rm "$SETTINGS_FILE"
611 </hudson.tasks.Shell>
612 <hudson.plugins.descriptionsetter.DescriptionSetterBuilder>
613 <regexp>^Build logs: .*</regexp>
614 </hudson.plugins.descriptionsetter.DescriptionSetterBuilder>
616 <scriptOnlyIfSuccess>false</scriptOnlyIfSuccess>
617 <scriptOnlyIfFailure>false</scriptOnlyIfFailure>
618 <markBuildUnstable>false</markBuildUnstable>
619 </org.jenkinsci.plugins.postbuildscript.PostBuildScript>
620 <hudson.plugins.ws__cleanup.WsCleanup plugin="ws-cleanup">
622 <hudson.plugins.ws__cleanup.Pattern>
623 <pattern>**/*.jenkins-trigger</pattern>
625 </hudson.plugins.ws__cleanup.Pattern>
627 <deleteDirs>false</deleteDirs>
628 <cleanupMatrixParent>false</cleanupMatrixParent>
630 <cleanWhenSuccess>true</cleanWhenSuccess>
631 <cleanWhenUnstable>true</cleanWhenUnstable>
632 <cleanWhenFailure>true</cleanWhenFailure>
633 <cleanWhenNotBuilt>true</cleanWhenNotBuilt>
634 <cleanWhenAborted>true</cleanWhenAborted>
635 <notFailBuild>true</notFailBuild>
636 </hudson.plugins.ws__cleanup.WsCleanup>
639 <com.michelin.cio.hudson.plugins.maskpasswords.MaskPasswordsBuildWrapper/>
640 <hudson.plugins.build__timeout.BuildTimeoutWrapper>
641 <timeoutMinutes>30</timeoutMinutes>
642 <timeoutEnvVar>BUILD_TIMEOUT</timeoutEnvVar>
643 <failBuild>true</failBuild>
644 <writingDescription>false</writingDescription>
645 <timeoutPercentage>0</timeoutPercentage>
646 <timeoutMinutesElasticDefault>3</timeoutMinutesElasticDefault>
647 <timeoutType>absolute</timeoutType>
648 </hudson.plugins.build__timeout.BuildTimeoutWrapper>
649 <hudson.plugins.timestamper.TimestamperBuildWrapper/>
650 <com.cloudbees.jenkins.plugins.sshagent.SSHAgentBuildWrapper>
651 <user>test-credential</user>
652 </com.cloudbees.jenkins.plugins.sshagent.SSHAgentBuildWrapper>
653 <jenkins.plugins.openstack.compute.JCloudsOneOffSlave/>