BigW Consortium Gitlab

issue_board.md 8.89 KB
Newer Older
1 2 3 4 5 6
# Issue board

> [Introduced][ce-5554] in GitLab 8.11.

The GitLab Issue Board is a software project management tool used to plan,
organize, and visualize a workflow for a feature or product release.
7
It can be seen like a light version of a [Kanban] or a [Scrum] board.
8

9 10 11 12 13
Other interesting links:

- [GitLab Issue Board landing page on about.gitlab.com][landing]
- [YouTube video introduction to Issue Boards][youtube]

14 15 16 17 18 19 20 21 22
## Overview

The Issue Board builds on GitLab's existing issue tracking functionality and
leverages the power of [labels] by utilizing them as lists of the scrum board.

With the Issue Board you can have a different view of your issues while also
maintaining the same filtering and sorting abilities you see across the
issue tracker.

23 24
Below is a table of the definitions used for GitLab's Issue Board.

25
| What we call it  | What it means |
26 27 28
| --------------  | ------------- |
| **Issue Board** | It represents a different view for your issues. It can have multiple lists with each list consisting of issues represented by cards. |
| **List**        | Each label that exists in the issue tracker can have its own dedicated list. Every list is named after the label it is based on and is represented by a column which contains all the issues associated with that label. You can think of a list like the results you get when you filter the issues by a label in your issue tracker. |
29
| **Card**        | Every card represents an issue and it is shown under the list for which it has a label. The information you can see on a card consists of the issue number, the issue title, the assignee and the labels associated with it. You can drag cards around from one list to another. Issues inside lists are [ordered by priority](labels.md#prioritize-labels). |
30

31 32
There are three types of lists, the ones you create based on your labels, and
two default:
33

34 35 36 37
- **Backlog** (default): shows all issues that do not fall in one of the other lists. Always appears on the very left.
- **Done** (default): shows all closed issues. Always appears on the very right.
Label list: a list based on a label. It shows all issues with that label.
- Label list: a list based on a label. It shows all opened issues with that label.
38 39 40 41 42

![GitLab Issue Board](img/issue_board.png)

---

43
In short, here's a list of actions you can take in an Issue Board:
44

45 46
- [Create a new list](#creating-a-new-list).
- [Delete an existing list](#deleting-a-list).
47 48 49 50
- Drag issues between lists.
- Drag and reorder the lists themselves.
- Change issue labels on-the-fly while dragging issues between lists.
- Close an issue if you drag it to the **Done** list.
51 52
- Create a new list from a non-existing label by [creating the label on-the-fly](#creating-a-new-list)
  within the Issue Board.
53
- [Filter issues](#filtering-issues) that appear across your Issue Board.
54

55 56
If you are not able to perform one or more of the things above, make sure you
have the right [permissions](#permissions).
57

58
## First time using the Issue Board
59 60

The first time you navigate to your Issue Board, you will be presented with the
61 62 63
two default lists (**Backlog** and **Done**) and a welcoming message that gives
you two options. You can either create a predefined set of labels and create
their corresponding lists to the Issue Board or opt-out and use your own lists.
64 65

![Issue Board welcome message](img/issue_board_welcome_message.png)
66

67
If you choose to use and create the predefined lists, they will appear as empty
68
because the labels associated to them will not exist up until that moment,
69 70 71
which means the system has no way of populating them automatically. That's of
course if the predefined labels don't already exist. If any of them does exist,
the list will be created and filled with the issues that have that label.
72

73
## Creating a new list
74

75
Create a new list by clicking on the **Add list** button at the upper
76
right corner of the Issue Board.
77

78
![Issue Board welcome message](img/issue_board_add_list.png)
79

80 81 82
Simply choose the label to create the list from. The new list will be inserted
at the end of the lists, before **Done**. Moving and reordering lists is as
easy as dragging them around.
83

84
To create a list for a label that doesn't yet exist, simply create the label by
85
choosing **Create new label**. The label will be created on-the-fly and it will
86
be immediately added to the dropdown. You can now choose it to create a list.
87

88
## Deleting a list
89

90
To delete a list from the Issue Board use the small trash icon that is present
91
in the list's heading. A confirmation dialog will appear for you to confirm.
92

93
Deleting a list doesn't have any effect in issues and labels, it's just the
94
list view that is removed. You can always add it back later if you need.
95

96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113
## Searching issues in the Backlog list

The very first time you start using the Issue Board, it is very likely your
issue tracker is already populated with labels and issues. In that case,
**Backlog** will have all the issues that don't belong to another list, and
**Done** will have all the closed ones.

For performance and visibility reasons, each list shows the first 20 issues
by default. If you have more than 20, you have to start scrolling down for the
next 20 issues to appear. This can be cumbersome if your issue tracker hosts
hundreds of issues, and for that reason it is easier to search for issues to
move from **Backlog** to another list.

Start typing in the search bar under the **Backlog** list and the relevant
issues will appear.

![Issue Board search Backlog](img/issue_board_search_backlog.png)

114
## Filtering issues
115

116 117 118
You should be able to use the filters on top of your Issue Board to show only
the results you want. This is similar to the filtering used in the issue tracker
since the metadata from the issues and labels are re-used in the Issue Board.
119

120
You can filter by author, assignee, milestone and label.
121

122 123
## Creating workflows

124
By reordering your lists, you can create workflows. As lists in Issue Boards are
125 126 127 128 129 130 131
based on labels, it works out of the box with your existing issues. So if you've
already labeled things with 'Backend' and 'Frontend', the issue will appear in
the lists as you create them. In addition, this means you can easily move
something between lists by changing a label.

A typical workflow of using the Issue Board would be:

132 133
1. You have [created][create-labels] and [prioritized][label-priority] labels
   so that you can easily categorize your issues.
134
1. You have a bunch of issues (ideally labeled).
135
1. You visit the Issue Board and start [creating lists](#creating-a-new-list) to
136 137 138 139 140 141 142 143
   create a workflow.
1. You move issues around in lists so that your team knows who should be working
   on what issue.
1. When the work by one team is done, the issue can be dragged to the next list
   so someone else can pick up.
1. When the issue is finally resolved, the issue is moved to the **Done** list
   and gets automatically closed.

144
For instance you can create a list based on the label of 'Frontend' and one for
145 146 147 148 149 150
'Backend'. A designer can start working on an issue by dragging it from
**Backlog** to 'Frontend'. That way, everyone knows that this issue is now being
worked on by the designers. Then, once they're done, all they have to do is
drag it over to the next list, 'Backend', where a backend developer can
eventually pick it up. Once they’re done, they move it to **Done**, to close the
issue.
151

152 153 154 155 156
This process can be seen clearly when visiting an issue since with every move
to another list the label changes and a system not is recorded.

![Issue Board system notes](img/issue_board_system_notes.png)

157
## Permissions
158

159
[Developers and up](../permissions.md) can use all the functionality of the
160
Issue Board, that is create/delete lists and drag issues around.
161

162 163 164
## Tips

A few things to remember:
165

166
- The label that corresponds to a list is hidden for issues under that list.
167 168 169
- Moving an issue between lists removes the label from the list it came from
  and adds the label from the list it goes to.
- When moving a card to **Done**, the label of the list it came from is removed
170 171
  and the issue gets closed.
- An issue can exist in multiple lists if it has more than one label.
172
- Lists are populated with issues automatically if the issues are labeled.
173
- Clicking on the issue title inside a card will take you to that issue.
174 175
- Clicking on a label inside a card will quickly filter the entire Issue Board
  and show only the issues from all lists that have that label.
176
- Issues inside lists are [ordered by priority][label-priority].
177 178 179
- For performance and visibility reasons, each list shows the first 20 issues
  by default. If you have more than 20 issues start scrolling down and the next
  20 will appear.
180 181 182

[ce-5554]: https://gitlab.com/gitlab-org/gitlab-ce/merge_requests/5554
[labels]: ./labels.md
183 184
[scrum]: https://en.wikipedia.org/wiki/Scrum_(software_development)
[kanban]: https://en.wikipedia.org/wiki/Kanban_(development)
185 186
[create-labels]: ./labels.md#create-new-labels
[label-priority]: ./labels.md#prioritize-labels
187 188
[landing]: https://about.gitlab.com/solutions/issueboard
[youtube]: https://www.youtube.com/watch?v=UWsJ8tkHAa8