Adding version label in downstream image (#673) #464
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
name: Build and push to quay.io | |
on: | |
push: | |
branches: [ main, release-*, workflow-test ] | |
env: | |
WF_REGISTRY_USER: netobserv+github_ci | |
WF_ORG: netobserv | |
WF_MULTIARCH_TARGETS: amd64 arm64 ppc64le s390x | |
WF_VERSION: ${{ github.ref_name }} | |
jobs: | |
push-image: | |
name: push image | |
runs-on: ubuntu-latest | |
strategy: | |
matrix: | |
go: ['1.22'] | |
steps: | |
- name: install make | |
run: sudo apt-get install make | |
- name: set up go 1.x | |
uses: actions/setup-go@v3 | |
with: | |
go-version: ${{ matrix.go }} | |
- name: checkout | |
uses: actions/checkout@v3 | |
- name: docker login to quay.io | |
uses: docker/login-action@v2 | |
with: | |
username: ${{ env.WF_REGISTRY_USER }} | |
password: ${{ secrets.QUAY_SECRET }} | |
registry: quay.io | |
- name: get short sha | |
run: echo "short_sha=$(git rev-parse --short HEAD)" >> $GITHUB_ENV | |
- name: build and push manifest with images | |
run: | | |
MULTIARCH_TARGETS="${{ env.WF_MULTIARCH_TARGETS }}" IMAGE_ORG=${{ env.WF_ORG }} VERSION=${{ env.WF_VERSION }} CLEAN_BUILD=1 make images | |
MULTIARCH_TARGETS="${{ env.WF_MULTIARCH_TARGETS }}" IMAGE_ORG=${{ env.WF_ORG }} VERSION=${{ env.short_sha }} CLEAN_BUILD=1 OCI_BUILD_OPTS="--label quay.expires-after=2w" make images | |
if [[ "main" == "$WF_VERSION" ]]; then | |
MULTIARCH_TARGETS="${{ env.WF_MULTIARCH_TARGETS }}" IMAGE_ORG=${{ env.WF_ORG }} VERSION=latest CLEAN_BUILD=1 make images | |
fi | |
- name: build and push manifest with images for standalone build | |
run: | | |
MULTIARCH_TARGETS="${{ env.WF_MULTIARCH_TARGETS }}" IMAGE_ORG=${{ env.WF_ORG }} VERSION=${{ env.WF_VERSION }} CLEAN_BUILD=1 STANDALONE=true make images | |
codecov-back: | |
name: Codecov backend upload | |
runs-on: ubuntu-latest | |
strategy: | |
matrix: | |
go: ['1.22'] | |
steps: | |
- name: install make | |
run: sudo apt-get install make | |
- name: set up go 1.x | |
uses: actions/setup-go@v3 | |
with: | |
go-version: ${{ matrix.go }} | |
- name: checkout | |
uses: actions/checkout@v3 | |
- name: Test | |
run: make test-backend | |
- name: Report coverage | |
uses: codecov/codecov-action@v4 | |
env: | |
CODECOV_TOKEN: ${{ secrets.CODECOV_TOKEN }} | |
with: | |
files: ./cover.out | |
flags: unittests | |
fail_ci_if_error: true | |
verbose: true | |
codecov-front: | |
name: Codecov frontend upload | |
runs-on: ubuntu-latest | |
steps: | |
- name: install make | |
run: sudo apt-get install make | |
- name: set up node.js | |
uses: actions/setup-node@v3 | |
with: | |
node-version: 18 | |
- name: checkout | |
uses: actions/checkout@v3 | |
- name: Test | |
run: make install-frontend test-frontend | |
- name: Report coverage | |
uses: codecov/codecov-action@v4 | |
env: | |
CODECOV_TOKEN: ${{ secrets.CODECOV_TOKEN }} | |
with: | |
files: ./web/coverage/cobertura-coverage.xml | |
flags: uitests | |
fail_ci_if_error: true | |
verbose: true |