Merge pull request #68 from DeterminateSystems/integration-test
This commit is contained in:
commit
07b8fc311f
10
.editorconfig
Normal file
10
.editorconfig
Normal file
|
@ -0,0 +1,10 @@
|
||||||
|
# https://editorconfig.org
|
||||||
|
root = true
|
||||||
|
|
||||||
|
[*]
|
||||||
|
indent_style = space
|
||||||
|
indent_size = 2
|
||||||
|
end_of_line = lf
|
||||||
|
charset = utf-8
|
||||||
|
trim_trailing_whitespace = true
|
||||||
|
insert_final_newline = true
|
32
.github/workflows/build.yaml
vendored
32
.github/workflows/build.yaml
vendored
|
@ -7,6 +7,12 @@ on:
|
||||||
jobs:
|
jobs:
|
||||||
build-artifacts:
|
build-artifacts:
|
||||||
runs-on: ${{ matrix.systems.runner }}
|
runs-on: ${{ matrix.systems.runner }}
|
||||||
|
permissions:
|
||||||
|
contents: read
|
||||||
|
id-token: write
|
||||||
|
env:
|
||||||
|
ARTIFACT_KEY: magic-nix-cache-${{ matrix.systems.system }}
|
||||||
|
ARCHIVE_NAME: magic-nix-cache.closure.xz
|
||||||
strategy:
|
strategy:
|
||||||
matrix:
|
matrix:
|
||||||
systems:
|
systems:
|
||||||
|
@ -22,20 +28,26 @@ jobs:
|
||||||
- nix-system: aarch64-darwin
|
- nix-system: aarch64-darwin
|
||||||
system: ARM64-macOS
|
system: ARM64-macOS
|
||||||
runner: macos-latest-xlarge
|
runner: macos-latest-xlarge
|
||||||
permissions:
|
|
||||||
contents: read
|
|
||||||
id-token: write
|
|
||||||
steps:
|
steps:
|
||||||
- uses: actions/checkout@v3
|
- uses: actions/checkout@v3
|
||||||
- uses: DeterminateSystems/nix-installer-action@main
|
- name: Install Nix on ${{ matrix.systems.system }}
|
||||||
- uses: DeterminateSystems/magic-nix-cache-action@main
|
uses: DeterminateSystems/nix-installer-action@main
|
||||||
- name: Build package
|
- name: Magic Nix Cache
|
||||||
run: "nix build .# -L --fallback && nix-store --export $(nix-store -qR ./result) | xz -9 > magic-nix-cache.closure.xz"
|
uses: DeterminateSystems/magic-nix-cache-action@main
|
||||||
|
|
||||||
- name: Upload a Build Artifact
|
- name: Build and cache dev shell for ${{ matrix.systems.nix-system }}
|
||||||
|
run: |
|
||||||
|
nix build ".#devShells.${{ matrix.systems.nix-system }}.default"
|
||||||
|
|
||||||
|
- name: Build package and create closure for ${{ matrix.systems.system }}
|
||||||
|
run: |
|
||||||
|
nix build .# -L --fallback && \
|
||||||
|
nix-store --export $(nix-store -qR ./result) | xz -9 > "${{ env.ARCHIVE_NAME }}"
|
||||||
|
|
||||||
|
- name: Upload magic-nix-cache closure for ${{ matrix.systems.system }}
|
||||||
uses: actions/upload-artifact@v3.1.2
|
uses: actions/upload-artifact@v3.1.2
|
||||||
with:
|
with:
|
||||||
# Artifact name
|
# Artifact name
|
||||||
name: magic-nix-cache-${{ matrix.systems.system }}
|
name: ${{ env.ARTIFACT_KEY }}
|
||||||
path: magic-nix-cache.closure.xz
|
path: ${{ env.ARCHIVE_NAME }}
|
||||||
retention-days: 1
|
retention-days: 1
|
||||||
|
|
90
.github/workflows/check-and-test.yaml
vendored
Normal file
90
.github/workflows/check-and-test.yaml
vendored
Normal file
|
@ -0,0 +1,90 @@
|
||||||
|
name: Run checks and integration test
|
||||||
|
|
||||||
|
on:
|
||||||
|
pull_request:
|
||||||
|
push:
|
||||||
|
branches: [main]
|
||||||
|
|
||||||
|
jobs:
|
||||||
|
checks:
|
||||||
|
name: Nix and Rust checks
|
||||||
|
runs-on: ubuntu-22.04
|
||||||
|
permissions:
|
||||||
|
contents: read
|
||||||
|
id-token: write
|
||||||
|
steps:
|
||||||
|
- uses: actions/checkout@v3
|
||||||
|
|
||||||
|
- name: Install Nix
|
||||||
|
uses: DeterminateSystems/nix-installer-action@main
|
||||||
|
- uses: DeterminateSystems/magic-nix-cache-action@main
|
||||||
|
|
||||||
|
- name: Check health of flake.lock
|
||||||
|
uses: DeterminateSystems/flake-checker-action@main
|
||||||
|
with:
|
||||||
|
fail-mode: true
|
||||||
|
|
||||||
|
- name: Check Rust formatting
|
||||||
|
run: nix develop --command cargo fmt --check
|
||||||
|
|
||||||
|
- name: Clippy
|
||||||
|
run: nix develop --command cargo clippy
|
||||||
|
|
||||||
|
build:
|
||||||
|
name: Build artifacts
|
||||||
|
needs: checks
|
||||||
|
uses: ./.github/workflows/build.yaml
|
||||||
|
secrets: inherit
|
||||||
|
|
||||||
|
action-integration-test:
|
||||||
|
name: Integration test for magic-nix-cache-action
|
||||||
|
runs-on: ${{ matrix.systems.runner }}
|
||||||
|
needs: build
|
||||||
|
env:
|
||||||
|
ARTIFACT_KEY: magic-nix-cache-${{ matrix.systems.system }}
|
||||||
|
ARCHIVE_NAME: magic-nix-cache.closure.xz
|
||||||
|
strategy:
|
||||||
|
matrix:
|
||||||
|
systems:
|
||||||
|
- system: X64-Linux
|
||||||
|
runner: ubuntu-22.04
|
||||||
|
- system: ARM64-Linux
|
||||||
|
runner: namespace-profile-default-arm64
|
||||||
|
- system: X64-macOS
|
||||||
|
runner: macos-12
|
||||||
|
- system: ARM64-macOS
|
||||||
|
runner: macos-latest-xlarge
|
||||||
|
permissions:
|
||||||
|
contents: read
|
||||||
|
id-token: write
|
||||||
|
steps:
|
||||||
|
- uses: actions/checkout@v3
|
||||||
|
|
||||||
|
- name: Download closure for ${{ matrix.systems.system }}
|
||||||
|
uses: actions/download-artifact@v3
|
||||||
|
with:
|
||||||
|
name: ${{ env.ARTIFACT_KEY }}
|
||||||
|
path: ${{ env.ARTIFACT_KEY }}
|
||||||
|
|
||||||
|
- name: Install Nix on ${{ matrix.systems.system }}
|
||||||
|
uses: DeterminateSystems/nix-installer-action@main
|
||||||
|
|
||||||
|
- name: Extract closure for ${{ matrix.systems.system }}
|
||||||
|
id: extract
|
||||||
|
run: |
|
||||||
|
ARTIFACT="${{ env.ARTIFACT_KEY }}/${{ env.ARCHIVE_NAME }}"
|
||||||
|
OUTPUT=$(cat ${ARTIFACT} | xz -d | nix-store --import)
|
||||||
|
MNC_BIN_PATH=$(echo "${OUTPUT}" | tail -n 1)
|
||||||
|
MAGIC_NIX_CACHE="${MNC_BIN_PATH}/bin/magic-nix-cache"
|
||||||
|
|
||||||
|
echo "mnc-path=${MAGIC_NIX_CACHE}" >> "$GITHUB_OUTPUT"
|
||||||
|
|
||||||
|
- name: Test magic-nix-cache-action@test-fail-mode on ${{ matrix.systems.runner }}
|
||||||
|
uses: DeterminateSystems/magic-nix-cache-action@test-fail-mode
|
||||||
|
with:
|
||||||
|
source-binary: "${{ steps.extract.outputs.mnc-path }}"
|
||||||
|
strict-mode: true
|
||||||
|
|
||||||
|
- name: Run nix to test magic-nix-cache-action
|
||||||
|
run: |
|
||||||
|
nix develop --command echo "just testing"
|
34
.github/workflows/checks.yaml
vendored
34
.github/workflows/checks.yaml
vendored
|
@ -1,34 +0,0 @@
|
||||||
name: Rust checks
|
|
||||||
|
|
||||||
on:
|
|
||||||
pull_request:
|
|
||||||
push:
|
|
||||||
branches: [main]
|
|
||||||
|
|
||||||
jobs:
|
|
||||||
checks:
|
|
||||||
runs-on: ubuntu-22.04
|
|
||||||
permissions:
|
|
||||||
contents: read
|
|
||||||
id-token: write
|
|
||||||
steps:
|
|
||||||
- uses: actions/checkout@v3
|
|
||||||
|
|
||||||
- name: Install Nix
|
|
||||||
uses: DeterminateSystems/nix-installer-action@main
|
|
||||||
- uses: DeterminateSystems/magic-nix-cache-action@main
|
|
||||||
|
|
||||||
- name: Check health of flake.lock
|
|
||||||
uses: DeterminateSystems/flake-checker-action@main
|
|
||||||
with:
|
|
||||||
fail-mode: true
|
|
||||||
|
|
||||||
- name: Check Rust formatting
|
|
||||||
run: nix develop --command cargo fmt --check
|
|
||||||
|
|
||||||
- name: Clippy
|
|
||||||
run: nix develop --command cargo clippy
|
|
||||||
|
|
||||||
build:
|
|
||||||
uses: ./.github/workflows/build.yaml
|
|
||||||
secrets: inherit
|
|
32
.github/workflows/flakehub-cache.yml
vendored
32
.github/workflows/flakehub-cache.yml
vendored
|
@ -1,32 +0,0 @@
|
||||||
name: Push dev shell to FlakeHub Cache
|
|
||||||
|
|
||||||
on:
|
|
||||||
push:
|
|
||||||
branches: [main]
|
|
||||||
|
|
||||||
jobs:
|
|
||||||
push-dev-shell-to-flakehub-cache:
|
|
||||||
env:
|
|
||||||
ACTIONS_STEP_DEBUG: true
|
|
||||||
runs-on: ${{ matrix.systems.runner }}
|
|
||||||
permissions:
|
|
||||||
id-token: "write"
|
|
||||||
contents: "read"
|
|
||||||
strategy:
|
|
||||||
matrix:
|
|
||||||
systems:
|
|
||||||
- nix-system: "aarch64-darwin"
|
|
||||||
runner: "macos-latest-xlarge"
|
|
||||||
- nix-system: "x86_64-darwin"
|
|
||||||
runner: "macos-12"
|
|
||||||
- nix-system: "x86_64-linux"
|
|
||||||
runner: "ubuntu-22.04"
|
|
||||||
steps:
|
|
||||||
- uses: actions/checkout@v3
|
|
||||||
- uses: DeterminateSystems/nix-installer-action@main
|
|
||||||
- uses: DeterminateSystems/magic-nix-cache-action@main
|
|
||||||
with:
|
|
||||||
use-flakehub: true
|
|
||||||
- name: Build dev shell for ${{ matrix.systems.nix-system }} on ${{ matrix.systems.runner }}
|
|
||||||
run: |
|
|
||||||
nix build .#devShells.${{ matrix.systems.nix-system }}.default
|
|
14
.github/workflows/release-prs.yml
vendored
14
.github/workflows/release-prs.yml
vendored
|
@ -10,13 +10,7 @@ on:
|
||||||
|
|
||||||
jobs:
|
jobs:
|
||||||
build:
|
build:
|
||||||
uses: ./.github/workflows/build.yaml
|
# We want to build artifacts only if the `upload to s3` label is applied
|
||||||
secrets: inherit
|
|
||||||
|
|
||||||
release:
|
|
||||||
needs: build
|
|
||||||
|
|
||||||
concurrency: release
|
|
||||||
# Only intra-repo PRs are allowed to have PR artifacts uploaded
|
# Only intra-repo PRs are allowed to have PR artifacts uploaded
|
||||||
# We only want to trigger once the upload once in the case the upload label is added, not when any label is added
|
# We only want to trigger once the upload once in the case the upload label is added, not when any label is added
|
||||||
if: |
|
if: |
|
||||||
|
@ -25,6 +19,12 @@ jobs:
|
||||||
(github.event.action == 'labeled' && github.event.label.name == 'upload to s3')
|
(github.event.action == 'labeled' && github.event.label.name == 'upload to s3')
|
||||||
|| (github.event.action != 'labeled' && contains(github.event.pull_request.labels.*.name, 'upload to s3'))
|
|| (github.event.action != 'labeled' && contains(github.event.pull_request.labels.*.name, 'upload to s3'))
|
||||||
)
|
)
|
||||||
|
uses: ./.github/workflows/build.yaml
|
||||||
|
secrets: inherit
|
||||||
|
|
||||||
|
release:
|
||||||
|
needs: build
|
||||||
|
concurrency: release
|
||||||
runs-on: ubuntu-latest
|
runs-on: ubuntu-latest
|
||||||
permissions:
|
permissions:
|
||||||
id-token: write # In order to request a JWT for AWS auth
|
id-token: write # In order to request a JWT for AWS auth
|
||||||
|
|
Loading…
Reference in a new issue