Fix risc-v by updating dependencies #123
Workflow file for this run
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: 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/[email protected] | |
- uses: DeterminateSystems/nix-installer-action@v1 | |
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@f054a8b539a109f9f41c372932f1ae047eff08c9 | |
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 |