improve ci #610
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: Check Stuff 👨🔧 | ||
on: | ||
merge_group: | ||
pull_request: | ||
push: | ||
branches: | ||
- main | ||
concurrency: | ||
group: ${{ github.ref }} | ||
cancel-in-progress: ${{ github.ref != 'refs/heads/main' }} | ||
permissions: | ||
packages: write | ||
pages: write | ||
id-token: write | ||
contents: read | ||
jobs: | ||
clippy: | ||
if: ${{ github.event_name == 'pull_request' || github.event_name == 'merge_group' }} | ||
name: Clippy | ||
runs-on: ubuntu-latest | ||
steps: | ||
- uses: actions/checkout@v4 | ||
- uses: taiki-e/install-action@just | ||
- uses: rui314/setup-mold@v1 | ||
- uses: heliaxdev/setup-protoc@v2 | ||
with: | ||
version: "25.0" | ||
repo-token: ${{ secrets.GITHUB_TOKEN }} | ||
- uses: actions-rust-lang/setup-rust-toolchain@v1 | ||
with: | ||
cache: true | ||
- run: just clippy | ||
test: | ||
if: ${{ github.event_name == 'pull_request' || github.event_name == 'merge_group' }} | ||
name: Tests | ||
runs-on: ubuntu-latest | ||
services: | ||
postgres: | ||
image: postgres:16-alpine | ||
env: | ||
POSTGRES_USER: postgres | ||
POSTGRES_PASSWORD: password | ||
PGUSER: postgres | ||
POSTGRES_DB: namada-indexer | ||
options: >- | ||
--health-cmd pg_isready | ||
--health-interval 10s | ||
--health-timeout 5s | ||
--health-retries 5 | ||
ports: | ||
- 5432:5432 | ||
steps: | ||
- uses: actions/checkout@v4 | ||
- uses: taiki-e/install-action@just | ||
- uses: rui314/setup-mold@v1 | ||
- uses: heliaxdev/setup-protoc@v2 | ||
with: | ||
version: "25.0" | ||
repo-token: ${{ secrets.GITHUB_TOKEN }} | ||
- uses: actions-rust-lang/setup-rust-toolchain@v1 | ||
with: | ||
cache: true | ||
- run: just test | ||
env: | ||
DATABASE_URL_TEST: postgres://postgres:[email protected]:5432 | ||
validate-swagger: | ||
runs-on: ubuntu-latest | ||
name: Validate Swagger | ||
steps: | ||
- uses: actions/checkout@v4 | ||
- name: Validate OpenAPI definition | ||
uses: swaggerexpert/swagger-editor-validate@v1 | ||
with: | ||
definition-file: swagger.yml | ||
format: | ||
if: ${{ github.event_name == 'pull_request' || github.event_name == 'merge_group' }} | ||
name: Format | ||
runs-on: ubuntu-latest | ||
steps: | ||
- uses: actions/checkout@v4 | ||
- uses: taiki-e/install-action@just | ||
- uses: rui314/setup-mold@v1 | ||
- uses: heliaxdev/setup-protoc@v2 | ||
with: | ||
version: "25.0" | ||
repo-token: ${{ secrets.GITHUB_TOKEN }} | ||
- uses: actions-rust-lang/setup-rust-toolchain@v1 | ||
with: | ||
toolchain: nightly | ||
components: rustfmt | ||
cache: true | ||
- run: just fmt | ||
docker: | ||
name: Docker | ||
runs-on: ubuntu-latest | ||
if: ${{ github.event_name == 'merge_group' || github.event_name == 'pull_request' }} | ||
env: | ||
GIT_LFS_SKIP_SMUDGE: 1 | ||
REGISTRY_URL: ghcr.io | ||
strategy: | ||
fail-fast: true | ||
matrix: | ||
docker: | ||
[ | ||
{ image: chain, package: chain }, | ||
{ image: governance, package: governance }, | ||
{ image: pos, package: pos }, | ||
{ image: rewards, package: rewards }, | ||
{ image: seeder, package: seeder }, | ||
{ image: webserver, package: webserver }, | ||
{ image: parameters, package: parameters }, | ||
{ image: transactions, package: transactions }, | ||
] | ||
steps: | ||
- name: Checkout repo | ||
uses: actions/checkout@v4 | ||
- name: Set up Docker Buildx | ||
uses: docker/setup-buildx-action@v3 | ||
- name: Docker meta | ||
id: meta | ||
uses: docker/metadata-action@v5 | ||
with: | ||
images: ${{ env.REGISTRY_URL }}/anoma/namada-indexer | ||
flavor: | | ||
latest=auto | ||
prefix=${{ matrix.docker.image }} | ||
suffix= | ||
tags: | | ||
type=ref,event=branch | ||
type=ref,event=pr | ||
type=semver,pattern={{version}} | ||
type=semver,pattern={{major}}.{{minor}} | ||
- name: Login to GHCR | ||
uses: docker/login-action@v3 | ||
with: | ||
registry: ghcr.io | ||
username: ${{ github.repository_owner }} | ||
password: ${{ secrets.GITHUB_TOKEN }} | ||
- name: Build and Push | ||
id: push | ||
uses: docker/build-push-action@v5 | ||
with: | ||
context: . | ||
file: Dockerfile | ||
build-args: PACKAGE=${{matrix.docker.package}} | ||
push: true | ||
tags: ${{ steps.meta.outputs.tags }} | ||
labels: ${{ steps.meta.outputs.labels }} | ||
cache-from: type=gha | ||
cache-to: type=gha,mode=max | ||
can_enqueue: | ||
needs: [clippy, format, build, validate-swagger] | ||
if: always() && github.event_name != 'merge_group' | ||
permissions: | ||
actions: read | ||
runs-on: ubuntu-latest | ||
steps: | ||
- env: | ||
NEEDS_JSON: "${{toJSON(needs)}}" | ||
name: Transform outcomes | ||
run: | | ||
echo "ALL_SUCCESS=$(echo "$NEEDS_JSON" | jq '. | to_entries | map([.value.result == "success", .value.result == "skipped"] | any) | all')" >> $GITHUB_ENV | ||
- name: check outcomes | ||
run: "[ $ALL_SUCCESS == true ]" | ||
can_merge: | ||
needs: [clippy, format, docker, validate-swagger] | ||
if: always() && github.event_name == 'merge_group' | ||
permissions: | ||
contents: read | ||
pages: write | ||
actions: read | ||
id-token: write | ||
runs-on: ubuntu-latest | ||
steps: | ||
- env: | ||
NEEDS_JSON: "${{toJSON(needs)}}" | ||
name: Transform outcomes | ||
run: | | ||
echo "ALL_SUCCESS=$(echo "$NEEDS_JSON" | jq '. | to_entries | map([.value.result == "success", .value.result == "skipped"] | any) | all')" >> $GITHUB_ENV | ||
- name: check outcomes | ||
run: "[ $ALL_SUCCESS == true ]" | ||