From 74953958c8e4b4f06dd946b9e55b2618f2df3f4b Mon Sep 17 00:00:00 2001 From: Arpad Borsos Date: Wed, 20 Mar 2024 11:51:07 +0100 Subject: [PATCH] Update CI and add a Release workflow (#151) --- .codecov.yml | 10 ++ .craft.yml | 15 +++ .editorconfig | 10 ++ .github/workflows/ci.yml | 93 ++++++++++--------- .../workflows/enforce-license-compliance.yml | 16 ++++ .github/workflows/release.yml | 30 ++++++ .github/workflows/weekly.yml | 31 +++++++ .gitignore | 1 + scripts/bump-version.sh | 25 +++++ 9 files changed, 188 insertions(+), 43 deletions(-) create mode 100644 .codecov.yml create mode 100644 .craft.yml create mode 100644 .editorconfig create mode 100644 .github/workflows/enforce-license-compliance.yml create mode 100644 .github/workflows/release.yml create mode 100644 .github/workflows/weekly.yml create mode 100644 scripts/bump-version.sh diff --git a/.codecov.yml b/.codecov.yml new file mode 100644 index 0000000..3d88dbb --- /dev/null +++ b/.codecov.yml @@ -0,0 +1,10 @@ +coverage: + status: + project: + default: + informational: true + patch: false + +comment: + layout: "diff" + require_changes: true diff --git a/.craft.yml b/.craft.yml new file mode 100644 index 0000000..17d81ed --- /dev/null +++ b/.craft.yml @@ -0,0 +1,15 @@ +minVersion: "1.8.1" +github: + owner: getsentry + repo: pdb +changelogPolicy: auto + +statusProvider: + name: github +artifactProvider: + name: none + +preReleaseCommand: bash scripts/bump-version.sh +targets: + - name: github + - name: crates diff --git a/.editorconfig b/.editorconfig new file mode 100644 index 0000000..6aa024c --- /dev/null +++ b/.editorconfig @@ -0,0 +1,10 @@ +root = true + +[*] +end_of_line = lf +insert_final_newline = true +trim_trailing_whitespace = true +charset = utf-8 + +[Makefile] +indent_style = tab diff --git a/.github/workflows/ci.yml b/.github/workflows/ci.yml index 6a6f0f0..53c536e 100644 --- a/.github/workflows/ci.yml +++ b/.github/workflows/ci.yml @@ -2,69 +2,76 @@ name: CI on: push: - branches: [master] + branches: + - master + - "release/**" pull_request: - branches: [master] env: - CARGO_TERM_COLOR: always + RUSTFLAGS: -Dwarnings jobs: - lint: - name: Lint + lints: + name: Style/Linting runs-on: ubuntu-latest steps: - - uses: actions/checkout@v3 + - uses: actions/checkout@v4 - - uses: actions-rs/toolchain@v1 - with: - toolchain: stable - profile: minimal - components: clippy, rustfmt, rust-docs - override: true + - run: rustup toolchain install stable --profile minimal --component rustfmt --component clippy --no-self-update + - uses: Swatinem/rust-cache@v2 - - uses: swatinem/rust-cache@v1 + - run: cargo fmt --all -- --check + - run: cargo clippy --all-features --workspace --tests --examples -- -D clippy::all - - name: Run Rustfmt - uses: actions-rs/cargo@v1 - with: - command: fmt - args: --all -- --check + doc-comments: + name: Documentation + runs-on: ubuntu-latest + env: + RUSTDOCFLAGS: -Dwarnings + steps: + - uses: actions/checkout@v4 - - name: Run Clippy - uses: actions-rs/cargo@v1 - with: - command: clippy - args: --all-targets --all-features -- -D warnings + - run: rustup toolchain install stable --profile minimal --component rust-docs --no-self-update + - uses: Swatinem/rust-cache@v2 - - name: Rust Doc Comments - uses: actions-rs/cargo@v1 - env: - RUSTDOCFLAGS: -Dwarnings - with: - command: doc - args: --no-deps --document-private-items + - run: cargo doc --workspace --all-features --document-private-items --no-deps test: - name: Test + strategy: + fail-fast: false + matrix: + os: [ubuntu-latest, windows-latest, macos-latest] + + name: Tests on ${{ matrix.os }} + runs-on: ${{ matrix.os }} + + steps: + - uses: actions/checkout@v4 + + - run: rustup toolchain install stable --profile minimal --no-self-update + - uses: Swatinem/rust-cache@v2 + + - run: scripts/download + + - run: cargo test --workspace --all-features --all-targets + - run: cargo test --workspace --all-features --doc + + codecov: + name: Code Coverage runs-on: ubuntu-latest steps: - - uses: actions/checkout@v3 + - uses: actions/checkout@v4 - - uses: actions-rs/toolchain@v1 - with: - toolchain: stable - profile: minimal - override: true + - run: rustup toolchain install stable --profile minimal --component llvm-tools-preview --no-self-update + - uses: Swatinem/rust-cache@v2 + - uses: taiki-e/install-action@cargo-llvm-cov - - uses: swatinem/rust-cache@v1 + - run: scripts/download - - name: Download Fixtures - run: scripts/download + - run: cargo llvm-cov --all-features --workspace --lcov --output-path lcov.info - - name: Run Cargo Tests - uses: actions-rs/cargo@v1 + - uses: codecov/codecov-action@v3 with: - command: test + files: lcov.info diff --git a/.github/workflows/enforce-license-compliance.yml b/.github/workflows/enforce-license-compliance.yml new file mode 100644 index 0000000..0f03db2 --- /dev/null +++ b/.github/workflows/enforce-license-compliance.yml @@ -0,0 +1,16 @@ +name: Enforce License Compliance + +on: + push: + branches: [master, release/*] + pull_request: + branches: [master] + +jobs: + enforce-license-compliance: + runs-on: ubuntu-latest + steps: + - name: "Enforce License Compliance" + uses: getsentry/action-enforce-license-compliance@main + with: + fossa_api_key: ${{ secrets.FOSSA_API_KEY }} diff --git a/.github/workflows/release.yml b/.github/workflows/release.yml new file mode 100644 index 0000000..fb674dc --- /dev/null +++ b/.github/workflows/release.yml @@ -0,0 +1,30 @@ +name: Release +on: + workflow_dispatch: + inputs: + version: + description: Version to release + required: false + force: + description: Force a release even when there are release-blockers (optional) + required: false + merge_target: + description: Target branch to merge into. Uses the default branch as a fallback (optional) + required: false +jobs: + release: + runs-on: ubuntu-latest + name: "Release a new version" + steps: + - uses: actions/checkout@v4 + with: + # Fetch all commits so we can determine previous version + fetch-depth: 0 + token: ${{ secrets.GH_RELEASE_PAT }} + - name: Prepare release + uses: getsentry/action-prepare-release@v1 + env: + GITHUB_TOKEN: ${{ secrets.GH_RELEASE_PAT }} + with: + version: ${{ github.event.inputs.version }} + force: ${{ github.event.inputs.force }} diff --git a/.github/workflows/weekly.yml b/.github/workflows/weekly.yml new file mode 100644 index 0000000..f952964 --- /dev/null +++ b/.github/workflows/weekly.yml @@ -0,0 +1,31 @@ +name: Weekly CI + +on: + schedule: + - cron: "14 3 * * 5" # every friday at 03:14 + workflow_dispatch: + +env: + RUSTFLAGS: -Dwarnings + +jobs: + weekly-ci: + strategy: + fail-fast: false + matrix: + rust: [nightly, beta] + + runs-on: ubuntu-latest + + steps: + - uses: actions/checkout@v4 + + - run: | + rustup toolchain install ${{ matrix.rust }} --profile minimal --component clippy --no-self-update + rustup default ${{ matrix.rust }} + + - uses: arduino/setup-protoc@v3 + + - run: cargo clippy --all-features --workspace --tests --examples -- -D clippy::all + - run: cargo test --workspace --all-features --all-targets + - run: cargo test --workspace --all-features --doc diff --git a/.gitignore b/.gitignore index f9a1d82..8f53039 100644 --- a/.gitignore +++ b/.gitignore @@ -1,5 +1,6 @@ target *.iml .idea +.DS_Store fixtures/symbol_server/* diff --git a/scripts/bump-version.sh b/scripts/bump-version.sh new file mode 100644 index 0000000..2318f20 --- /dev/null +++ b/scripts/bump-version.sh @@ -0,0 +1,25 @@ +#!/bin/bash +set -eux + +if [ "$(uname -s)" != "Linux" ]; then + echo "Please use the GitHub Action." + exit 1 +fi + +SCRIPT_DIR="$( dirname "$0" )" +cd $SCRIPT_DIR/.. + +OLD_VERSION="${1}" +NEW_VERSION="${2}" + +echo "Current version: $OLD_VERSION" +echo "Bumping version: $NEW_VERSION" + +function replace() { + ! grep "$2" $3 + perl -i -pe "s/$1/$2/g" $3 + grep "$2" $3 # verify that replacement was successful +} + +replace "^version = \"[0-9.]+\"" "version = \"$NEW_VERSION\"" Cargo.toml +cargo metadata --format-version 1 > /dev/null # update `Cargo.lock`