Skip to content

pkg-json

pkg-json #46

Workflow file for this run

name: CI
on:
push:
branches:
- main
- develop
- 'feature/**'
- 'release/**'
pull_request:
branches:
- main
- develop
workflow_dispatch:
env:
CARGO_TERM_COLOR: always
RUST_BACKTRACE: 1
jobs:
# Check code formatting
fmt:
name: Format Check
runs-on: ubuntu-latest
steps:
- name: Checkout code
uses: actions/checkout@v4
- name: Setup Rust
uses: dtolnay/rust-toolchain@stable
with:
components: rustfmt
- name: Check formatting
run: cargo fmt --all -- --check
# Lint with Clippy
clippy:
name: Clippy Lint
runs-on: ubuntu-latest
steps:
- name: Checkout code
uses: actions/checkout@v4
- name: Setup Rust
uses: dtolnay/rust-toolchain@stable
with:
components: clippy
- name: Cache dependencies
uses: Swatinem/rust-cache@v2
with:
cache-on-failure: true
- name: Run Clippy
run: cargo clippy --all-targets --all-features -- -D warnings
# Run tests
test:
name: Test Suite
runs-on: ${{ matrix.os }}
strategy:
fail-fast: false
matrix:
os: [ubuntu-latest, macos-latest]
rust: [stable, beta]
include:
- os: ubuntu-latest
rust: 1.75.0 # MSRV
steps:
- name: Checkout code
uses: actions/checkout@v4
- name: Setup Rust ${{ matrix.rust }}
uses: dtolnay/rust-toolchain@master
with:
toolchain: ${{ matrix.rust }}
- name: Cache dependencies
uses: Swatinem/rust-cache@v2
with:
cache-on-failure: true
key: ${{ matrix.os }}-${{ matrix.rust }}
- name: Run tests
run: cargo test --workspace --all-features --verbose
- name: Run doctests
run: cargo test --workspace --doc --verbose
# Code coverage
coverage:
name: Code Coverage
runs-on: ubuntu-latest
steps:
- name: Checkout code
uses: actions/checkout@v4
- name: Setup Rust
uses: dtolnay/rust-toolchain@stable
- name: Cache dependencies
uses: Swatinem/rust-cache@v2
- name: Install cargo-tarpaulin
run: cargo install cargo-tarpaulin
- name: Generate coverage
run: cargo tarpaulin --workspace --all-features --timeout 300 --out xml
- name: Upload coverage to Codecov
uses: codecov/codecov-action@v4
with:
files: ./cobertura.xml
fail_ci_if_error: false
token: ${{ secrets.CODECOV_TOKEN }}
# Security audit
security-audit:
name: Security Audit
runs-on: ubuntu-latest
steps:
- name: Checkout code
uses: actions/checkout@v4
- name: Setup Rust
uses: dtolnay/rust-toolchain@stable
- name: Cache dependencies
uses: Swatinem/rust-cache@v2
- name: Install cargo-audit
run: cargo install cargo-audit
- name: Run security audit
run: cargo audit --deny warnings
- name: Run cargo-deny
uses: EmbarkStudios/cargo-deny-action@v1
with:
log-level: warn
command: check
arguments: --all-features
# Check dependencies
dependency-check:
name: Dependency Check
runs-on: ubuntu-latest
steps:
- name: Checkout code
uses: actions/checkout@v4
- name: Setup Rust
uses: dtolnay/rust-toolchain@stable
- name: Cache dependencies
uses: Swatinem/rust-cache@v2
- name: Install cargo-outdated
run: cargo install cargo-outdated
- name: Check outdated dependencies
run: cargo outdated --exit-code 1
continue-on-error: true
# Build binaries
build:
name: Build
runs-on: ${{ matrix.os }}
strategy:
fail-fast: false
matrix:
include:
- os: ubuntu-latest
target: x86_64-unknown-linux-gnu
- os: ubuntu-latest
target: x86_64-unknown-linux-musl
- os: macos-latest
target: x86_64-apple-darwin
- os: macos-latest
target: aarch64-apple-darwin
steps:
- name: Checkout code
uses: actions/checkout@v4
- name: Setup Rust
uses: dtolnay/rust-toolchain@stable
with:
targets: ${{ matrix.target }}
- name: Cache dependencies
uses: Swatinem/rust-cache@v2
with:
key: ${{ matrix.target }}
- name: Install musl-tools (Linux musl)
if: matrix.target == 'x86_64-unknown-linux-musl'
run: sudo apt-get update && sudo apt-get install -y musl-tools
- name: Build release binary
run: cargo build --release --target ${{ matrix.target }} --bin sentinel
- name: Upload artifact
uses: actions/upload-artifact@v4
with:
name: sentinel-${{ matrix.target }}
path: target/${{ matrix.target }}/release/sentinel*
retention-days: 7
# Integration tests (requires Docker)
integration-tests:
name: Integration Tests
runs-on: ubuntu-latest
services:
kafka:
image: confluentinc/cp-kafka:7.5.0
env:
KAFKA_ZOOKEEPER_CONNECT: zookeeper:2181
options: >-
--health-cmd "kafka-broker-api-versions --bootstrap-server localhost:9092"
--health-interval 10s
--health-timeout 5s
--health-retries 5
steps:
- name: Checkout code
uses: actions/checkout@v4
- name: Setup Rust
uses: dtolnay/rust-toolchain@stable
- name: Cache dependencies
uses: Swatinem/rust-cache@v2
- name: Start dependencies
run: docker-compose -f docker-compose.yaml up -d kafka influxdb rabbitmq redis
- name: Wait for services
run: sleep 30
- name: Run integration tests
run: cargo test --workspace --test '*' --verbose
env:
KAFKA_BROKERS: localhost:9093
INFLUXDB_URL: http://localhost:8086
RABBITMQ_URL: amqp://localhost:5672
- name: Stop dependencies
if: always()
run: docker-compose down
# All checks pass
ci-success:
name: CI Success
needs:
- fmt
- clippy
- test
- coverage
- security-audit
- dependency-check
- build
runs-on: ubuntu-latest
if: always()
steps:
- name: Check all jobs
run: |
if [[ "${{ contains(needs.*.result, 'failure') }}" == "true" ]]; then
echo "One or more CI jobs failed"
exit 1
fi
echo "All CI jobs passed!"