controller-scope: "{controller-scope}"
controller-use-features-boot: "{use-features-boot}"
feature-elasticsearch-attribute: "{elasticsearch-attribute}"
+ - distribution-is-karaf-appl:
+ karaf-based-controller: "{karaf-based-controller}"
+ - distribution-karaf-version:
+ karaf-version: "{karaf-version}"
- parameter:
name: integration-controller-parameters
default: "{branch}"
description: "Distribution GIT branch"
+- parameter:
+ name: distribution-is-karaf-appl
+ parameters:
+ - string:
+ name: IS_KARAF_APPL
+ default: "{karaf-based-controller}"
+ description: "Boolean to let pipeline know if the project has a different deployer"
+
- parameter:
name: distribution-karaf-version
# Arguments:
- string:
name: KARAF_VERSION
default: "{karaf-version}"
- description: "karaf3, karaf4, odl, affects ODL deploy scripts"
+ description: "karaf3, karaf4, odl, bgpcep, controller, netconf affects ODL deploy scripts"
- parameter:
name: integration-bundle-url
jobs: "{jobs}"
result: "success"
-# Macro: integration-openstack-controller-mininet
-# Operation: this macro will spin the controller and mininet vms
-# Used by: {project}-csit-* job templates
-
-- wrapper:
- name: integration-openstack-controller-mininet
- wrappers:
- - openstack:
- instances:
- - cloud-name: "ODLRPC"
- template-name: "{controller-image}"
- count: "{controller-vms}"
- - cloud-name: "ODLRPC"
- template-name: "{mininet-image}"
- count: "{mininet-vms}"
-
-# Macro: integration-openstack-controller-devstack
-# Operation: this macro will spin the controller and devstack vms
-# Used by: {project}-csit-openstack job templates
-- wrapper:
- name: integration-openstack-controller-devstack
- wrappers:
- - openstack:
- instances:
- - cloud-name: "ODLRPC"
- template-name: "{controller-image}"
- count: "{controller-vms}"
- - cloud-name: "ODLRPC"
- template-name: "{openstack-image}"
- count: "{openstack-vms}"
-
#################
# Shell Scripts #
#################
- builder:
name: integration-get-slave-addresses
builders:
- - shell: !include-raw: integration-get-slave-addresses.sh
+ - shell: !include-raw-escape: integration-get-slave-addresses.sh
- builder:
name: integration-set-variables
# Required bash variables:
# KARAF_VERSION: 'karaf4' or 'karaf3'. Use distribution-karaf-version macro to set.
builders:
- - shell: !include-raw: integration-set-variables.sh
+ - shell: !include-raw-escape: integration-set-variables.sh
- inject:
properties-file: set_variables.env
# KARAF_VERSION: 'karaf4' or 'karaf3'. Use distribution-karaf-version macro to set.
builders:
- integration-set-variables
- - shell: !include-raw: integration-detect-variables.sh
+ - shell: !include-raw-escape: integration-detect-variables.sh
- inject:
properties-file: detect_variables.env
- builder:
name: integration-deploy-controller-run-test
builders:
- - shell: !include-raw: integration-deploy-controller-run-test.sh
+ - shell: !include-raw-escape: integration-deploy-controller-run-test.sh
+
+# Macro: integration-deply-non-karaf-controller-run-test
+# Operation: this macro deploys non-karaf controller application and run test
+# Used by: {project}-csit-1node-* job templates
+
+- builder:
+ name: integration-run-test
+ builders:
+ - shell: !include-raw-escape: integration-run-test.sh
# Macro: integration-configure-clustering
# Operation: this macro configures the clustering
- builder:
name: integration-configure-clustering
builders:
- - shell: !include-raw: integration-configure-clustering.sh
+ - shell: !include-raw-escape: integration-configure-clustering.sh
# Macro: integration-start-cluster-run-test
# Operation: this macro starts the 3-node cluster and runs test
- builder:
name: integration-start-cluster-run-test
builders:
- - shell: !include-raw: integration-start-cluster-run-test.sh
+ - shell: !include-raw-escape: integration-start-cluster-run-test.sh
# Macro: integration-install-robotframework
# Operation: Installs robotframework using pip to a virtualenv
- builder:
name: integration-install-robotframework
builders:
- - shell: !include-raw: integration-install-robotframework.sh
+ - shell: !include-raw-escape: integration-install-robotframework.sh
# Macro: integration-cleanup-tmp
# Operation: Cleans up temporary files created by build
- builder:
name: integration-cleanup-tmp
builders:
- - shell: !include-raw: integration-cleanup-tmp.sh
+ - shell: !include-raw-escape: integration-cleanup-tmp.sh
# Macro: integration-multipatch-builder
# Operation: checks out multiple patches and builds custom distribution
- builder:
name: integration-multipatch-builder
builders:
- - shell: !include-raw: multipatch-distribution.sh
-
-# Macro: integration-cleanup-workspace
-# Operation: Cleans up files possibly left there by the previous build
-# Used by: {project}-csit-* job templates
-
-- builder:
- name: integration-cleanup-workspace
- builders:
- - shell: !include-raw: integration-cleanup-workspace.sh
+ - shell: !include-raw-escape: multipatch-distribution.sh
# Macro: integration-rebase-patch
# Operation: For cloned project, rebase checked-out Gerrit patch onto $DISTROBRANCH.
- builder:
name: integration-rebase-gerrit-patch
builders:
- - shell: !include-raw: integration-rebase-gerrit-patch.sh
+ - shell: !include-raw-escape: integration-rebase-gerrit-patch.sh
# Macro: integration-install-common-functions
# Operation: Copy the common-functions.sh script to csit nodes
- builder:
name: integration-install-common-functions
builders:
- - shell: !include-raw:
+ - shell: !include-raw-escape:
- copy-common-functions.sh
- common-functions.sh
-- builder:
- name: integration-deploy-openstack-run-test
- builders:
- - shell: !include-raw:
- - integration-deploy-openstack-run-test.sh
-
- builder:
name: integration-compare-distributions
# Operation: will compare an already created distribtion (probably last
# Required bash variables:
# KARAF_ARTIFACT: 'karaf' or 'distribution-karaf'. Use integration-set-variables.
builders:
- - shell: !include-raw: integration-compare-distributions.sh
+ - shell: !include-raw-escape: integration-compare-distributions.sh
+
+- builder:
+ name: integration-csit-archive-artifacts
+ builders:
+ - shell: !include-raw-escape: integration-csit-archive-artifacts.sh
- builder:
name: integration-upload-distribution
files:
- file-id: global-settings
variable: GLOBAL_SETTINGS_FILE
- - file-id: integration-settings
+ - file-id: "{settings-project}-settings"
variable: SETTINGS_FILE
- integration-set-variables
- inject:
- SUCCESS
- UNSTABLE
build-steps:
- - shell: |
- #!/bin/bash
- echo "Archiving csit artifacts"
- cd $WORKSPACE
- mkdir -p ./archives
- for i in `seq 1 ${NUM_ODL_SYSTEM}`; do
- NODE_FOLDER="./archives/odl_${i}"
- mkdir -p ${NODE_FOLDER}
- mv odl${i}_* ${NODE_FOLDER} || true
- mv karaf_${i}_*_threads* ${NODE_FOLDER} || true
- mv *_${i}.png ${NODE_FOLDER} || true
- mv /tmp/odl${i}_* ${NODE_FOLDER} || true
- mv gclogs-${i} ${NODE_FOLDER} || true
- done
- curl --output robot-plugin.zip "$BUILD_URL/robot/report/*zip*/robot-plugin.zip"
- unzip -d ./archives robot-plugin.zip
- mv *.log *.log.gz *.csv *.png ./archives || true # Don't fail if file missing
- # TODO: Can the following line ever fail?
- find . -type f -name *.hprof -print0 \
- | tar -cvf - --null -T - | xz --threads=0 > ./archives/hprof.tar.xz
- # TODO: Tweak the compression level if better ratio (or speed) is needed.
+ - shell: !include-raw-escape: integration-csit-archive-artifacts.sh
mark-unstable-if-failed: true
- publisher:
- SUCCESS
- UNSTABLE
build-steps:
- - config-file-provider:
- files:
- - file-id: "odl-elastic-cloud"
- target: "${HOME}/.netrc"
- - shell: |
- #!/bin/bash
- #The following script runs any configurable postplan stored in test/csit/postplans.
- if [ -f "${WORKSPACE}/test/csit/postplans/${TESTPLAN}" ]; then
- echo "postplan exists!!!"
- echo "Changing the postplan path..."
- script_name=${WORKSPACE}/test/csit/postplans/${TESTPLAN}
- cat ${script_name} | sed "s:integration:${WORKSPACE}:" > postplan.txt
- cat postplan.txt
- egrep -v '(^[[:space:]]*#|^[[:space:]]*$)' postplan.txt | while read -r line ; do
- echo "Executing ${line}..."
- ${line}
- done
- fi
- rm ${HOME}/.netrc
- mark-unstable-if-failed: true
-
-- publisher:
- name: integration-csit-collect-netvirt-logs
- publishers:
- - postbuildscript:
- builders:
- - role: BOTH
- build-on:
- - ABORTED
- - FAILURE
- - NOT_BUILT
- - SUCCESS
- - UNSTABLE
- build-steps:
- - inject:
- properties-file: "slave_addresses.txt"
- - shell: |
- #!/bin/bash
- source /tmp/common-functions.sh ${BUNDLEFOLDER}
- collect_netvirt_logs
+ - shell: !include-raw-escape: integration-csit-run-postscript.sh
mark-unstable-if-failed: true