Skip to content

Latest commit

 

History

History
244 lines (167 loc) · 10.7 KB

README.md

File metadata and controls

244 lines (167 loc) · 10.7 KB

pre-commit.ci status

ge_releaser

A CLI tool built to streamline the process of cutting releases each week in the OSS repository.


Installation

# Preferably run all this in a venv
git clone git@github.com:greatexpectationslabs/ge_releaser.git
cd ge_releaser
pip install -e .
# Alternative
gh repo clone greatexpectationslabs/ge_releaser
cd ge_releaser
python3 -m venv .venv
source .venv/bin/activate
pip install -e .

Commands

These commands are to be executed in Great Expectations development directory (be sure to check out the develop branch).

# Commands are meant to be run sequentially
ge_releaser tag <git_hash> <semver>      # Tag the appropriate commit and trigger the build/deploy to pypi process
ge_releaser prep                         # Modify changelog and open a PR.
ge_releaser publish                      # Create a new GitHub release page

Please follow the detailed instructions below to know when to progress to the next step.

The tool is designed to do pretty much EVERYTHING for you. Do not run isolated git commands (unless resolving merge conflicts).


Version Release Policy

Default Process

  1. Release at least once a week (Wednesdays)
  2. We bump the patch version
  3. A release message is posted in our public slack workspace in the channel #gx-releases

Note for any given week we can skip the release. We are fine with doing ad hoc releases. One example of when we would do this is when we need to immediately release a feature for cloud.

Bumping Minor Version

If the commits in this release contain a PR with the title tag [MINORBUMP] we bump the minor version instead of a patch version.

We should follow semantic versioning when choosing to bump the minor version. In particular, when new functionality is made public this requires a minor version bump. New functionality is considered public when the @public_api decorator is added. We should hold off on adding this decorator until the end of an epic so we ship complete features. There will likely be a doc change that will accompany the feature release and you might want to hold off on adding the @public_api decorator until the docs pr is also ready to merge.

Walkthrough

ge_releaser acts as an abstraction on top of our standard manual release process. While the following steps should get you creating releases with ease, it is also important to understand what is happening under the hood. For each of the primary commands that ge_releaser offers, the individual manual steps taken by the machine are noted below. Although you shouldn't have to use them, it may be handy if debugging is required.

⚠️ Please note that if the release is for a major or minor version, the docs will need to be versioned manually. Please see the versioning instructions for the steps to follow.

CLI Process

Prereqs

  • Install and setup the tool
    • Install the tool using the above instructions.
    • Create a personal access GitHub token, unless you already have one. Create a "classic" token, currently "Fine-grained tokens" are not supported. Give it repo permissions.
    • Authorize it for use with SAML SSO, unless this has already been done previously.
export GITHUB_TOKEN=<token>
  • (Optional) Select trunk
    • If not releasing from develop, you'll need:
export GE_RELEASE_TRUNK=0.18.x

Collaborate

  • Make sure to ask the team about any necessary PR's that might need to go in before running this command.

  • Make sure to cordinate with #pod-zelda for the release of the GX Agent. Releases of the GX Agent will be on Thursdays.

tag

  1. cd into your great expectations repo

  2. Run the tag subcommand:

ge_releaser tag --stable "<commit_hash>" "<release_version>"

# Examples:
ge_releaser tag --stable HEAD 0.18.8
ge_releaser tag --stable eb548b9b58bed229e601f2fe60c4767bcfca8c1d 0.18.8

tag

  1. IMPORTANT - Wait until the PyPi Deployment finishes and version is published to the PyPi page. Now is a good time to start a thread in #gx-platform-release about the release. You can post updates to this thread as the release progresses.
# Shell command to check if any PR's are set to automerge (requires jq)
curl -s https://api.github.com/repos/great-expectations/great_expectations/pulls | jq '.[] | select(.auto_merge.merge_method == "squash") | {title: .title, author: .user.login, date: .created_at, link: .html_url}'

prep

  1. Ensure there are no untracked files will be committed and pushed to the repo, such as credentials
ge_releaser prep

prep

  • This will generate the changelog, update relevant files, and draft a PR titled [RELEASE] <RELEASE_NUMBER>.
  • Review the contents of this PR and ensure it looks appropriate before merging.
    • Check that the new changelog entry only contains changes that have transpired between the last release and this current one.
    • Additionally, ensure that any external contributors recieve attribution for their efforts.
    • NOTE: This process may include some additional entries (if the release commit selected is before HEAD). If so, please remove them to ensure an accurate changelog.

