-
Notifications
You must be signed in to change notification settings - Fork 118
Git Guidelines and Best Practices
In general we should follow the Git guidelines for the fcrepo project since they are sensible. They go into a lot of detail about line endings which we don't need to worry about as much at the moment. Specifically we should try and do the following, however:
Commit messages should follow the guidelines described in detail at http://tbaggery.com/2008/04/19/a-note-about-git-commit-messages.html.
In summary:
- First line: JIRA issue ID in all caps (if applicable), followed by a brief description (~ 50 characters)
- Second line: blank
- Following lines: more detailed description, line-wrapped at 72 characters. May contain multiple paragraphs, separated by blank lines. Link to the JIRA issue, if applicable. Use the present tense when writing messages, i.e. "Fix bug, apply patch", not "Fixed bug, applied patch."
Using the git command line tool you can add multi-line commit messages by typing a \ at the end of a line and continuing to type. E.g.,
$ git commit -m "ISLANDORA-110 Cannot delete content model when there is only one left.\
\
Remove logic that prevents delete widget from being drawn."
$
Each major release of Islandora has a tag associated with it. This tag will point to a commit in a -release
branch, that is the code actually released in the zip files on the islandora website. This way we will have an easily accessible archive of past releases.
Many of our projects are dependent on Drupal, and we have projects with multiple master
branches, one for each supported version of Drupal, the main branches for each projects repository are named after the version of Drupal that is supported by that version of the project. For example Islandora has 6.x
for Drupal 6 and 7.x
for Drupal 7. These branches should be treated as the master
branch for each version, and not developed on top of as is mentioned above. All of our projects should follow this naming convention for their master
branch for consistency.
There are also release branches associated with each of the master branches. These were named after the master branch they correspond to. For example: 6.x-release
and 7.x-release
. These branches were an archive of the "blessed" released code. They exist mainly so that we could do things like modify the module.info files for releases and cherry-pick commits from the master branch to backport bugfixes into a release. With Islandora 7.x-1.3 we have moved to a new approach where we will have a new branch for each release. When simple pull requests will not work for bringing code into these branches we will not require cherry-pick`d commits; simply re-commited edits will be acceptable. It is however highly advisable to use cherry-pick for anything other than the most trivial pull requests.
All JIRA issues should be worked on in separate git branches. The branch name should be the same as the JIRA issue number, including all-caps, so ISLANDORA-153, ISLANDORA-118, etc.
When working on a branch, before committing and merging it's best to pull updates from the master branch into your own branch. This makes for more graceful merge logic and more intuitive-looking github graphs. This is discussed extensively in the Development in a local branch section of the fcrepo git guidelines.
When ready to have a branch merged into master, the JIRA ticket should be resolved with a status of 'Ready to test'. We will discuss the changes at the weekly committers call and then if agreed upon the release manager will merge the changes into master and delete the topic branch. Once the merge with master is complete, change the fix status of the JIRA ticket to 'Fixed'.
You may be looking for the islandora-community wiki · new to islandora? · community calendar · interest groups