+1::tada: | First off, thanks for taking the time to contribute! 🎉👍 |
---|
The following is a set of guidelines for contributing to Bitmask and its packages, which are hosted in the LEAP git repo and mirrored on the LEAP organization on GitHub. These are just guidelines, not rules, use your best judgment and feel free to propose changes to this document in a pull request.
This project adheres to the Contributor Covenant 1.2. By participating, you are expected to uphold this code. Please report unacceptable behavior to info@leap.se.
Report all the bugs you can find to us! If something is not quite working yet, we really want to know. Reporting a bug to us is the best way to get it fixed quickly, and get our unconditional gratitude.
It is quick, easy, and probably the best way to contribute to Bitmask development, other than submitting patches.
Reporting better bugs: New to bug reporting? Here you have a great document about this noble art.
We use the LEAP Issue Tracker, although you can also use Github issues. But we reaaaally prefer if you sign up in the former to send your bugs our way.
- The symptoms of the bug itself: what went wrong? What items appear broken, or do not work as expected? Maybe an UI element that appears to freeze?
- The Bitmask version you are running. You can get it by doing
bitmask --version
, or you can go toHelp -> About Bitmask
menu. - The installation method you used: bundle? from source code? debian package?
- Your platform version and other details: Ubuntu 14.04? Debian unstable? Windows 8? OSX 10.8.4? If relevant, your desktop system also (gnome, kde...)
- When does the bug appear? What actions trigger it? Does it always happen, or is it sporadic?
- Maybe a screenshot of the problem you're seeing.
- The exact error message, if any.
- Attachments of the log files, if possible (see section below).
Also, try not to mix several issues in your bug report. If you are finding several problems, it's better to issue a separate bug report for each one of them.
If you can spend a little time getting them, please add some logs to the bug report. They are really useful when it comes to debug a problem. To do it:
Launch Bitmask in debug mode. Logs are way more verbose that way:
bitmask --debug
Get your hand on the logs. You can achieve that either by clicking on the "Help -> Show log" menu, and saving to file, or getting the log files from the config folder.
You can also find us in the #leap
channel on the freenode network. If you
do not have a IRC client at hand, you can enter the channel via web.
- Fork our repo
- Work your code in a separate branch
- Create a pull request against
develop
- All tests should pass
- The code needs to be pep8 compliant (run
pep8 .
from the top folder) - Remember to add an entry in the
changes/
folder, from where the CHANGELOG for a given release is gathered.
- Use the present tense ("add feature" not "added feature")
- Use the imperative mood ("move cursor to..." not "moves cursor to...")
- Short (50 chars or less) summary on the first line
- Separate subject from body with a blank line
- Wrap the body at 72 characters or less
- Do not end the subject line with a period
- Use the body to explain what and why vs. how
For a good reference on commit messages and why does it matter see: http://chris.beams.io/posts/git-commit/
You can activate a standard template for your commits on this repo with:
git config commit.template docs/leap-commit-template
The template looks like this:
[type] <subject> <body> <footer>
Type should be one of the following:
- bug (bug fix)
- feat (new feature)
- docs (changes to documentation)
- style (formatting, pep8 violations, etc; no code change)
- refactor (refactoring production code)
- test (adding missing tests, refactoring tests; no production code change)
- pkg (packaging related changes; no production code change)
- i18n translation related changes
Subject should use imperative tone and say what you did. For example, use 'change', NOT 'changed' or 'changes'.
The body should go into detail about changes made.
The footer should contain any issue references or actions. You can use one or several of the following:
- Resolves: #XYZ
- Related: #XYZ
- Documentation: #XYZ
- Releases: XYZ
The Documentation field should be included in every new feature commit, and it should link to an issue in the bug tracker where the new feature is analyzed and documented.
[feat] add soledad sync progress to the UI Register to Soledad's sync (send and receive) events and display the progress in the UI. - Resolves: #7353