Skip to content

Merge pull request #1 from niklasfrick/release-please--branches--main… #8

Merge pull request #1 from niklasfrick/release-please--branches--main…

Merge pull request #1 from niklasfrick/release-please--branches--main… #8

Workflow file for this run

name: CI
on:
push:
branches: [main]
pull_request:
concurrency:
group: ci-${{ github.ref }}
cancel-in-progress: true
jobs:
rust:
name: Rust (aarch64-linux)
runs-on: ubuntu-24.04-arm
steps:
- uses: actions/checkout@v4
- uses: dtolnay/rust-toolchain@stable
with:
components: rustfmt, clippy
- uses: Swatinem/rust-cache@v2
# rust-embed needs frontend/dist/ present at build time.
- uses: actions/setup-node@v4
with:
node-version: "20"
cache: npm
cache-dependency-path: frontend/package-lock.json
- name: Build frontend
working-directory: frontend
run: |
npm ci
npm run build
- name: Format
run: cargo fmt --all -- --check
- name: Clippy
run: cargo clippy --all-targets --locked -- -D warnings
- name: Test
run: cargo test --locked
- name: Release build smoke
run: cargo build --release --locked
frontend:
name: Frontend
runs-on: ubuntu-latest
defaults:
run:
working-directory: frontend
steps:
- uses: actions/checkout@v4
- uses: actions/setup-node@v4
with:
node-version: "20"
cache: npm
cache-dependency-path: frontend/package-lock.json
- run: npm ci
- run: npm run build
- run: npm test -- --run
installer:
name: Installer lint
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v4
- name: shellcheck install.sh
run: shellcheck packaging/install.sh
- name: systemd-analyze verify
run: |
# systemd-analyze exits non-zero on validation errors but can spit
# warnings about missing users at lint time — we care about syntax.
sudo apt-get update -qq && sudo apt-get install -y systemd
systemd-analyze verify packaging/systemd/spark-dashboard.service || \
echo "(warnings above are OK on a CI host without the service user)"