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.
61 <defaultValue>refs/heads/master</defaultValue>
62 </hudson.model.StringParameterDefinition>
63 <hudson.model.StringParameterDefinition>
64 <name>LFTOOLS_VERSION</name>
65 <description>Version of lftools to install. Can be a specific version like
66 '0.6.0' or a PEP-440 definition.
67 https://www.python.org/dev/peps/pep-0440/
68 For example '<1.0.0' or '>=1.0.0,<2.0.0'.
70 <defaultValue><1.0.0</defaultValue>
71 </hudson.model.StringParameterDefinition>
72 <hudson.model.StringParameterDefinition>
73 <name>MAVEN_OPTS</name>
74 <description>Maven Java opts. Example: -Xmx1024m -XX:MaxPermSize=256m
77 </hudson.model.StringParameterDefinition>
78 <hudson.model.StringParameterDefinition>
79 <name>MAVEN_PARAMS</name>
80 <description>Maven parameters to pass to the mvn command.
83 </hudson.model.StringParameterDefinition>
84 <hudson.model.StringParameterDefinition>
86 <description>Maven selector to be used by shell scripts</description>
87 <defaultValue>/w/tools/hudson.tasks.Maven_MavenInstallation/mvn33/bin/mvn</defaultValue>
88 </hudson.model.StringParameterDefinition>
89 <hudson.model.StringParameterDefinition>
90 <name>STAGING_PROFILE_ID</name>
91 <description>Nexus staging profile ID.
93 <defaultValue>uuddlrlrba</defaultValue>
94 </hudson.model.StringParameterDefinition>
95 </parameterDefinitions>
96 </hudson.model.ParametersDefinitionProperty>
98 <scm class="hudson.plugins.git.GitSCM">
99 <configVersion>2</configVersion>
101 <hudson.plugins.git.UserRemoteConfig>
103 <refspec>+refs/pull/*:refs/remotes/origin/pr/*</refspec>
104 <url>git@github.com:example-org/releng/ciman</url>
105 <credentialsId>test-credential</credentialsId>
106 </hudson.plugins.git.UserRemoteConfig>
109 <hudson.plugins.git.BranchSpec>
111 </hudson.plugins.git.BranchSpec>
114 <buildChooser class="hudson.plugins.git.util.DefaultBuildChooser"/>
115 <doGenerateSubmoduleConfigurations>false</doGenerateSubmoduleConfigurations>
116 <authorOrCommitter>false</authorOrCommitter>
117 <wipeOutWorkspace>true</wipeOutWorkspace>
118 <pruneBranches>false</pruneBranches>
119 <remotePoll>false</remotePoll>
120 <gitTool>Default</gitTool>
121 <submoduleCfg class="list"/>
126 <skipTag>true</skipTag>
128 <useShallowClone>false</useShallowClone>
129 <ignoreNotifyCommit>false</ignoreNotifyCommit>
131 <hudson.plugins.git.extensions.impl.SubmoduleOption>
132 <disableSubmodules>false</disableSubmodules>
133 <recursiveSubmodules>true</recursiveSubmodules>
134 <trackingSubmodules>false</trackingSubmodules>
136 <timeout>10</timeout>
137 </hudson.plugins.git.extensions.impl.SubmoduleOption>
138 <hudson.plugins.git.extensions.impl.WipeWorkspace/>
143 <command>mkdir -p $WORKSPACE/target/classes $WORKSPACE/jacoco/classes</command>
144 </hudson.tasks.Shell>
146 <command>echo "quiet=on" > "$HOME/.wgetrc"</command>
147 </hudson.tasks.Shell>
149 <targets>--version</targets>
151 <mavenName>mvn33</mavenName>
152 <usePrivateRepository>false</usePrivateRepository>
153 <settings class="jenkins.mvn.DefaultSettingsProvider"/>
154 <globalSettings class="jenkins.mvn.DefaultGlobalSettingsProvider"/>
155 </hudson.tasks.Maven>
157 <command>rm "$HOME/.wgetrc"</command>
158 </hudson.tasks.Shell>
159 <org.jenkinsci.plugins.configfiles.builder.ConfigFileBuildStep plugin="config-file-provider">
161 <org.jenkinsci.plugins.configfiles.buildwrapper.ManagedFile>
162 <fileId>global-settings</fileId>
164 <variable>GLOBAL_SETTINGS_FILE</variable>
165 </org.jenkinsci.plugins.configfiles.buildwrapper.ManagedFile>
166 <org.jenkinsci.plugins.configfiles.buildwrapper.ManagedFile>
167 <fileId>aproject-settings</fileId>
169 <variable>SETTINGS_FILE</variable>
170 </org.jenkinsci.plugins.configfiles.buildwrapper.ManagedFile>
172 </org.jenkinsci.plugins.configfiles.builder.ConfigFileBuildStep>
175 <propertiesContent>SERVER_ID=opendaylight-staging</propertiesContent>
180 # SPDX-License-Identifier: EPL-1.0
181 ##############################################################################
182 # Copyright (c) 2017 The Linux Foundation and others.
184 # All rights reserved. This program and the accompanying materials
185 # are made available under the terms of the Eclipse Public License v1.0
186 # which accompanies this distribution, and is available at
187 # http://www.eclipse.org/legal/epl-v10.html
188 ##############################################################################
189 echo "---> create-netrc.sh"
191 # Ensure we fail the job if any steps fail.
194 NEXUS_URL="${NEXUS_URL:-$NEXUSPROXY}"
195 CREDENTIAL=$(xmlstarlet sel -N "x=http://maven.apache.org/SETTINGS/1.0.0" \
196 -t -m "/x:settings/x:servers/x:server[x:id='${SERVER_ID}']" \
197 -v x:username -o ":" -v x:password \
198 "$SETTINGS_FILE")
200 machine=$(echo "$NEXUS_URL" | awk -F/ '{print $3}')
201 user=$(echo "$CREDENTIAL" | cut -f1 -d:)
202 pass=$(echo "$CREDENTIAL" | cut -f2 -d:)
204 echo "machine $machine login $user password $pass" > ~/.netrc
206 </hudson.tasks.Shell>
209 # SPDX-License-Identifier: EPL-1.0
210 ##############################################################################
211 # Copyright (c) 2017 The Linux Foundation and others.
213 # All rights reserved. This program and the accompanying materials
214 # are made available under the terms of the Eclipse Public License v1.0
215 # which accompanies this distribution, and is available at
216 # http://www.eclipse.org/legal/epl-v10.html
217 ##############################################################################
218 echo "---> lftools-install.sh"
220 # Script to install lftools via a version passed in via lf-infra-parameters
222 # Required parameters:
224 # LFTOOLS_VERSION: Passed in via lf-infra-parameters configuration. Can be
225 # set to a strict version number like '1.2.3' or using
226 # PEP-440 definitions.
230 # >=1.0.0,<2.0.0
232 # By default a released version of lftools should always be used.
233 # The purpose of the 2 variables below is so that lftools devs can test
234 # unreleased versions of lftools. There are 2 methods to install a dev version
237 # 1) gerrit patch: Used to test a patch that has not yet been merged.
238 # To do this set something like this:
239 # LFTOOLS_MODE=gerrit
240 # LFTOOLS_REFSPEC=refs/changes/96/5296/7
242 # 2) git branch: Used to install an lftools version from a specific branch.
243 # To use this set the variables as follows:
245 # LFTOOLS_REFSPEC=master
247 # 3) release : The intended use case and default setting.
248 # Set LFTOOLS_MODE=release, in this case LFTOOLS_REFSPEC is unused.
250 LFTOOLS_MODE=release # release | git | gerrit
251 LFTOOLS_REFSPEC=master
253 # Ensure we fail the job if any steps fail.
254 # DO NOT set -u as virtualenv's activate script has unbound variables
257 virtualenv --quiet "/tmp/v/lftools"
258 # shellcheck source=/tmp/v/lftools/bin/activate disable=SC1091
259 source "/tmp/v/lftools/bin/activate"
260 pip install --quiet --upgrade pip
262 case $LFTOOLS_MODE in
264 git clone https://gerrit.linuxfoundation.org/infra/releng/lftools.git /tmp/lftools
266 git fetch origin "$LFTOOLS_REFSPEC"
267 git checkout FETCH_HEAD
268 pip install --quiet --upgrade -r requirements.txt
269 pip install --quiet --upgrade -e .
274 pip install --quiet --upgrade git+https://gerrit.linuxfoundation.org/infra/releng/lftools.git@"$BRANCH"
278 if [[ $LFTOOLS_VERSION =~ ^[0-9] ]]; then
279 LFTOOLS_VERSION="==$LFTOOLS_VERSION"
282 pip install --quiet --upgrade "lftools${LFTOOLS_VERSION}"
288 # pipdeptree prints out a lot of information because lftools pulls in many
289 # dependencies. Let's only print it if we want to debug.
290 # echo "----> Pip Dependency Tree"
291 # pip install --quiet --upgrade pipdeptree
295 # SPDX-License-Identifier: EPL-1.0
296 ##############################################################################
297 # Copyright (c) 2017 The Linux Foundation and others.
299 # All rights reserved. This program and the accompanying materials
300 # are made available under the terms of the Eclipse Public License v1.0
301 # which accompanies this distribution, and is available at
302 # http://www.eclipse.org/legal/epl-v10.html
303 ##############################################################################
305 # This file contains a list of variables that are generally useful in many
306 # scripts. It is meant to be sourced in other scripts so that the variables can
309 MAVEN_OPTIONS="$(echo --show-version \
312 -Dorg.slf4j.simpleLogger.log.org.apache.maven.cli.transfer.Slf4jMavenTransferListener=warn \
313 -Dmaven.repo.local=/tmp/r \
314 -Dorg.ops4j.pax.url.mvn.localRepository=/tmp/r)"
315 echo "$MAVEN_OPTIONS"
318 # SPDX-License-Identifier: EPL-1.0
319 ##############################################################################
320 # Copyright (c) 2017 The Linux Foundation and others.
322 # All rights reserved. This program and the accompanying materials
323 # are made available under the terms of the Eclipse Public License v1.0
324 # which accompanies this distribution, and is available at
325 # http://www.eclipse.org/legal/epl-v10.html
326 ##############################################################################
328 # This script removes the -SNAPSHOT from a project to prepare it for release.
330 PATCH_DIR="$WORKSPACE/archives/patches"
331 mkdir -p "$PATCH_DIR"
333 # Ensure we fail the job if any steps fail.
336 echo "$PROJECT" "$(git rev-parse --verify HEAD)" | tee -a "$PATCH_DIR/taglist.log"
338 # Strip -SNAPSHOT from version to prepare release.
339 find . -name "*.xml" -print0 | xargs -0 sed -i 's/-SNAPSHOT//g'
341 git commit -am "Release $PROJECT"
342 git format-patch --stdout "origin/$GERRIT_BRANCH" > "$PATCH_DIR/${PROJECT//\//-}.patch"
343 git bundle create "$PATCH_DIR/${PROJECT//\//-}.bundle" "origin/${GERRIT_BRANCH}..HEAD"
346 # SPDX-License-Identifier: EPL-1.0
347 ##############################################################################
348 # Copyright (c) 2017 The Linux Foundation and others.
350 # All rights reserved. This program and the accompanying materials
351 # are made available under the terms of the Eclipse Public License v1.0
352 # which accompanies this distribution, and is available at
353 # http://www.eclipse.org/legal/epl-v10.html
354 ##############################################################################
356 # This script builds a Maven project and deploys it into a staging repo which
357 # can be used to deploy elsewhere later eg. Nexus staging / snapshot repos.
359 # DO NOT enable -u because $MAVEN_PARAMS and $MAVEN_OPTIONS could be unbound.
360 # Ensure we fail the job if any steps fail.
366 # Disable SC2086 because we want to allow word splitting for $MAVEN_* parameters.
367 # shellcheck disable=SC2086
369 --global-settings "$GLOBAL_SETTINGS_FILE" \
370 --settings "$SETTINGS_FILE" \
371 -DaltDeploymentRepository=staging::default::file:"$WORKSPACE"/m2repo \
372 $MAVEN_PARAMS $MAVEN_OPTIONS
375 # SPDX-License-Identifier: EPL-1.0
376 ##############################################################################
377 # Copyright (c) 2017 The Linux Foundation and others.
379 # All rights reserved. This program and the accompanying materials
380 # are made available under the terms of the Eclipse Public License v1.0
381 # which accompanies this distribution, and is available at
382 # http://www.eclipse.org/legal/epl-v10.html
383 ##############################################################################
385 # This script publishes artifacts to a staging repo in Nexus.
387 # $WORKSPACE/m2repo : Exists and used to deploy the staging repository.
388 # $NEXUS_URL : Jenkins global variable should be defined.
389 # $STAGING_PROFILE_ID : Provided by a job parameter.
391 # Ensure we fail the job if any steps fail.
394 TMP_FILE="$(mktemp)"
395 lftools deploy nexus-stage "$NEXUS_URL" "$STAGING_PROFILE_ID" "$WORKSPACE/m2repo" | tee "$TMP_FILE"
396 staging_repo=$(sed -n -e 's/Staging repository \(.*\) created\./\1/p' "$TMP_FILE")
398 # Store repo info to a file in archives
399 mkdir -p "$WORKSPACE/archives"
400 echo "$staging_repo" > "$WORKSPACE/archives/staging-repo.txt"
403 rm "$TMP_FILE"
405 </hudson.tasks.Shell>
408 set +e # DO NOT cause build failure if any of the rm calls fail.
410 rm "$GLOBAL_SETTINGS_FILE" "$SETTINGS_FILE"
412 # In some cases we use the lf-provide-maven-settings macro to produce
413 # a "$HOME/.netrc" file containing credentials. Remove that file here
415 rm "$HOME/.netrc"
417 # DO NOT fail build if any of the above lines fail.
420 </hudson.tasks.Shell>
423 <org.jenkinsci.plugins.postbuildscript.PostBuildScript>
427 # SPDX-License-Identifier: EPL-1.0
428 ##############################################################################
429 # Copyright (c) 2017 The Linux Foundation and others.
431 # All rights reserved. This program and the accompanying materials
432 # are made available under the terms of the Eclipse Public License v1.0
433 # which accompanies this distribution, and is available at
434 # http://www.eclipse.org/legal/epl-v10.html
435 ##############################################################################
436 echo "---> sysstat.sh"
437 set +e # DON'T fail build if script fails.
439 OS=$(facter operatingsystem)
440 case "$OS" in
442 SYSSTAT_PATH="/var/log/sysstat"
444 # Dont run the script when systat is not enabled by default
445 if ! grep --quiet 'ENABLED="true"' "/etc/default/sysstat"; then
450 SYSSTAT_PATH="/var/log/sa"
458 SAR_DIR="$WORKSPACE/archives/sar-reports"
459 mkdir -p "$SAR_DIR"
460 cp "$SYSSTAT_PATH/"* "$_"
461 # convert sar data to ascii format
462 while IFS="" read -r s
464 [ -f "$s" ] && LC_TIME=POSIX sar -A -f "$s" > "$SAR_DIR/sar${s//[!0-9]/}"
465 done < <(find "$SYSSTAT_PATH" -name "sa[0-9]*" || true)
467 # DON'T fail build if script fails.
470 </hudson.tasks.Shell>
471 <org.jenkinsci.plugins.configfiles.builder.ConfigFileBuildStep plugin="config-file-provider">
473 <org.jenkinsci.plugins.configfiles.buildwrapper.ManagedFile>
474 <fileId>jenkins-log-archives-settings</fileId>
476 <variable>SETTINGS_FILE</variable>
477 </org.jenkinsci.plugins.configfiles.buildwrapper.ManagedFile>
479 </org.jenkinsci.plugins.configfiles.builder.ConfigFileBuildStep>
482 <propertiesContent>SERVER_ID=logs</propertiesContent>
487 # SPDX-License-Identifier: EPL-1.0
488 ##############################################################################
489 # Copyright (c) 2017 The Linux Foundation and others.
491 # All rights reserved. This program and the accompanying materials
492 # are made available under the terms of the Eclipse Public License v1.0
493 # which accompanies this distribution, and is available at
494 # http://www.eclipse.org/legal/epl-v10.html
495 ##############################################################################
496 echo "---> create-netrc.sh"
498 # Ensure we fail the job if any steps fail.
501 NEXUS_URL="${NEXUS_URL:-$NEXUSPROXY}"
502 CREDENTIAL=$(xmlstarlet sel -N "x=http://maven.apache.org/SETTINGS/1.0.0" \
503 -t -m "/x:settings/x:servers/x:server[x:id='${SERVER_ID}']" \
504 -v x:username -o ":" -v x:password \
505 "$SETTINGS_FILE")
507 machine=$(echo "$NEXUS_URL" | awk -F/ '{print $3}')
508 user=$(echo "$CREDENTIAL" | cut -f1 -d:)
509 pass=$(echo "$CREDENTIAL" | cut -f2 -d:)
511 echo "machine $machine login $user password $pass" > ~/.netrc
513 </hudson.tasks.Shell>
516 # SPDX-License-Identifier: EPL-1.0
517 ##############################################################################
518 # Copyright (c) 2017 The Linux Foundation and others.
520 # All rights reserved. This program and the accompanying materials
521 # are made available under the terms of the Eclipse Public License v1.0
522 # which accompanies this distribution, and is available at
523 # http://www.eclipse.org/legal/epl-v10.html
524 ##############################################################################
525 echo "---> lftools-install.sh"
527 # Script to install lftools via a version passed in via lf-infra-parameters
529 # Required parameters:
531 # LFTOOLS_VERSION: Passed in via lf-infra-parameters configuration. Can be
532 # set to a strict version number like '1.2.3' or using
533 # PEP-440 definitions.
537 # >=1.0.0,<2.0.0
539 # By default a released version of lftools should always be used.
540 # The purpose of the 2 variables below is so that lftools devs can test
541 # unreleased versions of lftools. There are 2 methods to install a dev version
544 # 1) gerrit patch: Used to test a patch that has not yet been merged.
545 # To do this set something like this:
546 # LFTOOLS_MODE=gerrit
547 # LFTOOLS_REFSPEC=refs/changes/96/5296/7
549 # 2) git branch: Used to install an lftools version from a specific branch.
550 # To use this set the variables as follows:
552 # LFTOOLS_REFSPEC=master
554 # 3) release : The intended use case and default setting.
555 # Set LFTOOLS_MODE=release, in this case LFTOOLS_REFSPEC is unused.
557 LFTOOLS_MODE=release # release | git | gerrit
558 LFTOOLS_REFSPEC=master
560 # Ensure we fail the job if any steps fail.
561 # DO NOT set -u as virtualenv's activate script has unbound variables
564 virtualenv --quiet "/tmp/v/lftools"
565 # shellcheck source=/tmp/v/lftools/bin/activate disable=SC1091
566 source "/tmp/v/lftools/bin/activate"
567 pip install --quiet --upgrade pip
569 case $LFTOOLS_MODE in
571 git clone https://gerrit.linuxfoundation.org/infra/releng/lftools.git /tmp/lftools
573 git fetch origin "$LFTOOLS_REFSPEC"
574 git checkout FETCH_HEAD
575 pip install --quiet --upgrade -r requirements.txt
576 pip install --quiet --upgrade -e .
581 pip install --quiet --upgrade git+https://gerrit.linuxfoundation.org/infra/releng/lftools.git@"$BRANCH"
585 if [[ $LFTOOLS_VERSION =~ ^[0-9] ]]; then
586 LFTOOLS_VERSION="==$LFTOOLS_VERSION"
589 pip install --quiet --upgrade "lftools${LFTOOLS_VERSION}"
595 # pipdeptree prints out a lot of information because lftools pulls in many
596 # dependencies. Let's only print it if we want to debug.
597 # echo "----> Pip Dependency Tree"
598 # pip install --quiet --upgrade pipdeptree
602 # SPDX-License-Identifier: EPL-1.0
603 ##############################################################################
604 # Copyright (c) 2017 The Linux Foundation and others.
606 # All rights reserved. This program and the accompanying materials
607 # are made available under the terms of the Eclipse Public License v1.0
608 # which accompanies this distribution, and is available at
609 # http://www.eclipse.org/legal/epl-v10.html
610 ##############################################################################
611 echo "---> logs-deploy.sh"
613 # Ensure we fail the job if any steps fail.
616 set -x # Trace commands for this script to make debugging easier.
618 ARCHIVE_ARTIFACTS="${ARCHIVE_ARTIFACTS:-}"
619 LOGS_SERVER="${LOGS_SERVER:-None}"
621 if [ "${LOGS_SERVER}" == 'None' ]
623 set +x # Disable trace since we no longer need it
625 echo "WARNING: Logging server not set"
627 NEXUS_URL="${NEXUS_URL:-$NEXUSPROXY}"
628 NEXUS_PATH="${SILO}/${JENKINS_HOSTNAME}/${JOB_NAME}/${BUILD_NUMBER}"
629 BUILD_URL="${BUILD_URL}"
631 lftools deploy archives -p "$ARCHIVE_ARTIFACTS" "$NEXUS_URL" "$NEXUS_PATH" "$WORKSPACE"
632 lftools deploy logs "$NEXUS_URL" "$NEXUS_PATH" "$BUILD_URL"
634 set +x # Disable trace since we no longer need it.
636 echo "Build logs: <a href=\"$LOGS_SERVER/$NEXUS_PATH\">$LOGS_SERVER/$NEXUS_PATH</a>"
639 </hudson.tasks.Shell>
642 # SPDX-License-Identifier: EPL-1.0
643 ##############################################################################
644 # Copyright (c) 2017 The Linux Foundation and others.
646 # All rights reserved. This program and the accompanying materials
647 # are made available under the terms of the Eclipse Public License v1.0
648 # which accompanies this distribution, and is available at
649 # http://www.eclipse.org/legal/epl-v10.html
650 ##############################################################################
652 # Clear log credential files
653 rm "$SETTINGS_FILE"
656 </hudson.tasks.Shell>
657 <hudson.plugins.descriptionsetter.DescriptionSetterBuilder>
658 <regexp>^Build logs: .*</regexp>
659 </hudson.plugins.descriptionsetter.DescriptionSetterBuilder>
661 <scriptOnlyIfSuccess>false</scriptOnlyIfSuccess>
662 <scriptOnlyIfFailure>false</scriptOnlyIfFailure>
663 <markBuildUnstable>false</markBuildUnstable>
664 </org.jenkinsci.plugins.postbuildscript.PostBuildScript>
665 <hudson.plugins.ws__cleanup.WsCleanup plugin="ws-cleanup">
667 <hudson.plugins.ws__cleanup.Pattern>
668 <pattern>**/*.jenkins-trigger</pattern>
670 </hudson.plugins.ws__cleanup.Pattern>
672 <deleteDirs>false</deleteDirs>
673 <cleanupMatrixParent>false</cleanupMatrixParent>
675 <cleanWhenSuccess>true</cleanWhenSuccess>
676 <cleanWhenUnstable>true</cleanWhenUnstable>
677 <cleanWhenFailure>true</cleanWhenFailure>
678 <cleanWhenNotBuilt>true</cleanWhenNotBuilt>
679 <cleanWhenAborted>true</cleanWhenAborted>
680 <notFailBuild>true</notFailBuild>
681 </hudson.plugins.ws__cleanup.WsCleanup>
684 <com.michelin.cio.hudson.plugins.maskpasswords.MaskPasswordsBuildWrapper/>
685 <hudson.plugins.build__timeout.BuildTimeoutWrapper>
686 <timeoutMinutes>30</timeoutMinutes>
687 <timeoutEnvVar>BUILD_TIMEOUT</timeoutEnvVar>
688 <failBuild>true</failBuild>
689 <writingDescription>false</writingDescription>
690 <timeoutPercentage>0</timeoutPercentage>
691 <timeoutMinutesElasticDefault>3</timeoutMinutesElasticDefault>
692 <timeoutType>absolute</timeoutType>
693 </hudson.plugins.build__timeout.BuildTimeoutWrapper>
694 <hudson.plugins.timestamper.TimestamperBuildWrapper/>
695 <com.cloudbees.jenkins.plugins.sshagent.SSHAgentBuildWrapper>
696 <user>test-credential</user>
697 </com.cloudbees.jenkins.plugins.sshagent.SSHAgentBuildWrapper>
698 <jenkins.plugins.openstack.compute.JCloudsOneOffSlave/>