Triage Guidelines

Disclaimer

The most important thing: please use common sense. The guidelines below are likely not exhaustive and do not cover every case.

What should be triaged?

All Untriaged DevTools issues, as well as any Unconfirmed issues that also have the TE-NeedsTriageHelp label need to be triaged.

[Query]

Who is triaging?

Right now there is a Google-internal rotation set-up, with people that do weekly shifts. As Microsoft is in an opposite timezone they have a similar rotation on the same triage queue, but during a different time.

  • Google rotation: GMT+1
  • MS rotation: GMT-9

What are the SLOs?

[Query]

Issues in the untriaged queue should receive a meaningful response within a business week. This means that the goal is to make the query mentioned above return zero issues.

How are priorities defined?

  • P0: This needs to be urgently done, fire drill alert!
    • Most of the time, this seldom needs to be used.
    • Critical security exploits that affect stable are a good example for a P0
    • DevTools crashing on startup is a good example
  • P1: This is important. Let’s aim to get this done next
    • Non-critical security fixes will likely be in this category
    • Regression bugs will be likely in this category
    • Important features that partners are waiting for might be in this category
  • P2: We want to do that. The exact time of delivery is not that important though.
    • General feature work will likely be in this category
    • Non-severe bugs
  • P3: This is nice, but not important. We unlikely will do work here.
    • Edge-case bugs might fit this category
    • Non-important feature requests too

How should issues be triaged?

An issue is triaged when it meets the following criteria:

  • Priority is set correctly
  • Component is set correctly
  • Type is set correctly especially consider Feature vs Bug vs Bug-Regression
  • Status is set correctly (Available most of the time)
  • Request bisection from the Chrome Test Engineer team by adding the label “Needs-Bisect”.

Setting Assigned or Available

Set issues to Available if they don’t need immediate action and nobody right now and in the short-term future (an iteration) needs to work on it.

If you think they should be addressed in the short-term please add the label “Hotlist-DevTools-CurrentSprint”.

If you think they should be addressed mid-term or the next iteration, please add the label “Hotlist-DevTools-Backlog”

Issues that are handled by Microsoft have the label “Hotlist-DevTools-MS-Backlog” and “Hotlist-DevTools-MS-CurrentSprint” respectively and can be considered triaged.

If you think they are super urgent, please assign them to yangguo@chromium.org and cc bmeurer@chromium.org and hablich@chromium.org.

Closing issues

Don’t be afraid to close issues with WontFix if:

  • Bugs that are not reproducible
  • After two weeks you did not get a response back from the reporter on a question
  • The requested “bug” is the intended behavior Make sure that you bundle the WontFix with a brief comment explaining it e.g. “Setting to WontFix because not reproducible.”

FAQ

What if the issue belongs to another team?

If you think the to-triage issue is not a DevTools issue, please simply set it to a component that you think it should belong to and potentially remove the DevTools component. Make sure that the status is set to Untriaged. Feel free to CC people that you think might help with triaging this. This essentially moves the issue out of the DevTools triage queue into another team’s queue.

What if the issue is best handled by Microsoft?

If you think the to-triage issue or feature request is best handled by Microsoft then add the label “msft-consider” to the issue along with completing the other normal triage steps.

There is a feature request I am unsure how to handle. What should I do?

Please set the request to Available and add the label “Hotlist-DevTools-ProductReview”.

How do I indicate that a bug should block a release?

The combination of the label “M-” and “Release-Block-” signals that this very bug is blocking a release. Examples:

  • M-80, Release-Block-Stable
    • This blocks the release of 80 to the Stable channel
    • Depends in which release channel 80 is, this might not be an urgent (but still important bug to fix)
  • M-81, Release-Block-Beta
    • This blocks the release of 81 to the Beta channel
    • Depends in which release channel 81 is, this might not be an urgent (but still important bug to fix)
  • M-81, Release-Block-Dev
    • This blocks the release of 81 to the Dev channel
    • This typically means that the bug is urgent and important, as Dev releases are happening every week and are ok to be a little bit buggy.

Out of scope

Managing the backlog

[Query]

Managing the backlog is out of scope for the triage rotation. The backlog will be groomed continuously by hablich@ for now. The SLA is that there should be a maximum of 50 issues in there.

Managing the ProductReview queue

[Query]

Issues in ProductReview will continuously be handled by hablich@ to unblock items in there. SLA is max 10 issues.

References