| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198 |
- # 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@v6
- - 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@v6
- - 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@v6
- - 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@v6
- - 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@v6
- 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@v6
- 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@v6
- with:
- submodules: recursive
- - name: Compile
- uses: vmactions/openbsd-vm@v1
- with:
- release: '7.8'
- 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@v6
- - 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@v6
- - name: Install Nix
- uses: DeterminateSystems/nix-installer-action@v17
- - name: Nix Build
- run: nix build .#packages.${{ matrix.target }}.default -L
|