Skip to content

(1/1) Cover missing workspace layout offline navigation misses#93676

Closed
feedthejim wants to merge 1 commit into
feedthejim/offline-navigations-missing-parallel-slot-stressfrom
feedthejim/offline-navigations-missing-workspace-layout-stress
Closed

(1/1) Cover missing workspace layout offline navigation misses#93676
feedthejim wants to merge 1 commit into
feedthejim/offline-navigations-missing-parallel-slot-stressfrom
feedthejim/offline-navigations-missing-workspace-layout-stress

Conversation

@feedthejim

Copy link
Copy Markdown
Contributor

Stack position

This is a test-only stress slice on top of #93675, which covers the destructive missing activity parallel-slot case for the Slack-like workspace shell fixture introduced in #93673.

Stack context:

  1. (1/1) Cover missing route record offline navigation misses #93670 covers a missing persisted route record.
  2. (1/1) Cover missing head record offline navigation misses #93671 covers a missing persisted head record.
  3. (1/1) Cover missing page segment offline navigation misses #93672 covers a missing persisted page segment record.
  4. (1/1) Cover workspace shell offline navigation replay #93673 proves the complex workspace shell can replay when all required route, segment, slot, and head records are present.
  5. (1/1) Cover missing default slot offline navigation misses #93674 covers a missing required default sidebar slot record.
  6. (1/1) Cover missing parallel slot offline navigation misses #93675 covers a missing required activity parallel-slot record.
  7. This PR covers a missing required nested workspace layout record.

What changed

Adds one focused production e2e for offlineNavigations with Cache Components:

  • online-loads /docs and waits for the offline navigation service worker
  • prefetches /docs/workspace/acme/channel/general/thread/123
  • verifies the durable route record, nested workspace layout segment, page segment, default sidebar slot, activity parallel slot, and head record were persisted
  • deletes the exact URL entry so the hard reload must use route/segment reconstruction
  • deletes only the /workspace/$d$workspace layout segment record
  • stops the server, puts the browser offline, and hard-loads the workspace route
  • asserts the fallback boot emits router-cache-reconstruction-miss with missing-segment, falls back to visible missing-entry UI, and does not render the workspace page

Why this is separate

The previous workspace-shell stress slices cover the route record, head record, page segment, default slot, and parallel slot. This PR isolates the parent layout case so reviewers can verify that the replay path treats a missing layout as fatal instead of stitching child page or slot records under an absent workspace shell.

This continues the advanced e2e stress matrix in .private-investigation/offline-navigations-production-plan.md: after this PR, the route-graph missing-record matrix only has the root layout row left among the core shell records.

Reviewer focus

Please focus on the targeting and false-positive guards:

  • the test asserts /workspace/$d$workspace exists before deleting it
  • the exact URL entry is deleted first, so this cannot pass through direct exact-URL replay
  • the route, page segment, default sidebar slot, activity parallel slot, and head records remain present after the nested layout is deleted
  • the expected result is a structured missing-segment reconstruction miss plus visible missing-entry UI, not a partially rendered workspace page

Intentionally not covered here

Still pending in later stress slices:

  • missing root layout record
  • metadata/head style ordering integrity on successful replay
  • app/session or workspace-scope partitioning

Verification

  • pnpm prettier --with-node-modules --ignore-path .prettierignore --write test/production/app-dir/offline-navigations/offline-navigations.test.ts
  • npx eslint --config eslint.config.mjs --fix test/production/app-dir/offline-navigations/offline-navigations.test.ts
  • git diff --check -- test/production/app-dir/offline-navigations/offline-navigations.test.ts
  • NEXT_SKIP_ISOLATE=1 pnpm test-start-turbo test/production/app-dir/offline-navigations/offline-navigations.test.ts -t "misses a workspace shell route when a required nested layout record is missing during fallback boot"
  • pnpm test-start-webpack test/production/app-dir/offline-navigations/offline-navigations.test.ts -t "misses a workspace shell route when a required nested layout record is missing during fallback boot"

@github-actions

github-actions Bot commented May 8, 2026

Copy link
Copy Markdown
Contributor

Tests Passed

Commit: 87d2701

