Check crate MSRVs #6972
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
# | |
# Copyright (c) 2023 ZettaScale Technology | |
# | |
# This program and the accompanying materials are made available under the | |
# terms of the Eclipse Public License 2.0 which is available at | |
# http://www.eclipse.org/legal/epl-2.0, or the Apache License, Version 2.0 | |
# which is available at https://www.apache.org/licenses/LICENSE-2.0. | |
# | |
# SPDX-License-Identifier: EPL-2.0 OR Apache-2.0 | |
# | |
# Contributors: | |
# ZettaScale Zenoh Team, <[email protected]> | |
# | |
name: CI | |
on: | |
push: | |
branches: ["**"] | |
pull_request: | |
branches: ["**"] | |
schedule: | |
- cron: "0 6 * * 1-5" | |
env: | |
CARGO_REGISTRIES_CRATES_IO_PROTOCOL: sparse | |
CARGO_PROFILE_DEV_DEBUG: false | |
RUSTUP_WINDOWS_PATH_ADD_BIN: 1 | |
jobs: | |
check: | |
name: Lints and doc tests on ${{ matrix.os }} | |
runs-on: ${{ matrix.os }} | |
strategy: | |
fail-fast: false | |
matrix: | |
os: [ubuntu-latest, windows-latest, macos-13, macos-14] | |
steps: | |
- name: Clone this repository | |
uses: actions/checkout@v4 | |
- name: Setup rust-cache | |
uses: Swatinem/rust-cache@v2 | |
- name: Update Stable Rust toolchain | |
run: rustup update stable | |
- name: Install latest cargo-deny | |
uses: taiki-e/install-action@cargo-deny | |
- name: Code format check | |
run: cargo fmt --check | |
- name: Clippy | |
run: cargo +stable clippy --all-targets -- --deny warnings | |
- name: Clippy unstable targets | |
run: cargo +stable clippy --all-targets --features unstable -- --deny warnings | |
- name: Clippy all features | |
if: ${{ matrix.os == 'ubuntu-latest' || matrix.os == 'macOS-latest' }} | |
run: cargo +stable clippy --all-targets --all-features -- --deny warnings | |
- name: Install generic no_std target | |
# Generic no_std target architecture is x86_64-unknown-none | |
run: rustup target add x86_64-unknown-none | |
- name: Perform no_std checks | |
run: cargo check --bin nostd_check --target x86_64-unknown-none --manifest-path ci/nostd-check/Cargo.toml | |
- name: Run doctests | |
run: cargo test --doc | |
- name: Check licenses | |
run: cargo deny check licenses | |
test: | |
name: Unit tests on ${{ matrix.os }} | |
runs-on: ${{ matrix.os }} | |
strategy: | |
fail-fast: false | |
matrix: | |
os: [ubuntu-latest, windows-latest, macos-13, macos-14] | |
steps: | |
- name: Clone this repository | |
uses: actions/checkout@v4 | |
- name: Install latest Rust toolchain | |
run: rustup show | |
- name: Setup rust-cache | |
uses: Swatinem/rust-cache@v2 | |
- name: Set rustflags | |
shell: bash | |
run: | | |
case ${{ matrix.os }} in | |
*windows*) echo "RUSTFLAGS=-Clink-arg=/DEBUG:NONE" >> $GITHUB_ENV ;; | |
esac | |
- name: Install latest nextest | |
uses: taiki-e/install-action@nextest | |
- name: Run tests | |
run: cargo nextest run --exclude zenoh-examples --exclude zenoh-plugin-example --workspace | |
- name: Run tests with SHM | |
if: ${{ matrix.os == 'ubuntu-latest' }} | |
run: cargo nextest run -F shared-memory -F transport_unixpipe -p zenoh-transport | |
- name: Check for feature leaks | |
if: ${{ matrix.os == 'ubuntu-latest' }} | |
run: cargo nextest run -p zenohd --no-default-features | |
valgrind: | |
name: Memory leak checks | |
runs-on: ubuntu-latest | |
needs: check | |
steps: | |
- name: Clone this repository | |
uses: actions/checkout@v4 | |
- name: Install latest Rust toolchain | |
run: rustup show | |
- name: Install valgrind | |
uses: taiki-e/install-action@valgrind | |
- uses: Swatinem/rust-cache@v2 | |
- name: Run memory leaks check | |
run: ci/valgrind-check/run.sh | |
shell: bash | |
typos: | |
name: Typos Check | |
runs-on: ubuntu-latest | |
steps: | |
- name: Clone this repository | |
uses: actions/checkout@v4 | |
- name: Check spelling | |
uses: crate-ci/typos@master | |
msrvs: | |
name: MSRV checks on ${{ matrix.os }} | |
runs-on: ${{ matrix.os }} | |
# NOTE: It is necessary to run the check-msrv action on platforms since a crate's MSRV | |
# depends on the target it's compiled for. | |
strategy: | |
fail-fast: false | |
matrix: | |
os: | |
- ubuntu-latest | |
- macos-13 | |
- macos-14 | |
# - windows-latest | |
steps: | |
- name: Clone this repository | |
uses: actions/checkout@v4 | |
- uses: ZettaScaleLabs/ci/check-msrv@develop | |
with: | |
repo: ${{ github.repository }} | |
# NOTE: As of commit 25f06bd, the minimum MSRV found in the workspace is 1.68. | |
# This value should be as high as possible to avoid needlessly checking older versions. | |
min: 1.68.2 | |
# NOTE: In GitHub repository settings, the "Require status checks to pass | |
# before merging" branch protection rule ensures that commits are only merged | |
# from branches where specific status checks have passed. These checks are | |
# specified manually as a list of workflow job names. Thus we use this extra | |
# job to signal whether all CI checks have passed. | |
ci: | |
name: CI status checks | |
runs-on: ubuntu-latest | |
needs: [check, test, valgrind, typos] | |
if: always() | |
steps: | |
- name: Check whether all jobs pass | |
run: echo '${{ toJson(needs) }}' | jq -e 'all(.result == "success")' |