-
Notifications
You must be signed in to change notification settings - Fork 357
Home
Welcome to the DHIS 2 wiki pages.
The dhis2-core
repository contains the following branches.
-
Master: The
master
branch represents the snapshot / latest development branch. Master receives commits through pull requests from feature branches and maintenance branches. -
Stable release branches: Each stable release has a stable release branch. The stable release branches are the basis for the regular DHIS 2 releases, such as 2.23, 2.24 and so on. These branches receives bug-fixes and tweaks which are cherry-picked from master. An example of a stable release branch is
2.24
. -
Feature branches: Feature branches contains individual features. An example of feature branch could be
soft-deletes
. -
Maintenance branches: Maintenance branches is owned by individual developers and contains tweakes and minor fixes. An example of a feature branch could be
lars-dhis2-core
.
-
Create a branch for development work. Feature branches should be created for substantial features. Give the branch a descriptive name, e.g.
soft-data-value-deletes
. Maintenance branches should be created for minor tweaks and cleanup. Give the branch a name on the format {dev-name}-dhis2-core, e.g.lars-dhis2-core
. -
Do development work in the respective branch.
-
Publish your branch. This can be done by a) pushing your branch into the main dhis2-core branch or b) push it as a separate forked branch under the dhis2 github organization.
-
Open a pull request for your feature or fix. Provide the pull request with a descriptive message.
-
Ensure that tests are passing.
-
Optionally, request peer review of your pull request from another core developer.
-
Merge the pull request into master. For feature branches, do a squash merge, where a single commit is merged into master representing the entire feature. For maintenance branches you can potentially do an "expanded" commit where each individual commits are merged into master. In that case, ensure that each commit has a descriptive commit message.
- View all local branches:
git branch
- Pull remote changes into local branch:
git pull
- Create local branch e.g. soft-deletes:
git branch soft-deletes
- Switch to branch:
git checkout soft-deletes
- Add changes for later commit:
git add -A
orgit add {name-of-file-or-dir}
- Push repository or changes to Github:
git push origin soft-deletes
- Switch to master branch:
git checkout master
- Check out a stable branch e.g. 2.24 with:
git checkout 2.24
- To update the branch later with remote changes:
git fetch
- To pick a commit from master, find the commit hash and apply it with:
git cherry-pick -m1 {hash}
, the hash will look something likec3c1ede6cfd1f47f30490abfbdca622db1ef6259
.