@github-actions

github-actions Bot commented May 8, 2026

Copy link
Copy Markdown
Contributor

Stats from current PR

🔴 1 regression

Metric Canary PR Change Trend
node_modules Size 505 MB 508 MB 🔴 +2.69 MB (+1%) █████
📊 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) 812ms 812ms ▃▅▅▁▅
Cold (Ready in log) 773ms 777ms ▄▁▅▇█
Cold (First Request) 1.199s 1.205s ▄▁▄▄▆
Warm (Listen) 812ms 812ms ▃▆▃▁▆
Warm (Ready in log) 775ms 775ms ▄▁▅▆█
Warm (First Request) 576ms 579ms ▄▁▅▇█
📦 Dev Server (Webpack) (Legacy)

📦 Dev Server (Webpack)

Metric Canary PR Change Trend
Cold (Listen) 811ms 811ms █████
Cold (Ready in log) 785ms 788ms ▇████
Cold (First Request) 3.157s 3.167s ▄▇▇█▆
Warm (Listen) 810ms 811ms █████
Warm (Ready in log) 786ms 784ms ▇███▇
Warm (First Request) 3.186s 3.162s ▄▆▇█▅

⚡ Production Builds

Metric Canary PR Change Trend
Fresh Build 4.744s 4.770s ▃▂█▇▅
Cached Build 4.791s 4.793s ▃▃▃▆▅
📦 Production Builds (Webpack) (Legacy)

📦 Production Builds (Webpack)

Metric Canary PR Change Trend
Fresh Build 23.549s 23.997s ▃█▆▅▆
Cached Build 23.639s 23.847s ▂█▄▄▅
node_modules Size 505 MB 508 MB 🔴 +2.69 MB (+1%) █████
📦 Bundle Sizes

Bundle Sizes

⚡ Turbopack

Client

