X-Git-Url: https://git.opendaylight.org/gerrit/gitweb?a=blobdiff_plain;f=jjb%2Fautorelease%2Fautorelease-macros.yaml;h=2689a5a7e3c028421ac4775803f72ef1ea5d182c;hb=3f74d54d316d9ee1648aa645be5dc71fe5b6cfa3;hp=00316524b58816eca5a89db3b9e78d39bce1018f;hpb=347dd3417f85f06c999e7e9059de4df34bf57589;p=releng%2Fbuilder.git diff --git a/jjb/autorelease/autorelease-macros.yaml b/jjb/autorelease/autorelease-macros.yaml index 00316524b..e66dc54b6 100644 --- a/jjb/autorelease/autorelease-macros.yaml +++ b/jjb/autorelease/autorelease-macros.yaml @@ -8,14 +8,6 @@ default: '{release-tag}' description: "The Release train tag to use eg. Beryllium-SR1" -- parameter: - name: autorelease-release-branch - parameters: - - string: - name: RELEASE_BRANCH - default: '{release-branch}' - description: "The Release train branch to base build off eg. stable/beryllium" - - wrapper: name: autorelease-build-timeout wrappers: @@ -28,10 +20,24 @@ name: autorelease-checkout-gerrit-patch builders: - shell: | - cd ${GERRIT_PROJECT} + #!/bin/bash -l + set -eu -o pipefail + + # If the project is autorelease then we do not need to cd + if [ "$GERRIT_PROJECT" != "releng/autorelease" ]; then + cd "$WORKSPACE/$GERRIT_PROJECT" + fi + echo "Checking out ${GERRIT_PROJECT} patch ${GERRIT_REFSPEC}..." git fetch origin ${GERRIT_REFSPEC} && git checkout FETCH_HEAD - cd .. + + # If the project is autorelease then we need to init and update submodules + if [ "$GERRIT_PROJECT" == "releng/autorelease" ]; then + git submodule update --init + # The previous checkout might have failed to remove directory of a submodule being removed. + # See https://stackoverflow.com/a/10761699 + git clean -dff + fi - builder: name: autorelease-cfp @@ -47,10 +53,10 @@ name: autorelease-determine-merge-order builders: - shell: | + #!/bin/bash -l virtualenv --system-site-packages $WORKSPACE/venv source $WORKSPACE/venv/bin/activate PYTHON="$WORKSPACE/venv/bin/python" - $PYTHON -m pip install --upgrade pip $PYTHON -m pip install --upgrade networkx $PYTHON -m pip freeze ./scripts/determine-merge-order.py @@ -60,7 +66,7 @@ - builder: name: autorelease-maven-deploy builders: - - shell: !include-raw: include-raw-autorelease-maven-deploy.sh + - shell: !include-raw: autorelease-maven-deploy.sh - builder: name: autorelease-maven-sources @@ -80,51 +86,45 @@ settings-type: cfp global-settings: '{global-settings}' global-settings-type: cfp - -- builder: - name: autorelease-maven-sources-post-process - builders: - shell: | awk '/The following files have NOT been resolved:/,/^$/' sources.log > missing-sources.log -- builder: - name: autorelease-generate-taglist - builders: - - shell: | - echo autorelease `git rev-parse --verify HEAD` ${RELEASE_TAG} \ - | tee -a $WORKSPACE/taglist.log - git submodule foreach 'echo $path `git rev-parse --verify HEAD` ${RELEASE_TAG} \ - | tee -a $WORKSPACE/taglist.log' - - builder: name: autorelease-distribute-taglist builders: - integration-set-variables - shell: | - #!/bin/bash + #!/bin/bash -l set +e # DO NOT fail build if copying fails. - if [ -d "integration/distribution/distributions" ]; then - cp -vf "$WORKSPACE/taglist.log" "integration/distribution/distributions/karaf/src/main/assembly/" - else - cp -vf "$WORKSPACE/taglist.log" "integration/distribution/$KARAF_ARTIFACT/src/main/assembly/" - fi + cp -vf "$WORKSPACE/archives/patches/taglist.log" \ + "integration/distribution/$KARAF_ARTIFACT/src/main/assembly/" # DO NOT fail the build if copying failed. exit 0 +- builder: + name: autorelease-generate-artifact-versions + # Generate versions.csv containing version of all mvn artifacts in this build. + builders: + - shell: | + #!/bin/bash -l + set -eu -o pipefail + ./scripts/generate-artifact-versions.sh + mkdir -p "$WORKSPACE/archives" + mv versions.csv "$WORKSPACE/archives" + - builder: name: autorelease-generate-release-patches builders: - shell: !include-raw: - - ../global-jjb/shell/lftools-install.sh - - include-raw-autorelease-release-versions.sh + - prepare-release.sh - builder: name: autorelease-get-integration-test-variables builders: - integration-set-variables - - shell: !include-raw: include-raw-autorelease-get-integration-test-variables.sh + - shell: !include-raw: autorelease-get-integration-test-variables.sh - inject: properties-file: variables.prop @@ -137,21 +137,37 @@ - builder: name: autorelease-generate-release-notes builders: - - shell: | - cd $WORKSPACE/scripts/release_notes_management - java -jar target/autonotes.jar - if [ -f "$WORKSPACE/scripts/release_notes_management/projects/release-notes.rst" ]; then - mkdir -p $WORKSPACE/archives - cp -vf "$WORKSPACE/scripts/release_notes_management/projects/release-notes.rst" "$WORKSPACE/archives" - fi + - shell: !include-raw: + - generate-release-notes.sh + +- builder: + name: autorelease-update-project-views + builders: + - shell: !include-raw: update-autorelease-projects-views.sh + +- builder: + name: autorelease-update-validate-projects + builders: + - shell: !include-raw: update-validate-autorelease-projects.sh + +- builder: + name: autorelease-compare-projects + builders: + - shell: !include-raw: compare-autorelease-projects.sh - publisher: - # include-raw-autorelease-notify-build-failure.sh searches console log for - # failures and emails the status to the release mailing list. + # Search console log for failures and email status to the release mailing list. name: opendaylight-infra-notify-status publishers: - postbuildscript: builders: - - shell: !include-raw: include-raw-autorelease-notify-build-failure.sh - script-only-if-succeeded: 'False' - script-only-if-failed: 'True' + - role: BOTH + build-on: + - ABORTED + - FAILURE + - NOT_BUILT + - SUCCESS + - UNSTABLE + build-steps: + - shell: !include-raw: notify-build-failure.sh + mark-unstable-if-failed: true