Skip to content

Check crate MSRVs #6972

Check crate MSRVs

Check crate MSRVs #6972

Workflow file for this run

#
# 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")'