Skip to content

switch our test benchmark runs to release-with-assertions#94538

Merged
lukesandberg merged 9 commits into
canaryfrom
run_test_bench_without_lto
Jun 17, 2026
Merged

switch our test benchmark runs to release-with-assertions#94538
lukesandberg merged 9 commits into
canaryfrom
run_test_bench_without_lto

Conversation

@lukesandberg

@lukesandberg lukesandberg commented Jun 7, 2026

Copy link
Copy Markdown
Contributor

In ci when testing our benchmarks use our test profile release-with-assertions

This avoids an expensive lto step and ensures that our tests run with debug asserts.

I noticed that our workflow for 'test cargo benches' was very slow and a lot of that time was the build presumably due to lto overheads across so many benchmark binaries.

Compare:

Of course doing this revealed a few things

  • a birthday paradox panic in one of the persistence tests
  • some 'top level read' errors to address in the benchmarks and in the turbopack-cli server used for some benchmarks.

And finally, that the persistence tests are just extremely slow in test mode due to their initialization overhead (populating >1GB dbs), so that harness is rewritten to remove some variants and also to reduce max sizes in test mode

lukesandberg commented Jun 7, 2026

Copy link
Copy Markdown
Contributor Author

This stack of pull requests is managed by Graphite. Learn more about stacking.

@github-actions

github-actions Bot commented Jun 7, 2026

Copy link
Copy Markdown
Contributor

Stats from current PR

🔴 1 regression

Metric Canary PR Change Trend
Webpack Build Time (cached) 22.864s 23.401s 🔴 +537ms (+2%) ▇▅▄▆▇
📊 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) 760ms 761ms █████
Cold (Ready in log) 720ms 725ms ▇▇▆██
Cold (First Request) 1.146s 1.130s ▃▃▁▆█
Warm (Listen) 760ms 761ms █████
Warm (Ready in log) 719ms 721ms ▇▇▆██
Warm (First Request) 533ms 540ms ▅▄▁▇█
📦 Dev Server (Webpack) (Legacy)

📦 Dev Server (Webpack)

Metric Canary PR Change Trend
Cold (Listen) 709ms 711ms █████
Cold (Ready in log) 705ms 714ms ▇▇▇██
Cold (First Request) 3.058s 3.028s ▃▃▃▅▄
Warm (Listen) 709ms 760ms █████
Warm (Ready in log) 707ms 722ms ▇▇▇██
Warm (First Request) 3.056s 3.098s ▃▃▂▆▅

⚡ Production Builds

Metric Canary PR Change Trend
Fresh Build 4.754s 4.820s ▄▄▃▆█
Cached Build 4.793s 4.801s ▅▅▄▆█
📦 Production Builds (Webpack) (Legacy)

📦 Production Builds (Webpack)

Metric Canary PR Change Trend
Fresh Build 23.047s 23.024s █▅▄▅▆
Cached Build 22.864s 23.401s 🔴 +537ms (+2%) ▇▅▄▆▇
node_modules Size 512 MB 512 MB ▁▁▁▁▁
📦 Bundle Sizes

Bundle Sizes

⚡ Turbopack

Client

