mirror of
https://github.com/isar/rusqlite.git
synced 2024-11-22 16:29:20 +08:00
6766d6a6cd
And associated bindgen_3.6.8.rs
213 lines
7.9 KiB
YAML
213 lines
7.9 KiB
YAML
name: CI
|
||
|
||
on:
|
||
push:
|
||
branches:
|
||
- master
|
||
pull_request:
|
||
branches:
|
||
- master
|
||
schedule:
|
||
- cron: "00 01 * * *"
|
||
env:
|
||
RUST_BACKTRACE: short
|
||
# CI builds don't benefit very much from this.
|
||
CARGO_INCREMENTAL: 0
|
||
# We can't use a debugger in CI, and this makes builds faster and the cache
|
||
# smaller. (TODO: use -Cdebuginfo=0 if it doesn't make backtraces useless)
|
||
RUSTFLAGS: -Cdebuginfo=1
|
||
|
||
jobs:
|
||
test:
|
||
name: Test ${{ matrix.target }}
|
||
|
||
strategy:
|
||
fail-fast: false
|
||
|
||
matrix:
|
||
include:
|
||
- { target: x86_64-pc-windows-msvc, os: windows-latest }
|
||
- { target: x86_64-unknown-linux-gnu, os: ubuntu-latest }
|
||
- { target: x86_64-apple-darwin, os: macos-latest }
|
||
- target: x86_64-pc-windows-gnu
|
||
os: windows-latest
|
||
host: -x86_64-pc-windows-gnu
|
||
|
||
runs-on: ${{ matrix.os }}
|
||
|
||
steps:
|
||
- uses: actions/checkout@v2
|
||
# This has a matcher for test panics, so we use it even though elsewhere
|
||
# we use actions-rs/toolchain.
|
||
- uses: hecrj/setup-rust-action@v1
|
||
with:
|
||
rust-version: stable${{ matrix.host }}
|
||
targets: ${{ matrix.target }}
|
||
# The `{ sharedKey: ... }` allows different actions to share the cache.
|
||
# We're using a `fullBuild` key mostly as a "this needs to do the
|
||
# complete" that needs to do the complete build (that is, including
|
||
# `--features 'bundled-full session buildtime_bindgen`), which is very
|
||
# slow, and has several deps.
|
||
- uses: Swatinem/rust-cache@v1
|
||
with: { sharedKey: fullBuild }
|
||
|
||
- run: cargo build --features bundled --workspace --all-targets --verbose
|
||
- run: cargo test --features bundled --workspace --all-targets --verbose
|
||
- run: cargo test --features bundled --workspace --doc --verbose
|
||
|
||
- name: Add llvm path on Windows
|
||
if: matrix.os == 'windows-latest'
|
||
run: echo "C:\msys64\mingw64\bin" | Out-File -FilePath $env:GITHUB_PATH -Encoding utf8 -Append
|
||
|
||
- run: cargo test --features 'bundled-full session buildtime_bindgen' --all-targets --workspace --verbose
|
||
- run: cargo test --features 'bundled-full session buildtime_bindgen' --doc --workspace --verbose
|
||
|
||
# TODO: move into own action for better caching
|
||
- name: Static build
|
||
# Do we expect this to work / should we test with gnu toolchain?
|
||
if: matrix.os == 'x86_64-pc-windows-msvc'
|
||
env:
|
||
RUSTFLAGS: -Ctarget-feature=+crt-static -Cdebuginfo=1
|
||
run: cargo build --features bundled
|
||
|
||
test-sqlcipher-bundled:
|
||
name: Test ${{ matrix.os }} (bundled SQLcipher + OpenSSL)
|
||
runs-on: ${{ matrix.os }}
|
||
strategy:
|
||
fail-fast: false
|
||
matrix:
|
||
os: [ubuntu-latest, macos-latest]
|
||
# TODO: find a way to test this on windows :(
|
||
|
||
steps:
|
||
- uses: actions/checkout@v2
|
||
# This has a matcher for test panics, so we use it even though elsewhere
|
||
# we use actions-rs/toolchain.
|
||
- uses: hecrj/setup-rust-action@v1
|
||
with:
|
||
rust-version: stable${{ matrix.host }}
|
||
targets: ${{ matrix.target }}
|
||
- uses: Swatinem/rust-cache@v1
|
||
with: { sharedKey: fullBuild }
|
||
|
||
- run: cargo test --features 'bundled-sqlcipher' --workspace --all-targets --verbose
|
||
- run: cargo test --features 'bundled-sqlcipher' --workspace --doc --verbose
|
||
|
||
- run: cargo test --features 'modern-full bundled-sqlcipher' --workspace --all-targets --verbose
|
||
- run: cargo test --features 'modern-full bundled-sqlcipher' --workspace --doc --verbose
|
||
|
||
- run: cargo test --features 'bundled-sqlcipher-vendored-openssl' --workspace --all-targets --verbose
|
||
- run: cargo test --features 'bundled-sqlcipher-vendored-openssl' --workspace --doc --verbose
|
||
|
||
- run: cargo test --features 'modern-full bundled-sqlcipher-vendored-openssl' --all-targets --workspace --verbose
|
||
- run: cargo test --features 'modern-full bundled-sqlcipher-vendored-openssl' --doc --workspace --verbose
|
||
|
||
- name: Add llvm path on Windows
|
||
if: matrix.os == 'windows-latest'
|
||
run: echo "C:\msys64\mingw64\bin" | Out-File -FilePath $env:GITHUB_PATH -Encoding utf8 -Append
|
||
|
||
- run: cargo test --features 'bundled-full session buildtime_bindgen' --all-targets --workspace --verbose
|
||
- run: cargo test --features 'bundled-full session buildtime_bindgen' --doc --workspace --verbose
|
||
|
||
winsqlite3:
|
||
name: Test with winsqlite3
|
||
runs-on: windows-latest
|
||
steps:
|
||
- uses: actions/checkout@v2
|
||
- uses: hecrj/setup-rust-action@v1
|
||
- uses: Swatinem/rust-cache@v1
|
||
# TODO: Should this test GNU toolchain? What about +crt-static?
|
||
# TODO: Is it worth testing other features?
|
||
- run: cargo build --features winsqlite3 --workspace --all-targets --verbose
|
||
- run: cargo test --features winsqlite3 --workspace --all-targets --verbose
|
||
|
||
sqlcipher:
|
||
name: Test with sqlcipher
|
||
runs-on: ubuntu-latest
|
||
steps:
|
||
- uses: actions/checkout@v2
|
||
- uses: hecrj/setup-rust-action@v1
|
||
- uses: Swatinem/rust-cache@v1
|
||
- run: sudo apt-get install sqlcipher libsqlcipher-dev
|
||
- run: sqlcipher --version
|
||
# TODO: Is it worth testing other features?
|
||
- run: cargo build --features sqlcipher --workspace --all-targets --verbose
|
||
- run: cargo test --features sqlcipher --workspace --all-targets --verbose
|
||
|
||
sanitizer:
|
||
name: Address Sanitizer
|
||
runs-on: ubuntu-latest
|
||
steps:
|
||
- uses: actions/checkout@v2
|
||
# Need nightly rust.
|
||
- uses: hecrj/setup-rust-action@v1
|
||
with:
|
||
rust-version: nightly
|
||
components: rust-src
|
||
- uses: Swatinem/rust-cache@v1
|
||
- name: Tests with asan
|
||
env:
|
||
RUSTFLAGS: -Zsanitizer=address -Cdebuginfo=0
|
||
RUSTDOCFLAGS: -Zsanitizer=address
|
||
ASAN_OPTIONS: "detect_stack_use_after_return=1:detect_leaks=0"
|
||
# Work around https://github.com/rust-lang/rust/issues/59125 by
|
||
# disabling backtraces. In an ideal world we'd probably suppress the
|
||
# leak sanitization, but we don't care about backtraces here, so long
|
||
# as the other tests have them.
|
||
RUST_BACKTRACE: "0"
|
||
run: cargo -Z build-std test --features 'bundled-full session buildtime_bindgen with-asan' --target x86_64-unknown-linux-gnu
|
||
|
||
# Ensure clippy doesn't complain.
|
||
clippy:
|
||
name: Clippy
|
||
runs-on: ubuntu-latest
|
||
steps:
|
||
- uses: actions/checkout@v2
|
||
- uses: hecrj/setup-rust-action@v1
|
||
with:
|
||
components: clippy
|
||
- uses: Swatinem/rust-cache@v1
|
||
- run: cargo clippy --all-targets --workspace --features bundled -- -D warnings
|
||
# Clippy with all non-conflicting features
|
||
- run: cargo clippy --all-targets --workspace --features 'bundled-full session buildtime_bindgen' -- -D warnings
|
||
|
||
# Ensure patch is formatted.
|
||
fmt:
|
||
name: Format
|
||
runs-on: ubuntu-latest
|
||
steps:
|
||
- uses: actions/checkout@v2
|
||
- uses: hecrj/setup-rust-action@v1
|
||
with:
|
||
components: rustfmt
|
||
- run: cargo fmt --all -- --check
|
||
|
||
# Detect cases where documentation links don't resolve and such.
|
||
doc:
|
||
name: Docs
|
||
runs-on: ubuntu-latest
|
||
steps:
|
||
- uses: actions/checkout@v2
|
||
- uses: hecrj/setup-rust-action@v1
|
||
- uses: Swatinem/rust-cache@v1
|
||
with: { sharedKey: fullBuild }
|
||
- run: cargo doc --features 'bundled-full session buildtime_bindgen' --no-deps
|
||
env: { RUSTDOCFLAGS: -Dwarnings }
|
||
|
||
codecov:
|
||
name: Generate code coverage
|
||
runs-on: ubuntu-latest
|
||
steps:
|
||
- uses: actions/checkout@v2
|
||
- uses: hecrj/setup-rust-action@v1
|
||
# TODO: we don't use caching here because it's unclear if it will cause
|
||
# the coverage to get less accurate (this is the case for some coverage
|
||
# tools, although possibly not tarpaulin?)
|
||
- name: Run cargo-tarpaulin
|
||
uses: actions-rs/tarpaulin@v0.1
|
||
with:
|
||
args: '--features "bundled-full session buildtime_bindgen"'
|
||
|
||
- name: Upload to codecov.io
|
||
uses: codecov/codecov-action@v1
|