Model URLs in packages/react-native-executorch/src/constants/modelUrls.ts are built from two constants in versions.ts:
VERSION_TAG— the in-development version (resolve/v${LIB_VERSION}). Onmainit points at the upcoming release; HuggingFace files under this tag may not be published until release day.PREVIOUS_VERSION_TAG— the latest published stable release. Use for back-compat references that should follow the last shipped version.
Anything that must stay pinned to a specific older HuggingFace tag (e.g. deprecated aliases whose files were removed in a later release) should hardcode resolve/v{MAJOR}.{MINOR}.0 directly in modelUrls.ts rather than reusing PREVIOUS_VERSION_TAG.
The release process of new minor version consists of the following steps:
- On
main, confirm every model URL inpackages/react-native-executorch/src/constants/modelUrls.tsthat should ship in this release is already pointing atVERSION_TAG(the in-development tag) and that the matching files exist on 🤗 huggingface under thev{MAJOR}.{MINOR}.0tag. - Make sure
LIB_VERSIONinpackages/react-native-executorch/src/constants/versions.tsis{MAJOR}.{MINOR}.0soVERSION_TAGresolves toresolve/v{MAJOR}.{MINOR}.0. - Ensure the
versionfield ofpackage.jsonis{MAJOR}.{MINOR}.0for the core package (react-native-executorch) and both adapter packages (bare-resource-fetcher,expo-resource-fetcher). - If any of the above required changes, commit them on
mainwith the message 'Release v{MAJOR}.{MINOR}.0'. - Create a new release branch
release/{MAJOR}.{MINOR}frommainand push it to the remote. - Stability tests are performed on the release branch and all fixes to the new-found issues are pushed into the main branch and cherry-picked into the release branch. This allows for further development on the main branch without interfering with the release process.
- Once all tests are passed, tag the release branch with proper version tag
v{MAJOR}.{MINOR}.0and run the following publish workflows:- npm publish (core)
- npm publish satellite packages — run once per satellite package, selecting it via the
packageinput (react-native-executorch-bare-resource-fetcher,react-native-executorch-expo-resource-fetcher,react-native-executorch-webrtc)
- Create the release notes on GitHub.
- Bump
mainto the next development cycle in a single PR:- Bump
versioninpackage.jsonto{MAJOR}.{NEXT_MINOR}.0for the core package and both adapter packages. - Bump
LIB_VERSIONinversions.tsto{MAJOR}.{NEXT_MINOR}.0(this auto-bumpsVERSION_TAG). - Bump
PREVIOUS_VERSION_TAGinversions.tstoresolve/v{MAJOR}.{MINOR}.0(the version that was just published). - Commit with the message 'Bump version to v{MAJOR}.{NEXT_MINOR}.0'.
- Bump
- Create versioned docs by running from repo root
(cd docs && yarn docs:version {MAJOR}.{MINOR}.x)(the 'x' part is intentional and is not to be substituted). Also, make sure that all the links inapi-referenceare not broken. - Create a PR with the updated docs.
- Update README.md with release video, if available.
- Update README.md links to release branch.
After the release branch is created and the version is published to npm we only allow for bug fixes and other critical changes to be included into the release branch. For this purpose we use git cherry-pick command.
Caution
Those changes should NOT include documentation changes, as they would be released automatically on the PR's merge and before the code changes are live. Instead create a separate PR with doc changes according to the Docs update section.
- Create a PR with the fix to the
mainbranch. - Once the PR is merged, create a new branch off
release/{MAJOR}.{MINOR}, cherry-pick the relevant commits frommain, and open a PR targetingrelease/{MAJOR}.{MINOR}. - Once the PR is merged, bump version in
package.jsonof the core package and any adapter packages that require a fix to the new versionv{MAJOR}.{MINOR}.{REVISION}. Commit with a message 'Release v{MAJOR}.{MINOR}.{REVISION}'. - Tag release branch with proper version tag
v{MAJOR}.{MINOR}.{REVISION}and run the relevant publish workflows:- npm publish (core)
- npm publish satellite packages — run once per affected satellite package via the
packageinput (if applicable)
- Create release notes on GitHub.
We are using docusaurus with docs versioning. By default when merging PRs with docs changes to the main branch, a GitHub workflow is started to publish the docs. For this reason those changes should be merged only once the related changes are released. When updating docs the following steps should be considered.
- Update the desired doc pages.
- Check if the changes are applicable to past versions, if so make the same updates to the correct files in versioned docs inside
react-native-executorch/docs/versioned_docs/version-{MAJOR}.{MINOR}.x. - Create a PR to the main branch.