forked from nrabulinski/attic
85 lines
3.1 KiB
YAML
85 lines
3.1 KiB
YAML
name: Build
|
|
on:
|
|
pull_request:
|
|
push:
|
|
env:
|
|
REGISTRY: ghcr.io
|
|
IMAGE_NAME: ${{ github.repository }}
|
|
jobs:
|
|
tests:
|
|
strategy:
|
|
matrix:
|
|
os:
|
|
- ubuntu-latest
|
|
- macos-11
|
|
runs-on: ${{ matrix.os }}
|
|
permissions:
|
|
contents: read
|
|
packages: write
|
|
steps:
|
|
- uses: actions/checkout@v4.1.1
|
|
|
|
- uses: DeterminateSystems/nix-installer-action@v9
|
|
continue-on-error: true # Self-hosted runners already have Nix installed
|
|
|
|
- name: Install Attic
|
|
run: |
|
|
if ! command -v attic &> /dev/null; then
|
|
./.github/install-attic-ci.sh
|
|
fi
|
|
|
|
- name: Configure Attic
|
|
run: |
|
|
: "${ATTIC_SERVER:=https://staging.attic.rs/}"
|
|
: "${ATTIC_CACHE:=attic-ci}"
|
|
echo ATTIC_CACHE=$ATTIC_CACHE >>$GITHUB_ENV
|
|
export PATH=$HOME/.nix-profile/bin:$PATH # FIXME
|
|
attic login --set-default ci "$ATTIC_SERVER" "$ATTIC_TOKEN"
|
|
attic use "$ATTIC_CACHE"
|
|
env:
|
|
ATTIC_SERVER: ${{ secrets.ATTIC_SERVER }}
|
|
ATTIC_CACHE: ${{ secrets.ATTIC_CACHE }}
|
|
ATTIC_TOKEN: ${{ secrets.ATTIC_TOKEN }}
|
|
|
|
- name: Build and run tests
|
|
run: |
|
|
system=$(nix-instantiate --eval -E 'builtins.currentSystem')
|
|
echo system=$system >>$GITHUB_ENV
|
|
tests=$(nix build .#internal."$system".attic-tests --no-link --print-out-paths -L)
|
|
find "$tests/bin" -exec {} \;
|
|
|
|
# TODO: Just take a diff of the list of store paths, also abstract all of this out
|
|
- name: Push build artifacts
|
|
run: |
|
|
export PATH=$HOME/.nix-profile/bin:$PATH # FIXME
|
|
if [ -n "$ATTIC_TOKEN" ]; then
|
|
nix build .#internal."$system".attic-tests .#internal."$system".cargoArtifacts --no-link --print-out-paths -L | \
|
|
xargs attic push "ci:$ATTIC_CACHE"
|
|
fi
|
|
- name: Log in to the Container registry
|
|
uses: docker/login-action@v3.0.0
|
|
if: runner.os == 'Linux' && github.event_name == 'push' && github.ref == format('refs/heads/{0}', github.event.repository.default_branch)
|
|
with:
|
|
registry: ${{ env.REGISTRY }}
|
|
username: ${{ github.actor }}
|
|
password: ${{ secrets.GITHUB_TOKEN }}
|
|
|
|
- name: Push build container image
|
|
if: runner.os == 'Linux' && github.event_name == 'push' && github.ref == format('refs/heads/{0}', github.event.repository.default_branch)
|
|
continue-on-error: true
|
|
run: |
|
|
IMAGE_ID=ghcr.io/${IMAGE_NAME}
|
|
TARBALL=$(nix build --json .#attic-server-image | jq -r '.[].outputs.out')
|
|
BRANCH=$(echo "${{ github.ref }}" | sed -e 's,.*/\(.*\),\1,')
|
|
TAG="${{ github.sha }}"
|
|
[[ "${{ github.ref }}" == "refs/tags/"* ]] && TAG=$(echo $BRANCH | sed -e 's/^v//')
|
|
docker load < ${TARBALL}
|
|
echo IMAGE_ID=$IMAGE_ID
|
|
echo TAG=$TAG
|
|
docker tag attic-server:main "${IMAGE_ID}:${TAG}"
|
|
docker push ${IMAGE_ID}:${TAG}
|
|
if [ "$BRANCH" == "main" ]; then
|
|
TAG="latest"
|
|
docker tag attic-server:main "${IMAGE_ID}:${TAG}"
|
|
docker push ${IMAGE_ID}:${TAG}
|
|
fi
|