-
Notifications
You must be signed in to change notification settings - Fork 0
Sprints Issue Tracking
Your team should consider using GitHub not only for source code management, but also for issue reporting. The purpose of the following guidelines is to provide guidance on how to report an issue. You might be asking yourself "How hard can this be?". You might be surprised to find out how often bad issue reports are actually created. Here are some examples:
- "The profile screen doesn't work right. Please correct this asap."
- "When I hit the Option-B key combination nothing happens."
- "Damnit how many times must I ask for this frigging software to work right. On the account entry screen the phone number textbox doesn't accept a country code"
The problem with the first two examples are they don't describe what the error actually is or where it's occurring within the application. The second example is marginally better since it defines how to recreated the problem, but that information is useless since there's still no indication of which screen the user was on when Option-B was attempted.
The last issue report is the best of the three since it defines which screen the user experienced the issue on, what she was trying to do, and what the expected outcome was. Unfortunately the first sentence is totally useless information that's inappropriate for an issue report and sends a signal to whoever works on this issue that the user is going to be difficult to work with. The lesson here is that issue reports should be factual and not emotional.
Keep in mind that this what is presented below is a way to customize the out-of-the-box GitHub Issue reporting system. However, you could just as easily use the GitHub default until you see a need for customization. This is a team decision based on your projects unique needs.
The result of having the complete, accurate, and appropriate information is that the Developer will be able to resolve the issue faster and more correctly. The key information that should be entered into the issue are:
- Description of what occurred and what the desired outcome should have been.
- Summary of the symptoms including screenshots and logs, if available.
- List of steps the Developer can follow to recreate the problem. This should include not only navigation steps, but also data values that are to be entered.
The information above should be entered by the individual that report's the issue. When the issue is resolved the Developer is responsible for describing how the issue was resolved along with any supplemental information that may be useful to other Developers if the issue should reoccur in the future.
To help ensure that this information is properly captured we ask our users and developers to use the following template when creating issues for IdeaNebulae. Simply copy and paste this into new issues and then enter information about your issue in the appropriate section.
**_Issue Description & Expected Outcome:_**
Symptoms:
Steps to Recreate:
Resolution:
Having the complete and accurate information that describes an issue is important, but so is classification of the issue. Classifying or grouping issues into categories helps the Development team to triage issues so they are worked on in the proper order. However, if you choose to use the basic set of default labels already defined by GitHub on your repo that's okay. You can always get more complicated, but it tougher to go in the other direction.
This project uses GitHub Issue Labels for classification. These labels and their definitions are shown below.
Label Description
-------------------- ---------------------------------------------------------
Issue type
type:bug ..A defect resulting in a deviation from expected results
type:documentation ..A defect in documentation or need for additional clarity
type:enhancement ..Request for an minor enhancement
type:feature request ..Request for a major new feature
type:question ..A question to the Development Team
type:refactor ..Request by Developer to modify how the code currently
accomplishes a given function.
Priority
priority:must have ..Significant impact to user requiring ASAP resolution.
Users are encouraged to describe the impact in the
issue description.
priority:should have ..Issue has an impact to the app that detracts from it's usefulness, but a work around exists.
priority:nice to have ..Issue has no longterm impact to the effectiveness or value of the app, but would improve it.
Status
status:on hold ..Deferred, unable to resolve at this time.
status:duplicate ..Duplicate issue. Development team will add this tag along with the issue number of the original problem report, then close the duplicate issue.
Scope of Development Effort
scope:story ..Small or trivial unit of work
scope:epic ..Moderate amount of work that consists of multiple user stories and may span more than one sprint.
scope:saga ..Considerable effort required that consists of more than one epic and spans multiple sprints.
Issue Type and Priority labels are to be assigned by whoever creates the issue. Status and Scope labels are maintained by the Development Team.
While issue type, priority, status, and scope labels are used to classify an issue or task, state defines where the the issue or item resides within the team's workflow. Workflow states correspond to the lanes or silos in the Agile Task or Kanban board used by the team to manage and monitor their progress.
Label Description
-------------------- ---------------------------------------------------------
Workflow State
state:inbox ..Starting state for all new user issues awaiting triage.
state:backlog ..Issues and tasks that have been triaged, but have not yet been started.
state:next ..Issues and tasks that haven't been started, but are scheduled to be worked on next.
state:in progress ..Issues and tasks being actively worked on by the team.
state:review ..Issues and tasks that have been completed, but are awaiting review and PR.
state:done ..Issues and tasks that have been completed.
Issues and tasks added by the team typically start in state:backlog and move to other states following discussion during team meetings. On the other hand, issues and tasks directly created by users start out in state:inbox until they have been triaged by the team. This makes it easier for the team to ensure that user issues and requests aren't overlooked.
The best source of examples for how issues are to be defined an labeled is the Cohort Issue Log.
About this Wiki
HomeAbout Cohort
About CohortsCohort Roadmap
..Tier 1 Schedule
Tier 2 & 3 Schedule
Cohort Support
What Team Am I On
Project Setup
Understanding Your ObligationsEstablishing the Team
Setting Up Your Git Workflow
Defining Your Project