-
Notifications
You must be signed in to change notification settings - Fork 355
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
.
This section covers the regular development workflow.
-
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 repository under your personal account.
-
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.
The following git commands are useful in the regular development workflow.
- 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
- View local changes to files:
git status
- View local code diff:
git diff
- 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
When it is time to commit, supply a descriptive commit message under 70 characters. To add an additional description, supply a line break after the message and then the description. This can be done by using single-quotes and line breaks on the command line, and will look like this:
git commit -m 'Implemented super fast aggregation
> Enabled turbo boost switch in database.'
This section describes the workflow for back-porting bug-fixes and tweaks to stable branches.
- Check out a stable branch e.g. 2.24 with:
git checkout 2.24
- To fetch the branch from remote (only needed once):
git fetch
- To update the branch later with remote changes:
git pull
- To pick a commit from master, find the commit hash and apply it with:
git cherry-pick -x {hash}
, the hash will look something likec3c1ede6cfd1f47f30490abfbdca622db1ef6259
. If the given commit is a merge commit you will need to specify which parent is the base, using the-m{parent-number}
option. Example:git cherry-pick -x -m1 {hash}
. The-x
option appendscherry-picked from ...
to the commit message. - To publish the commit to the stable release branch for e.g. 2.24 do:
git push origin 2.24