This document is intended to make contributing to this project easier, more transparent, and more standardized.
This project uses Commitizen and Conventional Changelog to standardize commit messages and changelogs. This means when you enter git commit
to commit your code you will see a (maybe) unfamiliar, interactive series of questions. These questions will result in a standardized format for your commit message. If you have any questions about the possible categories, scopes, etc. please create an issue in GitHub and we will do our best to respond.
Note: For merge commits, just use chore
for the type of change, merge
for the scope, and merge commit
for the message. Likely, however, it will not matter what you put into Commitizen as you'll just get a normal merge commit message such as Merge branch 'my-branch' into master
.
develop:bootstrap
- Runlerna bootstrap
. If you encounter any issues with local development using linked packages, this should be your first stop in attempting to resolve your issues.develop:cleanup
- Clean out thenode_modules
directories of each Irving package. Useful for starting from a clean slate with dependencies.develop:link
- Runnpm link
within each package directory, in parallel. BEWARE! This is a memory-intensive operation.develop:setup
- Rundevelop:cleanup
thendvelop:bootstrap
in succession. You probably won't need to use this script, but ifdevelop:bootstrap
doesn't solve your issue you might try it.develop:prepare
"npm install && npm run develop:link && npm run develop:setup", - Run a combination of scripts to prepare your clone of the Irving repo for local development:npm install
in the root of the Irving repodevelop:link
develop:setup
npm run prerelease:alpha
- publish a prerelease to npm. This will use the npm@alpha
tag using the-alpha
prerelease identifier. Publish to the@alpha
tag from themaster
branch after doing a CR/PR from your feature branch. Because this is the alpha tag, don't worry about publishing something broken. NOTE: Travis will automatically publishalpha
versions from themaster
branch, so you will rarely (if ever) need to run this command yourself.npm run prerelease:beta
- publish a prerelease to both git and npm. This will use the npm@beta
tag using the-beta
prerelease identifier. Publishes to the@beta
tag don't need to be 100% stable, but should indicate all the major feature development for a release is finished and you're ready to start adding some polish. Beta releases should be made from arelease/*
branch.npm run prerelease:rc
- publish a release candidate to both git and npm. This will use the npm@rc
tag using the-rc
prerelease identifier. Publishes to the@rc
tag should be considered stable. This is the last check before publishing a new, stable release. Ideally, multiple folks at Alley should install and try out this code before a stable release. Release candidates should be made from arelease/*
branch.npm run release
- publish a stable release to the npm@latest
tag. Stable releases should be made from arelease/*
branch.
Specific branches will be used for specific purposes in this repo. Considering this, the lifecycle of a new feature, bugfix, etc. should largely follow the steps below.
Important:
- Before publishing any release manually, you will need to authenticate your machine to use the
alleyops
npm account by runningnpm adduser
and following the prompts. Credentials for the account can be found in the Alley Leads 1Password vault. - If you are publishing a
beta
,rc
, or stable release, you will also need to have a validGH_TOKEN
in your Irving.env
file. In Github, create your token under account > Settings > Developer Settings > Personal Access Tokens. Then create a.env
file at the root of the cloned Irving repo and assign it to aGH_TOKEN
environmental variable. NOTE: The project in which you are testing your Irving changes must be on at least Irving3.1.0
for this setup process to work properly.
- Fork or clone the Irving repo.
git checkout master
- Check out the NPM package release branch.npm run develop:prepare
- If you have run this script in the past, you can skip this step. Run this at the root of the Irving repo to prepare the irving repo for development. IMPORTANT NOTE this script is memory intensive and may take time, but you should only ever need to run it once. Get up and make yourself some coffee or a cocktail and just let it run! This script will:
- Run
npm install
. - Run
npm link
within all Irving packages to create global symlinks. (see docs on npm link) - Clean up
node_modules
within each package - Run
lerna bootstrap
to install and hoist dependencies for all packages, then link interdependent Irving packages together. - NOTE: If you run into an error attempting to run this script, try running
develop:cleanup
first then attempt to rundevelop:prepare
again.
npm install && npx irving link-all
- In the project where you'll be testing out your changes, run these commands to symlink all installed Irving packages.- A couple troubleshooting tips:
- If you run into errors with linked packages, especially errors related to missing imports, run
npm run develop:setup
in the irving repo root and your problems should be solved. - If you'd like to unlink all irving packages, run
npm install
in the root of your project. - If you'd like to re-link all irving packages, run
npx irving link-all
in the root of your project.
- If for some reason you need to reset links, run
npm run develop:setup
in the Irving repo root andnpx irving link-all
in your project. git checkout -b feature/issue-17/branch-title
- create a new feature branch based on master. If your branch relates to a specific GitHub issue, reference that issue in your branch name (and all subsequent commits).npm run test
and/ornpm run test:watch
- If you've fixed a bug or added a new feature, please write tests! These commands can be used to run tests from within the package you are modifying or at the root of the repo if you want to run all tests for all packages.- When ready, push your code and create a pull request into
master
branches. - Your code will be reviewed.
- Once your code passes review, a maintainer will merge your PR into
master
(or you can do so yourself if you are a maintainer). - If you are a maintainer, you may now:
git checkout master && git pull origin master
to checkoutmaster
and pull down your newly-merged code.- Travis will automatically create an
alpha
release for your changes. - Install and verify the new
alpha
release in your project vianpm install @irvingjs/package-name@alpha
. - When you're satisfied, notify the designated release organizer that your feature is ready to move along to
beta
.
- If you are not a maintainter:
- Keep an eye on the releases page. When you see your code has been released, install and test it!.
- If you find an issue with your code, notify the release orgainzer that you are still working on it.
- If the release organizer or someone else at Alley finds an issue with your code, they will notify you.
- In both of the above cases, try to address any issues in a timely manner (before the scheduled
beta
release of the upcoming version). - Otherwise, let the release organizer know your code is ready to go to
beta
, ideally in the GitHub issue your PR is associated with.
- Take stock of all features that will be going into this release. Verify with feature developers that those features are ready to move to beta. The schedule for when this happens may vary—coordinate with the team.
- When ready, break off a new branch for the release using the format
release/[version]
. Example:release/3.2.0
- Push your release branch to create a remote branch on
origin
as well. npm run prerelease:beta
- Release abeta
version from the release branch immediately for testing.- Likely when you first create the release branch there will be no releaseasable changes, so you will have to use
npm run prerelease:beta -- --force-publish
to graduate to the-beta.0
version. - Once released, ask feature developers to install beta and test their feature (and do tests yourself as well).
- Likely when you first create the release branch there will be no releaseasable changes, so you will have to use
npm run prerelease:rc
- Close to release deadline, publish a new release to the@rc
tag in npm from the release branch. Test again.- When ready, call attention to your upcoming release. This is an opportunity to have a conversation with others about code they might also want to release or objections they might have to releasing your code.
- Between the
beta
release and stable release, if bugfixes or additional changes are necessary for the release, be sure to pull-request those changes into bothmaster
and therelease
branch to keep them in sync. As a general rule,master
should never be merged into the release branch once it is created. npm run release
- Create a stable release from your release branch.git checkout master && git merge release/[version] && git push origin master
- update master with your release code.- Leave your release branch open in case we need to patch that version in the future.
Notes:
- All hotfixes should be
patch
releases in semver terms - You do not need to wait for a release organizer to release hotfixes, but you may ask them to do so if that's easier.
Steps:
git checkout main
- check out the main branch.git checkout -b bug/bug-branch-name
- check out a new branch for your patch or hotfix.- Work on your branch locally using linked packages.
- Once you’re satisfied with your code, open up a pull request to the
main
branch, get a peer code review, and merge intomain
. - verify your bugfix works on the resulting
alpha
prerelease. git checkout release/[version]
- checkout the release branch for which this hotfix needs to be released (this can be done on multiple different release branches separately).git cherry-pick [commit hash]
- cherry-pick the commits from your bugfix branch into the release branch, in the order they were committed.npm run prerelease:beta
- release a beta version and testnpm run release
- release apatch
version from this release branch.- Merge release branch back into
main
. IMPORTANT: Only peform a merge back intomain
from one release branch, if you are releasing this hotfix to multiple release branches.
- Important: After creating a
release
branch, never merge master into that branch again. Release branches should remain stagnant unless a patch needs to be introduced. - In prior versions of this document (and prior release processes) we made use of a
develop
branch. This branch is no more! Please don't merge into or make releases fromdevelop
. - Please read about Conventional Commits before publishing. The type of commit you choose will have ramifications on the semver version number you release. For example, a type of
fix
will indicate apatch
release, a type offeat
will indicate aminor
release. - When you want to test out a newly published package, don't forget the npm tag. For example, for a canary release, run
npm install @irvingjs/core@alpha --save-dev
. - When commitizen kicks in for a merge, choose
chore
for the type,merge
for the scope, andmerge
for the commit message. Everything else can be skipped.