Skip to content

chore: snub codecov codecov/codecov-action/issues/1262 #80

chore: snub codecov codecov/codecov-action/issues/1262

chore: snub codecov codecov/codecov-action/issues/1262 #80

Workflow file for this run

name: release
on:
push:
branches:
- main
jobs:
release:
runs-on: ubuntu-latest
outputs:
release_created: ${{ steps.release-please.outputs.release_created }}
steps:
- uses: actions/checkout@v2
- uses: google-github-actions/release-please-action@v3
id: release-please
with:
release-type: python
extra-files: |
icon_governance/config.py
test:
runs-on: ubuntu-latest
needs: release
if: ${{ needs.release.outputs.release_created }}
steps:
- name: Checkout
uses: actions/checkout@v2
- name: Install deps
run: |
pip3 install -r requirements_api.txt -r requirements_worker.txt -r requirements_dev.txt
- name: Bring up stack
run: make up-dbs && sleep 30
- name: Check stack
run: make ps
- name: Run tests with coverage
run: make test-coverage
- uses: codecov/codecov-action@v2
with:
token: ${{ secrets.CODECOV_TOKEN }}
files: ./coverage.xml
fail_ci_if_error: true
docker:
runs-on: ubuntu-latest
needs: test
if: ${{ needs.release.outputs.release_created }}
outputs:
tag: ${{ steps.source.outputs.TAG }}
steps:
- name: Checkout
uses: actions/checkout@v2
- id: last
uses: pozetroninc/github-action-get-latest-release@master
with:
repository: ${{ github.repository }}
- name: Tag name
id: source
run: |
echo ::set-output name=TAG::${{ steps.last.outputs.release }}-${{ github.run_number }}
- name: Login to DockerHub
uses: docker/login-action@v1
with:
username: ${{ secrets.DOCKERHUB_USERNAME }}
password: ${{ secrets.DOCKERHUB_TOKEN }}
- name: Build and push API
uses: docker/build-push-action@v2
with:
context: .
file: ./Dockerfile
target: prod
push: true
build-args: |
SERVICE_NAME=api
tags: sudoblock/icon-governance-api:latest, sudoblock/icon-governance-api:${{ steps.source.outputs.TAG }}
- name: Build and push worker
uses: docker/build-push-action@v2
with:
context: .
file: ./Dockerfile
target: prod
push: true
build-args: |
SERVICE_NAME=worker
tags: sudoblock/icon-governance-worker:latest, sudoblock/icon-governance-worker:${{ steps.source.outputs.TAG }}
push_refs:
runs-on: ubuntu-latest
needs: docker
if: ${{ needs.release.outputs.release_created }}
strategy:
max-parallel: 1
matrix:
include:
- cluster: prod-ams
network_name: mainnet
network_version: v2
- cluster: prod-ams
network_name: lisbon
network_version: v2
- cluster: prod-ams
network_name: berlin
network_version: v2
steps:
- name: Checkout charts repo
uses: actions/checkout@v2
with:
repository: sudoblockio/icon-charts
ref: main
path: charts
token: ${{ secrets.ICON_CHARTS_PAT }}
- name: Update API ${{ matrix.cluster }}/${{ matrix.network_name }}-${{ matrix.network_version }} deployment values file
uses: fjogeleit/yaml-update-action@master
with:
workDir: charts
repository: sudoblockio/icon-charts
valueFile: 'deployments/${{ matrix.cluster }}/${{ matrix.network_name }}-${{ matrix.network_version }}/governance/tags.yaml'
propertyPath: 'api.image.tag'
value: ${{needs.docker.outputs.tag}}
branch: main
createPR: 'false'
updateFile: true
commitChange: false
- name: Update worker ${{ matrix.cluster }}/${{ matrix.network_name }}-${{ matrix.network_version }} deployment values file
uses: fjogeleit/yaml-update-action@master
with:
workDir: charts
repository: sudoblockio/icon-charts
valueFile: 'deployments/${{ matrix.cluster }}/${{ matrix.network_name }}-${{ matrix.network_version }}/governance/tags.yaml'
propertyPath: 'worker.image.tag'
value: ${{needs.docker.outputs.tag}}
branch: main
createPR: 'false'
updateFile: true
message: "governance ${{ matrix.cluster }}/${{ matrix.network_name }}-${{ matrix.network_version }} deployment image version to ${{needs.docker.outputs.tag}}"
token: '${{ secrets.ICON_CHARTS_PAT }}'