Main Bundles
Canary PR Change
0-_gc56kf9tfo.js gzip 154 B N/A -
047ad-p-61fjn.js gzip 156 B N/A -
04hm05ar7kldw.js gzip 5.73 kB N/A -
0714gv_gbisrs.js gzip 70.8 kB N/A -
0cz1d0mv5g_q7.js gzip 39.4 kB 39.4 kB
0dvitrl5zg37g.js gzip 8.82 kB N/A -
0sf7ysou-72zd.js gzip 8.71 kB N/A -
11ny9t-iyn9yw.js gzip 154 B N/A -
157abun3hwc_s.js gzip 10.3 kB N/A -
1bhal_i5byhy7.js gzip 162 B N/A -
1elt1qium-r2m.css gzip 115 B 115 B
1jfwzy3ri2pyr.js gzip 154 B N/A -
1jj68jv9537mc.js gzip 13.8 kB N/A -
1jpaub6y8xlfr.js gzip 2.3 kB N/A -
1ot0mvscrc_uf.js gzip 233 B N/A -
2_m3xv2uq3sjc.js gzip 1.46 kB N/A -
24y34mwgrkqp4.js gzip 8.78 kB N/A -
28lrkt28g7fpx.js gzip 155 B N/A -
2c-fd4y1zozz8.js gzip 8.79 kB N/A -
2d7416h_xd36x.js gzip 8.71 kB N/A -
2extn3odmmem_.js gzip 12.9 kB N/A -
2fyhyy7niw9r6.js gzip 7.61 kB N/A -
2lyuhit6rn8fy.js gzip 9.44 kB N/A -
2q0gr8wfr3jwl.js gzip 8.77 kB N/A -
2qmtk0zius6fd.js gzip 157 B N/A -
2t9e75oz6r0zp.js gzip 8.76 kB N/A -
2uku_olcn15b7.js gzip 8.79 kB N/A -
30r8mm-46bdqy.js gzip 220 B 220 B
3c03ks8ic59bl.js gzip 160 B N/A -
3c03yiy5ds-h6.js gzip 65.5 kB N/A -
3d0blqiuhma_c.js gzip 155 B N/A -
3dd42mxmevz1t.js gzip 49.5 kB N/A -
3inab2jybr4k9.js gzip 450 B N/A -
3jkm5tdjvaf_q.js gzip 13.1 kB N/A -
3mix8ikliw_bj.js gzip 169 B N/A -
3mt67agm5wp40.js gzip 10.6 kB N/A -
3saabek4kohwi.js gzip 10 kB N/A -
3x_ftwxjtc4jr.js gzip 152 B N/A -
3x0-g47j0wg_t.js gzip 154 B N/A -
40pcd44z40i4a.js gzip 156 B N/A -
4189xmby9yu1p.js gzip 13.6 kB N/A -
turbopack-02..93y4.js gzip 4.2 kB N/A -
turbopack-0c..i2y5.js gzip 4.18 kB N/A -
turbopack-0m..eii3.js gzip 4.2 kB N/A -
turbopack-0t..cm46.js gzip 4.2 kB N/A -
turbopack-13..1jkn.js gzip 4.2 kB N/A -
turbopack-1s..s1zo.js gzip 4.21 kB N/A -
turbopack-23..--2_.js gzip 4.2 kB N/A -
turbopack-28..zluk.js gzip 4.2 kB N/A -
turbopack-2a..kxyc.js gzip 4.2 kB N/A -
turbopack-2s..sur4.js gzip 4.2 kB N/A -
turbopack-2z..x5dq.js gzip 4.19 kB N/A -
turbopack-3h..65h_.js gzip 4.2 kB N/A -
turbopack-3s..rdjl.js gzip 4.2 kB N/A -
turbopack-3y..gfl4.js gzip 4.2 kB N/A -
0_i7nqgx23st7.js gzip N/A 10 kB -
04kysrbwfzp5x.js gzip N/A 71.6 kB -
05e40c15cx1dd.js gzip N/A 7.61 kB -
06puhytyxk31p.js gzip N/A 8.82 kB -
0cgwxw9wez5uz.js gzip N/A 155 B -
0m34gln_kt4fg.js gzip N/A 5.73 kB -
0wjn_zvopg8j7.js gzip N/A 155 B -
1g3q1ww01thnl.js gzip N/A 2.3 kB -
1hraqxuiymq6v.js gzip N/A 8.79 kB -
1l9un1sl77287.js gzip N/A 1.46 kB -
1oj2783a6mjmk.js gzip N/A 153 B -
1tu42mhgspxaj.js gzip N/A 152 B -
2_n5io6i3e7-d.js gzip N/A 65.6 kB -
21-eavqb1k_36.js gzip N/A 13.9 kB -
2147zgtf14z-q.js gzip N/A 234 B -
23bz3xsg-5-1s.js gzip N/A 8.71 kB -
25m28ppgv1r-l.js gzip N/A 156 B -
25nu819x1bby_.js gzip N/A 53.7 kB -
27441mytv7pbm.js gzip N/A 9.43 kB -
2cjkwjgm1zcfs.js gzip N/A 8.71 kB -
2feeljlwn03ka.js gzip N/A 156 B -
2scd8zaoyb8md.js gzip N/A 8.79 kB -
2st_qs6p_9us0.js gzip N/A 13.1 kB -
2zo2exm1d8qj1.js gzip N/A 13.6 kB -
31gszfpoi49o_.js gzip N/A 157 B -
3g88fx8gbrpbb.js gzip N/A 159 B -
3hn75zuxly9az.js gzip N/A 10.3 kB -
3hqh7m128tvsn.js gzip N/A 8.77 kB -
3hqti_t-zy1x4.js gzip N/A 449 B -
3k_ox9mqvj991.js gzip N/A 162 B -
3lwd3rbxfr02f.js gzip N/A 157 B -
3mnawenie1flm.js gzip N/A 8.76 kB -
3sxqvx3vn2_or.js gzip N/A 155 B -
3ubsozlu6zs38.js gzip N/A 10.6 kB -
41_yhm_31fcf8.js gzip N/A 155 B -
41mf-x3mmsxae.js gzip N/A 12.9 kB -
41ovqpfyyufzz.js gzip N/A 168 B -
43iwfqjnx1cy_.js gzip N/A 8.78 kB -
turbopack-0g..-9g6.js gzip N/A 4.2 kB -
turbopack-0x..j0gn.js gzip N/A 4.18 kB -
turbopack-1b..n71_.js gzip N/A 4.2 kB -
turbopack-1e..hu78.js gzip N/A 4.2 kB -
turbopack-1g..7-n-.js gzip N/A 4.2 kB -
turbopack-1l..qd49.js gzip N/A 4.21 kB -
turbopack-1t..oruv.js gzip N/A 4.2 kB -
turbopack-2q..tzzk.js gzip N/A 4.2 kB -
turbopack-2s..khje.js gzip N/A 4.2 kB -
turbopack-31..xepd.js gzip N/A 4.2 kB -
turbopack-3q..wh7s.js gzip N/A 4.2 kB -
turbopack-3t..pfdy.js gzip N/A 4.2 kB -
turbopack-3y..qhsx.js gzip N/A 4.2 kB -
turbopack-43..rc4q.js gzip N/A 4.2 kB -
Total 468 kB 473 kB ⚠️ +4.93 kB

