Releases - acl-services/paprika GitHub Wiki
Note that the terms publish and release can be used interchangeably.
When you make a change to a component's source code (not stories, specs, or docs), before merging your branch you should run yarn changeset. This will prompt you to:
- indicate if changes were patch/minor/major for each modified package
- enter a release message
This generates a new file (/.changeset/some-random-name.md) that contains the list of packages that were modified and the scope of their changes (patch/minor/major).
The file should be committed and pushed.
Note: if you want to leave different messages on multiple packages you have changed, you can run yarn changeset multiple times, and create multiple changeset files. For example, in your PR, both package A and B need a bump, you can run yarn changeset first and mark package A as a major/minor/patch bump, and write the message for package A only. Then run yarn changeset again and mark package B as a major/minor/patch bump, and write the message for package B. In the end, commit and push both changeset generated files.
Reviewers should confirm the author ran yarn changeset -- that is, the PR includes /.changeset/some-random-name.md.
There is a GitHub Action (a bot) running on the Paprika repo that looks for this file. The bot will add a comment within the PR indicating if this file exists. If the file does not exist, it includes a link to generate the file. The reviewer should click the link, confirm the scope (patch/minor/major) and create the file.
- runs every 6 hours (8am, 2pm, 8pm, 2am)
- runs .semaphore/pre-release.ymlscript, which:- runs yarn changeset pre enter next(enters "pre-release" mode, where versions are appended withnext)
- runs yarn changeset version(which reads/.changeset/*.mdand for each changed package: updates the version in package.json, updates its changelog.md)
- runs git add .andgit commit
- runs yarn changeset publish(which publishes changed packages to npmjs.org, creates/modifies/.changeset/pre.json)
- pushes the changes to master
 
- runs 
If any changes are merged to master while step 2 or 3 is in progress, step 5 will fail. A Paprika administrator would need to pull the latest master and manually do the steps above in order to do a release.
- runs once a week (Saturday at 8pm UTC)
- runs .semaphore/release.ymlscript, which:- runs yarn changeset pre exit(exits "pre-release" mode, so versions are not appended withnext)
- runs yarn changeset version(which reads/.changeset/*.mdand for each changed package: updates the version in package.json, updates its changelog.md)
- runs git add .andgit commit
- runs yarn changeset publish(which publishes changed packages to npmjs.org, deletes/.changeset/*.md)
- pushes the changes to master
 
- runs 
If any changes are merged to master while step 2 or 3 is in progress, step 5 will fail. A Paprika administrator would need to pull the latest master and manually do the steps above in order to do a release.
- it would be very slow and tedious to develop and release:
- when you ran yarn install, each package would have its ownnode_modulesfolder with its own dependencies (even if there are duplicates across packages). This is very slow when developing.
- imagine you are working on Paprika and you update the <Button />, then you worked on the<OverflowMenu />(which uses the<Button />). To see the new<Button />in the<OverflowMenu />, you would have to update the Button's version inOverflowMenu/package.json
- when releasing you would have to manually bump the versions in Button/package.json(and optionally every package that used the<Button />) andOverflowMenu/package.json(and optionally every package that used the<OverflowMenu />)
 
- when you ran 
Yarn Workspaces make it easier to develop on a repo with multiple packages.
When you run yarn install, all dependencies are installed in the root node_modules folder, making it run much faster (*except if a package used a different version of a component, in which case it used its own node_modules folder).
Lerna transpiles ES6 with Babel and makes it easier to bump package versions. It can also generate changelogs and publish, but we are using Changeset for this now.
- link packages in a monorepo (lerna bootstrap), i.e. for each package:- runs npm install(installs 3rd-party dependencies)
- runs npm run prepublish(generates changelogs)
- runs npm run prepare(re-creates/lib, generatesreadme.md, generates type definitions, runspretranspilestep for each package -- e.g. the<L10n />component uses this step to convert translations from.ymlto.js)
 
- runs 
- bumps changed package versions (since last release to npmjs.org) and releases (lerna publish --from-package)
Changeset is just the name of a command line tool that: bumps package versions, updates package changelogs and releases all modified packages to npmjs.org.
- Before merging your code, you run yarn changesetto automatically create a file in the/.changesetsfolder. Each file will contain:
- a list of packages
- if the package had a patch/minor/major change
- some text that is used for the release notes
- When releasing your packages, you run yarn changeset versionwhich:
- reads all of the files in /.changesets
- sensibly updates each packages version in package.json (e.g. if one commit to a component did a "patch" update, and another did a "minor" commit, it will only bump the "minor" version -- not both)
- updates its changelog.md
- Then run yarn changeset publishwhich:
- publishes to npmjs.org
- deletes /.changesets
- You should then commit these changes (so the updated versions and changelogs are merged).