Skip to content

[IFT] review suggestions. #3897

[IFT] review suggestions.

[IFT] review suggestions. #3897

Workflow file for this run

on:
pull_request:
push:
branches:
- main
tags:
- "*"
schedule:
- cron: '22 2 * * *' # run at 2:22 every day
name: Continuous integration
jobs:
check:
name: Rustfmt
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v4
- uses: dtolnay/rust-toolchain@stable
- run: rustup component add rustfmt
- name: rustfmt check
run: cargo fmt --all -- --check
- name: cargo doc
run: cargo doc --all-features --document-private-items --no-deps
env:
RUSTDOCFLAGS: -D warnings
- name: check no println! or eprintln! statements
run: resources/scripts/check_no_println.sh
clippy-lint:
name: Clippy lints
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v4
- name: install stable toolchain
uses: dtolnay/rust-toolchain@stable
- name: cargo clippy --all-features
run: cargo clippy --all-features --all-targets -- -D warnings
- name: cargo clippy --no-default-features
run: cargo clippy --all-targets --no-default-features -- -D warnings
test-stable:
name: cargo test stable
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v4
- name: install stable toolchain
uses: dtolnay/rust-toolchain@stable
# test all packages individually to ensure deterministic resolution
# of dependencies for each package
- name: cargo test font-types
run: cargo test -p font-types --all-targets --all-features
- name: cargo test read-fonts
run: cargo test -p read-fonts --all-targets --all-features
- name: cargo test write-fonts
run: cargo test -p write-fonts --all-targets --all-features
- name: cargo test write-fonts default features
run: cargo test -p write-fonts --all-targets
- name: cargo test skrifa
run: cargo test -p skrifa --all-targets --all-features
- name: cargo test klippa
run: |
pip install -r resources/scripts/klippa_ci_requirements.txt
cargo test -p klippa --all-targets --all-features
- name: cargo test incremental-font-transfer
run: cargo test -p incremental-font-transfer --all-targets --all-features
- name: cargo test shared-brotli-patch-decoder
run: cargo test -p shared-brotli-patch-decoder --all-targets --all-features
ensure-clean-codegen:
name: check codegen is up-to-date
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v4
- name: install stable toolchain
uses: dtolnay/rust-toolchain@stable
- name: run codegen
run: cargo run --bin=codegen resources/codegen_plan.toml
- name: ensure no unstaged changes
run: |
git add .
git status -sb
git diff-index --quiet HEAD --
check-no-std:
name: cargo check no std
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v4
- name: install stable toolchain
uses: dtolnay/rust-toolchain@stable
with:
# Use a target without `std` to make sure we don't link to `std`
target: thumbv7em-none-eabihf
- name: cargo build font-types
run: cargo build -p font-types --target thumbv7em-none-eabihf --no-default-features
- name: cargo build read-fonts
run: cargo build -p read-fonts --target thumbv7em-none-eabihf --no-default-features --features=libm
- name: cargo build skrifa
run: cargo build -p skrifa --target thumbv7em-none-eabihf --no-default-features --features=libm
# We use `cargo build` here because `cargo check` doesn't pick up all
# warnings / errors. Notably, it misses `arithmetic_overflow`.
check-wasm:
name: cargo check wasm
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v4
- name: install stable toolchain
uses: dtolnay/rust-toolchain@stable
with:
target: wasm32-unknown-unknown
- name: cargo build font-types
run: cargo build -p font-types --target wasm32-unknown-unknown
- name: cargo build read-fonts
run: cargo build -p read-fonts --target wasm32-unknown-unknown
- name: cargo build skrifa
run: cargo build -p skrifa --target wasm32-unknown-unknown
- name: cargo build write-fonts
run: cargo build -p write-fonts --target wasm32-unknown-unknown
# If this fails, consider changing your text or adding something to .typos.toml
typos:
name: Check for typos
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v4
- name: check typos
uses: crate-ci/[email protected]