jobs:
- 'genesis-fuel-verify-{stream}'
- - 'genesis-fuel-merge'
+ - 'genesis-fuel-merge-{stream}'
- 'genesis-fuel-daily-{stream}'
- 'genesis-fuel-build-{stream}'
- 'genesis-fuel-deploy-{stream}'
- - 'genesis-fuel-deploy-virtual'
+ - 'genesis-fuel-deploy-runner-{stream}'
+ - 'genesis-fuel-lab-reconfig-{stream}'
+ - 'genesis-fuel-deploy-virtual-{stream}'
# stream: branch with - in place of / (eg. stable-arno)
# branch: branch (eg. stable/arno)
gs-pathname: ''
- stable-arno:
branch: 'stable/arno'
- gs-pathname: 'arno'
+ gs-pathname: '/arno'
########################
# job templates
- 'fuel-workspace-cleanup'
- job-template:
- name: 'genesis-fuel-merge'
+ name: 'genesis-fuel-merge-{stream}'
project-type: freestyle
- project-parameter:
project: '{project}'
- gerrit-parameter:
- branch: 'master'
+ branch: '{branch}'
- fuel-parameter:
installer: '{installer}'
gs-pathname: ''
project-pattern: 'genesis'
branches:
- branch-compare-type: 'ANT'
- branch-pattern: '**/master'
+ branch-pattern: '**/{branch}'
file-paths:
- compare-type: ANT
pattern: 'common/**'
disabled: false
+ triggers:
+ - 'fuel-{stream}'
+
parameters:
- project-parameter:
project: '{project}'
- git-scm:
credentials-id: '{ssh-credentials}'
refspec: ''
- branch: master
+ branch: '{branch}'
logrotate:
daysToKeep: 30
- project: 'genesis-fuel-build-{stream}'
git-revision: true
block: true
+ - trigger-builds:
+ - project: 'genesis-fuel-lab-reconfig-{stream}'
+ git-revision: true
+ block: true
- trigger-builds:
- project: 'genesis-fuel-deploy-{stream}'
git-revision: true
block: true
- trigger-builds:
- - project: 'functest-opnfv-jump-1'
+ - project: 'functest-fuel-{stream}'
+ block: true
+ - trigger-builds:
+ - project: 'yardstick-opnfv-jump-2'
+ block: true
+
+- job-template:
+ name: 'genesis-fuel-deploy-runner-{stream}'
+
+ project-type: freestyle
+
+ disabled: false
+
+ node: master
+
+ logrotate:
+ daysToKeep: 30
+ numToKeep: 10
+ artifactDaysToKeep: -1
+ artifactNumToKeep: -1
+
+ parameters:
+ - project-parameter:
+ project: '{project}'
+ - foreman-parameter:
+ installer: '{installer}'
+ gs-pathname: '{gs-pathname}'
+ - string:
+ name: GIT_BASE
+ default: ssh://gerrit.opnfv.org:29418/$PROJECT
+ description: "Used for overriding the GIT URL coming from parameters macro."
+
+ scm:
+ - git-scm:
+ credentials-id: '{ssh-credentials}'
+ refspec: ''
+ branch: '{branch}'
+
+ properties:
+ - build-blocker:
+ use-build-blocker: true
+ blocking-jobs:
+ - "genesis-foreman-daily.*"
+ - "genesis-foreman-deploy-runner-{stream}"
+ - "genesis-fuel-daily.*"
+
+ builders:
+ - 'fuel-lab-reconfig'
+ - trigger-builds:
+ - project: 'genesis-fuel-deploy-{stream}'
+ git-revision: true
block: true
- job-template:
- git-scm:
credentials-id: '{ssh-credentials}'
refspec: ''
- branch: master
+ branch: '{branch}'
builders:
- 'fuel-build'
disabled: false
- node: opnfv-jump-1
+ node: opnfv-jump-2
parameters:
- project-parameter:
- string:
name: GIT_BASE
default: ssh://gerrit.opnfv.org:29418/$PROJECT
- description: "POD1 has some issues with cloning using https so that's why GIT_BASE is overriden here again."
+ description: "POD2 has some issues with cloning using https so that's why GIT_BASE is overriden here again."
scm:
- git-scm:
credentials-id: '{ssh-credentials}'
refspec: ''
- branch: master
+ branch: '{branch}'
logrotate:
daysToKeep: 30
- 'fuel-deploy'
- job-template:
- name: 'genesis-fuel-deploy-virtual'
+ name: 'genesis-fuel-lab-reconfig-{stream}'
project-type: freestyle
- disabled: true
+ disabled: false
+
+ node: master
+
+ logrotate:
+ daysToKeep: 30
+ numToKeep: 10
+ artifactDaysToKeep: -1
+ artifactNumToKeep: -1
+
+ parameters:
+ - project-parameter:
+ project: '{project}'
+ - fuel-parameter:
+ installer: '{installer}'
+ gs-pathname: '{gs-pathname}'
+ - string:
+ name: GIT_BASE
+ default: ssh://gerrit.opnfv.org:29418/$PROJECT
+ description: "Used for overriding the GIT URL coming from parameters macro."
+
+ scm:
+ - git-scm:
+ credentials-id: '{ssh-credentials}'
+ refspec: ''
+ branch: '{branch}'
+
+ properties:
+ - build-blocker:
+ use-build-blocker: true
+ blocking-jobs:
+ - "genesis-foreman-daily.*"
+
+ builders:
+ - 'fuel-lab-reconfig'
+
+- job-template:
+ name: 'genesis-fuel-deploy-virtual-{stream}'
+
+ project-type: freestyle
+
+ disabled: false
node: ericsson-build
- git-scm:
credentials-id: '{ssh-credentials}'
refspec: ''
- branch: master
+ branch: 'master'
logrotate:
daysToKeep: 30
name: GIT_BASE
default: https://gerrit.opnfv.org/gerrit/$PROJECT
description: "Used for overriding the GIT URL coming from Global Jenkins configuration in case if the stuff is done on none-LF HW."
- - string:
- name: GS_PATHNAME
- default: '{gs-pathname}'
- description: "Subdirectory to store artifacts for different branches."
- string:
name: GS_URL
- default: artifacts.opnfv.org/$PROJECT/$INSTALLER/$GS_PATHNAME
+ default: artifacts.opnfv.org/$PROJECT/$INSTALLER{gs-pathname}
description: "URL to Google Storage."
########################
chmod a+x $HOME
chmod a+x $TMPDIR
- # set TOPDIR
- export TOPDIR=$WORKSPACE/fuel/prototypes/auto-deploy
+ # set CONFDIR, BRIDGE
+ export CONFDIR=$WORKSPACE/fuel/deploy/baremetal/conf/linux_foundation_lab/pod2/ha
+ export BRIDGE=pxebr
+
+ # cleanup first
+ sudo $WORKSPACE/common/ci/clean.sh -base_config $WORKSPACE/foreman/ci/inventory/lf_pod2_ksgen_settings.yml
+
+ # prepare for Fuel Deployment
+ sudo $WORKSPACE/common/ci/setup.sh
# log info to console
echo "Starting the deployment using $INSTALLER. This could take some time..."
# start the deployment
echo "Issuing command"
- echo "sudo TMPDIR=${TMPDIR} ${TOPDIR}/deploy/deploy.sh ${WORKSPACE}/opnfv.iso ${TOPDIR}/configs/lf_pod1/dea_no-ha.yaml ${TOPDIR}/configs/lf_pod1/dha.yaml"
- sudo TMPDIR=${TMPDIR} ${TOPDIR}/deploy/deploy.sh ${WORKSPACE}/opnfv.iso ${TOPDIR}/configs/lf_pod1/dea_no-ha.yaml ${TOPDIR}/configs/lf_pod1/dha.yaml
+ echo "sudo $WORKSPACE/fuel/ci/deploy.sh $WORKSPACE/opnfv.iso $CONFDIR/dea.yaml $CONFDIR/dha.yaml -s $TMPDIR -b $BRIDGE"
+ sudo $WORKSPACE/fuel/ci/deploy.sh $WORKSPACE/opnfv.iso $CONFDIR/dea.yaml $CONFDIR/dha.yaml -s $TMPDIR -b $BRIDGE
echo
echo "--------------------------------------------------------"
- shell: |
#!/bin/bash
set -o errexit
+ set -o nounset
set -o pipefail
# log info to console
echo
echo "--------------------------------------------------------"
echo "Done!"
+ echo "Artifact is available as http://$GS_URL/opnfv-$OPNFV_ARTIFACT_VERSION.iso"
- builder:
name: 'fuel-download-artifact'
- shell: |
#!/bin/bash
set -o errexit
+ set -o nounset
set -o pipefail
# get the latest.properties file in order to get info regarding latest artifact
# delete everything that is in $WORKSPACE
/bin/rm -rf $WORKSPACE
+
+- builder:
+ name: 'fuel-lab-reconfig'
+ builders:
+ - shell: |
+ #!/bin/bash
+ set -o errexit
+ set -o nounset
+ set -o pipefail
+
+ # check to see if ucs login info file exists
+ if [ -e ~/.ssh/ucs_creds ];then
+ source ~/.ssh/ucs_creds
+ else
+ echo "Unable to find UCS credentials for LF lab reconfiguration...Exiting"
+ exit 1
+ fi
+
+ # clone releng
+ echo "Cloning releng repo..."
+ if ! GIT_SSL_NO_VERIFY=true git clone https://gerrit.opnfv.org/gerrit/releng; then
+ echo "Unable to clone releng repo...Exiting"
+ exit 1
+ fi
+
+ # log info to console
+ echo "Starting the lab reconfiguration for $INSTALLER..."
+ echo "--------------------------------------------------------"
+ echo
+
+ # create venv
+ $WORKSPACE/releng/utils/lab-reconfiguration/create_venv.sh
+
+ # disable nounset because 'activate' script contains unbound variable(s)
+ set +o nounset
+ # enter venv
+ source $WORKSPACE/releng/utils/lab-reconfiguration/venv/bin/activate
+ # set nounset back again
+ set -o nounset
+
+ # verify we are in venv
+ if [[ ! $(which python | grep venv) ]]; then
+ echo "Unable to activate venv...Exiting"
+ exit 1
+ fi
+
+ python $WORKSPACE/releng/utils/lab-reconfiguration/reconfigUcsNet.py -i $ucs_host -u $ucs_user -p $ucs_password -f $WORKSPACE/releng/utils/lab-reconfiguration/fuel.yaml
+
+ # while undergoing reboot
+ sleep 30
+
+ # check to see if slave is back up
+ ping_counter=0
+ ping_flag=0
+ while [ "$ping_counter" -lt 20 ]; do
+ if [[ $(ping -c 5 172.30.10.72) ]]; then
+ ping_flag=1
+ break
+ fi
+ ((ping_counter++))
+ sleep 10
+ done
+
+ if [ "$ping_flag" -eq 1 ]; then
+ echo "Slave is pingable, now wait 180 seconds for services to start"
+ sleep 180
+ else
+ echo "Slave did not come back up after reboot: please check opnfv-jump-2"
+ exit 1
+ fi
+
+ set +o nounset
+ deactivate
+
+ echo
+ echo "--------------------------------------------------------"
+ echo "Done!"
+
+########################
+# trigger macros
+########################
+- trigger:
+ name: 'fuel-master'
+ triggers:
+ - timed: '0 5 * * *'
+
+- trigger:
+ name: 'fuel-stable-arno'
+ triggers:
+ - timed: '0 9 * * *'