Server

Middleware
Canary PR Change
middleware-b..fest.js gzip 717 B 719 B
Total 717 B 719 B ⚠️ +2 B
Build Details
Build Manifests
Canary PR Change
_buildManifest.js gzip 429 B 433 B
Total 429 B 433 B ⚠️ +4 B

📦 Webpack

Client

Main Bundles
Canary PR Change
2258-HASH.js gzip 61.1 kB N/A -
2266-HASH.js gzip 4.69 kB N/A -
3317.HASH.js gzip 169 B N/A -
4866-HASH.js gzip 5.64 kB N/A -
9e302639-HASH.js gzip 62.7 kB N/A -
framework-HASH.js gzip 59.5 kB 59.5 kB
main-app-HASH.js gzip 255 B 256 B
main-HASH.js gzip 39.9 kB 39.9 kB
webpack-HASH.js gzip 1.68 kB 1.68 kB
175fd0fd-HASH.js gzip N/A 62.7 kB -
2596-HASH.js gzip N/A 5.63 kB -
34-HASH.js gzip N/A 65.8 kB -
5691.HASH.js gzip N/A 169 B -
9156-HASH.js gzip N/A 4.68 kB -
Total 236 kB 240 kB ⚠️ +4.7 kB
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 193 B 193 B
_error-HASH.js gzip 181 B 182 B
css-HASH.js gzip 334 B 332 B
dynamic-HASH.js gzip 1.79 kB 1.81 kB
edge-ssr-HASH.js gzip 255 B 255 B
head-HASH.js gzip 351 B 348 B
hooks-HASH.js gzip 385 B 384 B
image-HASH.js gzip 580 B 580 B
index-HASH.js gzip 257 B 259 B
link-HASH.js gzip 2.51 kB 2.52 kB
routerDirect..HASH.js gzip 318 B 319 B
script-HASH.js gzip 387 B 386 B
withRouter-HASH.js gzip 316 B 316 B
1afbb74e6ecf..834.css gzip 106 B 106 B
Total 7.97 kB 7.99 kB ⚠️ +19 B

Server

Edge SSR
Canary PR Change
edge-ssr.js gzip 126 kB 126 kB
page.js gzip 275 kB 273 kB
Total 401 kB 399 kB ✅ -1.71 kB
Middleware
Canary PR Change
middleware-b..fest.js gzip 617 B 616 B
middleware-r..fest.js gzip 155 B 155 B
middleware.js gzip 44.5 kB 44.9 kB
edge-runtime..pack.js gzip 842 B 842 B
Total 46.1 kB 46.5 kB ⚠️ +372 B
Build Details
Build Manifests
Canary PR Change
_buildManifest.js gzip 719 B 717 B
Total 719 B 717 B ✅ -2 B
Build Cache
Canary PR Change
0.pack gzip 4.45 MB 4.52 MB 🔴 +67.9 kB (+2%)
index.pack gzip 115 kB 116 kB 🔴 +1.3 kB (+1%)
index.pack.old gzip 114 kB 117 kB 🔴 +2.68 kB (+2%)
Total 4.68 MB 4.75 MB ⚠️ +71.9 kB

🔄 Shared (bundler-independent)

