Merge pull request #191 from promised-ai/feature/pitman-yor #383
Workflow file for this run
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
name: 'Rust: Build and Test' | |
on: | |
push: | |
tags: | |
- rust-* | |
workflow_dispatch: | |
pull_request: | |
paths: | |
- 'lace/**' | |
- 'book/**' | |
- '.github/workflows/rust-build-test.yaml' | |
- '.github/scripts/run_code_in_mdfile.py' | |
concurrency: | |
group: ${{ github.workflow }}-${{ github.ref }} | |
cancel-in-progress: true | |
env: | |
CARGO_TERM_COLOR: always | |
jobs: | |
features: | |
runs-on: ubuntu-latest | |
steps: | |
- uses: actions/checkout@v4 | |
- name: Set up Rust | |
uses: dtolnay/rust-toolchain@stable | |
- name: Cache Rust | |
uses: Swatinem/rust-cache@v2 | |
with: | |
workspaces: . -> lace/target | |
- name: Install dependencies | |
run: cargo install cargo-hack | |
- name: Run cargo check on all features | |
working-directory: lace | |
run: cargo hack check --each-feature --all-targets | |
lint: | |
runs-on: ubuntu-latest | |
defaults: | |
run: | |
working-directory: lace | |
steps: | |
- uses: actions/checkout@v4 | |
- name: Set up Rust | |
uses: dtolnay/rust-toolchain@stable | |
with: | |
components: rustfmt, clippy | |
- name: Cache Rust | |
uses: Swatinem/rust-cache@v2 | |
with: | |
workspaces: . -> lace/target | |
- name: Run rustfmt (Lace) | |
working-directory: lace | |
run: cargo fmt --all -- --check | |
- name: Run rustfmt (CLI) | |
working-directory: cli | |
run: cargo fmt --all -- --check | |
- name: Run clippy (Lace) | |
working-directory: lace | |
env: | |
RUSTFLAGS: -C debuginfo=0 | |
run: | | |
cargo clippy --all-features | |
- name: Run clippy (CLI) | |
working-directory: cli | |
env: | |
RUSTFLAGS: -C debuginfo=0 | |
run: | | |
cargo clippy --all-features | |
- name: Install audit | |
run: cargo install cargo-audit | |
- name: Run audit (Lace) | |
working-directory: lace | |
# Note: Both `polars` and `arrow2` trigger this security violation | |
# due to their reliance on `chrono`, which is the ultimate source of the violation | |
# as of 2/21/23, no version of `chrono` has been published that fixes the issue | |
# and thus neither `polars` or `arrow2` can pass `audit` checks | |
run: cargo audit -f Cargo.lock --ignore RUSTSEC-2020-0071 | |
- name: Run audit (CLI) | |
working-directory: cli | |
# Note: Both `polars` and `arrow2` trigger this security violation | |
# due to their reliance on `chrono`, which is the ultimate source of the violation | |
# as of 2/21/23, no version of `chrono` has been published that fixes the issue | |
# and thus neither `polars` or `arrow2` can pass `audit` checks | |
run: cargo audit -f Cargo.lock --ignore RUSTSEC-2020-0071 | |
test: | |
runs-on: ${{ matrix.os }} | |
needs: ["lint", "features"] | |
strategy: | |
fail-fast: true | |
matrix: | |
os: [ubuntu-latest, windows-latest, macos-latest] | |
defaults: | |
run: | |
working-directory: lace | |
steps: | |
- uses: actions/checkout@v4 | |
- name: Set up Rust | |
uses: dtolnay/rust-toolchain@stable | |
- name: Cache Rust | |
uses: Swatinem/rust-cache@v2 | |
with: | |
workspaces: . -> lace/target | |
- name: Regen Examples | |
working-directory: cli | |
env: | |
RUSTFLAGS: -C debuginfo=0 | |
run: cargo run -- regen-examples | |
- name: Run Lace tests | |
env: | |
RUSTFLAGS: -C debuginfo=0 | |
run: cargo test --all-features | |
- name: Run CLI tests | |
working-directory: cli | |
env: | |
RUSTFLAGS: -C debuginfo=0 | |
run: cargo test --all-features | |
# semver-checks: | |
# runs-on: ubuntu-latest | |
# needs: ["features", "lint", "test"] | |
# steps: | |
# - name: Checkout branch | |
# uses: actions/checkout@v4 | |
# with: | |
# path: branch | |
# - name: Checkout master | |
# uses: actions/checkout@v4 | |
# with: | |
# ref: master | |
# path: master | |
# - name: Set up Rust | |
# uses: dtolnay/rust-toolchain@stable | |
# - name: Cache Rust | |
# uses: Swatinem/rust-cache@v2 | |
# with: | |
# workspaces: . -> lace/target | |
# - name: Install extra cargo tools | |
# run: cargo install cargo-semver-checks --locked | |
# - name: Check for semver-incompatibilities | |
# run: cargo semver-checks check-release --manifest-path branch/lace/Cargo.toml --baseline-root master/lace --verbose | |
compile-benchmarks: | |
runs-on: ubuntu-latest | |
needs: ["features", "lint", "test"] | |
steps: | |
- uses: actions/checkout@v4 | |
- name: Set up Rust | |
uses: dtolnay/rust-toolchain@stable | |
- name: Compile benchmark tests (but do not run) | |
uses: actions-rs/cargo@v1 | |
with: | |
command: bench | |
args: --manifest-path lace/Cargo.toml --no-run | |
test-mdbook-rust: | |
name: Test MDBook Rust Snippets | |
runs-on: ubuntu-latest | |
needs: ["features", "lint", "test"] | |
steps: | |
- uses: actions/checkout@v4 | |
- name: Install codedown | |
run: npm install -g codedown | |
- name: Set up Rust | |
uses: dtolnay/rust-toolchain@stable | |
- name: Cache Rust | |
uses: Swatinem/rust-cache@v2 | |
with: | |
workspaces: . -> lace/target | |
- name: Install rust-script | |
run: cargo install rust-script | |
- name: Test MDBook Code Samples (Rust) | |
env: | |
FORCE_COLOR: 1 | |
run: | | |
pip install termcolor yq | |
NEW_VERSION=$(tomlq -r .package.version < lace/Cargo.toml) | |
python3 .github/scripts/run_code_in_mdfile.py directory rust book $NEW_VERSION --exclusion-file .github/resources/mdbook_exclusions.txt | |
release: | |
name: release | |
runs-on: ubuntu-latest | |
if: startsWith(github.ref, 'refs/tags/rust-') | |
needs: ["compile-benchmarks", "features", "lint", "test", "test-mdbook-rust"] | |
steps: | |
- uses: actions/checkout@v4 | |
with: | |
fetch-depth: 0 | |
- name: Check Branch | |
env: | |
NEW_VERSION: ${{github.ref_name}} | |
run: | | |
git fetch origin master | |
git tag --merged origin/master | grep $NEW_VERSION | |
- uses: dtolnay/rust-toolchain@stable | |
- name: Check Semver | |
working-directory: lace | |
env: | |
NEW_VERSION: ${{github.ref_name}} | |
run: | | |
pip install yq | |
DEPLOYING_VERSION=$(echo "$NEW_VERSION" | perl -lpe 's/^rust-//') | |
MAIN_VERSION=$(tomlq -r .package.version Cargo.toml) | |
test "$DEPLOYING_VERSION" = "$MAIN_VERSION" | |
- name: Install dependencies | |
run: cargo install cargo-crate | |
- name: Publish Updated Library Crates to Crates.io | |
working-directory: lace | |
env: | |
CRATES_TOKEN: ${{ secrets.CRATES_TOKEN }} | |
PACKAGE_ORDER: "lace_utils lace_consts lace_data lace_stats lace_codebook lace_geweke lace_cc lace_metadata lace" | |
run: | | |
for PACKAGE_NAME in $PACKAGE_ORDER | |
do | |
echo "Processing package $PACKAGE_NAME" | |
if [ "$PACKAGE_NAME" == 'lace' ] | |
then | |
CARGO_FILE="Cargo.toml" | |
else | |
CARGO_FILE="$PACKAGE_NAME/Cargo.toml" | |
fi | |
PACKAGE_VERSION=$(tomlq .package.version $CARGO_FILE) | |
ALREADY_PUBLISHED=$(cargo crate info $PACKAGE_NAME --json --max-versions 100 | jq '[.krate.versions[].num] | any(. == '$PACKAGE_VERSION')') | |
if [ "$ALREADY_PUBLISHED" == 'false' ] | |
then | |
cargo publish --token "${CRATES_TOKEN}" -p $PACKAGE_NAME | |
fi | |
done | |
- name: Publish Updated CLI Crate to Crates.io | |
working-directory: cli | |
env: | |
CRATES_TOKEN: ${{ secrets.CRATES_TOKEN }} | |
run: | | |
PACKAGE_VERSION=$(tomlq .package.version Cargo.toml) | |
ALREADY_PUBLISHED=$(cargo crate info lace-cli --json --max-versions 100 | jq '[.krate.versions[].num] | any(. == '$PACKAGE_VERSION')') | |
if [ "$ALREADY_PUBLISHED" == 'false' ] | |
then | |
cargo publish --token "${CRATES_TOKEN}" -p lace-cli | |
fi |