Skip to content

[Skills] next-cache-components-optimizer: clarify private-cache scope rule#94113

Merged
gaojude merged 2 commits into
canaryfrom
codex/cc-instant-nav-skill-friction-fixes
May 27, 2026
Merged

[Skills] next-cache-components-optimizer: clarify private-cache scope rule#94113
gaojude merged 2 commits into
canaryfrom
codex/cc-instant-nav-skill-friction-fixes

Conversation

@gaojude
Copy link
Copy Markdown
Contributor

@gaojude gaojude commented May 25, 2026

Agent friction report flagged three gaps in the instant-nav loop's third-lever guidance:

  • "on the I/O function" wasn't precise enough. The directive needs to enclose the cookies() / headers() / searchParams read, not whatever function does the downstream fetch. When those are split across frames (page reads cookies, helper does the fetch), the natural reading puts 'use cache: private' on the helper alone and the page stays dynamic. Compiles fine, types fine — only runtime tells you.
  • The doc says private-cache results live in the browser only, never on the server. Skill didn't mention this, and without it the runtime-prefetch combo doesn't really make sense (why would link-visibility resolve a server-keyed cache?).
  • Verify recipe said "after-shot must visibly differ." Identical shots can also mean no I/O resolved either time — stale TLS sockets, DB unreachable, etc. Added a check-logs-first guard before iterating on code shape.

Also a separate gotcha bullet in SKILL.md: dev doesn't fire prefetch traffic at all (see packages/next/src/client/components/links.ts:247), so the network tab won't tell you whether your code works. Use the cookie-locked SPA-nav recipe instead.

Skill markdown only. No runtime changes.

… guidance and verify-recipe failure modes

- instant-nav-loop.md: retarget the third-lever sentence from "the I/O
  function" to "the scope that encloses the request-API read"; add an
  explicit scope rule for the split-frame case (page reads cookies, helper
  does fetch); state that private-cache results are browser-resident only;
  add a guard noting that identical before/after screenshots can mean
  either lever-didn't-apply or no-I/O-resolved-either-time.
- SKILL.md: add gotcha that dev doesn't fire prefetch traffic; point at
  the cookie-locked SPA-nav recipe as the canonical primitive instead.
@gaojude gaojude changed the title [Skills] next-cache-components-optimizer: tighten private-cache scope guidance and verify-recipe failure modes [Skills] next-cache-components-optimizer: clarify private-cache scope rule May 25, 2026
@gaojude gaojude requested a review from aurorascharff May 25, 2026 19:01
@gaojude gaojude marked this pull request as ready for review May 25, 2026 19:01
@github-actions
Copy link
Copy Markdown
Contributor

github-actions Bot commented May 25, 2026

Stats from current PR

🟢 1 improvement

Metric Canary PR Change Trend
node_modules Size 507 MB 507 MB 🟢 926 kB (0%) █████
📊 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) 779ms 780ms █▇▆▆▆
Cold (First Request) 1.198s 1.193s █▃▂▃▃
Warm (Listen) 812ms 812ms █▆▆▆▆
Warm (Ready in log) 778ms 780ms █▆▆▆▆
Warm (First Request) 583ms 582ms ▆▅▅▅▅
📦 Dev Server (Webpack) (Legacy)

📦 Dev Server (Webpack)

Metric Canary PR Change Trend
Cold (Listen) 810ms 810ms █████
Cold (Ready in log) 784ms 787ms ▇████
Cold (First Request) 3.189s 3.195s ▆▆▆▄▇
Warm (Listen) 811ms 811ms █████
Warm (Ready in log) 784ms 785ms ▇████
Warm (First Request) 3.220s 3.225s ▆▆▇▅▇

⚡ Production Builds

Metric Canary PR Change Trend
Fresh Build 4.717s 4.688s ▄▅▅▆▆
Cached Build 4.739s 4.724s ▆▆▅▆▇
📦 Production Builds (Webpack) (Legacy)

📦 Production Builds (Webpack)

Metric Canary PR Change Trend
Fresh Build 23.815s 23.727s █▆█▆█
Cached Build 23.933s 23.768s ███▆█
node_modules Size 507 MB 507 MB 🟢 926 kB (0%) █████
📦 Bundle Sizes

Bundle Sizes

⚡ Turbopack

Client

