Skip to content

Latest commit

 

History

History
87 lines (63 loc) · 3.29 KB

RELEASE_GUIDELINES.md

File metadata and controls

87 lines (63 loc) · 3.29 KB

Release Guidelines

The release manager in charge can release a Bittensor version using two scripts:

The release manager will need the right permissions for:

  • github.com
  • pypi.org
  • hub.docker.com

If you are new in this role, ask for the proper setup you need to run this process manually.

Process of release

  1. Create a branch called release/VERSION, having VERSION with the version to release.

  2. Make sure twine is installed: pip install twine

  3. Within the release branch:

  4. Update the version executing:./scripts/release/versioning.sh --update UPDATE_TYPE 1. UPDATE_TYPE could be major, minor or patch.

  5. Add release notes to CHANGELOG executing: ./scripts/release/add_notes_changelog.sh -A -V NEW_VERSION -P PREVIOUS_TAG -T GH_ACCESS_TOKEN 1. NEW_VERSION: e.g.: 3.6.4 1. PREVIOUS_TAG: e.g.: v3.6.3 1. GH_ACCESS_TOKEN: A github personal access token you need.

  6. Test the release branch and verify that it meets the requirements.

  7. After merging the release branch; Run the release script

Versioning script usage

Options:

  • -U, --update: type of update. It could be major, minor, patch or rc (release candidate).
  • -A, --apply: This specifies to apply the release. Without this the versioning will just show a dry run with no changes.

Release script usage

Options:

  • -A, --apply: This specifies to apply the release. Without this the release will just show a dry run with no changes.
  • -T,--github-token: A github personal access token to interact with the Github API.

Github token

Since you need to use a secret when releasing bittensor (github personal access token), I encourage you to use pass or a similar tool that allows you to store the secret safely and not expose it in the history of the machine you use.

So you can have:

GITHUB_ACCESS_TOKEN=$(pass github/your_personal_token_with_permisions)

or

GITHUB_ACCESS_TOKEN=$(whatever you need to get the token safely)

Executions

So, executing the script to release a minor version will be:

# For a dry run
./scripts/release/release.sh
# Applying changes
./scripts/release/release.sh --apply --github-token $GITHUB_ACCESS_TOKEN`

Checking release

After the execution of the release script we would have generated:

After release

After a Bittensor release we have to

Updating cubit

  1. Updating the Dockerfile
  2. Building its docker image (follow its README instructions)
  3. Push it to hub.docker.com
  4. The generated name will be the same but with -cubit in its name