renovate/docs/development/issue-labeling.md
HonkingGoose 378e9bbceb
chore: drop status:ready and improve triage docs (#25023)
Co-authored-by: Rhys Arkins <rhys@arkins.net>
2023-10-04 19:15:28 +00:00

6.9 KiB

Issue labeling

We try to keep issues well-classified through use of labels. Any repository collaborator can apply labels according to the below guidelines.

The general idea is that we have:

  • manager (manager:)
  • versioning (versioning:)
  • datasource (datasource:)
  • platform (platform:)
  • core functionality (core:)

The majority of issues should have at least one of those labels. These labels should also map approximately to our Conventional Commit scopes.

Basic knowledge about Renovate

You should know about platforms, package managers, datasources and versioning to label issues effectively.

Most issues should have a label relating to either a platform, manager, datasource, versioning or worker topic.

Label categories

Status

Status of issue
status:requirements
status:blocked
status:in-progress

Use these to label the status of an issue. For example, use status:requirements to mean that an issue is not yet ready for development to begin.

Type of issue

Type of issue
type:bug
type:docs
type:feature
type:refactor

Use these to label the type of issue. For example, use type:bug to label a bug type issue, and use type:feature for feature requests. Only use type:refactor for code changes, don't use type:refactor for documentation type changes.

All issues should have a type:* label. Use this search to find issues without a type:* label.

Add the breaking label for Issues or PRs which have changes that are not backwards compatible and require a major version bump.

Priority

Priority
priority-1-critical
priority-2-high
priority-3-medium
priority-4-low

Use these to assign a priority level to an issue. Try to select the proper priority. Nothing bad will happen if you select a "wrong" priority. At a high level: critical = needs immediate fix, high = to be prioritized ahead of others, medium = default priority, low = trivial issue, or impacts a very small percentage of the user base.

Use this search to find any issues which are missing a priority label.

Platform

Platform labels
platform:azure
platform:bitbucket
platform:bitbucket-server
platform:codecommit
platform:gitea
platform:github
platform:gitlab

Use these to mark the platform that is affected by this issue. Keep in mind that an issue can be both affecting a platform and a self-hosted instance.

Core

Core labels
core:automerge
core:autoreplace
core:cache
core:changelogs
core:config
core:dashboard
core:git
core:onboarding
core:package-rules
core:schedule
core:vulnerabilities

The purpose of these labels is to allow browsing of open issues by the most commonly-used functionality, such as automerging or Dependency Dashboard.

Manager

"manager" is short for "package manager". Add the relevant manager: labels to the issue. If there are multiple managers affected, add labels for all of them.

Datasource

Use a datasource: label when it is applicable specifically to particular datasources (for example, as defined in the docs list of datasources).

Worker

Worker
worker:branch
worker:global
worker:pr
worker:repository

A worker is the "core" logic of Renovate. Use these labels to differentiate between the different internal Renovate working stages.

New stuff

New stuff
new datasource
new package manager
new platform
new versioning

Apply these labels when somebody opens a feature type issue requesting a new datasource, package manager, platform, or new versioning scheme.

Housekeeping

Housekeeping
duplicate
good first issue
help wanted
auto:bad-vibes
auto:discussion-closed
auto:discussion-first
auto:format-code
auto:logs
auto:needs-details
auto:no-coverage-ignore
auto:no-done-comments
auto:reproduction
auto:retry-latest

Add a label duplicate to issues/PRs that are a duplicate of an earlier issue/PR.

Add a label good first issue to issues that are small, easy to fix, and do-able for a newcomer. This label is sometimes picked up by tools or websites that try to encourage people to contribute to open source.

Add the label help wanted to indicate that we need the original poster or someone else to do some work or it is unlikely to get done.

Add a label auto:bad-vibes to any discussion containing rude comments such as excessive criticism or ungratefulness.

Add a label auto:discussion-closed to close a discussion which had persistent or very bad vibes.

Add a label auto:discussion-first to any PR which needs discussing first.

Add a label auto:format-code to any Discussion which needs code formatting.

Add a label auto:logs to indicate that there's a problem with the logs, and the contributor needs to do one of these things:

  1. Provide logs (if there are none yet)
  2. Provide more logs (in case current logs are insufficient)
  3. Format their logs properly

Add a label auto:needs-details to discussions which need more details to move forward.

Add a label auto:no-coverage-ignore if PR authors avoid needed unit tests by istanbul ignoring code with the // istanbul ignore comment.

Add a label auto:no-done-comments if PR authors unnecessary "Done" comments, or type comments to ask for a review instead of requesting a new review through GitHub's UI.

Add a label auto:reproduction if nobody's reproduced it in a public repo yet and such a reproduction is necessary before further work can be done.

Add a label auto:retry-latest to any Discussion where the user should retry the latest version of Renovate to see if the problem persists.

Self-hosted

Self hosted
self-hosted

Apply the self-hosted label when an issue is applicable only to users who self-administer their own bot.