Main Bundles
Canary PR Change
008ypkwxhzol9.js gzip 151 B N/A -
04hm05ar7kldw.js gzip 5.73 kB N/A -
05pjmzkb6_bx2.js gzip 155 B N/A -
0cz1d0mv5g_q7.js gzip 39.4 kB 39.4 kB
0dj46kukqg96u.js gzip 13.9 kB N/A -
0dvitrl5zg37g.js gzip 8.82 kB N/A -
0gn57unzp9cj7.js gzip 156 B N/A -
0hgh7weswzeyc.js gzip 154 B N/A -
0n_jt34y59ek-.js gzip 156 B N/A -
0q8_3dusot1rk.js gzip 65.6 kB N/A -
0sf7ysou-72zd.js gzip 8.71 kB N/A -
0zt2vt-9glw4j.js gzip 156 B N/A -
13yi-ex_n8ps5.js gzip 156 B N/A -
157abun3hwc_s.js gzip 10.3 kB N/A -
1elt1qium-r2m.css gzip 115 B 115 B
1jpaub6y8xlfr.js gzip 2.3 kB N/A -
1ot0mvscrc_uf.js gzip 233 B N/A -
1vwk0543z0fpb.js gzip 7.61 kB N/A -
1web5rp_5ooxz.js gzip 71 kB N/A -
2_m3xv2uq3sjc.js gzip 1.46 kB N/A -
21fdvwgh64eqz.js gzip 153 B N/A -
22qvit7es5csn.js gzip 159 B N/A -
24y34mwgrkqp4.js gzip 8.78 kB N/A -
2c-fd4y1zozz8.js gzip 8.79 kB N/A -
2d7416h_xd36x.js gzip 8.71 kB N/A -
2jjk__fiybm3z.js gzip 169 B N/A -
2lyuhit6rn8fy.js gzip 9.44 kB N/A -
2q0gr8wfr3jwl.js gzip 8.77 kB 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
324onewq6pt5f.js gzip 155 B N/A -
39h0rj3rg3850.js gzip 50.7 kB N/A -
3c1jdxkzlb8oq.js gzip 12.9 kB N/A -
3inab2jybr4k9.js gzip 450 B N/A -
3jkm5tdjvaf_q.js gzip 13.1 kB N/A -
3kw5ih-u7m6yu.js gzip 154 B N/A -
3mt67agm5wp40.js gzip 10.6 kB N/A -
3oabm6bz3ucna.js gzip 159 B N/A -
3saabek4kohwi.js gzip 10 kB N/A -
4189xmby9yu1p.js gzip 13.6 kB N/A -
turbopack-01..n95f.js gzip 4.2 kB N/A -
turbopack-03..08mv.js gzip 4.2 kB N/A -
turbopack-0l..d4yd.js gzip 4.2 kB N/A -
turbopack-0t..tddl.js gzip 4.2 kB N/A -
turbopack-15.._7z6.js gzip 4.21 kB N/A -
turbopack-1i..twe9.js gzip 4.2 kB N/A -
turbopack-2h..pd3z.js gzip 4.2 kB N/A -
turbopack-2m..tjab.js gzip 4.2 kB N/A -
turbopack-30..4f3f.js gzip 4.2 kB N/A -
turbopack-38..xmc_.js gzip 4.2 kB N/A -
turbopack-3c..zl6e.js gzip 4.2 kB N/A -
turbopack-3p..5rc_.js gzip 4.18 kB N/A -
turbopack-3s..8uk3.js gzip 4.2 kB N/A -
turbopack-44..84hz.js gzip 4.2 kB N/A -
0_i7nqgx23st7.js gzip N/A 10 kB -
06puhytyxk31p.js gzip N/A 8.82 kB -
08nk339p9gvvz.js gzip N/A 157 B -
0f50yxs5dv2yk.js gzip N/A 70.9 kB -
0j_9aszpra-qr.js gzip N/A 13.9 kB -
0j42f9zonj0wd.js gzip N/A 13 kB -
0m34gln_kt4fg.js gzip N/A 5.73 kB -
0wlbdlk4_e4do.js gzip N/A 170 B -
15m8j3l4c3oy7.js gzip N/A 158 B -
1d638jq2r-pw8.js gzip N/A 155 B -
1g3q1ww01thnl.js gzip N/A 2.3 kB -
1hpx0u0fjqzuk.js gzip N/A 155 B -
1hraqxuiymq6v.js gzip N/A 8.79 kB -
1l9un1sl77287.js gzip N/A 1.46 kB -
1q5pzsmugt1sw.js gzip N/A 152 B -
2147zgtf14z-q.js gzip N/A 234 B -
23bz3xsg-5-1s.js gzip N/A 8.71 kB -
27441mytv7pbm.js gzip N/A 9.43 kB -
2cjkwjgm1zcfs.js gzip N/A 8.71 kB -
2cnvy9tswyud3.js gzip N/A 158 B -
2kqe5mpuqaajh.js gzip N/A 162 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 -
31i2t3cfybt1e.js gzip N/A 158 B -
32z0g980vfa1y.js gzip N/A 156 B -
34bczktl9n3gx.js gzip N/A 156 B -
34vcsc6938ixq.js gzip N/A 50.5 kB -
38npdmive1xa6.js gzip N/A 65.6 kB -
3f710q6kll2xn.js gzip N/A 7.61 kB -
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 -
3jj3ls-hi6740.js gzip N/A 156 B -
3mnawenie1flm.js gzip N/A 8.76 kB -
3ubsozlu6zs38.js gzip N/A 10.6 kB -
4371ttxpn0nn6.js gzip N/A 160 B -
43iwfqjnx1cy_.js gzip N/A 8.78 kB -
turbopack-0f..2xc-.js gzip N/A 4.2 kB -
turbopack-0x..rwp8.js gzip N/A 4.2 kB -
turbopack-0y..np0p.js gzip N/A 4.2 kB -
turbopack-0z..gytn.js gzip N/A 4.2 kB -
turbopack-1m..bjhk.js gzip N/A 4.2 kB -
turbopack-1s..s0ff.js gzip N/A 4.2 kB -
turbopack-2d..w2zz.js gzip N/A 4.18 kB -
turbopack-30..qx63.js gzip N/A 4.2 kB -
turbopack-3l..h25l.js gzip N/A 4.2 kB -
turbopack-3m..zp1q.js gzip N/A 4.2 kB -
turbopack-3p..1_v2.js gzip N/A 4.2 kB -
turbopack-3u..v5xe.js gzip N/A 4.2 kB -
turbopack-3u..ro77.js gzip N/A 4.2 kB -
turbopack-43..ze1i.js gzip N/A 4.21 kB -
Total 469 kB 469 kB ✅ -149 B