Main Bundles
Canary PR Change
01n68n8hhw5d_.js gzip 13.1 kB N/A -
02fz8lc6lybwb.js gzip 8.74 kB N/A -
075v0txxwen3_.js gzip 8.69 kB N/A -
08qm2nv6b_bbg.js gzip 158 B N/A -
0bb0vtp8dwsez.js gzip 450 B N/A -
0cz1d0mv5g_q7.js gzip 39.4 kB 39.4 kB
0mzjk-l98-o4b.js gzip 8.69 kB N/A -
0nxqz3q165m2l.js gzip 220 B N/A -
0pgydobf3vp0v.js gzip 8.74 kB N/A -
17h18zxt1915l.js gzip 1.46 kB N/A -
1bog81b1r3wr0.js gzip 9.45 kB N/A -
1elt1qium-r2m.css gzip 115 B 115 B
1i2_t1t81sbfn.js gzip 8.75 kB N/A -
1na0_mmowbzs4.js gzip 159 B N/A -
1nhcwsgfs5uqo.js gzip 9.99 kB N/A -
1pnlu5cagannf.js gzip 157 B N/A -
1us1yz4bql16v.js gzip 156 B N/A -
1x6vwv_ughfks.js gzip 65.6 kB N/A -
24r3mqx043s1y.js gzip 2.29 kB N/A -
26_4sf9hsqwo_.js gzip 52.4 kB N/A -
2clhqgth_afv8.js gzip 14.1 kB N/A -
2h98__d0aurpy.js gzip 12.9 kB N/A -
2i4g8qufm2arm.js gzip 10.6 kB N/A -
2nmq00u7cp37o.js gzip 8.79 kB N/A -
2o68f29iz8se2.js gzip 155 B N/A -
2owwc32a184nj.js gzip 152 B N/A -
2psd6_tif2qd9.js gzip 8.76 kB N/A -
2q7l440iv0b0n.js gzip 71 kB N/A -
2v4we8c_tktt-.js gzip 8.77 kB N/A -
3_1z8xdb2wu3_.js gzip 168 B N/A -
30q1j6lp1v3kk.js gzip 157 B N/A -
36ga78_9t08s2.js gzip 154 B N/A -
3hvpa2qug_4fr.js gzip 10.3 kB N/A -
3j3cslom066yc.js gzip 154 B N/A -
3ja-0alumk7z6.js gzip 156 B N/A -
3k5ce5pdeq26d.js gzip 153 B N/A -
3o75tf9xee9m5.js gzip 156 B N/A -
3rrtpnfw4h5e3.js gzip 5.72 kB N/A -
41095c-3_661x.js gzip 7.61 kB N/A -
414gsyd6ou0pb.js gzip 13.6 kB N/A -
turbopack-00..7nay.js gzip 3.52 kB N/A -
turbopack-0n..8sj7.js gzip 3.51 kB N/A -
turbopack-0u..5dhu.js gzip 3.51 kB N/A -
turbopack-0v..j0y9.js gzip 3.52 kB N/A -
turbopack-16..qpaf.js gzip 3.51 kB N/A -
turbopack-16..ko-6.js gzip 3.51 kB N/A -
turbopack-1o..w3ju.js gzip 3.51 kB N/A -
turbopack-29..hqv1.js gzip 3.51 kB N/A -
turbopack-2k..feaf.js gzip 3.51 kB N/A -
turbopack-2r..d8-0.js gzip 3.53 kB N/A -
turbopack-2r..uf7p.js gzip 3.51 kB N/A -
turbopack-39..s8b1.js gzip 3.5 kB N/A -
turbopack-3n..l0eo.js gzip 3.52 kB N/A -
turbopack-3w..xjgv.js gzip 3.52 kB N/A -
00tc16j5-eos9.js gzip N/A 1.46 kB -
02p2ama1hlxmp.js gzip N/A 12.9 kB -
03io7is1t5cd3.js gzip N/A 8.73 kB -
08yno6ed95-ct.js gzip N/A 8.69 kB -
09b7oi-jqaf0x.js gzip N/A 9.45 kB -
0elucsckb5jyr.js gzip N/A 8.77 kB -
0h3m0umsrtrru.js gzip N/A 157 B -
0o4m28ane260o.js gzip N/A 8.79 kB -
0o55_hk5l0ti-.js gzip N/A 157 B -
122ftuoqex5iz.js gzip N/A 157 B -
12rflpz3d10gs.js gzip N/A 156 B -
15xk07h-3v67s.js gzip N/A 71 kB -
19ju263c3-7c0.js gzip N/A 8.76 kB -
19pha0jjv7gqr.js gzip N/A 10.3 kB -
1hxq8fabuvoyt.js gzip N/A 161 B -
1i-mnyosv91cb.js gzip N/A 65.6 kB -
1iz7h6teklujn.js gzip N/A 5.72 kB -
1joe_q6qtgyke.js gzip N/A 153 B -
1kna9flh9acx-.js gzip N/A 154 B -
1lto102wnfl0p.js gzip N/A 168 B -
1xsdodfl0lozp.js gzip N/A 161 B -
26_rf4ulm-leq.js gzip N/A 8.68 kB -
265ltytw3myvh.js gzip N/A 13.6 kB -
2cwy_mx2smfa6.js gzip N/A 7.61 kB -
2f1m1eeybbw5g.js gzip N/A 156 B -
2xmpbcdnhigkh.js gzip N/A 8.73 kB -
2y747lzh8px6i.js gzip N/A 156 B -
2yxw5i7p8hz7-.js gzip N/A 156 B -
3_q86lxh6w8wo.js gzip N/A 9.98 kB -
30h_m0irj-q6p.js gzip N/A 221 B -
33tw1kv4ibs96.js gzip N/A 52.4 kB -
36_07upqn74xc.js gzip N/A 2.29 kB -
38c63ct4i1cy7.js gzip N/A 449 B -
3bxtggll2q95f.js gzip N/A 13.1 kB -
3i42jz3a2rqgo.js gzip N/A 14.1 kB -
3lb-k_lttc22r.js gzip N/A 10.6 kB -
3w5f--6_y4m2r.js gzip N/A 8.75 kB -
44nh54zwjy-4_.js gzip N/A 156 B -
turbopack-06..i73t.js gzip N/A 3.51 kB -
turbopack-1_..u724.js gzip N/A 3.51 kB -
turbopack-12..yh75.js gzip N/A 3.51 kB -
turbopack-1x..1z4e.js gzip N/A 3.51 kB -
turbopack-1z..avyt.js gzip N/A 3.51 kB -
turbopack-2h..6qdp.js gzip N/A 3.51 kB -
turbopack-2k..7bi_.js gzip N/A 3.52 kB -
turbopack-2n..iveo.js gzip N/A 3.5 kB -
turbopack-2y..7upz.js gzip N/A 3.51 kB -
turbopack-30..oy0w.js gzip N/A 3.51 kB -
turbopack-3c..okri.js gzip N/A 3.53 kB -
turbopack-3e..38o4.js gzip N/A 3.51 kB -
turbopack-3x..ytrm.js gzip N/A 3.51 kB -
turbopack-45..yqkl.js gzip N/A 3.51 kB -
Total 461 kB 461 kB ✅ -21 B

