From e91cab0c6d65119b4bfcac4bb640cbc820cbc08c Mon Sep 17 00:00:00 2001 From: dgtlmoon Date: Tue, 5 Oct 2021 10:28:27 +0200 Subject: [PATCH] try :latest and :tag in same workflow run --- .../workflows/dockerhub-container-tagged.yml | 80 ------------------- .github/workflows/dockerhub-container.yml | 3 +- .github/workflows/github-container.yml | 30 ++----- 3 files changed, 9 insertions(+), 104 deletions(-) delete mode 100644 .github/workflows/dockerhub-container-tagged.yml diff --git a/.github/workflows/dockerhub-container-tagged.yml b/.github/workflows/dockerhub-container-tagged.yml deleted file mode 100644 index d54f8c11..00000000 --- a/.github/workflows/dockerhub-container-tagged.yml +++ /dev/null @@ -1,80 +0,0 @@ -name: Build and Push > Docker Hub Container Repo by Tag - -on: - push: - tags: - - '*.*' - -jobs: - build: - runs-on: ubuntu-latest - steps: - - uses: actions/checkout@v2 - - name: Set up Python 3.9 - uses: actions/setup-python@v2 - with: - python-version: 3.9 - - - uses: olegtarasov/get-tag@v2.1 - id: tagName - -# with: -# tagRegex: "foobar-(.*)" # Optional. Returns specified group text as tag name. Full tag string is returned if regex is not defined. -# tagRegexGroup: 1 # Optional. Default is 1. - - - name: Install dependencies - run: | - python -m pip install --upgrade pip - pip install flake8 pytest - if [ -f requirements.txt ]; then pip install -r requirements.txt; fi - if [ -f requirements-dev.txt ]; then pip install -r requirements-dev.txt; fi - - - name: Create release metadata - run: | - # COPY'ed by Dockerfile into changedetectionio/ of the image, then read by the server in store.py - echo ${{ github.sha }} > changedetectionio/source.txt - echo ${{ github.ref }} > changedetectionio/tag.txt - - - name: Set up QEMU - uses: docker/setup-qemu-action@v1 - with: - image: tonistiigi/binfmt:latest - platforms: all - - name: Login to Docker Hub - uses: docker/login-action@v1 - with: - username: ${{ secrets.DOCKER_HUB_USERNAME }} - password: ${{ secrets.DOCKER_HUB_ACCESS_TOKEN }} - - - name: Set up Docker Buildx - id: buildx - uses: docker/setup-buildx-action@v1 - with: - install: true - version: latest - driver-opts: image=moby/buildkit:master - - - name: tag - run : | - set - echo ${{ github.event.release.tag_name }} - - - name: Build and push tagged version - id: docker_build - uses: docker/build-push-action@v2 - with: - context: ./ - file: ./Dockerfile - push: true - tags: | - ${{ secrets.DOCKER_HUB_USERNAME }}/changedetection.io:${{ steps.tagName.outputs.tag }} - platforms: linux/amd64,linux/arm64,linux/arm/v6,linux/arm/v7 - cache-from: type=local,src=/tmp/.buildx-cache - cache-to: type=local,dest=/tmp/.buildx-cache - env: - SOURCE_NAME: ${{ steps.branch_name.outputs.SOURCE_NAME }} - SOURCE_BRANCH: ${{ steps.branch_name.outputs.SOURCE_BRANCH }} - SOURCE_TAG: ${{ steps.branch_name.outputs.SOURCE_TAG }} - - - name: Image digest - run: echo step SHA ${{ steps.vars.outputs.sha_short }} tag ${{steps.vars.outputs.tag}} branch ${{steps.vars.outputs.branch}} digest ${{ steps.docker_build.outputs.digest }} diff --git a/.github/workflows/dockerhub-container.yml b/.github/workflows/dockerhub-container.yml index 8169b012..673f943f 100644 --- a/.github/workflows/dockerhub-container.yml +++ b/.github/workflows/dockerhub-container.yml @@ -57,7 +57,8 @@ jobs: file: ./Dockerfile push: true tags: | - ${{ secrets.DOCKER_HUB_USERNAME }}/changedetection.io + ${{ secrets.DOCKER_HUB_USERNAME }}/changedetection.io:latest + ${{ secrets.DOCKER_HUB_USERNAME }}/changedetection.io:${{ steps.tagName.outputs.tag }} platforms: linux/amd64,linux/arm64,linux/arm/v6,linux/arm/v7 cache-from: type=local,src=/tmp/.buildx-cache cache-to: type=local,dest=/tmp/.buildx-cache diff --git a/.github/workflows/github-container.yml b/.github/workflows/github-container.yml index 5ce15c65..68e71c52 100644 --- a/.github/workflows/github-container.yml +++ b/.github/workflows/github-container.yml @@ -1,18 +1,14 @@ name: Build and Push > GitHub Container Repo - on: - push: - tags: - - '*.*' - branches: - - master - - gcr + workflow_run: + workflows: ["ChangeDetection.io Test"] + types: [completed] jobs: - build: + on-success: runs-on: ubuntu-latest + if: ${{ github.event.workflow_run.conclusion == 'success' }} steps: - - uses: actions/checkout@v2 - name: Set up Python 3.9 uses: actions/setup-python@v2 @@ -34,24 +30,12 @@ jobs: if [ -f requirements.txt ]; then pip install -r requirements.txt; fi if [ -f requirements-dev.txt ]; then pip install -r requirements-dev.txt; fi - - name: Lint with flake8 - run: | - # stop the build if there are Python syntax errors or undefined names - flake8 . --count --select=E9,F63,F7,F82 --show-source --statistics - # exit-zero treats all errors as warnings. The GitHub editor is 127 chars wide - flake8 . --count --exit-zero --max-complexity=10 --max-line-length=127 --statistics - - name: Create release metadata run: | # COPY'ed by Dockerfile into changedetectionio/ of the image, then read by the server in store.py echo ${{ github.sha }} > changedetectionio/source.txt echo ${{ github.ref }} > changedetectionio/tag.txt - - name: Test with pytest - run: | - # Each test is totally isolated and performs its own cleanup/reset - cd changedetectionio; ./run_all_tests.sh - - name: Set up QEMU uses: docker/setup-qemu-action@v1 with: @@ -81,10 +65,10 @@ jobs: uses: docker/build-push-action@v2 with: push: true # Will only build if this is not here -# ghcr.io/${{ github.repository }}:${{ github.ref }} tags: | ghcr.io/${{ github.repository }}:latest - context: ./ + ghcr.io/dgtlmoon/changedetection.io:${{ steps.tagName.outputs.tag }} + context: . file: ./Dockerfile platforms: linux/amd64,linux/arm64,linux/arm/v6,linux/arm/v7 cache-from: type=local,src=/tmp/.buildx-cache