Server

Middleware
Canary PR Change
middleware-b..fest.js gzip 723 B 722 B
Total 723 B 722 B ✅ -1 B
Build Details
Build Manifests
Canary PR Change
_buildManifest.js gzip 434 B 435 B
Total 434 B 435 B ⚠️ +1 B

📦 Webpack

Client

Main Bundles
Canary PR Change
2258-HASH.js gzip 61.7 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.8 kB N/A -
framework-HASH.js gzip 59.5 kB 59.5 kB
main-app-HASH.js gzip 255 B 254 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.8 kB -
2596-HASH.js gzip N/A 5.63 kB -
34-HASH.js gzip N/A 61.4 kB -
5691.HASH.js gzip N/A 169 B -
9156-HASH.js gzip N/A 4.68 kB -
Total 236 kB 236 kB ✅ -366 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 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 277 kB 271 kB 🟢 5.84 kB (-2%)
Total 403 kB 397 kB ✅ -5.92 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.3 kB 44.8 kB 🔴 +519 B (+1%)
edge-runtime..pack.js gzip 842 B 842 B
Total 45.9 kB 46.4 kB ⚠️ +518 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.51 MB 4.49 MB 🟢 19 kB (0%)
index.pack gzip 114 kB 114 kB
index.pack.old gzip 114 kB 115 kB
Total 4.74 MB 4.72 MB ✅ -17.5 kB

🔄 Shared (bundler-independent)

Runtimes
Canary PR Change
app-page-exp...dev.js gzip 352 kB 351 kB
app-page-exp..prod.js gzip 196 kB 195 kB
app-page-tur...dev.js gzip 351 kB 350 kB
app-page-tur..prod.js gzip 195 kB 194 kB
app-page-tur...dev.js gzip 348 kB 347 kB
app-page-tur..prod.js gzip 193 kB 192 kB
app-page.run...dev.js gzip 348 kB 347 kB
app-page.run..prod.js gzip 194 kB 193 kB
app-route-ex...dev.js gzip 77.6 kB 77.6 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.2 kB 77.2 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.4 kB 39.4 kB
server.runti..prod.js gzip 63.1 kB 63.1 kB
use-cache-pr...dev.js gzip 69.9 kB 69.7 kB
use-cache-pr...dev.js gzip 69.9 kB 69.7 kB
use-cache-pr...dev.js gzip 68.3 kB 68 kB
use-cache-pr...dev.js gzip 68.2 kB 68 kB
Total 3.38 MB 3.37 MB ✅ -8.51 kB
📝 Changed Files (13 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
  • use-cache-pr..ntime.dev.js
  • use-cache-pr..ntime.dev.js
  • use-cache-pr..ntime.dev.js
  • use-cache-pr..ntime.dev.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

use-cache-pr..ntime.dev.js

Diff too large to display

use-cache-pr..ntime.dev.js

Diff too large to display

use-cache-pr..ntime.dev.js

Diff too large to display

use-cache-pr..ntime.dev.js

Diff too large to display

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

Commit: d8596ed

@github-actions
Copy link
Copy Markdown
Contributor

github-actions Bot commented May 25, 2026

Tests Passed

Commit: d8596ed

@gaojude gaojude merged commit 7941e38 into canary May 27, 2026
299 of 302 checks passed
@gaojude gaojude deleted the codex/cc-instant-nav-skill-friction-fixes branch May 27, 2026 17:56
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

None yet

Projects

None yet

Development

Successfully merging this pull request may close these issues.

2 participants