-
Notifications
You must be signed in to change notification settings - Fork 3
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
new release process using an action (and docs to go with it)
- Loading branch information
Showing
3 changed files
with
70 additions
and
1 deletion.
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
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,47 @@ | ||
name: tag and publish crate [manual] | ||
|
||
on: | ||
workflow_dispatch: | ||
inputs: | ||
tag-increment: | ||
default: patch | ||
required: true | ||
type: choice | ||
options: | ||
- patch | ||
- minor | ||
- major | ||
|
||
jobs: | ||
publish: | ||
runs-on: macos-latest | ||
permissions: | ||
# Give the default GITHUB_TOKEN write permission to commit and push the | ||
# added or changed files to the repository. | ||
contents: write | ||
steps: | ||
- name: checkout repo | ||
uses: actions/checkout@v2 | ||
- name: install stable toolchain | ||
uses: actions-rs/toolchain@v1 | ||
with: | ||
toolchain: stable | ||
override: true | ||
- name: install rustfmt | ||
run: rustup component add rustfmt | ||
- name: rustfmt check | ||
run: cargo fmt --all -- --check | ||
- name: install clippy | ||
run: rustup component add clippy | ||
- name: cargo clippy | ||
run: cargo clippy --all-features --all-targets | ||
- name: cargo test | ||
run: cargo test | ||
- name: install cargo bump | ||
run: cargo install cargo-bump | ||
- name: bump version | ||
run: cargo bump -g ${{ inputs.tag-increment }} | ||
- name: push | ||
run: git push && git push --tags | ||
- name: cargo publish | ||
run: cargo publish --token ${{ secrets.CRATES_TOKEN }} |
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,22 @@ | ||
# Release Process | ||
|
||
- leave the Cargo.toml package version alone :) | ||
- trigger the `tag and publish crate [manual]` action and specify the release increment (major, minor, or patch) | ||
- once the action completes, the Cargo.toml will be updated and the crate will be live on crates.io | ||
- create a release (with title, notes, thanks, etc) and tie it to the tag that was created by the action / new crate version | ||
|
||
## Execution | ||
|
||
The order of operations for tagging and publishing in the action is this | ||
|
||
1. run all checks, i.e. fmt, clippy, tests, etc | ||
1. push change / update to the Cargo.toml | ||
1. push the new tag to the repo | ||
1. publish the new version to crates.io | ||
|
||
## Troubleshooting | ||
|
||
- if step 1 of execution fails, after addressing the error, you run the action again | ||
- if step 2 of execution fails, after addressing the error, you run the action again | ||
- if step 3 of execution fails (the Cargo.toml version was incremented), after addressing the error, you should manually tag (github's ux or the cli) and manually publish the crate with `cargo publish` | ||
- if step 4 of execution fails (the Cargo.toml version was incremented and there's a new corresponding tag), after addressing the error, you should manually publish the crate with `cargo publish` |