Hi! Thank you for your interest in contributing to Calypso, we really appreciate it.
There are many ways to contribute – reporting bugs, feature suggestions, fixing bugs, submitting pull requests for enhancements.
Just file a GitHub issue, that’s all. If you want to prefix the title with a “Question:”, “Bug:”, or the general area of the application, that would be helpful, but by no means mandatory. If you have write access, add the appropriate labels.
If you’re filing a bug, specific steps to reproduce are helpful. Please include the URL of the page that has the bug, along with what you expected to see and what happened instead.
Here is a handy link for submitting a new bug.
Feel free to share your unique context to help us understand your perspective. You can add context tags such as: #journey
#anecdote
#narrative
#context
#empathy
#perspective
#reallife
#dogfooding
#livesharing
#flowsharing
#anxiety
#anxiety-flow
#stresscase
#painpoint
. We'd also love to know how you found the bug: #dogfooding
, #manual-testing
, #automated-testing
, or #user-report
if applicable.
If you’d like to contribute code, first, you will need to run Calypso locally. Here is the short version:
- Make sure you have
git
,node
, andnpm
installed. - Clone this repository locally.
- Add
127.0.0.1 calypso.localhost
to your local hosts file. - Execute
make run
from the root directory of the repository. - Open
http://calypso.localhost:3000
in your browser.
For more detailed instructions, see Installing Calypso.
Running make run
will build all the code and continuously watch the front-end JS and CSS/Sass for changes and rebuild accordingly. In the case of React components, after the rebuild, the code is reloaded live in the browser and you should be able to see the changes without a refresh (CSS and changes deeper in the logic still need a refresh, but this will change, soon).
Errors and warning appear in the normal places – the terminal where you ran make run
and the JavaScript console in the browser. If something isn’t going the way you expected it, look at those places first.
Calypso uses the debug module to handle debug messaging. To turn on debug mode for all modules, type the following in the browser console:
localStorage.setItem( 'debug', '*' );
You can also limit the debugging to a particular scope
localStorage.setItem( 'debug', 'calypso:*' );
The node
server uses the DEBUG
environment variable instead of localStorage
. make run
will pass along it’s environment, so you can turn on all debug messages with
DEBUG=* make run
or limit it as before with
DEBUG=calypso:* make run
Code reviews are an important part of the Calypso workflow. They help to keep code quality consistent, and they help every person working on Calypso learn and improve over time. We want to make you the best Calypso contributor you can be.
Every PR should be reviewed and approved by someone other than the author, even if the author has write access. Fresh eyes can find problems that can hide in the open if you’ve been working on the code for a while.
The recommended way of finding an appropriate person to review your code is by blaming one of the files you are updating and looking at who was responsible for previous commits on that file.
Then, you may ask that person to review your code by mentioning his/her GitHub username on the PR comments like this:
cc @username
Everyone is encouraged to review PRs and add feedback and ask questions, even people who are new to Calypso. Also, don’t just review PRs about what you’re working on. Reading other people’s code is a great way to learn new techniques, and seeing code outside of your own feature helps you to see patterns across the project. It’s also helpful to see the feedback other contributors are getting on their PRs.
Consistent coding style makes the code so much easier to read. Here are ours:
When you’re first starting out, your natural instinct when creating a new feature will be to create a local feature branch, and start building away. If you start doing this, stop, take your hands off the keyboard, grab a coffee and read on. :)
It’s important to break your feature down into small pieces first, each piece should become its own pull request. Even if after finishing the first piece your feature isn’t functional, that is okay, we love merging unfinished code early and often. You can place your feature behind a feature-check to make sure it’s not exposed until all pieces are completed.
Once you know what the first small piece of your feature will be, follow this general process while working:
- Create a new branch, using the branch naming scheme, e.g.
add/video-preview
orfix/1337-language-too-geeky
. - Make your first commit: any will do even if empty or trivial, but we need something in order to create the initial pull request. Create the pull request and prefix the name with the section of the product, e.g. Posts: Prepare store for desktop app. Don’t worry too much if there’s no obvious prefix.
- Write a detailed description of the problem you are solving, the part of Calypso it affects, and how you plan on going about solving it.
- If you have write access, add the [Status] In Progress label or wait until somebody adds it. This indicates that the pull request isn’t ready for a review and may still be incomplete. On the other hand, it welcomes early feedback and encourages collaboration during the development process.
- Start developing and pushing out commits to your new branch.
- Push your changes out frequently and try to avoid getting stuck in a long-running branch or a merge nightmare. Smaller changes are much easier to review and to deal with potential conflicts.
- Follow the merge checklist before pushing. This ensures that your code follows the style guidelines and doesn’t accidentally introduce any errors or regressions.
- Note that you can automate some of these tasks by setting up githooks and they will run whenever you
git commit
. - Don’t be afraid to change, squash, and rearrange commits or to force push -
git push -f origin fix/something-broken
. Keep in mind, however, that if other people are committing on the same branch then you can mess up their history. You are perfectly safe if you are the only one pushing commits to that branch. - Squash minor commits such as typo fixes or fixes to previous commits in the pull request.
- If you end up needing more than a few commits, consider splitting the pull request into separate components. Discuss in the new pull request and in the comments why the branch was broken apart and any changes that may have taken place that necessitated the split. Our goal is to catch early in the review process those pull requests that attempt to do too much.
- When you feel that you are ready for a formal review or for merging into
master
make sure you check this list and our merge checklist.
- Make sure your branch merges cleanly and consider rebasing against
master
to keep the branch history short and clean. - If there are visual changes, add before and after screenshots in the pull request comments.
- Add unit tests, or at a minimum, provide helpful instructions for the reviewer so he or she can test your changes. This will help speed up the review process.
- Ensure that your commit messages are meaningful.
- Mention that the PR is ready for review or if you have write access remove the [Status] In Progress label from the pull request and add the [Status] Needs Review label - someone will provide feedback on the latest unreviewed changes. The reviewer will also mark the pull request as [Status] Awaiting Fixes if they think you need to change anything.
- If you get a , , , , or a LGTM and the status has been changed to [Status] Ready to Merge – this is great – the pull request is ready to be merged into
master
.
Whether somebody is reviewing your code or you are reviewing somebody else’s code, a positive mindset towards code reviews helps a ton. We’re building something together that is greater than the sum of its parts.
If you feel yourself waiting for someone to review a PR, don’t hesitate to personally ask for someone to review it or to mention them on GitHub. The PR author is responsible for pushing the change through.
We encourage you to ask for help at any point. We want your first experience with Calypso to be a good one, so don’t be shy. If you’re wondering why something is the way it is, or how a decision was made, you can tag issues with [Type] Question or prefix them with “Question:”.
Calypso is licensed under GNU General Public License v2 (or later).
All materials contributed should be compatible with the GPLv2. This means that if you own the material, you agree to license it under the GPLv2 license. If you are contributing code that is not your own, such as adding a component from another Open Source project, or adding an npm
package, you need to make sure you follow these steps:
- Check that the code has a license. If you can't find one, you can try to contact the original author and get permission to use, or ask them to release under a compatible Open Source license.
- Check the license is compatible with GPLv2, note that the Apache 2.0 license is not compatible.
- Add the code source URL (e.g. a GitHub URL), the files where it's used in
wp-calypso
and the full license terms toCREDITS.md
- Add attribution to the code, if applicable. This line should include the copyright notice of the source, and a reference to the license contained in
CREDITS.md