-
Notifications
You must be signed in to change notification settings - Fork 847
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Update object_store
release documentation
#6565
Merged
Merged
Changes from 7 commits
Commits
Show all changes
8 commits
Select commit
Hold shift + click to select a range
fecc682
Update object_store release documentation
alamb 3d18a60
Update object store
alamb 293a9af
prettier
alamb e5c167d
tweak
alamb 28abde2
Update object_store/dev/release/README.md
alamb cd0c60e
update instructions
alamb f95ca17
fix
alamb 7fe2bf7
Update object_store/dev/release/README.md
alamb File filter
Filter by extension
Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
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 was deleted.
Oops, something went wrong.
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 |
---|---|---|
|
@@ -17,4 +17,179 @@ | |
under the License. | ||
--> | ||
|
||
See instructions in [`/dev/release/README.md`](../../../dev/release/README.md) | ||
|
||
# Release Process | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. I moved the relevant content for object store here -- it is somewhat redundant with arrow-rs but I think that is ok as it is much clearer (and will be required if/when we move to a new repo) |
||
|
||
## Overview | ||
|
||
This file documents the release process for the `object_store` crate. | ||
|
||
At the time of writing, we release a new version of `object_store` on demand rather than on a regular schedule. | ||
|
||
As we are still in an early phase, we use the 0.x version scheme. If any code has | ||
been merged to master that has a breaking API change, as defined in [Rust RFC 1105] | ||
the minor version number is incremented changed (e.g. `0.3.0` to `0.4.0`). | ||
Otherwise the patch version is incremented (e.g. `0.3.0` to `0.3.1`). | ||
|
||
[Rust RFC 1105]: https://github.com/rust-lang/rfcs/blob/master/text/1105-api-evolution.md | ||
# Release Mechanics | ||
|
||
## Process Overview | ||
|
||
As part of the Apache governance model, official releases consist of | ||
signed source tarballs approved by the PMC. | ||
|
||
We then use the code in the approved source tarball to release to | ||
crates.io, the Rust ecosystem's package manager. | ||
|
||
We create a `CHANGELOG.md` so our users know what has been changed between releases. | ||
|
||
The CHANGELOG is created automatically using | ||
[update_change_log.sh](https://github.com/apache/arrow-rs/blob/master/object_store/dev/release/update_change_log.sh) | ||
|
||
This script creates a changelog using github issues and the | ||
labels associated with them. | ||
|
||
## Prepare CHANGELOG and version: | ||
|
||
Now prepare a PR to update `CHANGELOG.md` and versions on `master` to reflect the planned release. | ||
|
||
Note this process is done in the `object_store` directory. See [#6227] for an example | ||
|
||
[#6227]: https://github.com/apache/arrow-rs/pull/6227 | ||
|
||
```bash | ||
# NOTE: Run commands in object_store sub directory (not main repo checkout) | ||
# cd object_store | ||
|
||
git checkout master | ||
git pull | ||
git checkout -b <RELEASE_BRANCH> | ||
|
||
# Update versions. Make sure to run it before the next step since we do not want CHANGELOG-old.md affected. | ||
sed -i '' -e 's/0.11.0/0.11.1/g' `find . -name 'Cargo.toml' -or -name '*.md' | grep -v CHANGELOG` | ||
git commit -a -m 'Update version' | ||
|
||
# ensure your github token is available | ||
export CHANGELOG_GITHUB_TOKEN=<TOKEN> | ||
|
||
# manually edit ./dev/release/update_change_log.sh to reflect the release version | ||
alamb marked this conversation as resolved.
Show resolved
Hide resolved
|
||
# create the changelog | ||
./dev/release/update_change_log.sh | ||
|
||
# review change log / and edit associated issues and labels if needed, rerun update_change_log.sh | ||
|
||
# Commit changes | ||
git commit -a -m 'Create changelog' | ||
|
||
# push changes to fork and create a PR to master | ||
git push | ||
``` | ||
|
||
Note that when reviewing the change log, rather than editing the | ||
`CHANGELOG.md`, it is preferred to update the issues and their labels | ||
(e.g. add `invalid` label to exclude them from release notes) | ||
|
||
Merge this PR to `master` prior to the next step. | ||
|
||
## Prepare release candidate tarball | ||
|
||
After you have merged the updates to the `CHANGELOG` and version, | ||
create a release candidate using the following steps. Note you need to | ||
be a committer to run these scripts as they upload to the apache `svn` | ||
distribution servers. | ||
|
||
### Create git tag for the release: | ||
|
||
While the official release artifact is a signed tarball, we also tag the commit it was created for convenience and code archaeology. | ||
|
||
For `object_store` releases, use a string such as `object_store_0.4.0` as the `<version>`. | ||
|
||
Create and push the tag thusly: | ||
|
||
```shell | ||
git fetch apache | ||
git tag <version> apache/master | ||
# push tag to apache | ||
git push apache <version> | ||
``` | ||
|
||
### Pick an Release Candidate (RC) number | ||
|
||
Pick numbers in sequential order, with `1` for `rc1`, `2` for `rc2`, etc. | ||
|
||
### Create, sign, and upload tarball | ||
|
||
Run `create-tarball.sh` with the `<version>` tag and `<rc>` and you found in previous steps. | ||
|
||
```shell | ||
./object_store/dev/release/create-tarball.sh 0.11.1 1 | ||
``` | ||
|
||
The `create-tarball.sh` script | ||
|
||
1. creates and uploads a release candidate tarball to the [arrow | ||
dev](https://dist.apache.org/repos/dist/dev/arrow) location on the | ||
apache distribution svn server | ||
|
||
2. provide you an email template to | ||
send to [email protected] for release voting. | ||
|
||
### Vote on Release Candidate tarball | ||
|
||
Send an email, based on the output from the script to [email protected]. The email should look like | ||
|
||
``` | ||
|
||
alamb marked this conversation as resolved.
Show resolved
Hide resolved
|
||
``` | ||
|
||
For the release to become "official" it needs at least three Apache Arrow PMC members to vote +1 on it. | ||
|
||
## Verifying release candidates | ||
|
||
The `object_store/dev/release/verify-release-candidate.sh` script can assist in the verification process. Run it like: | ||
|
||
``` | ||
./object_store/dev/release/verify-release-candidate.sh 0.11.0 1 | ||
``` | ||
|
||
#### If the release is not approved | ||
|
||
If the release is not approved, fix whatever the problem is and try again with the next RC number | ||
|
||
### If the release is approved, | ||
|
||
Move tarball to the release location in SVN, e.g. https://dist.apache.org/repos/dist/release/arrow/arrow-4.1.0/, using the `release-tarball.sh` script: | ||
|
||
|
||
```shell | ||
./object_store/dev/release/release-tarball.sh 4.1.0 2 | ||
``` | ||
|
||
Congratulations! The release is now official! | ||
|
||
### Publish on Crates.io | ||
|
||
Only approved releases of the tarball should be published to | ||
crates.io, in order to conform to Apache Software Foundation | ||
governance standards. | ||
|
||
An Arrow committer can publish this crate after an official project release has | ||
been made to crates.io using the following instructions. | ||
|
||
Follow [these | ||
instructions](https://doc.rust-lang.org/cargo/reference/publishing.html) to | ||
create an account and login to crates.io before asking to be added as an owner | ||
of the [arrow crate](https://crates.io/crates/arrow). | ||
|
||
Download and unpack the official release tarball | ||
|
||
Verify that the Cargo.toml in the tarball contains the correct version | ||
(e.g. `version = "0.11.0"`) and then publish the crate with the | ||
following commands | ||
|
||
|
||
```shell | ||
cargo publish | ||
``` | ||
|
Oops, something went wrong.
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I removed all references to object_store from this file