Skip to content

lint

lint #626

Workflow file for this run

name: lint
on:
schedule:
- cron: '0 0 * * *'
push:
branches: [ main ]
pull_request:
branches:
- 'main'
paths:
- '**/src/**/*'
- '**/tests/**/*'
- 'Cargo.toml'
- '**/Cargo.toml'
- 'Cargo.lock'
- '**/Cargo.lock'
- '.rustfmt.toml'
- 'docker-compose.yml'
- '.github/workflows/lint.yml'
env:
CARGO_TERM_COLOR: always
SQLX_VERSION: "0.8.3"
SQLX_FEATURES: "rustls,mysql"
DATABASE_URL: "mysql://root:[email protected]:3306/lrzcc"
jobs:
fmt:
name: rustfmt
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v4
with:
persist-credentials: false
- uses: dtolnay/rust-toolchain@stable
with:
components: rustfmt
- name: Enforce formatting
run: cargo fmt --check
clippy:
name: clippy
runs-on: ubuntu-latest
steps:
- uses: getong/[email protected]
with:
mysql database: 'lrzcc'
mysql root password: 'password'
- name: Check out repository code
uses: actions/checkout@v4
with:
persist-credentials: false
- name: Install the Rust toolchain
uses: dtolnay/rust-toolchain@stable
with:
components: clippy
- name: Rust Cache Action
uses: Swatinem/rust-cache@v2
with:
key: sqlx-${{ env.SQLX_VERSION }}
- name: Install sqlx-cli
run: |
cargo install sqlx-cli \
--version="${SQLX_VERSION}" \
--features "${SQLX_FEATURES}" \
--no-default-features \
--locked
- name: Install mariadb-client and mold
run: sudo apt update && sudo apt install mariadb-client mold -y
- name: Migrate database
run: SKIP_DOCKER=true ./scripts/init_db.sh
- name: Check sqlx offline data is up to date
run: cargo sqlx prepare --workspace --check
- name: Run tests
run: cargo clippy -- -D warnings
spellcheck:
name: spellcheck
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v4
with:
persist-credentials: false
- uses: taiki-e/[email protected]
with:
tool: cargo-spellcheck
- name: Check spelling
run: cargo spellcheck --cfg=.spellcheck.toml --code 1
machete:
runs-on: ubuntu-latest
steps:
- name: Checkout
uses: actions/checkout@v4
with:
persist-credentials: false
- name: Machete
uses: bnjbvr/cargo-machete@main