Server

Middleware
Canary PR Change
middleware-b..fest.js gzip 729 B 729 B
Total 729 B 729 B
Build Details
Build Manifests
Canary PR Change
_buildManifest.js gzip 432 B 428 B
Total 432 B 428 B ✅ -4 B

📦 Webpack

Client

Main Bundles
Canary PR Change
2486.HASH.js gzip 169 B N/A -
3146-HASH.js gzip 62.3 kB N/A -
39fcf99b-HASH.js gzip 62.9 kB N/A -
8443-HASH.js gzip 4.68 kB N/A -
9431-HASH.js gzip 5.62 kB N/A -
framework-HASH.js gzip 59.8 kB 59.8 kB
main-app-HASH.js gzip 255 B 253 B
main-HASH.js gzip 39.3 kB 39.8 kB 🔴 +438 B (+1%)
webpack-HASH.js gzip 1.68 kB 1.68 kB
6105-HASH.js gzip N/A 5.63 kB -
764.HASH.js gzip N/A 169 B -
8898-HASH.js gzip N/A 61.7 kB -
9597-HASH.js gzip N/A 4.65 kB -
e1ccab69-HASH.js gzip N/A 62.9 kB -
Total 237 kB 237 kB ✅ -136 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 182 B
css-HASH.js gzip 335 B 335 B
dynamic-HASH.js gzip 1.8 kB 1.8 kB
edge-ssr-HASH.js gzip 255 B 254 B
head-HASH.js gzip 351 B 349 B
hooks-HASH.js gzip 384 B 384 B
image-HASH.js gzip 580 B 581 B
index-HASH.js gzip 259 B 259 B
link-HASH.js gzip 2.49 kB 2.49 kB
routerDirect..HASH.js gzip 319 B 319 B
script-HASH.js gzip 386 B 386 B
withRouter-HASH.js gzip 315 B 313 B
1afbb74e6ecf..834.css gzip 106 B 106 B
Total 7.96 kB 7.95 kB ✅ -6 B

Server

Edge SSR
Canary PR Change
edge-ssr.js gzip 126 kB 127 kB
page.js gzip 281 kB 282 kB
Total 408 kB 408 kB ⚠️ +931 B
Middleware
Canary PR Change
middleware-b..fest.js gzip 616 B 618 B
middleware-r..fest.js gzip 156 B 155 B
middleware.js gzip 44.8 kB 44.9 kB
edge-runtime..pack.js gzip 842 B 842 B
Total 46.4 kB 46.5 kB ⚠️ +110 B
Build Details
Build Manifests
Canary PR Change
_buildManifest.js gzip 719 B 719 B
Total 719 B 719 B
Build Cache
Canary PR Change
0.pack gzip 4.59 MB 4.58 MB 🟢 8.27 kB (0%)
index.pack gzip 113 kB 113 kB
index.pack.old gzip 115 kB 114 kB
Total 4.82 MB 4.81 MB ✅ -9.36 kB

🔄 Shared (bundler-independent)

