(wip) refactor: redo how data collection is laid out #3752
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
# Main CI workflow to validate PRs and branches are correctly formatted | |
# and pass tests. | |
# | |
# CI workflow was based on a lot of work from other people: | |
# - https://github.com/heim-rs/heim/blob/master/.github/workflows/ci.yml | |
# - https://github.com/BurntSushi/ripgrep/blob/master/.github/workflows/ci.yml | |
# - https://www.reillywood.com/blog/rust-faster-ci/ | |
# - https://matklad.github.io/2021/09/04/fast-rust-builds.html | |
# | |
# Supported platforms run the following tasks: | |
# - cargo fmt | |
# - cargo test (built/test in separate steps) | |
# - cargo clippy (apparently faster to do it after the build/test) | |
# | |
# Unsupported platforms run the following tasks: | |
# - cargo build | |
# | |
# Note that not all platforms are tested using this CI action! There are some | |
# tested by Cirrus CI due to (free) platform limitations on GitHub. Currently, | |
# this is just macOS M1 and FreeBSD. | |
name: ci | |
on: | |
workflow_dispatch: | |
pull_request: | |
push: | |
branches: | |
- main | |
env: | |
RUST_BACKTRACE: 1 | |
CARGO_INCREMENTAL: 0 | |
CARGO_PROFILE_DEV_DEBUG: 0 | |
CARGO_HUSKY_DONT_INSTALL_HOOKS: true | |
COMPLETION_DIR: "target/tmp/bottom/completion/" | |
MANPAGE_DIR: "target/tmp/bottom/manpage/" | |
concurrency: | |
group: ${{ github.workflow }}-${{ github.ref }} | |
cancel-in-progress: ${{ github.event_name == 'pull_request' || github.repository != 'ClementTsang/bottom' }} | |
jobs: | |
# Check if things should be skipped. | |
pre-job: | |
runs-on: ubuntu-latest | |
outputs: | |
should_skip: ${{ steps.skip_check.outputs.should_skip }} | |
steps: | |
- name: Check if this action should be skipped | |
id: skip_check | |
uses: fkirc/skip-duplicate-actions@f75f66ce1886f00957d99748a42c724f4330bdcf # v5.3.1 | |
with: | |
skip_after_successful_duplicate: "true" | |
paths: '[".cargo/**", ".github/workflows/ci.yml", "sample_configs/**", "src/**", "tests/**", "build.rs", "Cargo.lock", "Cargo.toml", "clippy.toml", "rustfmt.toml", "Cross.toml"]' | |
do_not_skip: '["workflow_dispatch", "push"]' | |
# Runs rustfmt + tests + clippy on the main supported platforms. | |
# | |
# TODO: In the future, when ARM runners are available on github, switch ARM targets off of cross. | |
supported: | |
needs: pre-job | |
if: ${{ needs.pre-job.outputs.should_skip != 'true' }} | |
runs-on: ${{ matrix.info.os }} | |
timeout-minutes: 12 | |
strategy: | |
fail-fast: false | |
matrix: | |
info: | |
- { | |
os: "ubuntu-latest", | |
target: "x86_64-unknown-linux-gnu", | |
cross: false, | |
} | |
- { | |
os: "ubuntu-latest", | |
target: "aarch64-unknown-linux-gnu", | |
cross: true, | |
} | |
- { os: "macos-12", target: "x86_64-apple-darwin", cross: false } | |
- { os: "macos-14", target: "aarch64-apple-darwin", cross: false } | |
- { | |
os: "windows-2019", | |
target: "x86_64-pc-windows-msvc", | |
cross: false, | |
} | |
features: ["--all-features", "--no-default-features"] | |
steps: | |
- name: Checkout repository | |
uses: actions/checkout@692973e3d937129bcbf40652eb9f2f61becf3332 # v4.1.7 | |
- name: Set up Rust toolchain | |
uses: dtolnay/rust-toolchain@21dc36fb71dd22e3317045c0c31a3f4249868b17 | |
with: | |
toolchain: stable | |
components: rustfmt, clippy | |
target: ${{ matrix.info.target }} | |
- name: Enable Rust cache | |
uses: Swatinem/rust-cache@9bdad043e88c75890e36ad3bbc8d27f0090dd609 # 2.7.3 | |
if: ${{ github.event_name != 'pull_request' || ! github.event.pull_request.head.repo.fork }} # If it is a PR, only if not a fork | |
with: | |
key: ${{ matrix.info.target }} | |
cache-all-crates: true | |
- name: Check cargo fmt | |
run: cargo fmt --all -- --check | |
- name: Build tests | |
uses: ClementTsang/[email protected] | |
with: | |
command: test | |
args: --no-run --locked ${{ matrix.features }} --target=${{ matrix.info.target }} | |
use-cross: ${{ matrix.info.cross }} | |
cross-version: 0.2.5 | |
env: | |
RUST_BACKTRACE: full | |
- name: Run tests | |
uses: ClementTsang/[email protected] | |
with: | |
command: test | |
args: --no-fail-fast ${{ matrix.features }} --target=${{ matrix.info.target }} -- --nocapture --quiet | |
use-cross: ${{ matrix.info.cross }} | |
cross-version: 0.2.5 | |
env: | |
RUST_BACKTRACE: full | |
- name: Run clippy | |
uses: ClementTsang/[email protected] | |
with: | |
command: clippy | |
args: ${{ matrix.features }} --all-targets --workspace --target=${{ matrix.info.target }} -- -D warnings | |
use-cross: ${{ matrix.info.cross }} | |
cross-version: 0.2.5 | |
env: | |
RUST_BACKTRACE: full | |
# Try running cargo build on all other platforms. | |
# TODO: Maybe some of these should be allowed to fail? If so, I guess we can add back the "unofficial" MSRV, | |
# I would also put android there. | |
other-check: | |
needs: pre-job | |
runs-on: ${{ matrix.info.os }} | |
if: ${{ needs.pre-job.outputs.should_skip != 'true' }} | |
timeout-minutes: 12 | |
strategy: | |
fail-fast: false | |
matrix: | |
info: | |
# x86 or x86-64 | |
- { | |
os: "ubuntu-latest", | |
target: "i686-unknown-linux-gnu", | |
cross: true, | |
} | |
- { | |
os: "ubuntu-latest", | |
target: "x86_64-unknown-linux-musl", | |
cross: false, | |
} | |
- { | |
os: "ubuntu-latest", | |
target: "i686-unknown-linux-musl", | |
cross: true, | |
} | |
- { os: "windows-2019", target: "i686-pc-windows-msvc", cross: false } | |
- { | |
os: "windows-2019", | |
target: "x86_64-pc-windows-gnu", | |
cross: false, | |
} | |
# Beta | |
- { | |
os: "ubuntu-latest", | |
target: "x86_64-unknown-linux-gnu", | |
cross: false, | |
rust: "beta", | |
} | |
- { | |
os: "macos-12", | |
target: "x86_64-apple-darwin", | |
cross: false, | |
rust: "beta", | |
} | |
- { | |
os: "windows-2019", | |
target: "x86_64-pc-windows-msvc", | |
cross: false, | |
rust: "beta", | |
} | |
# armv7 | |
- { | |
os: "ubuntu-latest", | |
target: "armv7-unknown-linux-gnueabihf", | |
cross: true, | |
} | |
# armv6 | |
- { | |
os: "ubuntu-latest", | |
target: "arm-unknown-linux-gnueabihf", | |
cross: true, | |
} | |
# PowerPC 64 LE | |
- { | |
os: "ubuntu-latest", | |
target: "powerpc64le-unknown-linux-gnu", | |
cross: true, | |
} | |
# Risc-V 64gc | |
# Note: seems like this breaks with tests? | |
- { | |
os: "ubuntu-latest", | |
target: "riscv64gc-unknown-linux-gnu", | |
cross: true, | |
} | |
# Android ARM64 | |
- { | |
os: "ubuntu-latest", | |
target: "aarch64-linux-android", | |
cross: true, | |
cross-version: "git:cabfc3b02d1edec03869fabdabf6a7f8b0519160", | |
no-default-features: true, | |
no-clippy: true, | |
} | |
# Seems like cross' FreeBSD image is a bit broken? I | |
# get build errors, may be related to this issue: | |
# https://github.com/cross-rs/cross/issues/1291 | |
steps: | |
- name: Checkout repository | |
uses: actions/checkout@692973e3d937129bcbf40652eb9f2f61becf3332 # v4.1.7 | |
- name: Set up Rust toolchain | |
uses: dtolnay/rust-toolchain@21dc36fb71dd22e3317045c0c31a3f4249868b17 | |
with: | |
toolchain: ${{ matrix.info.rust || 'stable' }} | |
target: ${{ matrix.info.target }} | |
components: "clippy" | |
- name: Enable Rust cache | |
uses: Swatinem/rust-cache@9bdad043e88c75890e36ad3bbc8d27f0090dd609 # 2.7.3 | |
if: ${{ github.event_name != 'pull_request' || ! github.event.pull_request.head.repo.fork }} # If it is a PR, only if not a fork | |
with: | |
key: ${{ matrix.info.target }} | |
cache-all-crates: true | |
# - name: Test (default features) | |
# uses: ClementTsang/[email protected] | |
# if: ${{ matrix.info.no-default-features != true }} | |
# with: | |
# command: test | |
# args: --all-targets --workspace --target=${{ matrix.info.target }} --locked | |
# use-cross: ${{ matrix.info.cross }} | |
# cross-version: ${{ matrix.info.cross-version || '0.2.5' }} | |
# - name: Test (no features enabled) | |
# uses: ClementTsang/[email protected] | |
# if: ${{ matrix.info.no-default-features == true }} | |
# with: | |
# command: test | |
# args: --all-targets --workspace --target=${{ matrix.info.target }} --locked --no-default-features | |
# use-cross: ${{ matrix.info.cross }} | |
# cross-version: ${{ matrix.info.cross-version || '0.2.5' }} | |
- name: Check (default features) | |
uses: ClementTsang/[email protected] | |
if: ${{ matrix.info.no-default-features != true }} | |
with: | |
command: clippy | |
args: --all-targets --workspace --target=${{ matrix.info.target }} --locked | |
use-cross: ${{ matrix.info.cross }} | |
cross-version: ${{ matrix.info.cross-version || '0.2.5' }} | |
- name: Check (no features enabled) | |
uses: ClementTsang/[email protected] | |
if: ${{ matrix.info.no-default-features == true }} | |
with: | |
command: clippy | |
args: --all-targets --workspace --target=${{ matrix.info.target }} --locked --no-default-features | |
use-cross: ${{ matrix.info.cross }} | |
cross-version: ${{ matrix.info.cross-version || '0.2.5' }} | |
vm-check: | |
name: "Test using VMs" | |
needs: pre-job | |
if: ${{ needs.pre-job.outputs.should_skip != 'true' }} | |
runs-on: "ubuntu-latest" | |
timeout-minutes: 15 | |
strategy: | |
fail-fast: false | |
matrix: | |
info: | |
- { | |
type: "freebsd", | |
os_release: "14.1", | |
target: "x86_64-unknown-freebsd", | |
} | |
- { | |
type: "freebsd", | |
os_release: "13.3", | |
target: "x86_64-unknown-freebsd", | |
} | |
steps: | |
- name: Checkout repository | |
uses: actions/checkout@692973e3d937129bcbf40652eb9f2f61becf3332 # v4.1.7 | |
with: | |
fetch-depth: 1 | |
- name: Set up Rust toolchain | |
uses: dtolnay/rust-toolchain@21dc36fb71dd22e3317045c0c31a3f4249868b17 | |
with: | |
toolchain: ${{ matrix.info.rust || 'stable' }} | |
target: ${{ matrix.info.target }} | |
- name: Enable Rust cache | |
uses: Swatinem/rust-cache@9bdad043e88c75890e36ad3bbc8d27f0090dd609 # 2.7.3 | |
if: ${{ github.event_name != 'pull_request' || ! github.event.pull_request.head.repo.fork }} # If it is a PR, only if not a fork | |
with: | |
key: ${{ matrix.info.target }}-${{ matrix.info.os_release }} | |
cache-all-crates: true | |
- name: Test FreeBSD | |
if: ${{ matrix.info.type == 'freebsd' }} | |
uses: vmactions/[email protected] | |
with: | |
release: "${{ matrix.info.os_release }}" | |
envs: "CARGO_INCREMENTAL CARGO_PROFILE_DEV_DEBUG CARGO_HUSKY_DONT_INSTALL_HOOKS" | |
usesh: true | |
prepare: | | |
pkg install -y curl bash | |
curl --proto '=https' --tlsv1.2 -sSf https://sh.rustup.rs --output rustup.sh | |
sh rustup.sh --default-toolchain stable -y | |
run: | | |
. "$HOME/.cargo/env" | |
cargo clippy --all-targets --workspace -- -D warnings | |
completion: | |
name: "CI Pass Check" | |
needs: [supported, other-check, vm-check] | |
if: ${{ needs.supported.result != 'skipped' && needs.other-check.result != 'skipped' && needs.vm-check.result != 'skipped' }} | |
runs-on: "ubuntu-latest" | |
steps: | |
- name: CI Passed | |
if: ${{ needs.supported.result == 'success' && needs.other-check.result == 'success' && needs.vm-check.result == 'success' }} | |
run: | | |
echo "CI workflow completed successfully."; | |
- name: CI Failed | |
if: ${{ needs.supported.result == 'failure' && needs.other-check.result == 'failure' && needs.vm-check.result == 'failure' }} | |
run: | | |
echo "CI workflow failed."; | |
exit 1; | |
- name: CI Cancelled | |
if: ${{ needs.supported.result == 'cancelled' && needs.other-check.result == 'cancelled' && needs.vm-check.result == 'cancelled' }} | |
run: | | |
echo "CI workflow was cancelled."; | |
exit 1; |