Skip to content
This repository has been archived by the owner on Jan 23, 2023. It is now read-only.
/ corefx Public archive

Latest commit

 

History

History
164 lines (143 loc) · 26.4 KB

issue-guide.md

File metadata and controls

164 lines (143 loc) · 26.4 KB

Issue Guide

This page outlines how the CoreFx team thinks about and handles issues. For us, issues on GitHub represent actionable work that should be done at some future point. It may be as simple as a small product or test bug or as large as the work tracking the design of a new feature. However, it should be work that falls under the charter of CoreFx, which is a collection of foundational libraries that make up the .NET Core development stack. We will keep issues open even if the CoreFx team internally has no plans to address them in an upcoming release, as long as we consider the issue to fall under our purview.

When we close issues

As noted above, we don't close issues just because we don't plan to address them in an upcoming release. So why do we close issues? There are few major reasons:

  1. Issues unrelated to CoreFx. When possible, we'll try to find a better home for the issue and point you to it.
  2. Cross cutting work better suited for another team. Sometimes the line between the framework, languages and runtime blurs. For some issues, we may feel that the work is better suited for the runtime team, language team or other partner. In these cases, we'll close the issue and open it with the partner team. If they end up not deciding to take on the issue, we can reconsider it here.
  3. Nebulous and Large open issues. Large open issues are sometimes better suited for User Voice, especially when the work will cross the boundaries of the framework, language and runtime. A good example of this is the SIMD support we recently added to CoreFx. This started as a User Voice request, and eventually turned into work for both the core libraries and runtime.

Sometimes after debate, we'll decide an issue isn't a good fit for CoreFx. In that case, we'll also close it. Because of this, we ask that you don't start working on an issue until it's tagged with up-for-grabs or api-approved. Both you and the team will be unhappy if you spend time and effort working on a change we'll ultimately be unable to take. We try to avoid that.

Labels

We use GitHub labels on our issues in order to classify them. We have the following categories per issue:

  • Area: These area-* labels (e.g. area-System.Collections) call out the assembly or assemblies the issue applies to. In addition to labels per assembly, we have a few other area labels: area-Infrastructure, for issues that relate to our build or test infrastructure, and area-Meta for issues that deal with the repository itself, the direction of the .NET Core Platform, our processes, etc. See full list of areas.
  • Issue Type: These labels classify the type of issue. We use the following types:
  • Other:
    • easy - Good for starting contributors.
    • up-for-grabs: Small sections of work which we believe are well scoped. These sorts of issues are a good place to start if you are new. Anyone is free to work on these issues.
    • needs more info: Issues which need more information to be actionable. Usually this will be because we can't reproduce a reported bug. We'll close these issues after a little bit if we haven't gotten actionable information, but we welcome folks who have acquired more information to reopen the issue.
  • wishlist - Issues on top of our backlog we won't likely get to. Warning: Might not be easy.

In addition to the above, we have a handful of other labels we use to help classify our issues. Some of these tag cross cutting concerns (e.g. tenet-performance), whereas others are used to help us track additional work needed before closing an issue (e.g. api-needs-exposed).

Milestones

We use milestones to prioritize work for each upcoming release to NuGet.org.

Assignee

We assign each issue to assignee, when the assignee is ready to pick up the work and start working on it. If the issue is not assigned to anyone and you want to pick it up, please say so - we will assign the issue to you. If the issue is already assigned to someone, please coordinate with the assignee before you start working on it.

Areas

Areas are tracked by labels area-* (e.g. area-System.Collections). Each area typically corresponds to one or more contract assemblies.

Area Owners / experts Description
area-Infrastructure @ViktorHofer, @ericstj, @wtgodbe, @safern, @Anipik Covers:
  • Packaging
  • Build and test infra for CoreFX repo
  • VS integration

area-Meta @joperezr Issues without clear association to any specific API/contract, e.g.
  • new contract proposals
  • cross-cutting code/test pattern changes (e.g. FxCop failures)
  • project-wide docs

area-Serialization StephenMolloy, @HongGit Packages:
  • System.Runtime.Serialization.Xml
  • System.Runtime.Serialization.Json
  • System.Private.DataContractSerialization
  • System.Xml.XmlSerializer
Excluded:
  • System.Runtime.Serialization.Formatters
System contract assemblies
System.AppContext @safern, @Anipik
System.Buffers @layomia, @JeremyKuhne, @ahsonkhan
System.CodeDom @buyaa-n, @krwq
System.Collections @safern Excluded:
  • System.Array -> System.Runtime
