Merge remote-tracking branch 'ci/main' into ci
This commit is contained in:
commit
d2f4848f35
6 changed files with 415 additions and 0 deletions
21
.github/codecov.yml
vendored
Normal file
21
.github/codecov.yml
vendored
Normal file
|
|
@ -0,0 +1,21 @@
|
||||||
|
# ref: https://docs.codecov.com/docs/codecovyml-reference
|
||||||
|
coverage:
|
||||||
|
# Hold ourselves to a high bar
|
||||||
|
range: 85..100
|
||||||
|
round: down
|
||||||
|
precision: 1
|
||||||
|
status:
|
||||||
|
# ref: https://docs.codecov.com/docs/commit-status
|
||||||
|
project:
|
||||||
|
default:
|
||||||
|
# Avoid false negatives
|
||||||
|
threshold: 1%
|
||||||
|
|
||||||
|
# Test files aren't important for coverage
|
||||||
|
ignore:
|
||||||
|
- "tests"
|
||||||
|
|
||||||
|
# Make comments less noisy
|
||||||
|
comment:
|
||||||
|
layout: "files"
|
||||||
|
require_changes: yes
|
||||||
107
.github/workflows/check.yml
vendored
Normal file
107
.github/workflows/check.yml
vendored
Normal file
|
|
@ -0,0 +1,107 @@
|
||||||
|
on:
|
||||||
|
push:
|
||||||
|
branches: [main]
|
||||||
|
pull_request:
|
||||||
|
name: check
|
||||||
|
jobs:
|
||||||
|
fmt:
|
||||||
|
runs-on: ubuntu-latest
|
||||||
|
name: stable / fmt
|
||||||
|
steps:
|
||||||
|
- uses: actions/checkout@v3
|
||||||
|
with:
|
||||||
|
submodules: true
|
||||||
|
- name: Install stable
|
||||||
|
uses: actions-rs/toolchain@v1
|
||||||
|
with:
|
||||||
|
profile: minimal
|
||||||
|
toolchain: stable
|
||||||
|
components: rustfmt
|
||||||
|
- name: cargo fmt --check
|
||||||
|
uses: actions-rs/cargo@v1
|
||||||
|
with:
|
||||||
|
command: fmt
|
||||||
|
args: --check
|
||||||
|
clippy:
|
||||||
|
runs-on: ubuntu-latest
|
||||||
|
name: ${{ matrix.toolchain }} / clippy
|
||||||
|
strategy:
|
||||||
|
fail-fast: false
|
||||||
|
matrix:
|
||||||
|
toolchain: [stable, beta]
|
||||||
|
steps:
|
||||||
|
- uses: actions/checkout@v3
|
||||||
|
with:
|
||||||
|
submodules: true
|
||||||
|
- name: Install ${{ matrix.toolchain }}
|
||||||
|
uses: actions-rs/toolchain@v1
|
||||||
|
with:
|
||||||
|
profile: minimal
|
||||||
|
toolchain: ${{ matrix.toolchain }}
|
||||||
|
default: true
|
||||||
|
components: clippy
|
||||||
|
- name: cargo clippy
|
||||||
|
uses: actions-rs/clippy-check@v1
|
||||||
|
with:
|
||||||
|
token: ${{ secrets.GITHUB_TOKEN }}
|
||||||
|
doc:
|
||||||
|
runs-on: ubuntu-latest
|
||||||
|
name: nightly / doc
|
||||||
|
steps:
|
||||||
|
- uses: actions/checkout@v3
|
||||||
|
with:
|
||||||
|
submodules: true
|
||||||
|
- name: Install nightly
|
||||||
|
uses: actions-rs/toolchain@v1
|
||||||
|
with:
|
||||||
|
profile: minimal
|
||||||
|
toolchain: nightly
|
||||||
|
default: true
|
||||||
|
- name: cargo doc
|
||||||
|
uses: actions-rs/cargo@v1
|
||||||
|
with:
|
||||||
|
command: doc
|
||||||
|
args: --no-deps --all-features
|
||||||
|
env:
|
||||||
|
RUSTDOCFLAGS: --cfg docsrs
|
||||||
|
hack:
|
||||||
|
runs-on: ubuntu-latest
|
||||||
|
name: ubuntu / stable / features
|
||||||
|
steps:
|
||||||
|
- uses: actions/checkout@v3
|
||||||
|
with:
|
||||||
|
submodules: true
|
||||||
|
- name: Install stable
|
||||||
|
uses: actions-rs/toolchain@v1
|
||||||
|
with:
|
||||||
|
profile: minimal
|
||||||
|
toolchain: stable
|
||||||
|
- name: cargo install cargo-hack
|
||||||
|
uses: taiki-e/install-action@cargo-hack
|
||||||
|
- name: cargo hack
|
||||||
|
uses: actions-rs/cargo@v1
|
||||||
|
with:
|
||||||
|
command: hack
|
||||||
|
args: --feature-powerset check --all-targets
|
||||||
|
msrv:
|
||||||
|
runs-on: ubuntu-latest
|
||||||
|
# we use a matrix here just because env can't be used in job names
|
||||||
|
# https://docs.github.com/en/actions/learn-github-actions/contexts#context-availability
|
||||||
|
strategy:
|
||||||
|
matrix:
|
||||||
|
msrv: [1.56.1] # 2021 edition requires 1.56
|
||||||
|
name: ubuntu / ${{ matrix.msrv }}
|
||||||
|
steps:
|
||||||
|
- uses: actions/checkout@v3
|
||||||
|
with:
|
||||||
|
submodules: true
|
||||||
|
- name: Install ${{ matrix.toolchain }}
|
||||||
|
uses: actions-rs/toolchain@v1
|
||||||
|
with:
|
||||||
|
profile: minimal
|
||||||
|
toolchain: ${{ matrix.msrv }}
|
||||||
|
default: true
|
||||||
|
- name: cargo +${{ matrix.msrv }} check
|
||||||
|
uses: actions-rs/cargo@v1
|
||||||
|
with:
|
||||||
|
command: check
|
||||||
24
.github/workflows/nostd.yml
vendored
Normal file
24
.github/workflows/nostd.yml
vendored
Normal file
|
|
@ -0,0 +1,24 @@
|
||||||
|
on:
|
||||||
|
push:
|
||||||
|
branches: [main]
|
||||||
|
pull_request:
|
||||||
|
name: no-std
|
||||||
|
jobs:
|
||||||
|
nostd:
|
||||||
|
runs-on: ubuntu-latest
|
||||||
|
name: ${{ matrix.target }}
|
||||||
|
strategy:
|
||||||
|
matrix:
|
||||||
|
target: [thumbv7m-none-eabi, aarch64-unknown-none]
|
||||||
|
steps:
|
||||||
|
- uses: actions-rs/toolchain@v1
|
||||||
|
with:
|
||||||
|
profile: minimal
|
||||||
|
toolchain: stable
|
||||||
|
target: ${{ matrix.target }}
|
||||||
|
- uses: actions/checkout@v3
|
||||||
|
- name: cargo check
|
||||||
|
uses: actions-rs/cargo@v1
|
||||||
|
with:
|
||||||
|
command: check
|
||||||
|
args: --target ${{ matrix.target }} --no-default-features
|
||||||
86
.github/workflows/safety.yml
vendored
Normal file
86
.github/workflows/safety.yml
vendored
Normal file
|
|
@ -0,0 +1,86 @@
|
||||||
|
on:
|
||||||
|
push:
|
||||||
|
branches: [main]
|
||||||
|
pull_request:
|
||||||
|
name: safety
|
||||||
|
jobs:
|
||||||
|
sanitizers:
|
||||||
|
runs-on: ubuntu-latest
|
||||||
|
steps:
|
||||||
|
- uses: actions/checkout@v3
|
||||||
|
with:
|
||||||
|
submodules: true
|
||||||
|
- name: Install nightly
|
||||||
|
uses: actions-rs/toolchain@v1
|
||||||
|
with:
|
||||||
|
profile: minimal
|
||||||
|
toolchain: nightly
|
||||||
|
default: true
|
||||||
|
- run: |
|
||||||
|
# to get the symbolizer for debug symbol resolution
|
||||||
|
sudo apt install llvm
|
||||||
|
# to fix buggy leak analyzer:
|
||||||
|
# https://github.com/japaric/rust-san#unrealiable-leaksanitizer
|
||||||
|
sed -i '/\[features\]/i [profile.dev]' Cargo.toml
|
||||||
|
sed -i '/profile.dev/a opt-level = 1' Cargo.toml
|
||||||
|
cat Cargo.toml
|
||||||
|
name: Enable debug symbols
|
||||||
|
- name: cargo test -Zsanitizer=address
|
||||||
|
uses: actions-rs/cargo@v1
|
||||||
|
with:
|
||||||
|
command: test
|
||||||
|
# only --lib --tests b/c of https://github.com/rust-lang/rust/issues/53945
|
||||||
|
args: --lib --tests --all-features --target x86_64-unknown-linux-gnu
|
||||||
|
env:
|
||||||
|
ASAN_OPTIONS: "detect_odr_violation=0:detect_leaks=0"
|
||||||
|
RUSTFLAGS: "-Z sanitizer=address"
|
||||||
|
- name: cargo test -Zsanitizer=leak
|
||||||
|
if: always()
|
||||||
|
uses: actions-rs/cargo@v1
|
||||||
|
with:
|
||||||
|
command: test
|
||||||
|
args: --all-features --target x86_64-unknown-linux-gnu
|
||||||
|
env:
|
||||||
|
LSAN_OPTIONS: "suppressions=lsan-suppressions.txt"
|
||||||
|
RUSTFLAGS: "-Z sanitizer=leak"
|
||||||
|
miri:
|
||||||
|
runs-on: ubuntu-latest
|
||||||
|
steps:
|
||||||
|
- uses: actions/checkout@v3
|
||||||
|
with:
|
||||||
|
submodules: true
|
||||||
|
- run: |
|
||||||
|
echo "NIGHTLY=nightly-$(curl -s https://rust-lang.github.io/rustup-components-history/x86_64-unknown-linux-gnu/miri)" >> $GITHUB_ENV
|
||||||
|
- name: Install ${{ env.NIGHTLY }}
|
||||||
|
uses: actions-rs/toolchain@v1
|
||||||
|
with:
|
||||||
|
profile: minimal
|
||||||
|
toolchain: ${{ env.NIGHTLY }}
|
||||||
|
default: true
|
||||||
|
components: miri
|
||||||
|
- name: cargo miri test
|
||||||
|
uses: actions-rs/cargo@v1
|
||||||
|
with:
|
||||||
|
command: miri
|
||||||
|
args: test
|
||||||
|
env:
|
||||||
|
MIRIFLAGS: "-Zmiri-tag-raw-pointers"
|
||||||
|
loom:
|
||||||
|
runs-on: ubuntu-latest
|
||||||
|
steps:
|
||||||
|
- uses: actions/checkout@v3
|
||||||
|
with:
|
||||||
|
submodules: true
|
||||||
|
- name: Install stable
|
||||||
|
uses: actions-rs/toolchain@v1
|
||||||
|
with:
|
||||||
|
toolchain: stable
|
||||||
|
profile: minimal
|
||||||
|
- name: cargo test --test loom
|
||||||
|
uses: actions-rs/cargo@v1
|
||||||
|
with:
|
||||||
|
command: test
|
||||||
|
args: --release --test loom
|
||||||
|
env:
|
||||||
|
LOOM_MAX_PREEMPTIONS: 2
|
||||||
|
RUSTFLAGS: "--cfg loom"
|
||||||
64
.github/workflows/scheduled.yml
vendored
Normal file
64
.github/workflows/scheduled.yml
vendored
Normal file
|
|
@ -0,0 +1,64 @@
|
||||||
|
on:
|
||||||
|
push:
|
||||||
|
branches: [main]
|
||||||
|
pull_request:
|
||||||
|
schedule:
|
||||||
|
- cron: '7 7 * * *'
|
||||||
|
name: cargo test (rolling)
|
||||||
|
jobs:
|
||||||
|
# https://twitter.com/mycoliza/status/1571295690063753218
|
||||||
|
nightly:
|
||||||
|
runs-on: ubuntu-latest
|
||||||
|
name: ubuntu / nightly
|
||||||
|
steps:
|
||||||
|
- uses: actions/checkout@v3
|
||||||
|
with:
|
||||||
|
submodules: true
|
||||||
|
- name: Install nightly
|
||||||
|
uses: actions-rs/toolchain@v1
|
||||||
|
with:
|
||||||
|
profile: minimal
|
||||||
|
toolchain: nightly
|
||||||
|
default: true
|
||||||
|
- name: cargo generate-lockfile
|
||||||
|
if: hashFiles('Cargo.lock') == ''
|
||||||
|
uses: actions-rs/cargo@v1
|
||||||
|
with:
|
||||||
|
command: generate-lockfile
|
||||||
|
- name: cargo test --locked
|
||||||
|
uses: actions-rs/cargo@v1
|
||||||
|
with:
|
||||||
|
command: test
|
||||||
|
args: --locked --all-features --all-targets
|
||||||
|
# https://twitter.com/alcuadrado/status/1571291687837732873
|
||||||
|
update:
|
||||||
|
runs-on: ubuntu-latest
|
||||||
|
name: ubuntu / beta / updated
|
||||||
|
# There's no point running this if no Cargo.lock was checked in in the
|
||||||
|
# first place, since we'd just redo what happened in the regular test job.
|
||||||
|
# Unfortunately, hashFiles only works in if on steps, so we reepeat it.
|
||||||
|
# if: hashFiles('Cargo.lock') != ''
|
||||||
|
steps:
|
||||||
|
- uses: actions/checkout@v3
|
||||||
|
with:
|
||||||
|
submodules: true
|
||||||
|
- name: Install beta
|
||||||
|
if: hashFiles('Cargo.lock') != ''
|
||||||
|
uses: actions-rs/toolchain@v1
|
||||||
|
with:
|
||||||
|
profile: minimal
|
||||||
|
toolchain: beta
|
||||||
|
default: true
|
||||||
|
- name: cargo update
|
||||||
|
if: hashFiles('Cargo.lock') != ''
|
||||||
|
uses: actions-rs/cargo@v1
|
||||||
|
with:
|
||||||
|
command: update
|
||||||
|
- name: cargo test
|
||||||
|
if: hashFiles('Cargo.lock') != ''
|
||||||
|
uses: actions-rs/cargo@v1
|
||||||
|
with:
|
||||||
|
command: test
|
||||||
|
args: --locked --all-features --all-targets
|
||||||
|
env:
|
||||||
|
RUSTFLAGS: -D deprecated
|
||||||
113
.github/workflows/test.yml
vendored
Normal file
113
.github/workflows/test.yml
vendored
Normal file
|
|
@ -0,0 +1,113 @@
|
||||||
|
on:
|
||||||
|
push:
|
||||||
|
branches: [main]
|
||||||
|
pull_request:
|
||||||
|
name: test
|
||||||
|
jobs:
|
||||||
|
required:
|
||||||
|
runs-on: ubuntu-latest
|
||||||
|
name: ubuntu / ${{ matrix.toolchain }}
|
||||||
|
strategy:
|
||||||
|
matrix:
|
||||||
|
toolchain: [stable, beta]
|
||||||
|
steps:
|
||||||
|
- uses: actions/checkout@v3
|
||||||
|
with:
|
||||||
|
submodules: true
|
||||||
|
- name: Install ${{ matrix.toolchain }}
|
||||||
|
uses: actions-rs/toolchain@v1
|
||||||
|
with:
|
||||||
|
profile: minimal
|
||||||
|
toolchain: ${{ matrix.toolchain }}
|
||||||
|
default: true
|
||||||
|
- name: cargo generate-lockfile
|
||||||
|
if: hashFiles('Cargo.lock') == ''
|
||||||
|
uses: actions-rs/cargo@v1
|
||||||
|
with:
|
||||||
|
command: generate-lockfile
|
||||||
|
# https://twitter.com/jonhoo/status/1571290371124260865
|
||||||
|
- name: cargo test --locked
|
||||||
|
uses: actions-rs/cargo@v1
|
||||||
|
with:
|
||||||
|
command: test
|
||||||
|
args: --locked --all-features --all-targets
|
||||||
|
minimal:
|
||||||
|
runs-on: ubuntu-latest
|
||||||
|
name: ubuntu / stable / minimal-versions
|
||||||
|
steps:
|
||||||
|
- uses: actions/checkout@v3
|
||||||
|
with:
|
||||||
|
submodules: true
|
||||||
|
- name: Install stable
|
||||||
|
uses: actions-rs/toolchain@v1
|
||||||
|
with:
|
||||||
|
profile: minimal
|
||||||
|
toolchain: stable
|
||||||
|
- name: Install nightly for -Zminimal-versions
|
||||||
|
uses: actions-rs/toolchain@v1
|
||||||
|
with:
|
||||||
|
profile: minimal
|
||||||
|
toolchain: nightly
|
||||||
|
- name: cargo update -Zminimal-versions
|
||||||
|
uses: actions-rs/cargo@v1
|
||||||
|
with:
|
||||||
|
command: update
|
||||||
|
toolchain: nightly
|
||||||
|
args: -Zminimal-versions
|
||||||
|
- name: cargo test
|
||||||
|
uses: actions-rs/cargo@v1
|
||||||
|
with:
|
||||||
|
command: test
|
||||||
|
args: --locked --all-features --all-targets
|
||||||
|
os-check:
|
||||||
|
runs-on: ${{ matrix.os }}
|
||||||
|
name: ${{ matrix.os }} / stable
|
||||||
|
strategy:
|
||||||
|
fail-fast: false
|
||||||
|
matrix:
|
||||||
|
os: [macos-latest, windows-latest]
|
||||||
|
steps:
|
||||||
|
- uses: actions/checkout@v3
|
||||||
|
with:
|
||||||
|
submodules: true
|
||||||
|
- name: Install stable
|
||||||
|
uses: actions-rs/toolchain@v1
|
||||||
|
with:
|
||||||
|
profile: minimal
|
||||||
|
toolchain: stable
|
||||||
|
- name: cargo generate-lockfile
|
||||||
|
if: hashFiles('Cargo.lock') == ''
|
||||||
|
uses: actions-rs/cargo@v1
|
||||||
|
with:
|
||||||
|
command: generate-lockfile
|
||||||
|
- name: cargo test
|
||||||
|
uses: actions-rs/cargo@v1
|
||||||
|
with:
|
||||||
|
command: test
|
||||||
|
args: --locked --all-features --all-targets
|
||||||
|
coverage:
|
||||||
|
runs-on: ubuntu-latest
|
||||||
|
name: ubuntu / stable / coverage
|
||||||
|
steps:
|
||||||
|
- uses: actions/checkout@v3
|
||||||
|
with:
|
||||||
|
submodules: true
|
||||||
|
- name: Install stable
|
||||||
|
uses: actions-rs/toolchain@v1
|
||||||
|
with:
|
||||||
|
profile: minimal
|
||||||
|
toolchain: stable
|
||||||
|
components: llvm-tools-preview
|
||||||
|
- name: cargo install cargo-llvm-cov
|
||||||
|
uses: taiki-e/install-action@cargo-llvm-cov
|
||||||
|
- name: cargo generate-lockfile
|
||||||
|
if: hashFiles('Cargo.lock') == ''
|
||||||
|
uses: actions-rs/cargo@v1
|
||||||
|
with:
|
||||||
|
command: generate-lockfile
|
||||||
|
- name: cargo llvm-cov
|
||||||
|
run: cargo llvm-cov --locked --all-features --lcov --output-path lcov.info
|
||||||
|
- name: Upload to codecov.io
|
||||||
|
uses: codecov/codecov-action@v2
|
||||||
|
with:
|
||||||
|
fail_ci_if_error: true
|
||||||
Loading…
Add table
Reference in a new issue