- Create a
fastlane/.env
file with your GitHub API token (seefastlane/.env.SAMPLE
). This will be used to create the PR, so you should use your own token so the PR gets assigned to you. - Run
bundle exec fastlane bump
- Confirm base branch is correct
- Input new version number
- Update CHANGELOG.latest.md to include the latest changes. Call out API changes (if any). You can use the existing CHANGELOG.md as a base for formatting. To compile the changelog, you can compare the changes between the base branch for the release (usually main) against the latest release, by checking https://github.com/revenuecat/react-native-purchases/compare/<latest_release>...<base_branch>. For example, https://github.com/revenuecat/react-native-purchases/compare/3.10.0...main.
- A new branch and PR will automatically be created
bundle exec fastlane update_hybrid_common version:x.x.x
to set the purchases-hybrid-common version number if needed.- Run
npm run build
and make sure it works. If any issues appear, fix them first. - Wait until PR is approved (don't merge yet) and pull branch from origin (to make sure you've got all the changes locally)
- When the PR is approved, approve the hold job created in CircleCI. CircleCI will create a tag for the version. Alternatively, you can tag the last commit in the release branch and push it to the repository.
- The rest will be performed automatically by CircleCI. If the automation fails, you can revert to manually calling
bundle exec fastlane release
. - After that, you can merge the release PR to main and merge the bump to the next snapshot version PR right after.
Sometimes you might need to release a patch on a version that's not the latest. Or sometimes there might have been commits on main that shouldn't be released, but the latest version has a big bug. For example, let's say the last version is 4.0.0, but there's a bug on 3.9.0 that needs to be released as a 3.9.1:
- Open a PR with the fix, merge it to main.
- Jump to 3.9.0 and create a new branch release/3.9.0. Push this branch since it will be used as base for the PR you will open in the next steps.
- Run
bundle exec fastlane bump
as you would do with any release. This will create a new PRrelease/3.9.1
. Make sure the base branch of the PR is pointing torelease/3.9.0
- Locally, while in branch the release branch (
release/3.9.1
in this case), cherry pick the changes with your fix that you just merged tomain
usinggit cherry-pick <sha_of_the_squashed_commit_in_main>
. Fix any conflicts if there are any. Push the cherry picked commit to the remote branchrelease/3.9.1
. - When the PR is approved, approve the hold job in CircleCI as you would do for any other release. If there is no hold job because the release is older than when we introduced that job, manually tag the last commit in
release/3.9.1
with3.9.1
. - CircleCI will start the deployment process
- Merge the PR after the release has been completed and delete both
release/3.9.0
andrelease/3.9.1
branches. - Do
npm dist-tag add @revenuecat/[email protected] latest
. Being x.x.x the latest version of purchases-capacitor. When doing the publish to npm, the latest version is overriden with the hotfix, so we need to set it back to the latest version. - Remember to edit the CHANGELOG.md in
main
to include the version that has been just released