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

feat(worker): support dynamic worker option fields #19010

Open
wants to merge 10 commits into
base: main
Choose a base branch
from

Conversation

jamsinclair
Copy link
Contributor

Description

The Problem

Vite has a hard requirement that worker options are defined statically or it throws an error. This prevents some legitimate use cases, such as when a dynamic name is used to differentiate workers. As seen in the Emscripten project (code reference)

worker = new Worker(new URL('target.js', import.meta.url), {
  'type': 'module',
  'name': 'em-pthread-' + PThread.nextWorkerID,
})

This is causing some issues in trying to update Emscripten to support Vite when workers are in use.

Solution

Vite only needs to ensure that the type value is statically defined. Other fields could be dynamically computed with no effect on the Vite bundling process.

A side discussion was started in #18396 (comment) about relaxing the usage of some worker option fields to support this.

This PR hopes to solve this issue in a backwards compatible way that still ensures that Vite can have high confidence in asserting the worker type at compile time.

@jamsinclair jamsinclair changed the title feat(worker): Support dynamic worker option fields feat(worker): support dynamic worker option fields Dec 19, 2024
@jamsinclair
Copy link
Contributor Author

jamsinclair commented Dec 19, 2024

Looks like this change broke the tests in two ways 😅

  • Windows paths aren't resolving nicely with the unit tests (Edit: this was caused by a bug in the plugin)
  • It seems to have broken the worker integration tests Solved by 7cf1551

I'll look into fixing these tomorrow.

@sapphi-red sapphi-red added feat: web workers p3-significant High priority enhancement (priority) labels Dec 27, 2024
Copy link
Member

@sapphi-red sapphi-red left a comment

Choose a reason for hiding this comment

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

Thank you! I left some minor comments.

packages/vite/src/node/plugins/workerImportMetaUrl.ts Outdated Show resolved Hide resolved
packages/vite/src/node/plugins/workerImportMetaUrl.ts Outdated Show resolved Hide resolved
packages/vite/src/node/plugins/workerImportMetaUrl.ts Outdated Show resolved Hide resolved
packages/vite/src/node/plugins/workerImportMetaUrl.ts Outdated Show resolved Hide resolved
packages/vite/src/node/plugins/workerImportMetaUrl.ts Outdated Show resolved Hide resolved
@sapphi-red sapphi-red added this to the 6.1 milestone Jan 8, 2025
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
feat: web workers p3-significant High priority enhancement (priority)
Projects
Status: Approved
Development

Successfully merging this pull request may close these issues.

4 participants