Skip to content

Latest commit

 

History

History
51 lines (35 loc) · 3.86 KB

issue-triage.md

File metadata and controls

51 lines (35 loc) · 3.86 KB

Issue Triage

Triage is the process of reviewing and labeling incoming issues, identifying any which are critical, and escalating the critical ones.

Why We Triage

Triage sets us up for success, improves developer experience, and raises quality faster by prioritizing impactful issues. When all issues in a repository are regularly labeled, tested, and reviewed it makes it easy to know exactly where to see the highest needs to improve user experience. High quality bug reports in an organized and prioritized repository makes it easier to start working on maintenance and, in turn, helps us close the loop on user feedback.

Labels

All issues should have a label for the general area of the app it corresponds to and a [Type] label (e.g. [Type] Bug or [Type] Enhancement).

Useful links to find issues that need labels:

Prioritization

Bug reports (issues with the [Type] Bug label) should also have a Priority label. Priority is assigned based on severity and impact:

Low Severity Medium Severity High Severity Critical Severity
Low Impact Low Low Medium High
Medium Impact Low Medium High Blocking
High Impact Medium High Blocking Blocking

Severity

Severity is determined by what functionality is affected and how broken it is:

  • Low: Visual issue or edge case (doesn’t affect core/default functionality)
  • Medium: Bug with a workaround, low priority feature is broken/non-functional, visual issue in login/signup (first impressions)
  • High: High priority flow or feature is broken/non-functional, crash. High priority areas: login, signup, editing, stats, notifications
  • Critical: Critical impact on data or site: data loss (posts, pages, comments), unexpected publishing, security issue

Impact

Impact is determined by how many users are affected or how many reports we receive:

  • Low: Non-reproducible or single user report, or estimated 0-5% of users affected.
  • Medium: 2-4 user reports, or estimated 6-25% of users affected.
  • High: 5+ user reports, or estimated 26-100% of users affected.

If you aren't sure how to estimate the number of users affected, use the number of user reports you can find as a starting point. The issue can be escalated later if we find a good estimate of users affected or if more user reports are noted on the issue.

Special Cases

In addition to the guidelines above, we have specific criteria for prioritizing certain types of issues in a new production or beta release:

  • A new crash affecting more than 0.2% of users once the rollout of a production release is completed requires a hotfix. Some considerations here:
    • If the crash leaves the user in an unrecoverable situation, that’s a breaking incident. All hands on deck until we push a fix.
    • If the user can recover, we need to find the developer(s) that have the highest chance of success and redirect them to the issue.
  • All new crashes in a beta release should be fixed on the frozen branch (i.e. "Blocking" priority).
  • Issues with Tracks events should be fixed as soon as they are discovered. We rely on Tracks to evaluate whether a project was a success or not, or if we should keep iterating on it, so it’s extremely important that all our events are accurate. When to hotfix or target the frozen branch will be determined on a case by case basis.