name: CI
on:
push:
branches: [main]
pull_request:
branches: [main]
env:
CARGO_TERM_COLOR: always
RUSTFLAGS: -Dwarnings
ALL_FEATURES_NO_RING: >-
compression-all,aws-msk,schema-registry,aws-glue-schema-registry,
native-tls-roots,unstable-protocol,telemetry,socks5,rustls-aws-lc-rs
jobs:
check:
name: Check
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v4
- uses: dtolnay/rust-toolchain@stable
- uses: Swatinem/rust-cache@v2
- name: Check (rustls-aws-lc-rs backend, all other features)
run: cargo check --all-targets --no-default-features --features "$ALL_FEATURES_NO_RING"
check-ring:
name: Check (ring backend)
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v4
- uses: dtolnay/rust-toolchain@stable
- uses: Swatinem/rust-cache@v2
- name: Check (ring backend only, no rustls-aws-lc-rs)
run: cargo check --all-targets --no-default-features --features "compression-all,schema-registry,native-tls-roots,unstable-protocol,telemetry,socks5,ring"
fmt:
name: Format
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v4
- uses: dtolnay/rust-toolchain@stable
with:
components: rustfmt
- run: cargo fmt --all -- --check
clippy:
name: Clippy
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v4
- uses: dtolnay/rust-toolchain@stable
with:
components: clippy
- uses: Swatinem/rust-cache@v2
- run: cargo clippy --all-targets --no-default-features --features "$ALL_FEATURES_NO_RING"
test:
name: Test
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v4
- uses: dtolnay/rust-toolchain@stable
- uses: Swatinem/rust-cache@v2
- run: cargo test --no-default-features --features "$ALL_FEATURES_NO_RING"
doc:
name: Documentation
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v4
- uses: dtolnay/rust-toolchain@stable
- uses: Swatinem/rust-cache@v2
- run: cargo doc --no-deps --no-default-features --features "$ALL_FEATURES_NO_RING"
env:
RUSTDOCFLAGS: -Dwarnings
integration:
name: Integration Tests (Kafka ${{ matrix.kafka-version }})
runs-on: ubuntu-latest
strategy:
fail-fast: false
matrix:
include:
- kafka-version: "3.9.0"
kafka-image: "apache/kafka-native"
- kafka-version: "4.0.0"
kafka-image: "apache/kafka"
steps:
- uses: actions/checkout@v4
- uses: dtolnay/rust-toolchain@stable
- uses: Swatinem/rust-cache@v2
- name: Pre-pull Kafka image
run: |
for i in 1 2 3; do
docker pull ${{ matrix.kafka-image }}:${{ matrix.kafka-version }} && break
echo "Retry $i failed, waiting..."
sleep 10
done
- run: cargo test --test integration_tests -- --ignored --test-threads=1
timeout-minutes: 45
env:
KAFKA_VERSION: ${{ matrix.kafka-version }}
KAFKA_IMAGE: ${{ matrix.kafka-image }}
msrv:
name: MSRV (1.88)
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v4
- uses: dtolnay/rust-toolchain@master
with:
toolchain: "1.88"
- uses: Swatinem/rust-cache@v2
- run: cargo check