Skip to content

Latest commit

 

History

History
49 lines (27 loc) · 4.07 KB

CONTRIBUTING.md

File metadata and controls

49 lines (27 loc) · 4.07 KB

How to contribute to Unlock

Unlock thrives on your contributions. We're excited you are here! Whether you are a software developer, a designer, a writer, or a tester, you are welcome.

Our GitHub Workflow

We are documenting our process to organize and prioritize our work using GitHub's tools.

Labels and Priorities

We also use labels as a way to classify tasks and issues using other dimensions. For example, we use P-0, 1, 2, 3 to identify the priority of a given task of issue.

  • P-0: Blocking bugs that we should drop everything to fix.
  • P-1: Bugs that must be fixed before the next release.
  • P-2: Bugs that should be fixed before the next release, time and resources permitting.
  • P-3: Bugs that should be fixed when there's time.

We reach milestones by solving issues based on their priority.

Submitting Pull Requests

Each code change is submitted as a pull request. Make sure you complete the templates when opening one.

The Road to Production

Unlock has multiple projects ongoing whose release cycles are decoupled because they show different characteristics.

The web applications (both front-end and backend)

We use the traditional web-dev approach to release early and often. This allows for quick iterations and fast progress. Once reviewed and approved, any change is merged into our master branch and immediately (minutes) deployed to our staging environment. Each commit in the master branch should be expected to be deployed in production and should hence be "production-grade".

We also maintain a production branch which is used to deployed to ... production! This branch is also protected and the only way to add commits to it is to go thru a regular pull request process. This pull request has to be approved and manually merged by one of our team members. Once approved and merge the various production web applications are immediately updated.

If needed, we can also deploy specific versions to production. For this is recommended approach is to open a new pull request against the production branch containing only the commits to be deployed since the latest production deploy. One way to do this is to rebase a local production-fix branch against the remote production branch and cherry pick the commits to be deployed from master. After this is a pull request is made and has to be approved by some of our team members. Once approved the updated production branch is immediately deployed.

Execptions

Both wedlocks (email service) and unlock-protocol-com (static site) are deployed to production from the master branch. They do not have a staging environment.

The smart contracts (blockchain)

Smart contracts are on a slow release cycle. We set a goal to deploy them once per quarter. Since each version may introduce breaking tests, their deployment process is slightly more complicated. Once a "stable" version has been reached (key features fully implemented and usable), we publish the ABI as an npm module.

The next step is to add this new ABI npm package to all of the other (web and server if applicable) apps and ensure that they all run with both the old ABI and the new ABI (the smart contract including versioning to make feature detection easier if needed). Fixes are made to the applications if required.

Once all apps are compatible with the new and old ABIs, they are deployed. We then proceed to updating the rinkeby deployed smart contracts for the staging environment. At that point, we should run an acceptance test suite (TBD). If everything works as expected, we can safely upgrade the main net smart contracts.

Once everything has been upgraded, we can start removing support for the old ABI from the multiple applications.