#270: HTML General Review: Web Workers

Visit on Github.

Opened Apr 17, 2018

Hello TAG!

This issue is part of the TAG's larger effort to review the HTML spec in its entirety--please see the original issue https://github.com/w3ctag/design-reviews/issues/174 for a summary of all the break-out issues.

The "Sections" are all the sections of the WHATWG HTML spec that should be reviewed as part of this issue. Where the spec section has associated Web Platform Tests, the specific WPT path is noted. While the primary focus of the review is the specification text, it can be helpful to review the related tests to help clarify algorithms or see interoperability conformance issues (or find issues with the tests).

The "Features" are just a sample of what you will encounter as part of this spec section, it's not meant to be exhaustive.

Here are some example suggestions for what to look for during the review, but don't limit to only these suggestions!

  • Look for any APIs that could be 'modernized' according to current design practices.
  • Look for things that could require permissions that aren't modelled in the permissions API at the moment.
  • Look for areas of the platform that contain UA 'magic' (aren't possible for JavaScript programs to emulate due to missing primitives in the platform). These are candidates for future Extensible Web archeology.
  • Look for areas of the spec that describe "wishful thinking" (e.g., that describe a feature that is implemented by no one). Such features should at least have implementor commitments, or they might be candidates for removal from the spec.
  • Look for cryptic and hard-to-follow algorithms that could be improved with extra explanatory text or improved prose. E.g., sometimes adding a "developer note" (green box) can add the needed clarity to understand the intent/purpose or outcome of a complex concept.
  • Look for concepts that are meant to be used together, but where this is not spelled out or explained clearly
Sections WPT path Features
10 workers dedicated and shared workers

Please provide feedback as (please select one):

  • open issues in our Github repo for each point of feedback
  • open a single issue in our Github repo for the entire review
  • leave review feedback as a comment in this issue and @-notify [github usernames]

Discussions

Comment by @slightlyoff Jul 24, 2018 (See Github)

https://html.spec.whatwg.org/multipage/workers.html#workers

Comment by @travisleithead Jul 24, 2018 (See Github)

Workers can be created as module or classic scripts. I noted that there should probably be some way to get the "type" of script (and not just for workers either). It would be wherever script execution meta-data is surfaced (or on the global if nowhere else)..

Comment by @kenchris Jul 24, 2018 (See Github)

@travisleithead meta data similar to import.meta.url and the like, https://github.com/tc39/proposal-import-meta

Today you would have to try/catch a call to importScript

Comment by @cynthia Jul 24, 2018 (See Github)

[1] Blöcks were briefly discussed during the session - we would be happy to see such a mechanism move forward. Another thing that continues to pop up is accessing the DOM from a worker - especially from the aspect of finding elements within the DOM from a worker. (That said, write access to DOM has been brought up too.)

[1] https://github.com/domenic/proposal-blocks

Comment by @travisleithead Jul 24, 2018 (See Github)

As we wrap up this review, we thought it worthwhile to note our findings to some of the implementers working on "workers" from various browsers. These are things to consider when looking to future innovation in this area. @kinu @wanderview @aliams