ci: repository-dispatch@v3 #77
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: Main | |
on: | |
push: | |
branches: | |
- "*" | |
tags: | |
- "v*.*.*" | |
pull_request: {} | |
env: | |
APP_NAME: samling | |
IMAGE_NAME: samling | |
BUILD_CACHE_IMAGE_NAME: samling-cache | |
jobs: | |
clippy: | |
name: Check for common code mistakes | |
runs-on: ubuntu-latest | |
steps: | |
- uses: actions/checkout@v4 | |
- uses: dtolnay/rust-toolchain@stable | |
- uses: Swatinem/rust-cache@v2 | |
- name: Run clippy | |
continue-on-error: true | |
run: cargo clippy -- -D warnings | |
fmt: | |
name: Check code format | |
runs-on: ubuntu-latest | |
steps: | |
- uses: actions/checkout@v4 | |
- uses: dtolnay/rust-toolchain@stable | |
- uses: Swatinem/rust-cache@v2 | |
- name: Run rustfmt | |
continue-on-error: true | |
run: cargo fmt --all -- --check | |
test: | |
name: Test | |
runs-on: ubuntu-latest | |
steps: | |
- uses: actions/checkout@v4 | |
- uses: dtolnay/rust-toolchain@stable | |
- uses: Swatinem/rust-cache@v2 | |
- name: Run tests | |
run: cargo test --release | |
cargo-deny: | |
runs-on: ubuntu-latest | |
steps: | |
- uses: jacobsvante/cargo-deny-action@v1 | |
build-docker-image: | |
name: Build Docker image | |
runs-on: ubuntu-latest | |
if: ${{ github.repository == 'hyperkliv/samling' }} | |
steps: | |
- name: Checkout | |
uses: actions/checkout@v4 | |
- name: Set up Docker Buildx | |
uses: docker/setup-buildx-action@v3 | |
- name: Log in to Docker Hub registry | |
uses: docker/login-action@v3 | |
with: | |
username: ${{ secrets.DOCKERHUB_USER }} | |
password: ${{ secrets.DOCKERHUB_PASSWORD }} | |
- name: Build and push Docker image | |
uses: docker/build-push-action@v6 | |
with: | |
push: true | |
tags: ${{ secrets.DOCKERHUB_USER }}/${{ env.IMAGE_NAME }}:${{ github.sha }} | |
cache-from: | | |
type=registry,ref=${{ secrets.DOCKERHUB_USER }}/${{ env.BUILD_CACHE_IMAGE_NAME }}:${{ github.sha }} | |
type=registry,ref=${{ secrets.DOCKERHUB_USER }}/${{ env.BUILD_CACHE_IMAGE_NAME }}:main | |
cache-to: | | |
type=registry,ref=${{ secrets.DOCKERHUB_USER }}/${{ env.BUILD_CACHE_IMAGE_NAME }}:${{ github.sha }},compression=zstd,mode=max | |
test-docker-image: | |
name: Test Docker image | |
runs-on: ubuntu-latest | |
needs: [build-docker-image] | |
if: ${{ github.repository == 'hyperkliv/samling' }} | |
steps: | |
- name: Log in to Docker Hub registry | |
uses: docker/login-action@v3 | |
with: | |
username: ${{ secrets.DOCKERHUB_USER }} | |
password: ${{ secrets.DOCKERHUB_PASSWORD }} | |
- name: Create network | |
run: docker network create test | |
- name: Start postgres container | |
run: | | |
docker run \ | |
--name postgres \ | |
--network test \ | |
--rm \ | |
--detach \ | |
--env POSTGRES_DB=samling \ | |
--env POSTGRES_USER=samling \ | |
--env POSTGRES_PASSWORD=samling \ | |
--hostname postgres \ | |
postgres:14.5-alpine3.16 | |
until docker exec postgres pg_isready; do sleep 0.5; done | |
- name: Start samling container | |
run: | | |
docker run \ | |
--publish 8080:8080 \ | |
--network test \ | |
--rm \ | |
--detach \ | |
--env LOG_LEVEL=info \ | |
--env SECRET=abc123 \ | |
--env DB_NAME=samling \ | |
--env DB_HOST=postgres \ | |
--env DB_USER=samling \ | |
--env DB_PASSWORD=samling \ | |
--env DB_AUTO_MIGRATE=true \ | |
--env CLOUDFLARE_ACCOUNT_ID=abc \ | |
--env CLOUDFLARE_TOKEN=123 \ | |
${{ secrets.DOCKERHUB_USER }}/${{ env.IMAGE_NAME }}:${{ github.sha }} | |
sleep 1 | |
- name: Check /api/readyz response | |
run: | | |
curl http://127.0.0.1:8080/api/readyz > output.json | |
jq . output.json | |
[[ $(jq .ok output.json) == true ]] | |
- name: Notify hyperkliv/www-samling-io | |
uses: peter-evans/repository-dispatch@v3 | |
with: | |
token: ${{ secrets.TRIGGERING_GITHUB_TOKEN }} | |
repository: hyperkliv/www-samling-io | |
event-type: new-samling-docker-image | |
client-payload: '{"sha": "${{ github.sha }}"}' | |
version-tag-docker-image: | |
name: Add version tags to Docker image | |
needs: [test-docker-image] | |
runs-on: ubuntu-latest | |
permissions: | |
contents: read | |
pull-requests: write | |
issues: read | |
repository-projects: read | |
if: ${{ github.repository == 'hyperkliv/samling' && github.ref_type == 'tag' }} | |
steps: | |
- name: Get the version | |
id: version | |
run: echo version=${GITHUB_REF_NAME/v/} >> $GITHUB_OUTPUT | |
shell: bash | |
- uses: jacobsvante/[email protected] | |
if: ${{ steps.version.outputs.version != '' }} | |
with: | |
version: ${{ steps.version.outputs.version }} | |
image: ${{ secrets.DOCKERHUB_USER }}/${{ env.IMAGE_NAME }} | |
username: ${{ secrets.DOCKERHUB_USER }} | |
password: ${{ secrets.DOCKERHUB_PASSWORD }} | |
- name: Notify hyperkliv/www-samling-io | |
uses: peter-evans/repository-dispatch@v3 | |
if: ${{ steps.version.outputs.version != '' }} | |
with: | |
token: ${{ secrets.TRIGGERING_GITHUB_TOKEN }} | |
repository: hyperkliv/www-samling-io | |
event-type: new-samling-docker-image | |
client-payload: '{"sha": "${{ github.sha }}", "version": "${{ steps.version.outputs.version }}" }' | |
release-please: | |
needs: [clippy, cargo-deny, test] | |
runs-on: ubuntu-latest | |
if: ${{ github.repository == 'hyperkliv/samling' && github.ref == 'refs/heads/main' }} | |
permissions: | |
contents: write | |
pull-requests: write | |
steps: | |
- uses: actions/checkout@v4 | |
- uses: googleapis/release-please-action@v4 | |
id: release | |
with: | |
# https://docs.github.com/en/actions/using-workflows/triggering-a-workflow#triggering-a-workflow-from-a-workflow | |
# NOTE: The custom github token is important, as it allows the workflow to trigger new workflows | |
# release-please sometimes creates new tags, which we want to run this workflow with. | |
token: ${{ secrets.TRIGGERING_GITHUB_TOKEN }} | |
- name: Tag major and minor versions in Git | |
if: ${{ steps.release.outputs.release_created }} | |
uses: jacobsvante/[email protected] | |
with: | |
major: ${{ steps.release.outputs.major }} | |
minor: ${{ steps.release.outputs.minor }} | |
publish: | |
name: Publish to crates.io | |
runs-on: ubuntu-latest | |
if: ${{ github.repository == 'hyperkliv/samling' && github.ref_type == 'tag' }} | |
permissions: | |
contents: write | |
pull-requests: write | |
env: | |
CARGO_REGISTRY_TOKEN: ${{ secrets.CARGO_REGISTRY_TOKEN }} | |
steps: | |
- uses: actions/checkout@v4 | |
- uses: dtolnay/rust-toolchain@stable | |
- uses: Swatinem/rust-cache@v2 | |
- run: cargo publish -p samling-clorinde | |
- run: cargo publish -p samling |