System.ComponentModel @maryamariyan, @safern
System.ComponentModel.DataAnnotations @lajones, @ajcvickers
System.Composition @maryamariyan, @ViktorHofer
System.Configuration @maryamariyan, @safern
System.Console @wtgodbe
System.Data @ajcvickers,@cheenamalhotra, @david-engel
System.Data.SqlClient @cheenamalhotra, @karinazhou, @david-engel Archived component - limited churn/contributions (see https://devblogs.microsoft.com/dotnet/introducing-the-new-microsoftdatasqlclient/)
System.Diagnostics @wtgodbe, @krwq
  • System.Diagnostics.EventLog - @Anipik
System.Diagnostics.Process @wtgodbe, @krwq
System.Diagnostics.Tracing @noahfalk, @tommcdon, @Anipik Packages:
  • System.Diagnostics.DiagnosticSource
  • System.Diagnostics.PerformanceCounter - @Anipik
  • System.Diagnostics.Tracing
  • System.Diagnostics.TraceSource - @Anipik

System.DirectoryServices @tquerec, @josephisenhour
System.Drawing @safern, @maryamariyan
System.Dynamic.Runtime @cston, @333fred Archived component - limited churn/contributions (see #33170)
System.Globalization @krwq, @tarekgh
System.IO @JeremyKuhne, @carlossanlop
System.IO.Compression @carlossanlop, @ahsonkhan, @ViktorHofer
System.IO.Packaging @JeremyKuhne, @carlossanlop
System.IO.Pipelines @davidfowl, @halter73, @jkotalik, @anurse
System.Linq @maryamariyan
System.Linq.Expressions @cston, @333fred Archived component - limited churn/contributions (see #33170)
System.Linq.Parallel @tarekgh, @kouvel
System.Management @Anipik WMI
System.Memory @ahsonkhan
System.Net @davidsh, @wfurt, @scalablecory, @eiriktsarpalis, @karelz Included:
System.Net.Http @davidsh, @wfurt, @scalablecory, @eiriktsarpalis, @karelz
System.Net.Http.SocketsHttpHandler @geoffkizer, @wfurt, @davidsh, @scalablecory, @eiriktsarpalis, @karelz
System.Net.Security @davidsh, @wfurt, @scalablecory, @eiriktsarpalis, @karelz
System.Net.Sockets @davidsh, @wfurt, @scalablecory, @eiriktsarpalis, @karelz
System.Numerics @tannergooding, @ViktorHofer
System.Numerics.Tensors @tannergooding
System.Reflection @steveharter, @GrabYourPitchforks
System.Reflection.Emit @steveharter, @GrabYourPitchforks
System.Reflection.Metadata @tmat, @nguerrera
System.Resources @krwq, @tarekgh
System.Runtime @bartonjs, @joperezr Included:
  • System.Runtime.Serialization.Formatters
  • System.Runtime.InteropServices.RuntimeInfo
  • System.Array
Excluded:
  • Path -> System.IO
  • StopWatch -> System.Diagnostics
  • Uri -> System.Net
  • WebUtility -> System.Net
System.Runtime.Caching @StephenMolloy, @HongGit
System.Runtime.CompilerServices @Anipik
System.Runtime.Extensions @Anipik
System.Runtime.InteropServices @AaronRobinsonMSFT, @jkoritzinsky Excluded:
  • System.Runtime.InteropServices.RuntimeInfo
System.Runtime.Intrinsics @tannergooding, @CarolEidt, @RussKeldorph
System.Security @bartonjs, @GrabYourPitchforks
System.ServiceModel N/A dotnet/wcf (except System.ServiceModel.Syndication)
System.ServiceModel.Syndication StephenMolloy, @HongGit
System.ServiceProcess @maryamariyan, @Anipik
System.Text.Encoding @layomia, @krwq, @tarekgh
System.Text.Encodings.Web @GrabYourPitchforks, @layomia, @tarekgh
System.Text.Json @ahsonkhan, @steveharter
System.Text.Unicode @GrabYourPitchforks, @layomia, @tarekgh
System.Text.RegularExpressions @ViktorHofer, @maryamariyan
System.Threading @kouvel
System.Threading.Channels @tarekgh, @stephentoub
System.Threading.Tasks @tarekgh, @stephentoub
System.Transactions @dasetser, @HongGit
System.Xml @buyaa-n, @krwq
Microsoft contract assemblies
Microsoft.CSharp @cston, @333fred Archived component - limited churn/contributions (see #33170)
Microsoft.VisualBasic.Core @cston, @333fred Archived component - limited churn/contributions (see #33170)
Microsoft.Win32 @maryamariyan, @Anipik

Note: Area triage will apply the new scheme (issue types and assignee) throughout 2016.

Community Partner Experts

Area Owners / experts Description
Tizen @alpencolt, @gbalykov For issues around Tizen CI and build issues

Triage rules - simplified

  1. Each issue has exactly one area-* label
  2. Issue has no Assignee, unless someone is working on the issue at the moment
  3. Use up-for-grabs as much as possible, ideally with a quick note about next steps / complexity of the issue
  4. Set milestone to Future, unless you can 95%-commit you can fund the issue in specific milestone
  5. Each issue has exactly one "issue type" label (bug, enhancement, api-needs-work, test bug, test enhancement, question, documentation, etc.)
  6. Don't be afraid to say no, or close issues - just explain why and be polite
  7. Don't be afraid to be wrong - just be flexible when new information appears

Feel free to use other labels if it helps your triage efforts (e.g. needs more info, Design Discussion, blocked, blocking-partner, tenet-performance, tenet-compatibility, os-linux/os-windows/os-mac-os-x/os-unsupported, os-windows-uwp/os-windows-wsl, arch-arm32/arch-arm64)

Motivation for triage rules

  1. Each issue has exactly one area-* label
    • Motivation: Issues with multiple areas have loose responsibility (everyone blames the other side) and issues are double counted in reports.
  2. Issue has no Assignee, unless someone is working on the issue at the moment
    • Motivation: Observation is that contributors are less likely to grab assigned issues, no matter what the repo rules say.
  3. Use up-for-grabs as much as possible, ideally with a quick note about next steps / complexity of the issue
    • Note: Per http://up-for-grabs.net, such issues should be no longer than few nights' worth of work. They should be actionable (i.e. no misterious CI failures or UWP issues that can't be tested in the open).
  4. Set milestone to Future, unless you can 95%-commit you can fund the issue in specific milestone
    • Motivation: Helps communicate desire/timeline to community. Can spark further priority/impact discussion.
  5. Each issue has exactly one "issue type" label (bug, enhancement, api-needs-work, test bug, test enhancement, question, documentation, etc.)
    • Don't be afraid to be wrong when deciding 'bug' vs. 'test bug' (flip a coin if you must). The most useful values for tracking are 'api-*' vs. 'enhancement', 'question', and 'documentation'.
    • Note: The api-* labels are important for tracking API approvals, the other issue type labels are in practice optional.
  6. Don't be afraid to say no, or close issues - just explain why and be polite
  7. Don't be afraid to be wrong - just be flexible when new information appears

PR rules

  1. Each PR has exactly one area-* label
    • Movitation: Area owners will get email notification about new issue in their area.
  2. PR has Assignee set to author of the PR, if it is non-CoreFX engineer, then area owners are co-assignees
    • Motivation #1: Area owners are responsible to do code reviews for PRs from external contributors. CoreFX engineers know how to get code reviews from others.
    • Motivation #2: Assignees will get notifications for anything happening on the PR.
  3. [Optional] Set milestone according to the branch the PR is against (master = 5.0, release/3.0 = 3.0, release/2.1 = 2.1.x, etc.)
    • Motivation: Easier to track and audit where which fix ended up and if it needs to be ported into another branch (hence reflecting branch the specific PR ended up and not the abstract issue).
    • Note: This is easily done after merge via simple queries & bulk-edits, you don't have to do this one.
  4. Any other labels on PRs are superfluous and not needed (exceptions: blocked, NO MERGE)
    • Motivation: All the important info (issue type label, api approval label, OS label, etc.) is already captured on the associated issue.
  5. Push PRs forward, don't let them go stale (response every 5+ days, ideally no PRs older than 2 weeks)
  6. Stuck or long-term blocked PRs (e.g. due to missing API approval, etc.) should be closed and reopened once they are unstuck
    • Motivation: Keep only active PRs. WIP (work-in-progress) PRs should be rare and should not become stale (2+ weeks old). If a PR is stale and there is not immediate path forward, consider closing the PR until it is unblocked/unstuck.
  7. PR should be linked to related issue, use auto-closing (add "Fixes #12345" into your PR description)