Your contributions are what make OpenMRS an awesome Health IT system in developing countries. We want to make it as easy and fun as possible for you to contribute to the project and interact with the community. Before you get started contributing to OpenMRS, we encourage you to read both our OpenMRS Developers Guide and our Getting Started as a Developer wiki page.
-
Please check to see if you are running the latest version of OpenMRS; the bug may already be resolved. If you are running an old version, it may no longer be supported. Check our Unsupported Releases page for details.
-
Search for similar problems using the OpenMRS Global Search; it may already be an identified problem.
-
Make sure you can reproduce your problem on our demo site at demo.openmrs.org.
-
If you know the problem is related to the function or performance of a specific add-on module you're running, please consult the Module Repository and that module's documentation about how to get support.
-
If you believe the problem is with OpenMRS itself, or if you're honestly not sure, you can file the bug report in the OpenMRS Trunk project in JIRA. You'll need to have an OpenMRS ID to do so. You'll receive e-mail updates as the bug is investigated and resolved.
Regardless of whether you're reporting the bug to the OpenMRS core team or to a module developer, to help those developers understand the problem, please include as much information as possible:
- A clear description of how to recreate the error, including any error messages shown.
- The version of OpenMRS you are using.
- The type and version of the database you are using, if known.
- If you are using any additional modules, custom templates, stylesheets, or messages, please list them.
- If applicable, please copy and paste the full Java stack trace.
- If you have already communicated with a developer about this issue, please provide their name.
-
We encourage you to discuss your feature ideas with our community before creating a New Feature issue in our issue tracker. Use our global OpenMRS search to see if someone has already proposed similar features. If not, use our mailing lists or OpenMRS Talk to discuss your ideas with us.
-
Provide a clear and detailed explanation of the feature you want and why it's important to add. The feature must apply to a wide array of users of OpenMRS; for smaller, more targeted "one-off" features, you might consider writing an add-on module for OpenMRS. You may also want to provide us with some advance documentation on the feature, which will help the community to better understand where it will fit.
-
If you're an advanced programmer, build the feature yourself (refer to the "Contributing (Step-by-step)" section below).
-
After finding a JIRA issue for the "Ready for Work" bug or feature on which you'd like to work, claim the issue by clicking the "Claim Issue" button. This will assign the issue to you and change its status to "In Progress".
-
Fork the repo on which you're working, clone your forked repo to your local computer, and set up the upstream remote:
git clone git://github.com/YourGitHubUserName/openmrs-core.git git remote add upstream https://github.com/openmrs/openmrs-core.git
-
Checkout to a new local branch based on your master and update it to the latest. The convention is to name the branch after the current ticket, e.g. TRUNK-123:
git checkout -b TRUNK-123 master git clean -df git pull --rebase upstream master
Please keep your code clean. Name your branch after the JIRA issue or other description of the work being done. If you find another bug, you want to fix while being in a new branch, please fix it in a separated branch instead.
-
Push the branch to your fork. Treat it as a backup.
git push origin TRUNK-123
-
Code
- Adhere to common conventions you see in the existing code
- Include tests, and ensure they pass
- Search to see if your new functionality has been discussed using our OpenMRS global search, and include updates as appropriate
- Follow the Coding Conventions described on our wiki.
However, please note that pull requests consisting entirely of style changes are not welcome on this project. Style changes in the context of pull requests that also refactor code, fix bugs, improve functionality are welcome.
- Commit
For every commit please write a short (max 72 characters) summary in the first line followed with a blank line and then more detailed descriptions of the change. Use markdown syntax for simple styling. Please include any JIRA issue numbers in your summary.
git commit -m "TRUNK-123: Put change summary here (can be a ticket title)"
NEVER leave the commit message blank! Provide a detailed, clear, and complete description of your commit!
- Issue a Pull Request
Before submitting a pull request, update your branch to the latest code.
git pull --rebase upstream master
If you have made many commits, we ask you to squash them into atomic units of work. Most of tickets should have one commit only, especially bug fixes, which makes them easier to back port.
git checkout master
git pull --rebase upstream master
git checkout TRUNK-123
git rebase -i master
Make sure all unit tests still pass:
mvn clean package
Push changes to your fork:
git push -f
In order to make a pull request,
- Navigate to the OpenMRS repository you just pushed to (e.g. https://github.com/your-user-name/openmrs-core)
- Click "Pull Request".
- Write your branch name in the branch field (this is filled with "master" by default)
- Click "Update Commit Range".
- Ensure the changesets you introduced are included in the "Commits" tab.
- Ensure that the "Files Changed" incorporate all of your changes.
- Fill in some details about your potential patch including a meaningful title.
- Click "Send pull request".
- In JIRA, open your issue and click the "Request Code Review" button to change the issue's status to "Code Review". Add a comment linking to the URL of the pull request.
Thanks for that -- we'll get to your pull request ASAP. We love pull requests!
The OpenMRS team may recommend adjustments to your code. Part of interacting with a healthy open source community requires you to be open to learning new techniques and strategies; don't get discouraged! Remember: if the OpenMRS team suggests changes to your code, they care enough about your work that they want to include it, and hope that you can assist by implementing those revisions on your own.
Though we ask you to clean your history and squash commit before submitting a pull-request, please do not change any commits you've submitted already (as other work might be build on top).
- If you haven't already, get an OpenMRS ID
- Make sure you have a GitHub account
- Submit or select a JIRA issue or choose from the introductory issues on our Getting Started as a Developer page.
- Fork openmrs-core or the repository for the module you are working on
- Chat live with developers on IRC within #openmrs on freenode
- Join our developers mailing list
- Hang out with other community members at OpenMRS Talk