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

fix(optimizer): use correct default install state path for yarn PnP #19119

Merged
merged 12 commits into from
Jan 10, 2025

Conversation

smeng9
Copy link
Contributor

@smeng9 smeng9 commented Jan 2, 2025

Fix #19118 for the yarn's default config. Main reason is if it can't find the file, it will use empty string to generate the hash, causing the result to be the same every time.

For yarn's custom config https://yarnpkg.com/configuration/yarnrc#installStatePath we probably need a different PR.

Also are we still going to support yarn 2.4 for optimize deps? Do we have a compatibility chart for vite version vs different package manger's version?
https://github.com/yarnpkg/berry/blob/93a56643ba3c813a87920dcf75c644eaf3b38e6f/CHANGELOG.md?plain=1#L392

bluwy
bluwy previously approved these changes Jan 2, 2025
Copy link
Member

@bluwy bluwy left a comment

Choose a reason for hiding this comment

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

Good catch. It's also showing up as install-state.gz for me.

@bluwy
Copy link
Member

bluwy commented Jan 2, 2025

For yarn's custom config yarnpkg.com/configuration/yarnrc#installStatePath we probably need a different PR.

Maybe it's also possible for us to use a different file to detect? From https://yarnpkg.com/getting-started/qa#which-files-should-be-gitignored, we could also use .pnp.js or .pnp.cjs I think.

Also are we still going to support yarn 2.4 for optimize deps?

Ideally I think we should support all versions if it's not too hard to do so. Otherwise I think it's also fine for Vite to not support very old package managers. We don't really test against or track compatibility with different package managers.

@smeng9
Copy link
Contributor Author

smeng9 commented Jan 2, 2025

Hi @bluwy ,

Maybe it's also possible for us to use a different file to detect? From https://yarnpkg.com/getting-started/qa#which-files-should-be-gitignored, we could also use .pnp.js or .pnp.cjs I think.

I have applied your suggestion to check for .pnp.cjs/.pnp.js file so we don't need to deal with custom installStatePath

We don't really test against or track compatibility with different package managers.

It's not hard to add for .pnp.js for yarn v2 this time (https://yarnpkg.com/advanced/changelog#breaking-changes), but the order of files gets checked matters. .pnp.js should be checked after but not before checking the existence of .pnp.cjs https://yarnpkg.com/advanced/changelog#major-changes as the old file is not removed when updating yarn. Otherwise vite will never re-run the pre-bundle step if the unused file gets left on the disk after upgrading yarn from 2 directly to 4.

However I think probably in next major version release of vite we can specify supported package managers versions through package.json engines field for yarn https://endoflife.date/yarn and pnpm https://endoflife.date/pnpm so we no longer need to deal with edge cases like this.

@smeng9
Copy link
Contributor Author

smeng9 commented Jan 2, 2025

I guess the failing test is flaky, need to rerun.

@smeng9 smeng9 requested a review from bluwy January 2, 2025 20:23
@smeng9
Copy link
Contributor Author

smeng9 commented Jan 3, 2025

Switched back to calling yarn to get installStatePath, and if yarn is not installed will use default installStatePath location

@bluwy
Copy link
Member

bluwy commented Jan 3, 2025

Is there a reason to switch back to that. I don't think we can afford calling execSync when importing Vite, especially if the user don't use yarn either. I think the .pnp.cjs and .pnp.js was fine though

Otherwise vite will never re-run the pre-bundle step if the unused file gets left on the disk after upgrading yarn from 2 directly to 4.

I don't think we should worry about this. Shouldn't the user remove the .pnp.js themselves ultimately? Assuming it's pretty much a dormant file.

If all else doesn't work, I think we can fallback to yarn.lock still as that's the previous behaviour.

@smeng9
Copy link
Contributor Author

smeng9 commented Jan 3, 2025

@bluwy Reverted back to using .pnp.js/.pnp.cjs file.

@smeng9 smeng9 requested a review from bluwy January 7, 2025 06:34
Copy link
Member

