Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Process: Add documentation for labels, current and proposed #533

Merged
merged 6 commits into from
Feb 14, 2024

Conversation

inexorabletash
Copy link
Member

@inexorabletash inexorabletash commented Jan 26, 2024

For review - I left lots of notes which should get resolved before this ever merges. Editors - please make edits directly if you can!

Before merging we should also:

  • Add links from CONTRIBUTING.md etc
  • Consider creating a docs/ directory to capture these files
  • Do a pass over existing issues to adjust labels if they don't match, e.g. a few "question" issues should maybe be "feature request" ?

Preview | Diff

Copy link
Member

@anssiko anssiko left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Thanks @inexorabletash!

I dropped some unused labels, did some renames and proposed some changes to this PR accordingly. This doc will be very helpful for the group.

IssueTriage.md Outdated Show resolved Hide resolved
IssueTriage.md Outdated Show resolved Hide resolved
IssueTriage.md Outdated Show resolved Hide resolved
IssueTriage.md Outdated Show resolved Hide resolved
IssueTriage.md Outdated Show resolved Hide resolved
@inexorabletash
Copy link
Member Author

Given that it already warrants special consideration, we should decide and document how new operator proposals should be labeled.

Ignoring operation/operator spelling for the moment, is that operation set (because it's claiming the current op set is incomplete, and an addition to the op set), operator specific (because it's about specific new ops), or a new label e.g. "new operator" ?

If we expect this to be common, we could introduce an issue template that automatically applies labels, which would ease the triage burden.

@anssiko
Copy link
Member

anssiko commented Jan 31, 2024

How about if we settle on short and sweet "opset" and "op" to sidestep the naming discussion, while allow to filter out global from specific?

@inexorabletash
Copy link
Member Author

I worry that "op" without a qualifier like "specific" could end up being applied to everything relating to ops. I guess that's why we have docs.

I'll defer to others who know the space better than I do re: "opset" vs. "op set" vs. "operator set" etc.

IssueTriage.md Outdated Show resolved Hide resolved
IssueTriage.md Outdated Show resolved Hide resolved
IssueTriage.md Outdated

TODO: Consider removing these, or fit these into the documentation below.

- **enhancement** - unclear if this is about the spec text, the proposed API, etc. Prefer **feature request** etc.
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I did some further triage, and the issues with enhancement are only a few. We should probably drop this label entirely.

@inexorabletash
Copy link
Member Author

A good process question: do we actually want to tag "the normative spec text has a flaw" with bug, or is that considered the default?

@huningxin
Copy link
Contributor

Tagging "the normative spec text has a flaw" with bug sounds good to me. I think "lack of normative spec text" is also a bug, for example, #283

@anssiko
Copy link
Member

anssiko commented Feb 2, 2024

There was a request for a new webgpu interop label so I created one, @inexorabletash to be reflected in this PR.

@huningxin
Copy link
Contributor

huningxin commented Feb 2, 2024

There was a request for a new webgpu interop label so I created one

MLBuffer is also useful for chained inference use case. Should we also create a tag for it?

@inexorabletash
Copy link
Member Author

There was a request for a new webgpu interop label so I created one, @inexorabletash to be reflected in this PR.