publish

ge_releaser publish

publish

  • This command will take the changelog notes generated from the previous step and write them to our GitHub Releases page.

Community Announcement

Release message has the format:

:gx-blinking-logo-slow: 📣 :gx-blinking-logo-slow: We are pleased to announce the release of Great Expectations 1..! We’d like to give a special thanks to our contributors:

  • <contributor name> for contributing <contribution description>
  • <contributor name> for contributing <contribution description>

Some of the highlights:

  • <release highlight>
  • <release highlight>

The complete changelog is [here](link to release notes).

<contributor name> is either a persons slack name (preferred) or their github handle.

For examples please look in #gx-releases.

Note it’s ok for a highlights to be non-user facing:

  • Reworked internals to support an upcoming improved metrics interface
  • Added test coverage around X
Formatting the Community Announcement Changelog

Entries in the changelog should appear as:

[FEATURE] Enable customization of candidate Regular Expression patterns when running OnboardingDataAssistant (#7104)

Specifically:

  • Capitalize the first letter of the subject after the [TAG]
  • Do not use punctuation as the first character of the subject after the [TAG]
  • Tags are one of the defined tags in our contributor guide
  • Make clear call-outs for adding expectations by including the name of the expectation (ex: expect_values_are_prime_numbers)
  • PRs should be written in the present tense
  • The PR numbers should appear in parenthesis and be linked to the PR
  • Contributors are credited with (thanks @username)

Appendix

Manual Process

tag:

  • Checkout the specific commit you want to tag.
    • Command: get checkout <commit_hash>
  • Create a tag for the new release.
    • Command: git tag -a <release_version> -m "<release_version>"; git push origin <release_version>
  • Wait for Azure to finish its checks.
    • A successful run with automatically publish the new version to PyPI.

prep:

  • Pull remote changes into your local develop.
    • Command: git checkout develop; git pull origin/develop
  • Create a new branch from develop called release-X.Y.Z.
    • Command: git checkout -b release-X.Y.Z
  • Update the version in great_expectations/deployment_version.
  • Update the version in docs/tutorials/getting_started/tutorial_version_snippet.mdx.
  • Add a new entry to docs/changelog.md.
    • Ensure that lines are ordered by: [BREAKING] | [MINORBUMP] | [FEATURE] | [BUGFIX] | [DOCS] | [MAINTENANCE]
    • Ensure that each line has a reference to its corresponding PR.
    • If coming from an external contributor, make sure the line ends in (thanks @<contributor_id>).
    • Make sure we're only adding commits that have transpired between the last release and this current one.
  • Commit these four files and create a PR against develop.
    • Command: git add great_expectations; git commit -m "release prep"; git push
  • Receive approval and merge the PR.

publish:

  • Create a release entry in GitHub.

post-release:

  • Send a draft message (to be reviewed by the team) to #topic-great_expectations, with the message that will be sent in the community Slack.
  • Send the reviewed meesage to the community Slack channel #announcements.
  • Request emoji signal boosting from the team in private Slack channel #topic-great_expectations.

Override the default trunk value

If doing an pre-v1 bugfix you may need to change the trunk value to something other than develop. ge_releaser will check for an environment variable called GE_RELEASE_TRUNK and use this if it is set instead of develop.

Example: export GE_RELEASE_TRUNK=0.18.x

Yanking Releases

  • Although it shouldn't be a common occurrence due to our CI, there may be situations that necessitate the removal or yanking of a release.

  • In the case a release needs to be yanked, please take the following steps:

    1. Patch the issue and release a new version (following all the steps noted above).
    2. Pair with a PyPI maintainer with "Owner" privileges (as of 0.16.6, James, Don, and Chetan are owners).
    • Navigate to Your account -> great_expectations -> Releases.
    • Click the Options drop-down for the target release and select Yank.
    • Omit the Reason field and submit.
    1. Draft a community announcement, have the team review it in #topic-great_expectations, and send the reviewed message to the community Slack channel #announcements.

Troubleshooting

Optionally you can set a GE_RELEASER_LOG_LEVEL environment variable to enable more verbose logging.