Skip to content

latest-dependencies #766

latest-dependencies

latest-dependencies #766

# yaml-language-server: $schema=https://json.schemastore.org/github-workflow
name: latest-dependencies
permissions:
contents: read
on:
pull_request:
push:
branches:
- main
schedule:
# Weekly, i.e. on Monday at 03:20 UTC
- cron: "20 3 * * 1"
workflow_dispatch:
concurrency:
group: ${{ github.workflow }}-${{ github.ref }}
cancel-in-progress: true
env:
CARGO_INCREMENTAL: 0
CARGO_TERM_COLOR: always
RUST_BACKTRACE: short
jobs:
run:
strategy:
# Don't give up on the whole matrix if one variant fails.
fail-fast: false
matrix:
# Keep target archs in sync with `test.yaml`. Use latest versions of
# runner OS here and supported ones in `test.yaml`.
include:
- target: aarch64-apple-darwin
runner_os: macos-latest
- target: armv7-unknown-linux-gnueabihf
runner_os: ubuntu-latest
- target: x86_64-apple-darwin
runner_os: macos-latest
- target: x86_64-pc-windows-msvc
runner_os: windows-latest
- target: x86_64-unknown-linux-gnu
runner_os: ubuntu-latest
- target: x86_64-unknown-linux-musl
runner_os: ubuntu-latest
runs-on: ${{ matrix.runner_os }}
steps:
- name: Adjust build settings for Windows
if: contains(matrix.target, '-windows-')
# Required for Windows builds: for version numbers with pre-release part
# as suffix, the resulting paths would get too long to build otherwise.
run: >-
echo "CARGO_TARGET_DIR=D:\t" >> $env:GITHUB_ENV
- name: Install Rust toolchain
# Use latest stable Rust version.
uses: dtolnay/rust-toolchain@stable
- name: Install cross-compilation tools
uses: taiki-e/setup-cross-toolchain-action@v1
with:
target: ${{ matrix.target }}
- name: Install Cargo helpers
# Fall back to installing with locked dependencies when installed rustc
# is too old.
run: >-
cargo install cargo-hack || cargo install --locked cargo-hack
# Check out the repository before the remaining steps that depend on it.
# All preceding steps are independent of the repository contents.
- name: Check out repository
uses: actions/checkout@v4
- name: Cache Rust toolchain and build artifacts
uses: Swatinem/rust-cache@v2
with:
# The cache should not be shared between different workflows, jobs, and targets.
shared-key: ${{ github.workflow }}-${{ github.job }}-${{ matrix.target }}-${{ matrix.runner_os }}
- name: Update Rust to latest version
run: >-
rustup update
- name: Update crates to latest versions
run: >-
cargo update --verbose
- name: Build with feature combinations
run: >-
cargo hack --each-feature build --locked
- name: Run tests (bins/lib/tests/examples) with feature combinations
run: >-
cargo hack --each-feature test --locked
--bins --lib --tests --examples
# Compile and run doctests, which have been excluded in the previous
# step(s).
#
# Doctests may use any features and there is no easy way to activate
# certain features only for some doctests, so we run them without
# `cargo-hack`.
- name: Run doctests with all features enabled
run: >-
cargo test --locked --all-features
--doc
- name: Build package with all features enabled
# We allow dirty state here because it is only expected after update.
run: >-
cargo package --locked --all-features --allow-dirty