# SPDX-FileCopyrightText: 2024 Christina Sørensen # SPDX-License-Identifier: EUPL-1.2 name: Unit tests on: push: branches: [main] pull_request: branches: [main] workflow_dispatch: concurrency: group: ${{ github.workflow }}-${{ github.event_name == 'pull_request' && github.head_ref || github.sha }} cancel-in-progress: true env: CARGO_TERM_COLOR: always RUSTFLAGS: --deny warnings msrv: 1.82 jobs: security_audit: runs-on: ubuntu-latest steps: - uses: actions/checkout@v4 - uses: taiki-e/install-action@cargo-deny - name: Scan for vulnerabilities run: cargo deny check check_if_pr: runs-on: ubuntu-latest outputs: is_pr: ${{ steps.check.outputs.is_pr }} steps: - name: Check if it's a PR id: check run: | if [ "${{ github.event_name }}" == "pull_request" ]; then echo "is_pr=true" >> $GITHUB_OUTPUT else echo "is_pr=false" >> $GITHUB_OUTPUT fi no-merge-commits: needs: check_if_pr if: needs.check_if_pr.outputs.is_pr == 'true' runs-on: ubuntu-latest steps: - name: Checkout uses: actions/checkout@v4 - name: Run test uses: NexusPHP/no-merge-commits@v2.2.1 with: token: ${{ secrets.GITHUB_TOKEN }} conventional: needs: [check_if_pr, no-merge-commits] name: Conventional Commits runs-on: ubuntu-latest steps: - uses: actions/checkout@v4 - uses: webiny/action-conventional-commits@v1.3.0 unit-tests: needs: conventional runs-on: ${{ matrix.os }} continue-on-error: ${{ matrix.rust == 'nightly' }} strategy: matrix: os: [ubuntu-latest, macos-latest, windows-latest] rust: [msrv, stable, beta, nightly] steps: - name: Checkout repository uses: actions/checkout@v4 - run: rustup toolchain install ${{ matrix.rust == 'msrv' && env.msrv || matrix.rust }} --profile minimal - uses: Swatinem/rust-cache@v2 - name: Install cargo-hack uses: nick-fields/retry@v3 with: timeout_minutes: 5 max_attempts: 5 command: cargo install cargo-hack - name: Run rustfmt checks run: cargo fmt --check - name: Run clippy lints if: ${{ matrix.os != 'windows-latest' }} run: cargo clippy -- -D warnings - name: Run unit tests run: cargo hack test unit-tests-freebsd: needs: conventional runs-on: ubuntu-22.04 timeout-minutes: 20 continue-on-error: ${{ matrix.rust == 'nightly' }} strategy: matrix: rust: [msrv, stable, beta, nightly] steps: - uses: actions/checkout@v4 with: submodules: recursive - name: Compile uses: vmactions/freebsd-vm@v1 with: release: '14.3' usesh: true prepare: | pkg install -y curl git curl --proto '=https' --tlsv1.2 -sSf https://sh.rustup.rs | sh -s -- --default-toolchain ${{ matrix.rust == 'msrv' && env.msrv || matrix.rust }} --profile minimal -y . ~/.cargo/env cargo install cargo-hack git config --global --add safe.directory /home/runner/work/eza/eza run: | set -e . ~/.cargo/env export CARGO_TERM_COLOR="always" export RUSTFLAGS="--deny warnings" cargo fmt --check cargo clippy -- -D warnings cargo hack test unit-tests-netbsd: needs: conventional runs-on: ubuntu-22.04 timeout-minutes: 20 continue-on-error: ${{ matrix.rust == 'nightly' }} strategy: matrix: rust: [msrv, stable, beta, nightly] steps: - uses: actions/checkout@v4 with: submodules: recursive - name: Compile uses: vmactions/netbsd-vm@v1 with: release: '10.1' usesh: true prepare: | PATH="/root/.cargo/bin:/usr/pkg/sbin:/usr/pkg/bin:$PATH" PKG_PATH="https://ftp.netbsd.org/pub/pkgsrc/packages/NetBSD/amd64/10.1/All/" export PATH PKG_PATH /usr/sbin/pkg_add curl git curl --proto '=https' --tlsv1.2 -sSf https://sh.rustup.rs | sh -s -- --default-toolchain ${{ matrix.rust == 'msrv' && env.msrv || matrix.rust }} --profile minimal -y . ~/.cargo/env cargo install cargo-hack git config --global --add safe.directory /home/runner/work/eza/eza run: | set -e . ~/.cargo/env export CARGO_TERM_COLOR="always" export RUSTFLAGS="--deny warnings" cargo fmt --check cargo clippy -- -D warnings cargo hack test unit-tests-openbsd: needs: conventional runs-on: ubuntu-22.04 timeout-minutes: 20 steps: - uses: actions/checkout@v4 with: submodules: recursive - name: Compile uses: vmactions/openbsd-vm@v1 with: release: '7.7' usesh: true prepare: | pkg_add rust rust-rustfmt rust-clippy git cargo install cargo-hack git config --global --add safe.directory /home/runner/work/eza/eza run: | set -e export CARGO_TERM_COLOR="always" export RUSTFLAGS="--deny warnings" cargo fmt --check cargo clippy -- -D warnings cargo hack test flake-check: needs: conventional name: Check Nix Flake runs-on: ubuntu-latest strategy: matrix: checks: [build, formatting, lint, pre-commit-check, test, trycmd] target: [x86_64-linux] steps: - uses: actions/checkout@v4 - name: Install Nix uses: DeterminateSystems/nix-installer-action@v17 - name: Nix Flake Check run: nix build .#checks.${{ matrix.target }}.${{ matrix.checks }} -L flake-build: needs: conventional name: Build Nix package # if cross compilation is desired add 'aarch64-linux', 'x86_64-darwin' and 'aarch64-darwin' and fix the flake to support cross compilation. strategy: matrix: target: [x86_64-linux] runs-on: ubuntu-latest steps: - uses: actions/checkout@v4 - name: Install Nix uses: DeterminateSystems/nix-installer-action@v17 - name: Nix Build run: nix build .#packages.${{ matrix.target }}.default -L