git clone [email protected]:endojs/endo.git
cd endo
yarn
Endo is a yarn workspaces repository. Running yarn in the root will install and hoist most dependencies up to the root node_modules
.
Note: running yarn --ignore-scripts
will not complete the setup of SES.
Note: Endo uses lerna
only for releasing. lerna bootstrap
is unlikely to work.
Changes to ses
require a yarn build
to be reflected in any dependency where import 'ses';
appears. Use yarn build
under packages/ses
to refresh the build.
Everything else is wired up thanks to workspaces, so no need to run installs in other packages.
-
Review the next release label for additional tasks or pending changes particular to this release.
-
Do not release from a Git workspace. In a Git workspace,
.git
is a file and not a directory. At time of writing, Lerna does not account for Git workspaces when it looks up the repository location. -
Create a release branch.
now=`date -u +%Y-%m-%d-%H-%M-%S` git checkout -b release-$now
-
Create the release CHANGELOGs.
yarn lerna version --no-push --conventional-graduate --no-git-tag-version
Use
--conventional-prerelease
instead of--conventional-graduate
if you just want to generate a dev release. -
Commit the results.
git commit -am 'chore: lerna version'
-
Identify
NEWS.md
files that need to be updated. EnsureNEWS.md
captures all user-visible changes in prose that are user-relevant.git grep '# Next'
For each of these files, copy the version number and timestamp from the adjacent
CHANGELOG.md
generated in the previous step. For example,-# Next release +# 0.5.1 (2021-08-12)
-
Commit the results.
git commit -am 'docs: Update release notes'
-
Update
yarn.lock
.yarn git commit -um 'chore: Update yarn.lock'
-
Push the branch.
git push -u origin release-$now
-
Create a pull request and request a review. This is an opportunity to:
- verify that the changes pass tests under continuous integration,
- reflect on whether the automatically chosen version numbers tell an accurate story about the backward and mutual compatibility of the packages you are about to publish,
- and to verify that all user-facing changes are noted in the NEWS.md files with appropriate migration advice when necessary.
-
When your reviewer has approved your release, use
git rebase -i origin/master
to remove the automatically generatedchore: lerna version
commit. -
Ensure your dependency solution is fresh and rebuild all generated assets.
yarn install yarn build
-
Recreate the changelogs with the current date and generate tags for the new versions. This is the effect of removing the
--no-git-tag-version
flag.yarn lerna version --no-push --conventional-graduate
-
Update
yarn.lock
.yarn git commit -um 'chore: Update yarn.lock'
-
Publish the versions to npm. Being a member of the project or organization and having two-factor authentication may be necessary. It may be necessary to login with
npm login
. You can check withnpm whoami
.npm whoami # if it does not show you logged in, then do npm login # two factor authentication stuff yarn lerna publish from-package # repeat this command until all packages are successfully published
-
To verify that packages were published, go to the npm web page for the package, for example https://www.npmjs.com/package/ses. However do not be alarmed if it does not show your new version for a distressingly long time. Instead you can verify the version with
npm view ses
-
Force push these changes back to the pull request branch.
git push origin -f release-$now
-
Merge the release PR into master. DO NOT REBASE OR SQUASH OR YOU WILL LOSE REFERENCES TO YOUR TAGS.
Notice the little triangle on the merge button and select "Create a merge commit" from the drop down menu. Do not rebase. Do not squash. Rebasing or squashing will remove the tag from the history of the
master
branch. -
Selecting "Create a merge commit" in that drop down is sticky. Assuming you normally want "Squash and merge", be sure to set it back to that at your next opportunity.
-
Push the released tags to Github.
git tag -l | egrep -e '@[0-9]+\.[0-9]+\.[0-9]+$' | xargs git push origin
To get help for the command-line options that will affect these commands, use:
yarn lerna version --help
yarn lerna publish --help