The dev tools are tested with Node 8.11.3 and yarn 1.7.0.
Set up locally:
$ git clone https://github.com/uber/react-map-gl.git
$ cd react-map-gl
$ yarn bootstrap
$ npm run start
Test:
$ npm run test
Test in Node:
$ npm run test node
Test in browser (can use Chrome dev tools for debugging):
$ npm run test browser
Any intended change to the code base must open a pull request and be approved.
Generally speaking, all PRs are open against the master
branch, unless the feature being affected no longer exists on master.
- Tests
npm run test
must be successful.- New code should be covered by unit tests whenever possible.
- Documentation
- If public APIs are added/modified, update component documentation in
docs/api-reference
. - Breaking changes and deprecations must be added to
docs/upgrade-guide.md
. - Noteworthy new features should be added to
docs/whats-new.md
.
- If public APIs are added/modified, update component documentation in
- Description on GitHub
- Link to relevant issue.
- Label with a milestone (latest release or vNext).
- If public APIs are added/modified, describe the intended behavior.
- If visual/interaction is affected, consider attaching a screenshot/GIF.
The master
branch of the repo is the latest dev branch. It is used to publish the latest beta release, e.g. 4.0.0-alpha.1
.
Each minor release branches off from master, e.g. 2.0-release
, 3.3-release
. All production releases are built and published from respective release branches.
Website is built from the <latest>-release
branch.
Documentation is served directly from the <latest>-release
branch.
Only the master
branch and the <latest>-release
branch are actively maintained.
NOTE: for authorized team members only
- Push to new
<latest>-release
branch.<latest>
represents a minor release number, e.g.3.3
,4.0
. - Run
npm run update-release-branch <latest>
to upate the dependencies of examples to the latest version, and the links in all documentation to point to the new branch - Publish new minor release
- Publish website
NOTE: for authorized team members only
-
Log into an authorized npmjs.com account. You can use npmrc to manage multiple npm profiles.
-
Make sure both the
master
and the release branch are up to date:$ git checkout master $ git pull $ git checkout 3.3-release $ git pull
-
Find the last release commit on the
<latest>-release
branch:$ git log ... commit a05d23059444cf29bb4e38ea5e4cd6172a4f463d Author: Xiaoji Chen <[email protected]> Date: Fri Aug 3 10:11:45 2018 -0700 3.3.3
Find the commits on
master
after this commit:$ git log master --since="`git show -s --format=%ci a05d2305`"
-
Find out which new commits should be cherry-picked into the release branch.
If a commit is a bug fix for the current production release, or a minor, non-breaking new feature, it can be published as a patch. When in doubt, check the original PR's milestone label on GitHub. For example #565:
$ git cherry-pick 1238140a
If the commit affects code that is published to npm, add its commit message to CHANGELOG.md:
## 3.3.4 (Aug 4, 2018) - fix capture* props for overlay components (#565)
Examples of changes that are published:
- A change anywhere in `src`
- A change in Babel config
- A change in `README.md`
- A change in `package.json`'s user-facing fields, e.g. `file`, `main`, `browser`, `dependencies`, `peerDependencies`
Examples of changes that are not published:
- A change in `docs`
- Improvement of an example
- Adding a new lint rule
- Adding a new npm script
-
Include the changelog in the version commit, and publish:
$ git add . # This will bump version to the next patch release, commit, tag and publish: $ npm run publish-prod
-
If the new patch release fixes a bug on the website, republish the website.
-
Log into an authorized npmjs.com account. You can use npmrc to manage multiple npm profiles.
-
Make sure the
master
branch is up to daate:$ git checkout master $ git pull
-
Find the last release commit on the
master
branch:$ git log ... commit a05d23059444cf29bb4e38ea5e4cd6172a4f463d Author: Xiaoji Chen <[email protected]> Date: Fri Aug 3 10:11:45 2018 -0700 4.0.0-alpha.1
Find the commits on
master
after this commit:$ git log --since="`git show -s --format=%ci a05d2305`"
-
If a commit affects code that is published to npm, add its commit message to CHANGELOG.md.
-
If some beta version has been published for the target release (e.g.
4.0.0-alpha.1
), do not make changes topackage.json
. Otherwise, manually bump the version inpackage.json
to the appropriate pre-release version (e.g.4.1.0-alpha.0
). -
Include the changelog in the version commit, and publish:
$ git add . # This will bump version to the next pre-release, commit, tag and publish: $ npm run publish-beta
-
Make sure the
<latest>-release
branch is up to date:$ git checkout 3.3-release $ git pull
-
Make sure you have the correct Mapbox token:
$ echo $MapboxAccessToken
-
Test the website:
$ cd website $ yarn $ yarn start
-
Build and publish the website:
$ yarn build $ git checkout gh-pages
Copy the content from
website/dist
to the root of the project. Commit with the corresponding release version:$ git add . $ git commit -m "3.3.4" $ git push