Runtimes
Canary PR Change
app-page-exp...dev.js gzip 349 kB 355 kB 🔴 +5.83 kB (+2%)
app-page-exp..prod.js gzip 194 kB 198 kB 🔴 +4.33 kB (+2%)
app-page-tur...dev.js gzip 349 kB 355 kB 🔴 +5.85 kB (+2%)
app-page-tur..prod.js gzip 194 kB 198 kB 🔴 +4.33 kB (+2%)
app-page-tur...dev.js gzip 345 kB 351 kB 🔴 +5.79 kB (+2%)
app-page-tur..prod.js gzip 192 kB 196 kB 🔴 +4.33 kB (+2%)
app-page.run...dev.js gzip 346 kB 352 kB 🔴 +5.78 kB (+2%)
app-page.run..prod.js gzip 192 kB 196 kB 🔴 +4.32 kB (+2%)
app-route-ex...dev.js gzip 77.5 kB 77.5 kB
app-route-ex..prod.js gzip 52.9 kB 52.9 kB
app-route-tu...dev.js gzip 77.6 kB 77.6 kB
app-route-tu..prod.js gzip 52.9 kB 52.9 kB
app-route-tu...dev.js gzip 77.2 kB 77.2 kB
app-route-tu..prod.js gzip 52.7 kB 52.7 kB
app-route.ru...dev.js gzip 77.1 kB 77.1 kB
app-route.ru..prod.js gzip 52.7 kB 52.7 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 44.3 kB 44.3 kB
pages-api-tu..prod.js gzip 33.8 kB 33.8 kB
pages-api.ru...dev.js gzip 44.3 kB 44.3 kB
pages-api.ru..prod.js gzip 33.7 kB 33.7 kB
pages-turbo....dev.js gzip 53.7 kB 53.7 kB
pages-turbo...prod.js gzip 39.4 kB 39.4 kB
pages.runtim...dev.js gzip 53.6 kB 53.6 kB
pages.runtim..prod.js gzip 39.3 kB 39.3 kB
server.runti..prod.js gzip 63.2 kB 63.2 kB
use-cache-pr...dev.js gzip 69.7 kB 69.7 kB
use-cache-pr...dev.js gzip 69.7 kB 69.7 kB
use-cache-pr...dev.js gzip 68 kB 68 kB
use-cache-pr...dev.js gzip 68 kB 68 kB
Total 3.36 MB 3.4 MB ⚠️ +40.6 kB
📝 Changed Files (9 files)

Files with changes:

  • app-page-exp..ntime.dev.js
  • app-page-exp..time.prod.js
  • app-page-tur..ntime.dev.js
  • app-page-tur..time.prod.js
  • app-page-tur..ntime.dev.js
  • app-page-tur..time.prod.js
  • app-page.runtime.dev.js
  • app-page.runtime.prod.js
  • server.runtime.prod.js
View diffs
app-page-exp..ntime.dev.js
failed to diff
app-page-exp..time.prod.js
failed to diff
app-page-tur..ntime.dev.js
failed to diff
app-page-tur..time.prod.js
failed to diff
app-page-tur..ntime.dev.js
failed to diff
app-page-tur..time.prod.js
failed to diff
app-page.runtime.dev.js
failed to diff
app-page.runtime.prod.js
failed to diff
server.runtime.prod.js

Diff too large to display

📎 Tarball URL
https://vercel-packages.vercel.app/next/commits/87d27016c522d17399dc3fed85f7393d1d6670f3/next

Commit: 87d2701

@feedthejim

Copy link
Copy Markdown
Contributor Author

Closing this draft as part of the offline navigations first-usable restack.

The current review stack is the 25-PR sequence rooted at #93622, ending at #93656, with #93648 folded into PR 22 and the stress-only rows deferred into named P1/P2 owners. The branch is intentionally left intact so the coverage can be recovered or rebundled later.

Review guide: https://gist.github.com/feedthejim/b3d9fe26a7c05655fd57adcce371b93d

@feedthejim feedthejim closed this May 8, 2026
@github-actions github-actions Bot locked as resolved and limited conversation to collaborators May 23, 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.

1 participant