-
Notifications
You must be signed in to change notification settings - Fork 111
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
change(release): Update release script and check it in CI (#7128)
* Activate production features on docs.rs * Make version requirements more flexible to work around unpublished versions * Remove a redundant feature requirement that causes publishing issues * fix release auto-replacement format * cargo release replace --verbose --execute --package zebrad * Add a missing 1.0.1 changelog entry * Fix incorrect commands in the release checklist * Check the crates.io release script in CI, to avoid release failures * Fix release date in changelog * Fix workflow typo * Add --no-confirm to the workflow * Fix outdated version in release check command * After the release, add a "remove do-not-merge" step * Set git identity before committing * Don't overwrite tweaked versions on upgrade * cargo release version doesn't support --dependent-version * Update the same commands in the release checklist * Commit to git after each change * And in the checklist * Add cargo release config * In CI, allow any branch and provide a fake previous tag name * Remove redundant `cargo release commit` * Use a simpler release version process * Start simplifying the release dry run in CI * Fix a cargo dependency lint * just skip the failing crates for now * Fix the release checklist to match CI * Use the latest versions of all Zebra dependencies
- Loading branch information
Showing
9 changed files
with
214 additions
and
19 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,28 @@ | ||
name: Release crates | ||
|
||
on: | ||
# Only patch the Release PR test job | ||
pull_request: | ||
paths-ignore: | ||
# code and tests | ||
- '**/*.rs' | ||
# hard-coded checkpoints (and proptest regressions, which are not actually needed) | ||
- '**/*.txt' | ||
# dependencies | ||
- '**/Cargo.toml' | ||
- '**/Cargo.lock' | ||
# configuration files | ||
- '.cargo/config.toml' | ||
- '**/clippy.toml' | ||
# READMEs, which are shown on the crate page | ||
- '**/README.md' | ||
# workflow definitions | ||
- '.github/workflows/release-crates.io.yml' | ||
|
||
|
||
jobs: | ||
check-release: | ||
name: Check crate release dry run | ||
runs-on: ubuntu-latest | ||
steps: | ||
- run: 'echo "No check required"' |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,125 @@ | ||
# This workflow checks that Zebra's crates.io release script works. | ||
# | ||
# We use a separate action, because the changed files are different to a Continuous Deployment | ||
# or Docker release. | ||
# | ||
# This workflow is triggered when: | ||
# - A PR that changes Rust files, a README, or this workflow is opened or updated | ||
# - A change is pushed to the main branch | ||
# | ||
# TODO: | ||
# If we decide to automate crates.io releases, we can also publish crates using this workflow, when: | ||
# - A release is published | ||
# - A pre-release is changed to a release | ||
|
||
name: Release crates | ||
|
||
# Ensures that only one workflow task will run at a time. Previous releases, if | ||
# already in process, won't get cancelled. Instead, we let the first release complete, | ||
# then queue the latest pending workflow, cancelling any workflows in between. | ||
# | ||
# Since the different event types do very different things (test vs release), | ||
# we can run different event types concurrently. | ||
# | ||
# For pull requests, we only run the tests from this workflow, and don't do any releases. | ||
# So an in-progress pull request gets cancelled, just like other tests. | ||
concurrency: | ||
group: ${{ github.workflow }}-${{ github.event_name }}-${{ github.ref }} | ||
cancel-in-progress: ${{ github.event_name == 'pull_request' }} | ||
|
||
|
||
on: | ||
# disabled for now | ||
# release: | ||
# types: | ||
# - released | ||
|
||
# Only runs the release tests, doesn't release any crates. | ||
# | ||
# We test all changes on the main branch, just in case the PR paths are too strict. | ||
push: | ||
branches: | ||
- main | ||
|
||
pull_request: | ||
paths: | ||
# code and tests | ||
- '**/*.rs' | ||
# hard-coded checkpoints (and proptest regressions, which are not actually needed) | ||
- '**/*.txt' | ||
# dependencies | ||
- '**/Cargo.toml' | ||
- '**/Cargo.lock' | ||
# configuration files | ||
- '.cargo/config.toml' | ||
- '**/clippy.toml' | ||
# READMEs, which are shown on the crate page | ||
- '**/README.md' | ||
# workflow definitions | ||
- '.github/workflows/release-crates.io.yml' | ||
|
||
|
||
jobs: | ||
# Test that Zebra can be released to crates.io using `cargo`. | ||
# This checks that Zebra's dependencies and release configs are correct. | ||
check-release: | ||
name: Check crate release dry run | ||
timeout-minutes: 15 | ||
runs-on: ubuntu-latest | ||
steps: | ||
- uses: r7kamura/[email protected] | ||
|
||
- name: Checkout git repository | ||
uses: actions/[email protected] | ||
with: | ||
persist-credentials: false | ||
|
||
- name: Inject slug/short variables | ||
uses: rlespinasse/github-slug-action@v4 | ||
with: | ||
short-length: 7 | ||
|
||
# Setup Rust with stable toolchain and minimal profile | ||
- name: Setup Rust | ||
run: | | ||
curl --proto '=https' --tlsv1.2 -sSf https://sh.rustup.rs | sh -s -- -y --default-toolchain=stable --profile=minimal | ||
- name: Install cargo-release | ||
uses: baptiste0928/[email protected] | ||
with: | ||
crate: cargo-release | ||
|
||
# Make sure Zebra can be released! | ||
# | ||
# These steps should be kept up to date with the release checklist. | ||
# | ||
# TODO: move these steps into a script which is run in the release checklist and CI | ||
- name: Crate release dry run | ||
run: | | ||
set -ex | ||
git config --global user.email "[email protected]" | ||
git config --global user.name "Automated Release Test" | ||
# This script must be the same as: | ||
# https://github.com/ZcashFoundation/zebra/blob/main/.github/PULL_REQUEST_TEMPLATE/release-checklist.md#update-crate-versions | ||
# with an extra `--no-confirm` argument for non-interactive testing. | ||
cargo release version --verbose --execute --no-confirm --allow-branch '*' --workspace --exclude zebrad beta | ||
cargo release version --verbose --execute --no-confirm --allow-branch '*' --package zebrad patch | ||
cargo release replace --verbose --execute --no-confirm --allow-branch '*' --package zebrad | ||
cargo release commit --verbose --execute --no-confirm --allow-branch '*' | ||
# Check the release will work using a dry run | ||
# | ||
# Workaround unpublished dependency version errors by skipping those crates: | ||
# https://github.com/crate-ci/cargo-release/issues/691 | ||
# | ||
# TODO: check all crates after fixing these errors | ||
cargo release publish --verbose --dry-run --allow-branch '*' --workspace --exclude zebra-consensus --exclude zebra-utils --exclude zebrad | ||
# TODO: actually do the release here | ||
#release-crates: | ||
# name: Release Zebra Crates | ||
# needs: [ check-release ] | ||
# runs-on: ubuntu-latest | ||
# timeout-minutes: 30 | ||
# if: ${{ !cancelled() && !failure() && github.event_name == 'release' }} | ||
# steps: |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,20 @@ | ||
# Only allow releases from the main branch | ||
allow-branch = [ 'main' ] | ||
|
||
# TODO: | ||
# configure all zebra-* crates with a shared version, | ||
# and all tower-* crates with a different one: | ||
# https://github.com/crate-ci/cargo-release/blob/master/docs/reference.md#config-fields | ||
#shared-version = "TODO named groups" | ||
|
||
# Verify releases with release features | ||
# | ||
# TODO: add this feature to all crates | ||
#enable-features = [ 'default-release-binaries' ] | ||
|
||
# Don't do a git push or tag | ||
push = false | ||
tag = false | ||
|
||
# Owners for new crates | ||
owners = [ 'dconnolly', 'teor2345', 'zcashfoundation/owners' ] |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters