Skip to content

Latest commit

 

History

History
50 lines (34 loc) · 1.95 KB

Readme.md

File metadata and controls

50 lines (34 loc) · 1.95 KB

Git Scrum

Git scripts to simplify development using feature branches (Scrum tasks).

Installation

Clone this repository to a location you can easily get to, e.g. $HOME/bin/git-scrum.

Add the cloned folder to your path, e.g. in your .bash_profile add:

export PATH=$HOME/bin/git-scrum:$PATH

Restart your shell (or source ~/.bash_profile) to activate your new path and there you go.

Overview

There are 4 types of branches in this setup:

  1. master
  2. feature branches (tasks)
  3. test branch(es)
  4. release branch

Development takes place in feature branches that correspond to Scrum tasks. A feature branche is merged back into master after it has been tested and approved by the product owner. In theory this should mean that master is always stable. Bug-fixing for tasks that have already been merged into master (this shouldn't happen often) are done directly on master. The release branch tracks the last result from a sprint and can be used for the product demo. Test branches are used to test an in-progress task on an external environment (for example, a Jenkins task that periodically pulls, builds and tests the test branch).

Commands

  • task-start - create a new remote+local feature branch
  • task-test- push a task that is busy to a testing branch
  • task-done - merge the feature branch into master and delete it
  • task-sync - synchronize with upstream and remove branches that have already been fully merged into master
  • task-list - list all tasks and their status (both you and colleagues)
  • task-switch - Switch between tasks (feature branches)
  • task-update - merge the commits in master back into your feature branch
  • task-status - display the status of a single task (done, busy, ...)
  • task-reject - not used anymore

Example workflow

git task-start $ID

echo "hello world" > hello.exe
git add hello.exe
git commit

git task-update $ID
git task-test $ID 2
git task-done $ID