Skip to content

Turbopack: Enable server HMR by default for app pages#91476

Merged
wbinnssmith merged 1 commit into
canaryfrom
wbinnssmith/server-hmr-default
Mar 16, 2026
Merged

Turbopack: Enable server HMR by default for app pages#91476
wbinnssmith merged 1 commit into
canaryfrom
wbinnssmith/server-hmr-default

Conversation

@wbinnssmith

@wbinnssmith wbinnssmith commented Mar 16, 2026

Copy link
Copy Markdown
Member

This enables server HMR (formally, this is called server fast refresh) by default for app router pages. For now, it's still disabled for routes and middleware even with app router.

  • Replaces --experimental-server-fast-refresh with --no-server-fast-refresh to opt out

  • Updates telemetry to record feature.serverFastRefreshDisabled when the disable flag is passed

  • Verify next dev enables server HMR by default (Turbopack, app dir, non-edge routes)

  • Verify next dev --no-server-fast-refresh disables it

  • CI

…ext dev` with Turbopack. Previously it required opting in with `--experimental-server-fast-refresh`.

- Replaces `--experimental-server-fast-refresh` with `--no-server-fast-refresh` to opt out
- Updates telemetry to record `feature.serverFastRefreshDisabled` when the disable flag is passed

- [ ] Verify `next dev` enables server HMR by default (Turbopack, app dir, non-edge routes)
- [ ] Verify `next dev --no-server-fast-refresh` disables it
- CI
@nextjs-bot

nextjs-bot commented Mar 16, 2026

Copy link
Copy Markdown
Contributor

Failing test suites

Commit: c6017da | About building and testing Next.js

pnpm test-start-turbo test/production/graceful-shutdown/index.test.ts (turbopack) (job)

  • Graceful Shutdown > production (standalone mode) > should not accept new requests during shutdown cleanup > should stop accepting new requests when shutting down (DD)
Expand output

● Graceful Shutdown › production (standalone mode) › should not accept new requests during shutdown cleanup › should stop accepting new requests when shutting down

expect(received).toEqual(expected) // deep equality

- Expected  - 1
+ Received  + 1

  Array [
-   143,
    null,
+   "SIGTERM",
  ]

  227 |
  228 |         // App finally shuts down with signal-based exit code (128 + 15 for SIGTERM)
> 229 |         expect(await appKilledPromise).toEqual([143, null])
      |                                        ^
  230 |         expect(app.exitCode).toBe(143)
  231 |       })
  232 |     })

  at Object.toEqual (production/graceful-shutdown/index.test.ts:229:40)

pnpm test-start test/production/app-dir/metadata-static-route-cache/metadata-static-route-cache.test.ts (job)

  • app dir - metadata static routes cache > should generate different content after replace the static metadata file (DD)
Expand output

● app dir - metadata static routes cache › should generate different content after replace the static metadata file

next already started

  63 |   public async start(options: { skipBuild?: boolean } = {}) {
  64 |     if (this.childProcess) {
> 65 |       throw new Error('next already started')
     |             ^
  66 |     }
  67 |
  68 |     this._cliOutput = ''

  at NextStartInstance.start (lib/next-modes/next-start.ts:65:13)
  at Object.start (production/app-dir/metadata-static-route-cache/metadata-static-route-cache.test.ts:17:16)

pnpm test-start-turbo test/production/deterministic-build/deployment-id.test.ts (turbopack) (job)

  • deterministic build - changing deployment id > build output API - standard builder > should produce identical build outputs even when changing deployment id (DD)
Expand output

● deterministic build - changing deployment id › build output API - standard builder › should produce identical build outputs even when changing deployment id

can not run export while server is running, use next.stop() first

  251 |   ) {
  252 |     if (this.childProcess) {
> 253 |       throw new Error(
      |             ^
  254 |         `can not run export while server is running, use next.stop() first`
  255 |       )
  256 |     }

  at NextStartInstance.build (lib/next-modes/next-start.ts:253:13)
  at build (production/deterministic-build/deployment-id.test.ts:125:22)
  at Object.runTest (production/deterministic-build/deployment-id.test.ts:262:36)

@wbinnssmith wbinnssmith changed the title Server-side Fast Refresh (server HMR) is now enabled by default in next dev with Turbopack. Previously it required opting in with --experimental-server-fast-refresh. Turbopack: Enable server HMR by default Mar 16, 2026
@wbinnssmith wbinnssmith changed the title Turbopack: Enable server HMR by default Turbopack: Enable server HMR by default for app pages Mar 16, 2026
@codspeed-hq

codspeed-hq Bot commented Mar 16, 2026

Copy link
Copy Markdown

Merging this PR will not alter performance

✅ 17 untouched benchmarks
⏩ 3 skipped benchmarks1


Comparing wbinnssmith/server-hmr-default (c6017da) with canary (672b02b)

Open in CodSpeed

Footnotes

  1. 3 benchmarks were skipped, so the baseline results were used instead. If they were deleted from the codebase, click here and archive them to remove them from the performance reports.

@nextjs-bot

Copy link
Copy Markdown
Contributor

Stats from current PR

✅ No significant changes detected

📊 All Metrics
📖 Metrics Glossary

Dev Server Metrics:

  • Listen = TCP port starts accepting connections
  • First Request = HTTP server returns successful response
  • Cold = Fresh build (no cache)
  • Warm = With cached build artifacts

Build Metrics:

  • Fresh = Clean build (no .next directory)
  • Cached = With existing .next directory

Change Thresholds:

  • Time: Changes < 50ms AND < 10%, OR < 2% are insignificant
  • Size: Changes < 1KB AND < 1% are insignificant
  • All other changes are flagged to catch regressions

⚡ Dev Server

Metric Canary PR Change Trend
Cold (Listen) 455ms 455ms █▁▁▁▁
Cold (Ready in log) 437ms 439ms █▁▁▁▂
Cold (First Request) 1.191s 1.176s █▂▂▁▃
Warm (Listen) 456ms 457ms █▁▁▁▁
Warm (Ready in log) 444ms 443ms █▁▁▁▁
Warm (First Request) 350ms 344ms █▁▁▁▁
📦 Dev Server (Webpack) (Legacy)

📦 Dev Server (Webpack)

Metric Canary PR Change Trend
Cold (Listen) 455ms 455ms ▁█▁▁▃
Cold (Ready in log) 439ms 439ms ▃█▃▁▃
Cold (First Request) 1.976s 1.960s ▂█▂▁▂
Warm (Listen) 456ms 456ms ▁█▁▁▁
Warm (Ready in log) 439ms 438ms ▃█▃▁▃
Warm (First Request) 1.964s 1.969s ▂█▂▁▂

⚡ Production Builds

Metric Canary PR Change Trend
Fresh Build 3.753s 3.800s █▃▃▂▁
Cached Build 3.744s 3.788s █▃▂▂▁
📦 Production Builds (Webpack) (Legacy)

📦 Production Builds (Webpack)

Metric Canary PR Change Trend
Fresh Build 14.335s 14.350s ▁█▁▁▁
Cached Build 14.597s 14.668s ▁█▁▁▂
node_modules Size 483 MB 483 MB █████
📦 Bundle Sizes

Bundle Sizes

⚡ Turbopack

Client

Main Bundles
Canary PR Change
0_lpxhkyog9-9.js gzip 162 B N/A -
0.-r71sd1j_zb.js gzip 7.61 kB N/A -
0~dh.pe76tp4s.js gzip 154 B N/A -
0~lwfcrlb4v_9.css gzip 115 B 115 B
00h0nz7r436~l.js gzip 13.3 kB N/A -
010veokj5t9nf.js gzip 169 B N/A -
02ku7edzc_wf7.js gzip 450 B N/A -
03~yq9q893hmn.js gzip 39.4 kB 39.4 kB
034~ea1.fumud.js gzip 48.5 kB N/A -
06ifmqyzqzamf.js gzip 157 B N/A -
092lcb3fqrrf9.js gzip 8.52 kB N/A -
0aj~xs1l1g8tg.js gzip 8.53 kB N/A -
0eg78sqvyqa0_.js gzip 13.7 kB N/A -
0ehfdrc23-o0h.js gzip 154 B N/A -
0h35gmp9u328z.js gzip 8.54 kB N/A -
0h6fkavebp.iz.js gzip 8.47 kB N/A -
0i1_a9rimqo25.js gzip 70.8 kB N/A -
0ino_yf1k3h6k.js gzip 10.4 kB N/A -
0k.sixc712dq1.js gzip 10.1 kB N/A -
0kkm7tesfinr6.js gzip 12.9 kB N/A -
0moy~uao4dl.m.js gzip 9.19 kB N/A -
0n~bmvrddbhmi.js gzip 154 B N/A -
0q50rtpusjy90.js gzip 2.28 kB N/A -
0smgy2grrrlka.js gzip 8.58 kB N/A -
0sv1h.1~4785f.js gzip 156 B N/A -
0syjr-z700d-h.js gzip 163 B N/A -
0t1dzhdfh0txh.js gzip 215 B 215 B
0w_gs_7ptie.q.js gzip 156 B N/A -
0y0~bkd6ge6gu.js gzip 65.7 kB N/A -
0zid7o0-vupvp.js gzip 225 B N/A -
109-8lzwgo3p0.js gzip 158 B N/A -
11yo3xfd6b147.js gzip 12.9 kB N/A -
13.84hqxl_1p7.js gzip 9.76 kB N/A -
14ob4-.af1o4f.js gzip 154 B N/A -
1554wr-t7p6z-.js gzip 8.55 kB N/A -
15tjst79~qy3_.js gzip 1.46 kB N/A -
15z_v00ne4ud0.js gzip 8.47 kB N/A -
16yzjq-v.qe0c.js gzip 156 B N/A -
17d_m3p4j9w6r.js gzip 5.62 kB N/A -
17yu~3yiu7d2m.js gzip 8.52 kB N/A -
1808zda6e6e_u.js gzip 160 B N/A -
turbopack-0d..8tpw.js gzip 4.17 kB N/A -
turbopack-0f..9a0w.js gzip 4.16 kB N/A -
turbopack-0i..zgu_.js gzip 4.16 kB N/A -
turbopack-0j..a72m.js gzip 4.16 kB N/A -
turbopack-0k..0-f4.js gzip 4.16 kB N/A -
turbopack-0n..f5~n.js gzip 4.16 kB N/A -
turbopack-0o..0-9y.js gzip 4.14 kB N/A -
turbopack-0q..m0x3.js gzip 4.16 kB N/A -
turbopack-0r..qsv_.js gzip 4.16 kB N/A -
turbopack-0y..4sn_.js gzip 4.16 kB N/A -
turbopack-14...pe_.js gzip 4.16 kB N/A -
turbopack-15..dibb.js gzip 4.16 kB N/A -
turbopack-16..ranj.js gzip 4.16 kB N/A -
turbopack-17..76x..js gzip 4.16 kB N/A -
012y56ntzw0t5.js gzip N/A 157 B -
02dx9nc6vmlnb.js gzip N/A 48.4 kB -
03t__~.5lvgeu.js gzip N/A 5.62 kB -
044nffvczz1qm.js gzip N/A 70.8 kB -
04d6ll75jqx3r.js gzip N/A 9.19 kB -
0583exyh-yhc7.js gzip N/A 9.76 kB -
05b07nana~4_..js gzip N/A 10.1 kB -
072lv63r8dcz~.js gzip N/A 8.58 kB -
07k6dcww5s4pu.js gzip N/A 13.7 kB -
09e5u94edfzfq.js gzip N/A 155 B -
0a2l7vlz.o~r3.js gzip N/A 155 B -
0ar1~bwpezfgw.js gzip N/A 13.3 kB -
0c99mq1ez2bke.js gzip N/A 450 B -
0cq-cmde_ws6u.js gzip N/A 8.47 kB -
0fwf102w10o9~.js gzip N/A 8.52 kB -
0g8327dwv5atv.js gzip N/A 157 B -
0gtmn.q_j1v5r.js gzip N/A 10.4 kB -
0kj2h8~mdlx-1.js gzip N/A 154 B -
0l~38duq8a8dv.js gzip N/A 65.7 kB -
0l4d~z7ixj3wz.js gzip N/A 12.9 kB -
0lfnovet50w7k.js gzip N/A 167 B -
0nclq9z6yzzm5.js gzip N/A 1.46 kB -
0nemy_y2k67sk.js gzip N/A 153 B -
0nzumcogektg7.js gzip N/A 8.55 kB -
0ptp-zz6dyc7o.js gzip N/A 157 B -
0s.c-cn5eebrx.js gzip N/A 8.47 kB -
0t2z1.qeavu-v.js gzip N/A 156 B -
0tna7lg6q4zne.js gzip N/A 12.9 kB -
0votdfxr5fb5u.js gzip N/A 2.28 kB -
0xkuhv202qqhu.js gzip N/A 7.6 kB -
0y-uo6cjo9tid.js gzip N/A 162 B -
0ykl9bs_qj.5..js gzip N/A 8.52 kB -
0zfen0tnxp4gh.js gzip N/A 8.55 kB -
10wkq1h9jzkg..js gzip N/A 225 B -
10xnkv79ab92c.js gzip N/A 155 B -
149ndfh8zfcaz.js gzip N/A 8.53 kB -
14dt9u0vmrrzt.js gzip N/A 156 B -
16brhmoc1r.wt.js gzip N/A 161 B -
turbopack-04..9nwf.js gzip N/A 4.16 kB -
turbopack-07..v.g8.js gzip N/A 4.16 kB -
turbopack-07..jpcn.js gzip N/A 4.16 kB -
turbopack-07..kqj5.js gzip N/A 4.16 kB -
turbopack-0f.._ski.js gzip N/A 4.16 kB -
turbopack-0f..frw~.js gzip N/A 4.16 kB -
turbopack-0h..j304.js gzip N/A 4.16 kB -
turbopack-0o..aso3.js gzip N/A 4.16 kB -
turbopack-0r..ud62.js gzip N/A 4.16 kB -
turbopack-0v..-.xx.js gzip N/A 4.18 kB -
turbopack-0v.._uuo.js gzip N/A 4.16 kB -
turbopack-12..mwvp.js gzip N/A 4.14 kB -
turbopack-12..v_26.js gzip N/A 4.16 kB -
turbopack-17..jaa_.js gzip N/A 4.16 kB -
Total 463 kB 463 kB ✅ -15 B

Server

Middleware
Canary PR Change
middleware-b..fest.js gzip 712 B 711 B
Total 712 B 711 B ✅ -1 B
Build Details
Build Manifests
Canary PR Change
_buildManifest.js gzip 433 B 432 B
Total 433 B 432 B ✅ -1 B

📦 Webpack

Client

Main Bundles
Canary PR Change
5528-HASH.js gzip 5.54 kB N/A -
6280-HASH.js gzip 60.3 kB N/A -
6335.HASH.js gzip 169 B N/A -
912-HASH.js gzip 4.59 kB N/A -
e8aec2e4-HASH.js gzip 62.7 kB N/A -
framework-HASH.js gzip 59.7 kB 59.7 kB
main-app-HASH.js gzip 256 B 254 B
main-HASH.js gzip 39.2 kB 39.2 kB
webpack-HASH.js gzip 1.68 kB 1.68 kB
262-HASH.js gzip N/A 4.59 kB -
2889.HASH.js gzip N/A 169 B -
5602-HASH.js gzip N/A 5.55 kB -
6948ada0-HASH.js gzip N/A 62.7 kB -
9544-HASH.js gzip N/A 60.9 kB -
Total 234 kB 235 kB ⚠️ +653 B
Polyfills
Canary PR Change
polyfills-HASH.js gzip 39.4 kB 39.4 kB
Total 39.4 kB 39.4 kB
Pages
Canary PR Change
_app-HASH.js gzip 194 B 194 B
_error-HASH.js gzip 183 B 180 B 🟢 3 B (-2%)
css-HASH.js gzip 331 B 330 B
dynamic-HASH.js gzip 1.81 kB 1.81 kB
edge-ssr-HASH.js gzip 256 B 256 B
head-HASH.js gzip 351 B 352 B
hooks-HASH.js gzip 384 B 383 B
image-HASH.js gzip 580 B 581 B
index-HASH.js gzip 260 B 260 B
link-HASH.js gzip 2.51 kB 2.51 kB
routerDirect..HASH.js gzip 320 B 319 B
script-HASH.js gzip 386 B 386 B
withRouter-HASH.js gzip 315 B 315 B
1afbb74e6ecf..834.css gzip 106 B 106 B
Total 7.98 kB 7.98 kB ✅ -1 B

Server

Edge SSR
Canary PR Change
edge-ssr.js gzip 125 kB 125 kB
page.js gzip 269 kB 268 kB
Total 393 kB 393 kB ✅ -300 B
Middleware
Canary PR Change
middleware-b..fest.js gzip 614 B 615 B
middleware-r..fest.js gzip 156 B 155 B
middleware.js gzip 43.8 kB 43.9 kB
edge-runtime..pack.js gzip 842 B 842 B
Total 45.5 kB 45.5 kB ⚠️ +66 B
Build Details
Build Manifests
Canary PR Change
_buildManifest.js gzip 715 B 718 B
Total 715 B 718 B ⚠️ +3 B
Build Cache
Canary PR Change
0.pack gzip 4.26 MB 4.26 MB 🟢 4.67 kB (0%)
index.pack gzip 109 kB 109 kB
index.pack.old gzip 108 kB 108 kB
Total 4.48 MB 4.48 MB ✅ -3.76 kB

🔄 Shared (bundler-independent)

Runtimes
Canary PR Change
app-page-exp...dev.js gzip 333 kB 333 kB
app-page-exp..prod.js gzip 181 kB 181 kB
app-page-tur...dev.js gzip 332 kB 332 kB
app-page-tur..prod.js gzip 181 kB 181 kB
app-page-tur...dev.js gzip 329 kB 329 kB
app-page-tur..prod.js gzip 179 kB 179 kB
app-page.run...dev.js gzip 329 kB 329 kB
app-page.run..prod.js gzip 179 kB 179 kB
app-route-ex...dev.js gzip 76 kB 76 kB
app-route-ex..prod.js gzip 51.7 kB 51.7 kB
app-route-tu...dev.js gzip 76 kB 76 kB
app-route-tu..prod.js gzip 51.7 kB 51.7 kB
app-route-tu...dev.js gzip 75.6 kB 75.6 kB
app-route-tu..prod.js gzip 51.5 kB 51.5 kB
app-route.ru...dev.js gzip 75.6 kB 75.6 kB
app-route.ru..prod.js gzip 51.5 kB 51.5 kB
dist_client_...dev.js gzip 324 B 324 B
dist_client_...dev.js gzip 326 B 326 B
dist_client_...dev.js gzip 318 B 318 B
dist_client_...dev.js gzip 317 B 317 B
pages-api-tu...dev.js gzip 43.3 kB 43.3 kB
pages-api-tu..prod.js gzip 33 kB 33 kB
pages-api.ru...dev.js gzip 43.3 kB 43.3 kB
pages-api.ru..prod.js gzip 33 kB 33 kB
pages-turbo....dev.js gzip 52.7 kB 52.7 kB
pages-turbo...prod.js gzip 38.6 kB 38.6 kB
pages.runtim...dev.js gzip 52.7 kB 52.7 kB
pages.runtim..prod.js gzip 38.6 kB 38.6 kB
server.runti..prod.js gzip 62.4 kB 62.4 kB
Total 2.95 MB 2.95 MB ⚠️ +2 B
📎 Tarball URL
https://vercel-packages.vercel.app/next/commits/267a1b2f1e7202036ebb3fc5e40df2f8e9bacae4/next

@wbinnssmith wbinnssmith marked this pull request as ready for review March 16, 2026 23:21

@andrewimm andrewimm left a comment

Copy link
Copy Markdown
Contributor

Choose a reason for hiding this comment

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

spent forever trying to figure out how the option was getting sent to the actual dev server, before I realized that Commander has special casing for options that start with "no-"

@wbinnssmith wbinnssmith merged commit 0f867bb into canary Mar 16, 2026
282 of 287 checks passed
@wbinnssmith wbinnssmith deleted the wbinnssmith/server-hmr-default branch March 16, 2026 23:37
AlessioGr added a commit to payloadcms/payload that referenced this pull request Mar 26, 2026
…ext.js 16.2+ compatibility (#16074)

[Next.js 16.2 enables server fast refresh by
default](vercel/next.js#91476), which breaks
Payload's HMR - config changes don't propagate until a full server
restart. Adding `--no-server-fast-refresh` to the dev command fixes it.
This is a temporary workaround until the upstream issue is resolved.

---
- To see the specific tasks where the Asana app for GitHub is being
used, see below:
  - https://app.asana.com/0/0/1213814287069601
@github-actions github-actions Bot locked as resolved and limited conversation to collaborators Mar 31, 2026
Sign up for free to subscribe to this conversation on GitHub. Already have an account? Sign in.

Labels

Projects

None yet

Development

Successfully merging this pull request may close these issues.

3 participants