79 lines
3.3 KiB
YAML
79 lines
3.3 KiB
YAML
name: aws-zig nightly build
|
|
run-name: ${{ github.actor }} building AWS Zig SDK
|
|
on:
|
|
schedule:
|
|
- cron: '30 12 * * *' # 12:30 UTC, 4:30AM Pacific
|
|
push:
|
|
branches:
|
|
- 'zig-develop*'
|
|
env:
|
|
PKG_PREFIX: nightly-zig
|
|
jobs:
|
|
build-zig-nightly:
|
|
container:
|
|
# We need CAP_SYS_PTRACE for stack traces due to a regression in 0.14.0
|
|
# TODO: Remove this after https://github.com/ziglang/zig/issues/21815 is
|
|
# addressed
|
|
options: --cap-add CAP_SYS_PTRACE
|
|
runs-on: ubuntu-latest
|
|
# Need to use the default container with node and all that, so we can
|
|
# use JS-based actions like actions/checkout@v3...
|
|
# container:
|
|
# image: alpine:3.15.0
|
|
steps:
|
|
- name: Check out repository code
|
|
uses: actions/checkout@v3
|
|
with:
|
|
ref: zig-develop
|
|
- name: Setup Zig
|
|
uses: https://git.lerch.org/lobo/setup-zig@v3
|
|
with:
|
|
version: master
|
|
- name: Run tests
|
|
run: zig build test --verbose
|
|
# Zig package manager expects everything to be inside a directory in the archive,
|
|
# which it then strips out on download. So we need to shove everything inside a directory
|
|
# the way GitHub/Gitea does for repo archives
|
|
#
|
|
# Also, zig tar process doesn't handle gnu format for long names, nor does it seam to
|
|
# handle posix long name semantics cleanly either. ustar works. This
|
|
# should be using git archive, but we need our generated code to be part of it
|
|
- name: Package source code with generated models
|
|
run: |
|
|
tar -czf ${{ runner.temp }}/${{ github.sha }}${{ env.PKG_PREFIX }}-with-models.tar.gz \
|
|
--format ustar \
|
|
--exclude 'zig-*' \
|
|
--transform 's,^,${{ github.sha }}/,' *
|
|
# - name: Sign
|
|
# id: sign
|
|
# uses: https://git.lerch.org/lobo/action-hsm-sign@v1
|
|
# with:
|
|
# pin: ${{ secrets.HSM_USER_PIN }}
|
|
# files: ???
|
|
# public_key: 'https://emil.lerch.org/serverpublic.pem'
|
|
# - run: |
|
|
# echo "Source 0 should be ./bar: ${{ steps.sign.outputs.SOURCE_0 }}"
|
|
# - run: |
|
|
# echo "Signature 0 should be ./bar.sig: ${{ steps.sign.outputs.SIG_0 }}"
|
|
# - run: echo "URL of bar (0) is ${{ steps.sign.outputs.URL_0 }}"
|
|
# - run: |
|
|
# echo "Source 1 should be ./foo: ${{ steps.sign.outputs.SOURCE_1 }}"
|
|
# - run: |
|
|
# echo "Signature 1 should be ./foo.sig: ${{ steps.sign.outputs.SIG_1 }}"
|
|
# - run: echo "URL of foo (1) is ${{ steps.sign.outputs.URL_1 }}"
|
|
- name: Publish source code with generated models
|
|
run: |
|
|
curl --user ${{ github.actor }}:${{ secrets.PACKAGE_PUSH }} \
|
|
--upload-file ${{ runner.temp }}/${{ github.sha }}${{ env.PKG_PREFIX }}-with-models.tar.gz \
|
|
https://git.lerch.org/api/packages/lobo/generic/aws-sdk-with-models/${{ github.sha }}/${{ github.sha }}${{ env.PKG_PREFIX }}-with-models.tar.gz
|
|
- name: Build example
|
|
run: ( cd example && zig build ) # Make sure example builds
|
|
- name: Notify
|
|
uses: https://git.lerch.org/lobo/action-notify-ntfy@v2
|
|
if: always()
|
|
with:
|
|
host: ${{ secrets.NTFY_HOST }}
|
|
topic: ${{ secrets.NTFY_TOPIC }}
|
|
user: ${{ secrets.NTFY_USER }}
|
|
password: ${{ secrets.NTFY_PASSWORD }}
|