Added! (I don't get the nice formatting of labels in comments, it seems.) And renamed the section to "Workstreams" but ideas welcome.

Also removed the normative suggestion and added a link to the Process doc.

New suggestion: drop cr and v2 and use Milestones instead, which have nice progress indicators.

@anssiko
Copy link
Member

anssiko commented Feb 5, 2024

MLBuffer is also useful for chained inference use case. Should we also create a tag for it?

Thanks, this would be a good feature-specific label for consideration.

@inexorabletash would it makes sense to use a combo of type: feature request + feature: "name" label for significant new features? This suggest we'd have a few feature-specific label for bigger features. Are there good experiences from the spec-land for this?

New suggestion: drop cr and v2

No open issue associated with cr label (we've addressed them!) so I dropped https://github.com/webmachinelearning/webnn/labels/cr 👋

v2 label is quite popular. This is "work deferred to the next version" which means this collection becomes a mixed bag. It is something we should look from time to time and especially after each major spec milestone to plan for the next.

and use Milestones instead, which have nice progress indicators.

What is the best example of the GH Milestones feature used right in a spec project so we could learn from it and evaluate if this feature would help the broader group? I've used this feature for some spec projects long time ago so asking for more recent view on how things have improved.

@anssiko
Copy link
Member

anssiko commented Feb 5, 2024

Was looking at #531 and thinking:

Do we want to label proposed feature removals, the reverse of "feature request"? On the impact scale they're similar.

Proposal: expand the semantics of "feature request" to repurpose it as follows: "suggestion for an addition to or removal from the proposed API". Feature removal is a feature.

@inexorabletash
Copy link
Member Author

Do we want to label proposed feature removals, the reverse of "feature request"? On the impact scale they're similar.

My concern here is that a feature request is (in most cases) purely additive. It can be deferred to "v.next", allowed to linger indefinitely, wait for use cases, etc. A removal, on the other hand, needs to consider compatibility, probably needs to happen within a version, acknowledge that use cases have been de-prioritized, etc. A feature addition that doesn't happen is neutral for the long term maintenance of implementations. But a feature removal that doesn't happen implies long term work for implementations, tests, interop, etc. So I agree that in terms of impact scale to the spec itself they're similar, but the attention needed and urgency seem quite different. I'd really hate for a suggested removal to not get the attention it deserves.

@inexorabletash
Copy link
Member Author

Are there good experiences from the spec-land for this?

For both feature-specific labels and milestones - I'm asking around. I have anecdotes but not data. :)

@inexorabletash
Copy link
Member Author

From asking around, more anecdotes:

  • an issue can only be associated with 1 milestone, you can't use them for any overlapping deadlines. So if you have clear unambiguous milestones those can work, but pick one scale for your milestones, and use labels for any other scale of grouping.
  • CSS consistently uses "topic" labels for separate specs (multiple in one repo, a very different pattern than here); use of feature-level labels is infrequent but does happen.

In personal projects I like the use of Milestones to indicate when an issue is "accepted" as a requirement for the current release or explicitly "deferred" to a future release, and issues with no Milestone are undecided (so: action is required). Using labels is fine but you don't get the nice bar graphs. The current situation is that we have a handful of v2 but (1) IMHO many of those should be considered blockers for TR and (2) anything not marked v2 is ambiguous. Ultimately it all comes down to: I want a clear view on what work remains and what next action is needed, so I'll be happy with anything that helps with that!

Labels for "significant new features" SGTM, on a case-by-case basis, like has happened for webgpu interop.

@inexorabletash
Copy link
Member Author

For the proposed "operator specific" label, this is the list of open issues I'd apply it to:

@inexorabletash
Copy link
Member Author

I dropped the proposals for "samples" and "interop" as I couldn't identify enough proposed issues in each category for it to make sense.

@anssiko
Copy link
Member

anssiko commented Feb 7, 2024

Created operator specific and populated per triage #533 (comment)

@inexorabletash inexorabletash force-pushed the meta-labels branch 3 times, most recently from 6b6453a to 71ed611 Compare February 12, 2024 17:04
@anssiko
Copy link
Member

anssiko commented Feb 14, 2024

I've updated https://github.com/webmachinelearning/webnn/labels to match. A few notes:

  • did not yet add PROPOSED "needs PR", "has PR", "needs WPT", "has WPT" labels
  • kept TODO enhancement until we remap those issues, removed TODO "help wanted" that was empty

@inexorabletash, do you also feel like we could merge this soon? Please check things are cohesive e.g. remove "help wanted".

* Removed TODO re: "help wanted" - label deleted
* Removed TODO: "needs PR"/"has PR" and "needs WPT" / "has WPT" - needs more discussion
@inexorabletash
Copy link
Member Author

I just went through and removed usage of "enhancement" (there were only 4).

#448 is an example of an issue that I'm not sure how to label. In prose I'd say "the spec is missing normative text to explain how something works". Should that just be "bug" ?

I think if we delete the "enhancement" label (and remove the TODO here) then this is good to merge and we can iterate further e.g. with guidance for issues like #448

@anssiko
Copy link
Member

anssiko commented Feb 14, 2024

Let's call #448 a bug for the time being and remove the TODO from here and merge this PR.

Triage is always an imperfect practice and the best way to improve is to try in production and adjust. Thanks for iterating on this PR!

* Remove TODOs
@inexorabletash
Copy link
Member Author

TODOs removed - merge at your leisure.

@anssiko anssiko merged commit eb06ccf into webmachinelearning:main Feb 14, 2024
2 checks passed
@inexorabletash inexorabletash deleted the meta-labels branch February 14, 2024 20:15
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

4 participants