Runtimes
Canary PR Change
app-page-exp...dev.js gzip 359 kB 359 kB
app-page-exp..prod.js gzip 198 kB 198 kB
app-page-tur...dev.js gzip 359 kB 359 kB
app-page-tur..prod.js gzip 198 kB 198 kB
app-page-tur...dev.js gzip 355 kB 355 kB
app-page-tur..prod.js gzip 196 kB 196 kB
app-page.run...dev.js gzip 356 kB 356 kB
app-page.run..prod.js gzip 196 kB 196 kB
app-route-ex...dev.js gzip 78.8 kB 78.8 kB
app-route-ex..prod.js gzip 53.3 kB 53.3 kB
app-route-tu...dev.js gzip 78.8 kB 78.8 kB
app-route-tu..prod.js gzip 53.3 kB 53.3 kB
app-route-tu...dev.js gzip 78.4 kB 78.4 kB
app-route-tu..prod.js gzip 53.1 kB 53.1 kB
app-route.ru...dev.js gzip 78.4 kB 78.4 kB
app-route.ru..prod.js gzip 53.1 kB 53.1 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 45 kB 45 kB
pages-api-tu..prod.js gzip 33.8 kB 33.8 kB
pages-api.ru...dev.js gzip 45 kB 45 kB
pages-api.ru..prod.js gzip 33.8 kB 33.8 kB
pages-turbo....dev.js gzip 54.5 kB 54.5 kB
pages-turbo...prod.js gzip 39.4 kB 39.4 kB
pages.runtim...dev.js gzip 54.5 kB 54.5 kB
pages.runtim..prod.js gzip 39.4 kB 39.4 kB
server.runti..prod.js gzip 64.9 kB 64.9 kB
use-cache-pr...dev.js gzip 71 kB 71 kB
use-cache-pr...dev.js gzip 71 kB 71 kB
use-cache-pr...dev.js gzip 69.3 kB 69.3 kB
use-cache-pr...dev.js gzip 69.3 kB 69.3 kB
Total 3.43 MB 3.43 MB
📎 Tarball URL
https://vercel-packages.vercel.app/next/commits/2518afba06bdf4e5f3bc95e02e49681e659e2c8c/next

Commit: 2518afb

@github-actions

github-actions Bot commented Jun 7, 2026

Copy link
Copy Markdown
Contributor

Tests Passed

Commit: 2518afb

@lukesandberg lukesandberg marked this pull request as ready for review June 7, 2026 16:32
@lukesandberg lukesandberg requested a review from bgw June 7, 2026 16:32
@lukesandberg lukesandberg force-pushed the run_test_bench_without_lto branch from e8b410b to a9756f7 Compare June 8, 2026 00:40
Comment thread turbopack/crates/turbopack-tracing/benches/node_file_trace.rs
@lukesandberg lukesandberg marked this pull request as draft June 8, 2026 14:20
Comment thread turbopack/crates/turbo-persistence/benches/mod.rs Outdated
@lukesandberg lukesandberg force-pushed the run_test_bench_without_lto branch 2 times, most recently from 68efe24 to dd6a1c2 Compare June 15, 2026 22:12
@lukesandberg lukesandberg marked this pull request as ready for review June 15, 2026 23:17
@lukesandberg lukesandberg requested a review from bgw June 15, 2026 23:19
Comment thread turbopack/crates/turbo-persistence/benches/mod.rs
Comment thread turbopack/crates/turbopack-trace-server/src/reader/mod.rs Outdated
Under release-with-assertions (debug-assertions on), the dev server tripped
debug_assert_not_in_top_level_task by reading task outputs eventually
consistently from top-level run_once tasks, panicking worker threads and
hanging the turbopack-cli benchmark.

- Make IssueReporter::report_issues a plain async method (not a turbo-task)
  that takes pre-collected PlainIssues; collect them in a new collect_issues
  operation read strongly consistently in handle_issues. Mark ConsoleUi::new
  root so the reporter can be resolved strongly consistently.
- Apply content-source side effects via a new apply_side_effects_operation
  read strongly consistently instead of awaiting each apply() at the top level.
- Compute the initial HMR version in initial_version_operation and read the
  update-stream content strongly consistently in UpdateStream::new.
Replace the implicit `--bench` argv detection (IS_TEST_MODE) with an
explicit LARGE_DB env var. The benches now scale down by default for both
`cargo bench` and `cargo test --benches`; set LARGE_DB to run the full
(large) sizes.
@lukesandberg lukesandberg enabled auto-merge (squash) June 17, 2026 15:31
@lukesandberg lukesandberg merged commit 723c062 into canary Jun 17, 2026
130 checks passed
@lukesandberg lukesandberg deleted the run_test_bench_without_lto branch June 17, 2026 16:05
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