Skip to content

Use newtypes for certificate and private key #706

Use newtypes for certificate and private key

Use newtypes for certificate and private key #706

Workflow file for this run

# yaml-language-server: $schema=https://json.schemastore.org/github-workflow
name: test
permissions:
contents: read
on:
pull_request:
push:
branches:
- main
workflow_dispatch:
concurrency:
group: ${{ github.workflow }}-${{ github.ref }}
cancel-in-progress: true
env:
CARGO_INCREMENTAL: 0
CARGO_TERM_COLOR: always
RUST_BACKTRACE: short
jobs:
run:
strategy:
fail-fast: false # don't give up on the whole matrix if one variant fails
matrix:
# Keep list of targets in sync with `latest-dependencies.yaml`.
include:
- target: aarch64-apple-darwin
runner_os: macos-latest
- target: armv7-unknown-linux-gnueabihf
runner_os: ubuntu-latest
- target: x86_64-apple-darwin
runner_os: macos-latest
- target: x86_64-pc-windows-msvc
runner_os: windows-latest
- target: x86_64-unknown-linux-gnu
runner_os: ubuntu-latest
- target: x86_64-unknown-linux-musl
runner_os: ubuntu-latest
runs-on: ${{ matrix.runner_os }}
steps:
- name: Adjust build settings for Windows
if: contains(matrix.target, '-windows-')
# Required for Windows builds: for version numbers with pre-release part
# as suffix, the resulting paths would get too long to build otherwise.
run: >-
echo "CARGO_TARGET_DIR=D:\t" >> $env:GITHUB_ENV
- name: Install Rust toolchain
# Use specific Rust version that is the minimum supported `rust-version`
# (MSRV) from `Cargo.toml`.
uses: dtolnay/[email protected]
- name: Install cross-compilation tools
uses: taiki-e/setup-cross-toolchain-action@v1
with:
target: ${{ matrix.target }}
- name: Install Cargo helpers
run: >-
cargo install cargo-hack
# Check out the repository before the remaining steps that depend on it.
# All preceding steps are independent of the repository contents.
- name: Check out repository
uses: actions/checkout@v4
- name: Cache Rust toolchain and build artifacts
uses: Swatinem/rust-cache@v2
with:
# The cache should not be shared between different workflows, jobs, and targets.
shared-key: ${{ github.workflow }}-${{ github.job }}-${{ matrix.target }}
- name: Build with feature combinations
run: >-
cargo hack --each-feature build --locked
- name: Run tests (bins/lib/tests/examples) with feature combinations
run: >-
cargo hack --each-feature test --locked
--bins --lib --tests --examples
# Compile and run doctests, which have been excluded in the previous
# step(s).
#
# Doctests may use any features and there is no easy way to activate
# certain features only for some doctests, so we run them without
# `cargo-hack`.
- name: Run doctests with all features enabled
run: >-
cargo test --locked --all-features
--doc
- name: Build package with all features enabled
run: >-
cargo package --locked --all-features