diff --git a/.github/actions/setup-branch/action.yml b/.github/actions/setup-branch/action.yml index 7dae9376873..e47c0d15aa8 100644 --- a/.github/actions/setup-branch/action.yml +++ b/.github/actions/setup-branch/action.yml @@ -10,7 +10,7 @@ runs: pull_request) BRANCH=${GITHUB_HEAD_REF} ;; - push) + push | release) BRANCH=${GITHUB_REF##*/} ;; esac diff --git a/.github/workflows/ci-build-binaries.yml b/.github/workflows/ci-build-binaries.yml new file mode 100644 index 00000000000..c3441180fa0 --- /dev/null +++ b/.github/workflows/ci-build-binaries.yml @@ -0,0 +1,28 @@ +name: Build binaries + +on: + push: + branches: [ master ] + pull_request: + branches: [ master ] + +jobs: + build-binaries: + runs-on: ubuntu-latest + steps: + - uses: actions/checkout@v2 + with: + submodules: true + + - uses: actions/setup-go@v2 + with: + go-version: ^1.15 + + - name: Export BRANCH variable + uses: ./.github/actions/setup-branch + + - name: Install tools + run: make install-ci + + - name: Build binaries + run: make build-all-platforms diff --git a/.github/workflows/ci-docker-build.yml b/.github/workflows/ci-docker-build.yml new file mode 100644 index 00000000000..5a8692c3e52 --- /dev/null +++ b/.github/workflows/ci-docker-build.yml @@ -0,0 +1,53 @@ +name: Build docker images + +on: + push: + branches: [ master ] + pull_request: + branches: [ master ] + +jobs: + docker-images: + runs-on: ubuntu-latest + steps: + - uses: actions/checkout@v2 + with: + submodules: true + + - name: Fetch git tags + run: | + git fetch --prune --unshallow --tags + + - uses: actions/setup-go@v2 + with: + go-version: ^1.15 + + - uses: actions/setup-node@v2-beta + with: + node-version: '10' + + - uses: docker/login-action@v1 + id: dockerhub-login + with: + username: jaegertracingbot + password: ${{ secrets.DOCKERHUB_TOKEN }} + env: + DOCKERHUB_TOKEN: ${{ secrets.DOCKERHUB_TOKEN }} + if: env.DOCKERHUB_TOKEN != null + + - name: Export DOCKERHUB_LOGIN variable + run: | + echo "DOCKERHUB_LOGIN=true" >> $GITHUB_ENV + if: steps.dockerhub-login.outcome == 'success' + + - name: Export BRANCH variable + uses: ./.github/actions/setup-branch + + - name: Install tools + run: make install-ci + + - name: Build docker images + run: make docker + + - name: Upload docker images + run: bash scripts/travis/upload-all-docker-images.sh diff --git a/.github/workflows/ci-release.yml b/.github/workflows/ci-release.yml new file mode 100644 index 00000000000..b4b9affff1b --- /dev/null +++ b/.github/workflows/ci-release.yml @@ -0,0 +1,75 @@ +name: Publish release + +on: + release: + types: + - published + +jobs: + publish-release: + runs-on: ubuntu-latest + steps: + - uses: actions/checkout@v2 + with: + submodules: true + + - name: Fetch git tags + run: | + git fetch --prune --unshallow --tags + + - uses: actions/setup-go@v2 + with: + go-version: ^1.15 + + - uses: actions/setup-node@v2-beta + with: + node-version: '10' + + - uses: docker/login-action@v1 + id: dockerhub-login + with: + username: jaegertracingbot + password: ${{ secrets.DOCKERHUB_TOKEN }} + env: + DOCKERHUB_TOKEN: ${{ secrets.DOCKERHUB_TOKEN }} + if: env.DOCKERHUB_TOKEN != null + + - name: Export DOCKERHUB_LOGIN variable + run: | + echo "DOCKERHUB_LOGIN=true" >> $GITHUB_ENV + if: steps.dockerhub-login.outcome == 'success' + + - name: Export BRANCH variable + uses: ./.github/actions/setup-branch + + - name: Install tools + run: make install-ci + + - name: Build binaries + id: build-binaries + run: make build-all-platforms + + - name: Package binaries + id: package-binaries + run: bash scripts/travis/package-deploy.sh + if: steps.build-binaries.outcome == 'success' + + - name: Upload binaries + uses: svenstaro/upload-release-action@v2 + with: + file: deploy/*.tar.gz + file_glob: true + tag: ${{ github.ref }} + repo_token: ${{ secrets.GITHUB_TOKEN }} + if: steps.package-binaries.outcome == 'success' + + - name: Build docker images + id: build-images + run: make docker + + - name: Upload docker images + run: bash scripts/travis/upload-all-docker-images.sh + if: steps.build-images.outcome == 'success' + + - name: Build, test, and publish all-in-one image + run: bash scripts/travis/build-all-in-one-image.sh diff --git a/scripts/travis/package-deploy.sh b/scripts/travis/package-deploy.sh index 2bed8213843..e0e22540bad 100755 --- a/scripts/travis/package-deploy.sh +++ b/scripts/travis/package-deploy.sh @@ -46,12 +46,6 @@ function package { rm -rf $PACKAGE_STAGING_DIR } -# script start -if [ "$DEPLOY" != true ]; then - echo "Skipping the packaging of binaries as \$DEPLOY was not true." - exit 0 -fi - set -e DEPLOY_STAGING_DIR=./deploy-staging diff --git a/scripts/travis/upload-all-docker-images.sh b/scripts/travis/upload-all-docker-images.sh index 8273b950a1f..2fc33892c61 100755 --- a/scripts/travis/upload-all-docker-images.sh +++ b/scripts/travis/upload-all-docker-images.sh @@ -1,18 +1,14 @@ #!/bin/bash -# this script should only be run after build-docker-images.sh +# this script expects all docker images to be already built, it only uploads them to Docker Hub -set -e +set -euxf -o pipefail BRANCH=${BRANCH:?'missing BRANCH env var'} +DOCKERHUB_LOGIN=${DOCKERHUB_LOGIN:-false} -if [[ "$TRAVIS_SECURE_ENV_VARS" == "false" ]]; then - echo "skip docker upload, TRAVIS_SECURE_ENV_VARS=$TRAVIS_SECURE_ENV_VARS" - exit 0 -fi - -# Only push images to Docker Hub for master branch or for release tags vM.N.P -if [[ "$BRANCH" == "master" || $BRANCH =~ ^v[0-9]+\.[0-9]+\.[0-9]+$ ]]; then +# Only push images to Docker Hub for master branch or for release tags vM.N.P and when dockerhub login is done +if [[ ("$BRANCH" == "master" || $BRANCH =~ ^v[0-9]+\.[0-9]+\.[0-9]+$) && "$DOCKERHUB_LOGIN" == "true" ]]; then echo "upload to Docker Hub, BRANCH=$BRANCH" else echo 'skip Docker upload, only allowed for tagged releases or master (latest tag)'