chore: enable github actions with rekres #3
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: default | |
"on": | |
push: | |
branches: | |
- main | |
tags: | |
- v* | |
pull_request: {} | |
env: | |
CI_ARGS: --cache-from=type=registry,ref=registry.dev.siderolabs.io/${GITHUB_REPOSITORY}:buildcache --cache-to=type=registry,ref=registry.dev.siderolabs.io/${GITHUB_REPOSITORY}:buildcache,mode=max | |
jobs: | |
default: | |
permissions: | |
contents: write | |
packages: write | |
runs-on: | |
- self-hosted | |
- X64 | |
steps: | |
- name: checkout | |
uses: actions/checkout@v3 | |
- name: Unshallow | |
run: | | |
git fetch --prune --unshallow | |
- name: Set up Docker Buildx | |
uses: docker/setup-buildx-action@v2 | |
with: | |
config-inline: | | |
[worker.oci] | |
gc = true | |
gckeepstorage = 100000 # 100 GiB | |
[[worker.oci.gcpolicy]] | |
keepBytes = 32212254720 # 30 GiB | |
keepDuration = 604800 | |
filters = [ "type==source.local", "type==exec.cachemount", "type==source.git.checkout"] | |
[[worker.oci.gcpolicy]] | |
all = true | |
keepBytes = 107374182400 # 100 GiB | |
- name: base | |
run: | | |
make base | |
- name: unit-tests | |
run: | | |
make unit-tests | |
- name: unit-tests-race | |
run: | | |
make unit-tests-race | |
- name: coverage | |
run: | | |
make coverage | |
- name: conform | |
run: | | |
make conform | |
- name: lint | |
run: | | |
make lint | |
- name: Login to registry | |
if: github.event_name != 'pull_request' | |
uses: docker/login-action@v2 | |
with: | |
password: ${{ secrets.GITHUB_TOKEN }} | |
registry: ghcr.io | |
username: ${{ github.repository_owner }} | |
- name: image-conform | |
run: | | |
make image-conform | |
- name: push-conform | |
if: github.event_name != 'pull_request' | |
env: | |
PUSH: "true" | |
run: | | |
make image-conform | |
- name: push-conform-latest | |
if: github.event_name != 'pull_request' | |
env: | |
PUSH: "true" | |
run: | | |
make image-conform TAG=latest | |
- name: Generate Checksums | |
if: startsWith(github.ref, 'refs/tags/') | |
run: | | |
sha256sum _out/conform-* > _out/sha256sum.txt | |
sha512sum _out/conform-* > _out/sha512sum.txt | |
- name: release-notes | |
if: startsWith(github.ref, 'refs/tags/') | |
run: | | |
make release-notes | |
- name: Release | |
if: startsWith(github.ref, 'refs/tags/') | |
uses: crazy-max/ghaction-github-release@v1 | |
with: | |
body_path: _out/RELEASE_NOTES.md | |
draft: "true" | |
files: |- | |
_out/conform-* | |
_out/sha*.txt |