-
Notifications
You must be signed in to change notification settings - Fork 27.8k
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
Change default typescript moduleResolution to bundler to match nextjs heuristics of using webpack/turbopack #75805
base: canary
Are you sure you want to change the base?
Conversation
… webpack/turbppack
Allow CI Workflow Run
Note: this should only be enabled once the PR is ready to go and can only be enabled by a maintainer |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Basically just completing #51957. Let's see what CI says.
Thank you.
Failing test suitesCommit: 097748a
Expand output● correct tsconfig.json defaults › should add
● correct tsconfig.json defaults › should not warn for
Read more about building and testing Next.js in contributing.md.
Expand output● next-dist-client-esm-import › should resolve ESM modules that have "next/dist/client" in their filename
Read more about building and testing Next.js in contributing.md.
Expand output● tsconfig.json verifier › Creates a default tsconfig.json when one is missing
● tsconfig.json verifier › Works with an empty tsconfig.json (docs)
● tsconfig.json verifier › Updates an existing tsconfig.json without losing comments
● tsconfig.json verifier › allows you to set commonjs module mode
● tsconfig.json verifier › allows you to set es2020 module mode
● tsconfig.json verifier › allows you to set target mode
● tsconfig.json verifier › allows you to set verbatimModuleSyntax true without adding isolatedModules
● tsconfig.json verifier › allows you to set verbatimModuleSyntax true via extends without adding isolatedModules
Read more about building and testing Next.js in contributing.md. |
Stats from current PRDefault Build (Increase detected
|
vercel/next.js canary | fuxingloh/next.js patch-module-resolution | Change | |
---|---|---|---|
buildDuration | 19s | 17.3s | N/A |
buildDurationCached | 16.2s | 13.5s | N/A |
nodeModulesSize | 393 MB | 393 MB | N/A |
nextStartRea..uration (ms) | 446ms | 447ms | N/A |
Client Bundles (main, webpack)
vercel/next.js canary | fuxingloh/next.js patch-module-resolution | Change | |
---|---|---|---|
5306-HASH.js gzip | 54.3 kB | 54.3 kB | N/A |
8276.HASH.js gzip | 169 B | 168 B | N/A |
8377-HASH.js gzip | 5.46 kB | 5.46 kB | N/A |
bccd1874-HASH.js gzip | 53 kB | 53 kB | ✓ |
framework-HASH.js gzip | 57.5 kB | 57.5 kB | N/A |
main-app-HASH.js gzip | 245 B | 246 B | N/A |
main-HASH.js gzip | 34.6 kB | 34.5 kB | N/A |
webpack-HASH.js gzip | 1.71 kB | 1.71 kB | N/A |
Overall change | 53 kB | 53 kB | ✓ |
Legacy Client Bundles (polyfills)
vercel/next.js canary | fuxingloh/next.js patch-module-resolution | Change | |
---|---|---|---|
polyfills-HASH.js gzip | 39.4 kB | 39.4 kB | ✓ |
Overall change | 39.4 kB | 39.4 kB | ✓ |
Client Pages
vercel/next.js canary | fuxingloh/next.js patch-module-resolution | Change | |
---|---|---|---|
_app-HASH.js gzip | 193 B | 193 B | ✓ |
_error-HASH.js gzip | 193 B | 193 B | ✓ |
amp-HASH.js gzip | 512 B | 510 B | N/A |
css-HASH.js gzip | 343 B | 342 B | N/A |
dynamic-HASH.js gzip | 1.84 kB | 1.84 kB | ✓ |
edge-ssr-HASH.js gzip | 265 B | 265 B | ✓ |
head-HASH.js gzip | 363 B | 362 B | N/A |
hooks-HASH.js gzip | 393 B | 392 B | N/A |
image-HASH.js gzip | 4.59 kB | 4.58 kB | N/A |
index-HASH.js gzip | 268 B | 268 B | ✓ |
link-HASH.js gzip | 2.35 kB | 2.35 kB | N/A |
routerDirect..HASH.js gzip | 328 B | 328 B | ✓ |
script-HASH.js gzip | 397 B | 397 B | ✓ |
withRouter-HASH.js gzip | 323 B | 326 B | N/A |
1afbb74e6ecf..834.css gzip | 106 B | 106 B | ✓ |
Overall change | 3.59 kB | 3.59 kB | ✓ |
Client Build Manifests
vercel/next.js canary | fuxingloh/next.js patch-module-resolution | Change | |
---|---|---|---|
_buildManifest.js gzip | 748 B | 747 B | N/A |
Overall change | 0 B | 0 B | ✓ |
Rendered Page Sizes
vercel/next.js canary | fuxingloh/next.js patch-module-resolution | Change | |
---|---|---|---|
index.html gzip | 522 B | 523 B | N/A |
link.html gzip | 538 B | 538 B | ✓ |
withRouter.html gzip | 518 B | 520 B | N/A |
Overall change | 538 B | 538 B | ✓ |
Edge SSR bundle Size
vercel/next.js canary | fuxingloh/next.js patch-module-resolution | Change | |
---|---|---|---|
edge-ssr.js gzip | 130 kB | 130 kB | N/A |
page.js gzip | 211 kB | 211 kB | N/A |
Overall change | 0 B | 0 B | ✓ |
Middleware size
vercel/next.js canary | fuxingloh/next.js patch-module-resolution | Change | |
---|---|---|---|
middleware-b..fest.js gzip | 676 B | 671 B | N/A |
middleware-r..fest.js gzip | 155 B | 156 B | N/A |
middleware.js gzip | 31.3 kB | 31.3 kB | N/A |
edge-runtime..pack.js gzip | 844 B | 844 B | ✓ |
Overall change | 844 B | 844 B | ✓ |
Next Runtimes
vercel/next.js canary | fuxingloh/next.js patch-module-resolution | Change | |
---|---|---|---|
app-page-exp...dev.js gzip | 394 kB | 394 kB | ✓ |
app-page-exp..prod.js gzip | 132 kB | 132 kB | ✓ |
app-page-tur..prod.js gzip | 145 kB | 145 kB | ✓ |
app-page-tur..prod.js gzip | 141 kB | 141 kB | ✓ |
app-page.run...dev.js gzip | 381 kB | 381 kB | ✓ |
app-page.run..prod.js gzip | 129 kB | 129 kB | ✓ |
app-route-ex...dev.js gzip | 39.3 kB | 39.3 kB | ✓ |
app-route-ex..prod.js gzip | 25.6 kB | 25.6 kB | ✓ |
app-route-tu..prod.js gzip | 25.6 kB | 25.6 kB | ✓ |
app-route-tu..prod.js gzip | 25.4 kB | 25.4 kB | ✓ |
app-route.ru...dev.js gzip | 40.9 kB | 40.9 kB | ✓ |
app-route.ru..prod.js gzip | 25.4 kB | 25.4 kB | ✓ |
dist_client_...dev.js gzip | 356 B | 356 B | ✓ |
dist_client_...dev.js gzip | 349 B | 349 B | ✓ |
pages-api-tu..prod.js gzip | 9.69 kB | 9.69 kB | ✓ |
pages-api.ru...dev.js gzip | 11.8 kB | 11.8 kB | ✓ |
pages-api.ru..prod.js gzip | 9.68 kB | 9.68 kB | ✓ |
pages-turbo...prod.js gzip | 21.9 kB | 21.9 kB | ✓ |
pages.runtim...dev.js gzip | 31.5 kB | 31.5 kB | ✓ |
pages.runtim..prod.js gzip | 21.9 kB | 21.9 kB | ✓ |
server.runti..prod.js gzip | 60.6 kB | 60.6 kB | ✓ |
Overall change | 1.67 MB | 1.67 MB | ✓ |
build cache Overall increase ⚠️
vercel/next.js canary | fuxingloh/next.js patch-module-resolution | Change | |
---|---|---|---|
0.pack gzip | 2.11 MB | 2.11 MB | N/A |
index.pack gzip | 75.4 kB | 76.4 kB | |
Overall change | 75.4 kB | 76.4 kB |
Diff details
Diff for main-HASH.js
Diff too large to display
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Can you take care of updating the remaining tests?
I fix a few more that are obvious to me, but I don't have a proper setup so I'm gonna stop here. |
Piggybacking on top of #51957
I believe the default generated
tsconfig.json
module resolution should be bundler for better DevEx and typescript language server compatibility—matching nextjs heuristics of using webpack/turbopack.I started a new NextJS project manually (nextra to be precise) instead of using
create-next-app
, ranpnpm run dev
and got an TS error/warning. The typescript language server was complaining that it doesn't understand the import semantics:I ditched the manual setup and instead used
create-next-app
to set it up. I saw thetsconfig.json
provided increate-next-app
was different from the one created by "We detected TypeScript in your project and created a".