@bluwy bluwy left a comment

Choose a reason for hiding this comment

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

Thanks!

@bluwy bluwy added p3-minor-bug An edge case that only affects very specific usage (priority) feat: deps optimizer Esbuild Dependencies Optimization labels Jan 9, 2025
@patak-dev patak-dev merged commit e690d8b into vitejs:main Jan 10, 2025
17 checks passed
@smeng9 smeng9 deleted the fix-yarn-install-state-path branch January 10, 2025 19:10
renovate bot added a commit to andrei-picus-tink/auto-renovate that referenced this pull request Jan 20, 2025
| datasource | package | from  | to    |
| ---------- | ------- | ----- | ----- |
| npm        | vite    | 6.0.7 | 6.0.9 |


## [v6.0.9](https://github.com/vitejs/vite/blob/HEAD/packages/vite/CHANGELOG.md#small609-2025-01-20-small)

-   fix!: check host header to prevent DNS rebinding attacks and introduce `server.allowedHosts` ([bd896fb](vitejs/vite@bd896fb))
-   fix!: default `server.cors: false` to disallow fetching from untrusted origins ([b09572a](vitejs/vite@b09572a))
-   fix: verify token for HMR WebSocket connection ([029dcd6](vitejs/vite@029dcd6))


## [v6.0.8](https://github.com/vitejs/vite/blob/HEAD/packages/vite/CHANGELOG.md#small608-2025-01-20-small)

-   fix: avoid SSR HMR for HTML files ([#19193](vitejs/vite#19193)) ([3bd55bc](vitejs/vite@3bd55bc)), closes [#19193](vitejs/vite#19193)
-   fix: build time display 7m 60s ([#19108](vitejs/vite#19108)) ([cf0d2c8](vitejs/vite@cf0d2c8)), closes [#19108](vitejs/vite#19108)
-   fix: don't resolve URL starting with double slash ([#19059](vitejs/vite#19059)) ([35942cd](vitejs/vite@35942cd)), closes [#19059](vitejs/vite#19059)
-   fix: ensure `server.close()` only called once ([#19204](vitejs/vite#19204)) ([db81c2d](vitejs/vite@db81c2d)), closes [#19204](vitejs/vite#19204)
-   fix: resolve.conditions in ResolvedConfig was `defaultServerConditions` ([#19174](vitejs/vite#19174)) ([ad75c56](vitejs/vite@ad75c56)), closes [#19174](vitejs/vite#19174)
-   fix: tree shake stringified JSON imports ([#19189](vitejs/vite#19189)) ([f2aed62](vitejs/vite@f2aed62)), closes [#19189](vitejs/vite#19189)
-   fix: use shared sigterm callback ([#19203](vitejs/vite#19203)) ([47039f4](vitejs/vite@47039f4)), closes [#19203](vitejs/vite#19203)
-   fix(deps): update all non-major dependencies ([#19098](vitejs/vite#19098)) ([8639538](vitejs/vite@8639538)), closes [#19098](vitejs/vite#19098)
-   fix(optimizer): use correct default install state path for yarn PnP ([#19119](vitejs/vite#19119)) ([e690d8b](vitejs/vite@e690d8b)), closes [#19119](vitejs/vite#19119)
-   fix(types): improve `ESBuildOptions.include / exclude` type to allow `readonly (string | RegExp)[]`  ([ea53e70](vitejs/vite@ea53e70)), closes [#19146](vitejs/vite#19146)
-   chore(deps): update dependency pathe to v2 ([#19139](vitejs/vite#19139)) ([71506f0](vitejs/vite@71506f0)), closes [#19139](vitejs/vite#19139)
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
feat: deps optimizer Esbuild Dependencies Optimization p3-minor-bug An edge case that only affects very specific usage (priority)
Projects
None yet
Development

Successfully merging this pull request may close these issues.

V6 regression: dependency optimizer pre-bundler did not re-run after lock file change
3 participants