X-Git-Url: https://git.opendaylight.org/gerrit/gitweb?a=blobdiff_plain;f=jjb%2Fautorelease%2Fautorelease-macros.yaml;h=06daa22d2d138890afba844aa2ddbca2d81f6531;hb=45dda826d667777fa16b4e937bce5e736cdcfa3c;hp=83653e4e54736ec55fac413d3e27d4e7c3d74933;hpb=d51dbb74ba2115f10dea28fe069dcecc6076107a;p=releng%2Fbuilder.git diff --git a/jjb/autorelease/autorelease-macros.yaml b/jjb/autorelease/autorelease-macros.yaml index 83653e4e5..06daa22d2 100644 --- a/jjb/autorelease/autorelease-macros.yaml +++ b/jjb/autorelease/autorelease-macros.yaml @@ -34,6 +34,9 @@ # 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: @@ -55,7 +58,8 @@ PYTHON="$WORKSPACE/venv/bin/python" $PYTHON -m pip install --upgrade pip $PYTHON -m pip install --upgrade networkx - $PYTHON -m pip freeze + $PYTHON -m pip install --upgrade pipdeptree + pipdeptree ./scripts/determine-merge-order.py deactivate rm -rf $WORKSPACE/venv @@ -63,7 +67,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 @@ -90,15 +94,6 @@ - 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: @@ -107,15 +102,23 @@ #!/bin/bash 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 + 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: @@ -127,7 +130,7 @@ 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 @@ -140,21 +143,20 @@ - 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-validate-projects + builders: + - shell: !include-raw: update-validate-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' + - shell: !include-raw: notify-build-failure.sh + script-only-if-succeeded: false + script-only-if-failed: true