Skip to content

[world-vercel] Use v3 stream endpoint (supports transparent reconnect on timeout)#2424

Open
VaguelySerious wants to merge 2 commits into
mainfrom
peter/stream-read-v3
Open

[world-vercel] Use v3 stream endpoint (supports transparent reconnect on timeout)#2424
VaguelySerious wants to merge 2 commits into
mainfrom
peter/stream-read-v3

Conversation

@VaguelySerious

@VaguelySerious VaguelySerious commented Jun 15, 2026

Copy link
Copy Markdown
Member

Needs V3 stream API to be live on the server first.

Point the world-vercel live-stream reader (world.streams.get, used by run.getReadable()) at the v3 stream endpoint instead of v2. Writes, stream completion, and snapshot reads (chunks/info/list) stay on v2 — only the long-lived live read is affected.

Why

On the v3 endpoint the server errors the response body on a max-duration timeout (or a mid-stream connection drop) rather than closing it cleanly. That thrown error is exactly what the reconnecting reader (createReconnectingFramedStream) needs to resume from the next chunk via startIndex. On v2 the server closes cleanly, which the reader treats as end-of-stream — so today long-lived streams silently truncate at the server's 2-minute limit. This change makes object-stream reads (e.g. the AI chat UIMessageChunk stream) transparently survive the timeout.

The reconnecting reader already shipped (#2318 on main, #1847 on stable); it's been inert because the server never errored on timeout. This flips it on.

Point the world-vercel live-stream reader at the v3 stream endpoint. On a
max-duration timeout (or mid-stream connection drop) the v3 server errors
the response body rather than closing it cleanly, which is what lets the
reconnecting reader resume from the next chunk instead of treating the
timeout as end-of-stream. Writes, completion, and snapshot reads stay on v2.

Co-Authored-By: Claude Opus 4.8 <noreply@anthropic.com>
@changeset-bot

changeset-bot Bot commented Jun 15, 2026

Copy link
Copy Markdown

🦋 Changeset detected

Latest commit: 7b7f9d7

The changes in this PR will be included in the next version bump.

This PR includes changesets to release 17 packages
Name Type
@workflow/world-vercel Patch
@workflow/cli Patch
@workflow/core Patch
@workflow/web Patch
workflow Patch
@workflow/world-testing Patch
@workflow/builders Patch
@workflow/next Patch
@workflow/nitro Patch
@workflow/vitest Patch
@workflow/web-shared Patch
@workflow/astro Patch
@workflow/nest Patch
@workflow/rollup Patch
@workflow/sveltekit Patch
@workflow/vite Patch
@workflow/nuxt Patch

Not sure what this means? Click here to learn what changesets are.

Click here if you're a maintainer who wants to add another changeset to this PR

@vercel

vercel Bot commented Jun 15, 2026

Copy link
Copy Markdown
Contributor

The latest updates on your projects. Learn more about Vercel for GitHub.

Project Deployment Actions Updated (UTC)
example-nextjs-workflow-turbopack Ready Ready Preview, Comment Jun 15, 2026 1:16pm
example-nextjs-workflow-webpack Ready Ready Preview, Comment Jun 15, 2026 1:16pm
example-workflow Ready Ready Preview, Comment Jun 15, 2026 1:16pm
workbench-astro-workflow Ready Ready Preview, Comment Jun 15, 2026 1:16pm
workbench-express-workflow Ready Ready Preview, Comment Jun 15, 2026 1:16pm
workbench-fastify-workflow Ready Ready Preview, Comment Jun 15, 2026 1:16pm
workbench-hono-workflow Ready Ready Preview, Comment Jun 15, 2026 1:16pm
workbench-nitro-workflow Ready Ready Preview, Comment Jun 15, 2026 1:16pm
workbench-nuxt-workflow Ready Ready Preview, Comment Jun 15, 2026 1:16pm
workbench-sveltekit-workflow Ready Ready Preview, Comment Jun 15, 2026 1:16pm
workbench-tanstack-start-workflow Ready Ready Preview, Comment Jun 15, 2026 1:16pm
workbench-vite-workflow Ready Ready Preview, Comment Jun 15, 2026 1:16pm
workflow-docs Ready Ready Preview, Comment, Open in v0 Jun 15, 2026 1:16pm
workflow-swc-playground Ready Ready Preview, Comment Jun 15, 2026 1:16pm
workflow-tarballs Ready Ready Preview, Comment Jun 15, 2026 1:16pm
workflow-web Ready Ready Preview, Comment Jun 15, 2026 1:16pm

@github-actions

github-actions Bot commented Jun 15, 2026

Copy link
Copy Markdown
Contributor

📊 Benchmark Results

📈 Comparing against baseline from main branch. Green 🟢 = faster, Red 🔺 = slower.

workflow with no steps

💻 Local Development

World Framework Workflow Time Wall Time Overhead Samples vs Fastest
💻 Local 🥇 Nitro 0.041s (-11.4% 🟢) 1.007s (~) 0.966s 10 1.00x
💻 Local Express 0.042s (-1.2%) 1.006s (~) 0.964s 10 1.02x
🐘 Postgres Nitro 0.057s (-3.3%) 1.011s (~) 0.955s 10 1.37x
💻 Local Next.js (Turbopack) 0.059s (-6.3% 🟢) 1.007s (~) 0.948s 10 1.44x
🐘 Postgres Express 0.065s (+6.0% 🔺) 1.012s (~) 0.947s 10 1.58x
🐘 Postgres Next.js (Turbopack) 0.071s (+2.0%) 1.013s (~) 0.942s 10 1.73x

▲ Production (Vercel)

World Framework Workflow Time Wall Time Overhead Samples vs Fastest
▲ Vercel 🥇 Nitro 0.355s (-32.3% 🟢) 2.477s (+0.5%) 2.121s 10 1.00x
▲ Vercel Next.js (Turbopack) 0.397s (-26.7% 🟢) 2.430s (+10.8% 🔺) 2.032s 10 1.12x
▲ Vercel Express 0.406s (-32.5% 🟢) 2.401s (+7.7% 🔺) 1.995s 10 1.14x

🔍 Observability: Nitro | Next.js (Turbopack) | Express

workflow with 1 step

💻 Local Development

World Framework Workflow Time Wall Time Overhead Samples vs Fastest
💻 Local 🥇 Nitro 1.092s (~) 2.006s (~) 0.914s 10 1.00x
💻 Local Express 1.096s (~) 2.006s (~) 0.910s 10 1.00x
🐘 Postgres Nitro 1.109s (~) 2.010s (~) 0.902s 10 1.01x
🐘 Postgres Express 1.114s (+0.9%) 2.011s (~) 0.897s 10 1.02x
💻 Local Next.js (Turbopack) 1.132s (-1.1%) 2.006s (~) 0.874s 10 1.04x
🐘 Postgres Next.js (Turbopack) 1.168s (+2.4%) 2.010s (~) 0.842s 10 1.07x

▲ Production (Vercel)

World Framework Workflow Time Wall Time Overhead Samples vs Fastest
▲ Vercel 🥇 Next.js (Turbopack) 1.662s (-13.2% 🟢) 3.741s (+3.8%) 2.079s 10 1.00x
▲ Vercel Nitro 1.672s (-8.8% 🟢) 3.784s (+3.5%) 2.112s 10 1.01x
▲ Vercel Express 1.846s (-6.9% 🟢) 3.784s (+9.8% 🔺) 1.938s 10 1.11x

🔍 Observability: Next.js (Turbopack) | Nitro | Express

workflow with 10 sequential steps

💻 Local Development

World Framework Workflow Time Wall Time Overhead Samples vs Fastest
💻 Local 🥇 Express 10.527s (~) 11.023s (~) 0.496s 3 1.00x
🐘 Postgres Express 10.541s (~) 11.019s (~) 0.478s 3 1.00x
💻 Local Nitro 10.542s (~) 11.022s (~) 0.481s 3 1.00x
🐘 Postgres Nitro 10.557s (~) 11.018s (~) 0.460s 3 1.00x
💻 Local Next.js (Turbopack) 10.891s (+0.8%) 11.357s (+3.0%) 0.466s 3 1.03x
🐘 Postgres Next.js (Turbopack) 10.962s (+0.9%) 11.354s (+3.1%) 0.392s 3 1.04x

▲ Production (Vercel)

World Framework Workflow Time Wall Time Overhead Samples vs Fastest
▲ Vercel 🥇 Express 13.938s (-16.4% 🟢) 16.035s (-11.6% 🟢) 2.097s 2 1.00x
▲ Vercel Nitro 13.960s (-15.6% 🟢) 15.943s (-14.3% 🟢) 1.983s 2 1.00x
▲ Vercel Next.js (Turbopack) 14.064s (-19.7% 🟢) 16.001s (-15.6% 🟢) 1.937s 2 1.01x

🔍 Observability: Express | Nitro | Next.js (Turbopack)

workflow with 25 sequential steps

💻 Local Development

World Framework Workflow Time Wall Time Overhead Samples vs Fastest
💻 Local 🥇 Express 13.716s (~) 14.028s (~) 0.312s 5 1.00x
💻 Local Nitro 13.764s (~) 14.027s (~) 0.263s 5 1.00x
🐘 Postgres Express 13.815s (~) 14.019s (~) 0.203s 5 1.01x
🐘 Postgres Nitro 13.843s (~) 14.019s (~) 0.176s 5 1.01x
🐘 Postgres Next.js (Turbopack) 14.630s (+0.6%) 15.026s (~) 0.395s 4 1.07x
💻 Local Next.js (Turbopack) 14.707s (+1.8%) 15.282s (+1.7%) 0.575s 4 1.07x

▲ Production (Vercel)

World Framework Workflow Time Wall Time Overhead Samples vs Fastest
▲ Vercel 🥇 Nitro 23.885s (-20.6% 🟢) 26.012s (-17.9% 🟢) 2.127s 3 1.00x
▲ Vercel Express 23.994s (-23.5% 🟢) 27.571s (-15.0% 🟢) 3.577s 3 1.00x
▲ Vercel Next.js (Turbopack) 24.844s (+3.8%) 26.828s (+7.4% 🔺) 1.984s 3 1.04x

🔍 Observability: Nitro | Express | Next.js (Turbopack)

workflow with 50 sequential steps

💻 Local Development

World Framework Workflow Time Wall Time Overhead Samples vs Fastest
💻 Local 🥇 Express 12.441s (~) 13.025s (~) 0.584s 7 1.00x
💻 Local Nitro 12.481s (~) 13.025s (~) 0.543s 7 1.00x
🐘 Postgres Express 12.562s (+1.5%) 13.021s (~) 0.458s 7 1.01x
🐘 Postgres Nitro 12.654s (~) 13.018s (~) 0.364s 7 1.02x
💻 Local Next.js (Turbopack) 13.615s (-1.1%) 14.026s (~) 0.411s 7 1.09x
🐘 Postgres Next.js (Turbopack) 13.951s (+0.5%) 14.164s (~) 0.213s 7 1.12x

▲ Production (Vercel)

World Framework Workflow Time Wall Time Overhead Samples vs Fastest
▲ Vercel 🥇 Express 34.795s (+7.4% 🔺) 37.167s (+8.8% 🔺) 2.371s 3 1.00x
▲ Vercel Nitro 35.725s (+18.7% 🔺) 37.889s (+19.0% 🔺) 2.164s 3 1.03x
▲ Vercel Next.js (Turbopack) 39.066s (+28.2% 🔺) 41.381s (+29.8% 🔺) 2.315s 3 1.12x

🔍 Observability: Express | Nitro | Next.js (Turbopack)

Promise.all with 10 concurrent steps

💻 Local Development

World Framework Workflow Time Wall Time Overhead Samples vs Fastest
🐘 Postgres 🥇 Nitro 1.204s (~) 2.007s (~) 0.803s 15 1.00x
💻 Local Nitro 1.207s (-4.4%) 2.006s (~) 0.799s 15 1.00x
🐘 Postgres Express 1.209s (~) 2.007s (~) 0.798s 15 1.00x
💻 Local Express 1.284s (+6.4% 🔺) 2.006s (~) 0.722s 15 1.07x
🐘 Postgres Next.js (Turbopack) 1.299s (~) 2.009s (~) 0.709s 15 1.08x
💻 Local Next.js (Turbopack) 1.387s (-3.2%) 2.006s (-3.2%) 0.619s 15 1.15x

▲ Production (Vercel)

World Framework Workflow Time Wall Time Overhead Samples vs Fastest
▲ Vercel 🥇 Next.js (Turbopack) 2.361s (-18.2% 🟢) 3.824s (-11.1% 🟢) 1.463s 8 1.00x
▲ Vercel Express 2.402s (+4.9%) 3.882s (+10.1% 🔺) 1.480s 8 1.02x
▲ Vercel Nitro 2.787s (+18.3% 🔺) 4.648s (+18.9% 🔺) 1.861s 7 1.18x

🔍 Observability: Next.js (Turbopack) | Express | Nitro

Promise.all with 25 concurrent steps

💻 Local Development

World Framework Workflow Time Wall Time Overhead Samples vs Fastest
🐘 Postgres 🥇 Nitro 1.409s (+0.6%) 2.471s (-4.6%) 1.062s 13 1.00x
🐘 Postgres Express 1.412s (~) 2.395s (-12.5% 🟢) 0.983s 13 1.00x
🐘 Postgres Next.js (Turbopack) 1.639s (+5.7% 🔺) 2.315s (-7.7% 🟢) 0.676s 13 1.16x
💻 Local Express 1.733s (-7.3% 🟢) 2.006s (-6.3% 🟢) 0.273s 15 1.23x
💻 Local Next.js (Turbopack) 1.805s (-3.6%) 2.150s (+7.2% 🔺) 0.345s 14 1.28x
💻 Local Nitro 1.830s (-7.2% 🟢) 2.074s (-10.4% 🟢) 0.245s 15 1.30x

▲ Production (Vercel)

World Framework Workflow Time Wall Time Overhead Samples vs Fastest
▲ Vercel 🥇 Next.js (Turbopack) 3.897s (+38.6% 🔺) 5.686s (+43.6% 🔺) 1.790s 6 1.00x
▲ Vercel Express 4.129s (+13.6% 🔺) 5.633s (+7.3% 🔺) 1.504s 6 1.06x
▲ Vercel Nitro 4.229s (+44.5% 🔺) 6.115s (+36.8% 🔺) 1.886s 5 1.09x

🔍 Observability: Next.js (Turbopack) | Express | Nitro

Promise.all with 50 concurrent steps

💻 Local Development

World Framework Workflow Time Wall Time Overhead Samples vs Fastest
🐘 Postgres 🥇 Nitro 1.561s (-3.0%) 4.136s (+6.4% 🔺) 2.575s 8 1.00x
🐘 Postgres Express 1.773s (~) 4.135s (+6.3% 🔺) 2.362s 8 1.14x
🐘 Postgres Next.js (Turbopack) 4.194s (+13.0% 🔺) 4.731s (+10.0% 🔺) 0.536s 7 2.69x
💻 Local Next.js (Turbopack) 4.541s (-16.7% 🟢) 5.347s (-14.0% 🟢) 0.806s 6 2.91x
💻 Local Express 4.568s (-15.8% 🟢) 5.013s (-11.8% 🟢) 0.444s 6 2.93x
💻 Local Nitro 5.473s (+4.3%) 6.013s (+2.9%) 0.540s 5 3.51x

▲ Production (Vercel)

World Framework Workflow Time Wall Time Overhead Samples vs Fastest
▲ Vercel 🥇 Nitro 4.090s (-11.6% 🟢) 6.011s (-6.5% 🟢) 1.921s 5 1.00x
▲ Vercel Express 4.722s (+17.6% 🔺) 6.761s (+22.0% 🔺) 2.039s 5 1.15x
▲ Vercel Next.js (Turbopack) 4.785s (-7.7% 🟢) 6.306s (-3.9%) 1.521s 5 1.17x

🔍 Observability: Nitro | Express | Next.js (Turbopack)

Promise.race with 10 concurrent steps

💻 Local Development

World Framework Workflow Time Wall Time Overhead Samples vs Fastest
🐘 Postgres 🥇 Nitro 1.203s (~) 2.007s (~) 0.804s 15 1.00x
🐘 Postgres Express 1.228s (-1.6%) 2.008s (~) 0.779s 15 1.02x
🐘 Postgres Next.js (Turbopack) 1.295s (-0.5%) 2.008s (~) 0.713s 15 1.08x
💻 Local Next.js (Turbopack) 1.379s (~) 2.008s (~) 0.628s 15 1.15x
💻 Local Express 1.524s (~) 2.006s (~) 0.482s 15 1.27x
💻 Local Nitro 1.576s (~) 2.006s (~) 0.430s 15 1.31x

▲ Production (Vercel)

World Framework Workflow Time Wall Time Overhead Samples vs Fastest
▲ Vercel 🥇 Next.js (Turbopack) 2.273s (-8.2% 🟢) 3.768s (-1.5%) 1.496s 8 1.00x
▲ Vercel Express 2.409s (-9.5% 🟢) 4.008s (+2.3%) 1.599s 8 1.06x
▲ Vercel Nitro 2.422s (+10.2% 🔺) 3.845s (+0.9%) 1.423s 8 1.07x

🔍 Observability: Next.js (Turbopack) | Express | Nitro

Promise.race with 25 concurrent steps

💻 Local Development

World Framework Workflow Time Wall Time Overhead Samples vs Fastest
🐘 Postgres 🥇 Nitro 1.316s (+1.5%) 2.223s (-4.0%) 0.907s 14 1.00x
🐘 Postgres Express 1.422s (+6.2% 🔺) 2.317s (~) 0.895s 13 1.08x
🐘 Postgres Next.js (Turbopack) 1.516s (-0.6%) 2.152s (-7.1% 🟢) 0.637s 14 1.15x
💻 Local Next.js (Turbopack) 1.973s (-2.8%) 2.470s (-9.7% 🟢) 0.497s 13 1.50x
💻 Local Express 2.228s (-3.7%) 2.736s (-3.2%) 0.508s 11 1.69x
💻 Local Nitro 2.230s (+6.8% 🔺) 2.757s (+6.3% 🔺) 0.528s 12 1.69x

▲ Production (Vercel)

World Framework Workflow Time Wall Time Overhead Samples vs Fastest
▲ Vercel 🥇 Nitro 2.830s (-60.3% 🟢) 4.436s (-50.7% 🟢) 1.606s 7 1.00x
▲ Vercel Next.js (Turbopack) 3.222s (-13.4% 🟢) 4.776s (-7.4% 🟢) 1.553s 7 1.14x
▲ Vercel Express 3.447s (+15.6% 🔺) 5.332s (+14.4% 🔺) 1.884s 6 1.22x

🔍 Observability: Nitro | Next.js (Turbopack) | Express

Promise.race with 50 concurrent steps

💻 Local Development

World Framework Workflow Time Wall Time Overhead Samples vs Fastest
🐘 Postgres 🥇 Nitro 1.776s (+7.6% 🔺) 4.012s (~) 2.236s 8 1.00x
🐘 Postgres Express 1.844s (~) 3.887s (-9.5% 🟢) 2.044s 8 1.04x
🐘 Postgres Next.js (Turbopack) 2.915s (-16.6% 🟢) 3.762s (-17.9% 🟢) 0.847s 8 1.64x
💻 Local Next.js (Turbopack) 5.365s (-6.3% 🟢) 6.014s (-5.3% 🟢) 0.649s 6 3.02x
💻 Local Express 5.832s (-8.3% 🟢) 6.817s (~) 0.985s 5 3.28x
💻 Local Nitro 6.115s (+4.9%) 6.820s (+7.4% 🔺) 0.705s 5 3.44x

▲ Production (Vercel)

World Framework Workflow Time Wall Time Overhead Samples vs Fastest
▲ Vercel 🥇 Next.js (Turbopack) 4.057s (-35.8% 🟢) 6.558s (-16.6% 🟢) 2.500s 5 1.00x
▲ Vercel Express 4.067s (-20.9% 🟢) 6.025s (-24.5% 🟢) 1.958s 5 1.00x
▲ Vercel Nitro 4.272s (+6.7% 🔺) 6.447s (+17.0% 🔺) 2.175s 5 1.05x

🔍 Observability: Next.js (Turbopack) | Express | Nitro

workflow with 10 sequential data payload steps (10KB)

💻 Local Development

World Framework Workflow Time Wall Time Overhead Samples vs Fastest
🐘 Postgres 🥇 Nitro 0.576s (+1.0%) 1.006s (~) 0.430s 60 1.00x
🐘 Postgres Express 0.594s (+4.0%) 1.023s (-1.7%) 0.429s 59 1.03x
💻 Local Express 0.608s (+2.9%) 1.005s (~) 0.397s 60 1.06x
💻 Local Nitro 0.627s (+3.5%) 1.005s (~) 0.378s 60 1.09x
🐘 Postgres Next.js (Turbopack) 0.861s (+3.6%) 1.059s (+3.5%) 0.199s 57 1.49x
💻 Local Next.js (Turbopack) 0.881s (+0.6%) 1.021s (~) 0.140s 59 1.53x

▲ Production (Vercel)

World Framework Workflow Time Wall Time Overhead Samples vs Fastest
▲ Vercel 🥇 Express 6.340s (-12.0% 🟢) 8.307s (-7.1% 🟢) 1.968s 8 1.00x
▲ Vercel Nitro 6.899s (+23.8% 🔺) 8.649s (+12.2% 🔺) 1.750s 7 1.09x
▲ Vercel Next.js (Turbopack) 7.191s (-12.8% 🟢) 9.034s (-8.0% 🟢) 1.843s 7 1.13x

🔍 Observability: Express | Nitro | Next.js (Turbopack)

workflow with 25 sequential data payload steps (10KB)

💻 Local Development

World Framework Workflow Time Wall Time Overhead Samples vs Fastest
🐘 Postgres 🥇 Express 1.386s (+3.6%) 2.008s (-1.1%) 0.621s 45 1.00x
🐘 Postgres Nitro 1.437s (+3.1%) 2.053s (+1.1%) 0.615s 44 1.04x
💻 Local Nitro 1.521s (~) 2.006s (~) 0.485s 45 1.10x
💻 Local Express 1.523s (+0.9%) 2.006s (~) 0.483s 45 1.10x
🐘 Postgres Next.js (Turbopack) 2.035s (+3.4%) 2.440s (+10.8% 🔺) 0.405s 37 1.47x
💻 Local Next.js (Turbopack) 2.122s (+0.6%) 3.008s (~) 0.886s 30 1.53x

▲ Production (Vercel)

World Framework Workflow Time Wall Time Overhead Samples vs Fastest
▲ Vercel 🥇 Nitro 16.550s (-6.5% 🟢) 18.896s (-2.8%) 2.347s 5 1.00x
▲ Vercel Express 16.651s (-2.3%) 18.790s (+1.9%) 2.138s 5 1.01x
▲ Vercel Next.js (Turbopack) 16.689s (-3.0%) 19.101s (+0.9%) 2.412s 5 1.01x

🔍 Observability: Nitro | Express | Next.js (Turbopack)

workflow with 50 sequential data payload steps (10KB)

💻 Local Development

World Framework Workflow Time Wall Time Overhead Samples vs Fastest
🐘 Postgres 🥇 Express 2.707s (+3.4%) 3.086s (+1.7%) 0.378s 39 1.00x
🐘 Postgres Nitro 2.739s (+0.6%) 3.085s (~) 0.345s 39 1.01x
💻 Local Express 3.271s (+0.8%) 4.010s (~) 0.739s 30 1.21x
💻 Local Nitro 3.300s (-0.9%) 4.043s (+0.9%) 0.743s 30 1.22x
🐘 Postgres Next.js (Turbopack) 3.978s (+1.7%) 4.492s (+8.4% 🔺) 0.514s 27 1.47x
💻 Local Next.js (Turbopack) 4.446s (+1.3%) 5.011s (~) 0.565s 24 1.64x

▲ Production (Vercel)

World Framework Workflow Time Wall Time Overhead Samples vs Fastest
▲ Vercel 🥇 Express 31.902s (+5.6% 🔺) 34.784s (+9.9% 🔺) 2.881s 4 1.00x
▲ Vercel Next.js (Turbopack) 32.890s (+2.6%) 35.476s (+7.1% 🔺) 2.586s 4 1.03x
▲ Vercel Nitro 34.050s (+12.3% 🔺) 37.074s (+14.6% 🔺) 3.025s 4 1.07x

🔍 Observability: Express | Next.js (Turbopack) | Nitro

workflow with 10 concurrent data payload steps (10KB)

💻 Local Development

World Framework Workflow Time Wall Time Overhead Samples vs Fastest
🐘 Postgres 🥇 Nitro 0.239s (+1.1%) 1.006s (~) 0.766s 60 1.00x
🐘 Postgres Express 0.252s (+0.7%) 1.006s (~) 0.754s 60 1.05x
🐘 Postgres Next.js (Turbopack) 0.304s (-1.3%) 1.007s (~) 0.703s 60 1.27x
💻 Local Express 0.418s (-2.2%) 1.004s (-1.7%) 0.586s 60 1.75x
💻 Local Nitro 0.437s (+4.3%) 1.004s (~) 0.567s 60 1.82x
💻 Local Next.js (Turbopack) 0.581s (+5.8% 🔺) 1.005s (~) 0.424s 60 2.42x

▲ Production (Vercel)

World Framework Workflow Time Wall Time Overhead Samples vs Fastest
▲ Vercel 🥇 Next.js (Turbopack) 1.891s (-9.5% 🟢) 3.904s (+13.2% 🔺) 2.012s 16 1.00x
▲ Vercel Nitro 1.982s (+9.0% 🔺) 4.008s (+7.8% 🔺) 2.026s 15 1.05x
▲ Vercel Express 2.025s (+6.1% 🔺) 4.006s (+12.2% 🔺) 1.981s 15 1.07x

🔍 Observability: Next.js (Turbopack) | Nitro | Express

workflow with 25 concurrent data payload steps (10KB)

💻 Local Development

World Framework Workflow Time Wall Time Overhead Samples vs Fastest
🐘 Postgres 🥇 Nitro 0.405s (+2.5%) 1.104s (+2.5%) 0.698s 82 1.00x
🐘 Postgres Express 0.413s (+3.4%) 1.029s (+1.1%) 0.615s 88 1.02x
🐘 Postgres Next.js (Turbopack) 0.690s (+11.8% 🔺) 1.237s (+7.9% 🔺) 0.547s 74 1.70x
💻 Local Nitro 2.087s (-5.4% 🟢) 2.638s (-3.6%) 0.551s 35 5.15x
💻 Local Express 2.203s (+1.5%) 2.737s (+0.8%) 0.533s 33 5.44x
💻 Local Next.js (Turbopack) 2.554s (+1.8%) 3.225s (-1.1%) 0.671s 28 6.30x

▲ Production (Vercel)

World Framework Workflow Time Wall Time Overhead Samples vs Fastest
▲ Vercel 🥇 Nitro 3.295s (-4.5%) 5.234s (~) 1.938s 18 1.00x
▲ Vercel Express 3.328s (+4.6%) 5.377s (+14.4% 🔺) 2.049s 17 1.01x
▲ Vercel Next.js (Turbopack) 3.729s (+0.8%) 5.429s (+7.8% 🔺) 1.700s 17 1.13x

🔍 Observability: Nitro | Express | Next.js (Turbopack)

workflow with 50 concurrent data payload steps (10KB)

💻 Local Development

World Framework Workflow Time Wall Time Overhead Samples vs Fastest
🐘 Postgres 🥇 Nitro 0.753s (-3.0%) 1.489s (-5.3% 🟢) 0.736s 81 1.00x
🐘 Postgres Express 0.822s (+5.3% 🔺) 1.527s (+7.6% 🔺) 0.705s 79 1.09x
🐘 Postgres Next.js (Turbopack) 3.019s (+3.4%) 3.919s (+0.8%) 0.900s 31 4.01x
💻 Local Nitro 9.436s (-2.5%) 10.025s (-1.6%) 0.589s 12 12.53x
💻 Local Express 9.737s (+3.8%) 10.194s (+1.6%) 0.457s 12 12.93x
💻 Local Next.js (Turbopack) 11.190s (+6.2% 🔺) 12.032s (+4.8%) 0.842s 11 14.86x

▲ Production (Vercel)

World Framework Workflow Time Wall Time Overhead Samples vs Fastest
▲ Vercel 🥇 Express 6.198s (+10.6% 🔺) 8.637s (+20.2% 🔺) 2.439s 14 1.00x
▲ Vercel Nitro 7.058s (+29.4% 🔺) 9.348s (+33.7% 🔺) 2.289s 13 1.14x
▲ Vercel Next.js (Turbopack) 7.346s (~) 9.754s (+10.8% 🔺) 2.408s 13 1.19x

🔍 Observability: Express | Nitro | Next.js (Turbopack)

Stream Benchmarks (includes TTFB metrics)
workflow with stream

💻 Local Development

World Framework Workflow Time TTFB Slurp Wall Time Overhead Samples vs Fastest
💻 Local 🥇 Nitro 1.164s (~) 2.005s (~) 0.012s (-0.9%) 2.019s (~) 0.855s 10 1.00x
🐘 Postgres Nitro 1.165s (~) 2.002s (~) 0.001s (~) 2.010s (~) 0.845s 10 1.00x
🐘 Postgres Express 1.167s (~) 1.998s (~) 0.001s (+20.0% 🔺) 2.011s (~) 0.844s 10 1.00x
💻 Local Express 1.179s (+0.9%) 2.004s (~) 0.010s (-19.0% 🟢) 2.017s (~) 0.838s 10 1.01x
💻 Local Next.js (Turbopack) 1.206s (~) 2.004s (~) 0.010s (-17.6% 🟢) 2.018s (~) 0.812s 10 1.04x
🐘 Postgres Next.js (Turbopack) 1.255s (+1.8%) 2.001s (~) 0.001s (-13.3% 🟢) 2.012s (~) 0.757s 10 1.08x

▲ Production (Vercel)

World Framework Workflow Time TTFB Slurp Wall Time Overhead Samples vs Fastest
▲ Vercel 🥇 Nitro 2.571s (+7.9% 🔺) 3.772s (+11.6% 🔺) 0.977s (+28.7% 🔺) 5.226s (+13.5% 🔺) 2.654s 10 1.00x
▲ Vercel Express 2.574s (+13.2% 🔺) 3.687s (+21.5% 🔺) 0.743s (-37.3% 🟢) 4.909s (+6.6% 🔺) 2.336s 10 1.00x
▲ Vercel Next.js (Turbopack) 2.622s (-0.6%) 3.841s (+12.0% 🔺) 0.816s (-34.8% 🟢) 5.166s (+2.0%) 2.544s 10 1.02x

🔍 Observability: Nitro | Express | Next.js (Turbopack)

stream pipeline with 5 transform steps (1MB)

💻 Local Development

World Framework Workflow Time TTFB Slurp Wall Time Overhead Samples vs Fastest
💻 Local 🥇 Express 1.582s (-0.6%) 2.011s (~) 0.012s (+0.6%) 2.025s (~) 0.443s 30 1.00x
🐘 Postgres Nitro 1.587s (~) 2.007s (~) 0.005s (+3.0%) 2.025s (~) 0.438s 30 1.00x
💻 Local Nitro 1.594s (~) 2.011s (~) 0.012s (-6.8% 🟢) 2.025s (~) 0.431s 30 1.01x
🐘 Postgres Express 1.613s (+2.6%) 2.005s (~) 0.005s (-2.5%) 2.027s (~) 0.413s 30 1.02x
💻 Local Next.js (Turbopack) 1.777s (+2.1%) 2.041s (+1.6%) 0.014s (-4.6%) 2.058s (+1.5%) 0.281s 30 1.12x
🐘 Postgres Next.js (Turbopack) 1.824s (+2.8%) 2.010s (~) 0.005s (+7.2% 🔺) 2.027s (~) 0.203s 30 1.15x

▲ Production (Vercel)

World Framework Workflow Time TTFB Slurp Wall Time Overhead Samples vs Fastest
▲ Vercel 🥇 Nitro 6.455s (-12.0% 🟢) 7.819s (-8.1% 🟢) 0.258s (+36.4% 🔺) 8.651s (-6.5% 🟢) 2.195s 7 1.00x
▲ Vercel Express 6.556s (-8.8% 🟢) 7.816s (-8.2% 🟢) 0.809s (+318.7% 🔺) 9.145s (~) 2.590s 7 1.02x
▲ Vercel Next.js (Turbopack) 6.728s (-13.8% 🟢) 8.665s (-1.8%) 0.383s (-36.1% 🟢) 9.538s (-3.4%) 2.810s 7 1.04x

🔍 Observability: Nitro | Express | Next.js (Turbopack)

10 parallel streams (1MB each)

💻 Local Development

World Framework Workflow Time TTFB Slurp Wall Time Overhead Samples vs Fastest
🐘 Postgres 🥇 Nitro 0.756s (-3.1%) 1.068s (+3.6%) 0.000s (+103.6% 🔺) 1.089s (+2.9%) 0.333s 56 1.00x
🐘 Postgres Express 0.779s (+4.9%) 1.047s (~) 0.000s (~) 1.060s (~) 0.280s 57 1.03x
🐘 Postgres Next.js (Turbopack) 1.066s (+6.7% 🔺) 1.667s (+13.9% 🔺) 0.000s (-43.1% 🟢) 1.675s (+13.9% 🔺) 0.609s 36 1.41x
💻 Local Nitro 1.361s (-1.5%) 2.013s (~) 0.000s (-14.3% 🟢) 2.015s (~) 0.654s 30 1.80x
💻 Local Express 1.424s (+2.0%) 2.013s (~) 0.000s (~) 2.015s (~) 0.592s 30 1.88x
💻 Local Next.js (Turbopack) 1.537s (+4.2%) 2.014s (~) 0.000s (+30.0% 🔺) 2.017s (~) 0.480s 30 2.03x

▲ Production (Vercel)

World Framework Workflow Time TTFB Slurp Wall Time Overhead Samples vs Fastest
▲ Vercel 🥇 Nitro 3.421s (+5.2% 🔺) 4.927s (+7.0% 🔺) 0.000s (-100.0% 🟢) 5.539s (+9.2% 🔺) 2.118s 11 1.00x
▲ Vercel Express 4.042s (+24.0% 🔺) 5.549s (+29.1% 🔺) 0.000s (+30.0% 🔺) 6.071s (+28.3% 🔺) 2.029s 10 1.18x
▲ Vercel Next.js (Turbopack) 4.272s (+42.6% 🔺) 5.874s (+41.4% 🔺) 0.000s (NaN%) 6.409s (+39.7% 🔺) 2.137s 10 1.25x

🔍 Observability: Nitro | Express | Next.js (Turbopack)

fan-out fan-in 10 streams (1MB each)

💻 Local Development

World Framework Workflow Time TTFB Slurp Wall Time Overhead Samples vs Fastest
🐘 Postgres 🥇 Nitro 1.642s (-1.3%) 2.142s (-5.1% 🟢) 0.000s (-3.6%) 2.151s (-5.1% 🟢) 0.509s 28 1.00x
🐘 Postgres Express 1.731s (+5.8% 🔺) 2.214s (~) 0.000s (~) 2.232s (-0.6%) 0.501s 27 1.05x
🐘 Postgres Next.js (Turbopack) 2.539s (+19.6% 🔺) 3.005s (+13.2% 🔺) 0.000s (+Infinity% 🔺) 3.012s (+13.2% 🔺) 0.473s 20 1.55x
💻 Local Next.js (Turbopack) 2.952s (-3.4%) 3.466s (-5.6% 🟢) 0.001s (-21.3% 🟢) 3.477s (-5.4% 🟢) 0.525s 18 1.80x
💻 Local Express 3.073s (-0.8%) 3.775s (-1.4%) 0.001s (+14.3% 🔺) 3.781s (-1.6%) 0.708s 16 1.87x
💻 Local Nitro 3.142s (-2.6%) 3.895s (-1.8%) 0.001s (-37.5% 🟢) 3.906s (-1.6%) 0.764s 16 1.91x

▲ Production (Vercel)

World Framework Workflow Time TTFB Slurp Wall Time Overhead Samples vs Fastest
▲ Vercel 🥇 Express 4.580s (-15.1% 🟢) 6.205s (-5.5% 🟢) 0.000s (NaN%) 6.723s (-3.6%) 2.143s 9 1.00x
▲ Vercel Next.js (Turbopack) 4.966s (-11.0% 🟢) 6.426s (-1.2%) 0.006s (+Infinity% 🔺) 6.946s (-0.7%) 1.981s 9 1.08x
▲ Vercel Nitro 5.065s (+3.2%) 6.805s (+7.9% 🔺) 0.000s (-66.7% 🟢) 7.344s (+8.3% 🔺) 2.279s 9 1.11x

🔍 Observability: Express | Next.js (Turbopack) | Nitro

Summary

Fastest Framework by World

Winner determined by most benchmark wins

World 🥇 Fastest Framework Wins
💻 Local Nitro 8/21
🐘 Postgres Nitro 16/21
▲ Vercel Nitro 9/21
Fastest World by Framework

Winner determined by most benchmark wins

Framework 🥇 Fastest World Wins
Express 🐘 Postgres 15/21
Next.js (Turbopack) 🐘 Postgres 15/21
Nitro 🐘 Postgres 15/21
Column Definitions
  • Workflow Time: Runtime reported by workflow (completedAt - createdAt) - primary metric
  • TTFB: Time to First Byte - time from workflow start until first stream byte received (stream benchmarks only)
  • Slurp: Time from first byte to complete stream consumption (stream benchmarks only)
  • Wall Time: Total testbench time (trigger workflow + poll for result)
  • Overhead: Testbench overhead (Wall Time - Workflow Time)
  • Samples: Number of benchmark iterations run
  • vs Fastest: How much slower compared to the fastest configuration for this benchmark

Worlds:

  • 💻 Local: In-memory filesystem world (local development)
  • 🐘 Postgres: PostgreSQL database world (local development)
  • ▲ Vercel: Vercel production/preview deployment
  • 🌐 Turso: Community world (local development)
  • 🌐 MongoDB: Community world (local development)
  • 🌐 Redis: Community world (local development)
  • 🌐 Jazz: Community world (local development)
  • 🌐 Redis: Community world (local development)
  • 🌐 Redis + BullMQ: Community world (local development)
  • 🌐 Cloudflare: Community world (local development)
  • 🌐 MySQL: Community world (local development)
  • 🌐 Azure: Community world (local development)
  • 🌐 NATS JetStream: Community world (local development)
  • 🌐 Upstash: Community world (local development)

📋 View full workflow run

@github-actions

github-actions Bot commented Jun 15, 2026

Copy link
Copy Markdown
Contributor

🧪 E2E Test Results

All tests passed

Summary

Passed Failed Skipped Total
✅ ▲ Vercel Production 1442 0 219 1661
✅ 💻 Local Development 1895 0 219 2114
✅ 📦 Local Production 1895 0 219 2114
✅ 🐘 Local Postgres 1881 0 233 2114
✅ 🪟 Windows 151 0 0 151
✅ 📋 Other 879 0 178 1057
Total 8143 0 1068 9211

Details by Category

✅ ▲ Vercel Production
App Passed Failed Skipped
✅ astro 125 0 26
✅ example 125 0 26
✅ express 125 0 26
✅ fastify 125 0 26
✅ hono 125 0 26
✅ nextjs-turbopack 149 0 2
✅ nextjs-webpack 149 0 2
✅ nitro 125 0 26
✅ nuxt 125 0 26
✅ sveltekit 144 0 7
✅ vite 125 0 26
✅ 💻 Local Development
App Passed Failed Skipped
✅ astro-stable 126 0 25
✅ express-stable 126 0 25
✅ fastify-stable 126 0 25
✅ hono-stable 126 0 25
✅ nextjs-turbopack-canary 132 0 19
✅ nextjs-turbopack-stable-lazy-discovery-disabled 151 0 0
✅ nextjs-turbopack-stable-lazy-discovery-enabled 151 0 0
✅ nextjs-webpack-canary 132 0 19
✅ nextjs-webpack-stable-lazy-discovery-disabled 151 0 0
✅ nextjs-webpack-stable-lazy-discovery-enabled 151 0 0
✅ nitro-stable 126 0 25
✅ nuxt-stable 126 0 25
✅ sveltekit-stable 145 0 6
✅ vite-stable 126 0 25
✅ 📦 Local Production
App Passed Failed Skipped
✅ astro-stable 126 0 25
✅ express-stable 126 0 25
✅ fastify-stable 126 0 25
✅ hono-stable 126 0 25
✅ nextjs-turbopack-canary 132 0 19
✅ nextjs-turbopack-stable-lazy-discovery-disabled 151 0 0
✅ nextjs-turbopack-stable-lazy-discovery-enabled 151 0 0
✅ nextjs-webpack-canary 132 0 19
✅ nextjs-webpack-stable-lazy-discovery-disabled 151 0 0
✅ nextjs-webpack-stable-lazy-discovery-enabled 151 0 0
✅ nitro-stable 126 0 25
✅ nuxt-stable 126 0 25
✅ sveltekit-stable 145 0 6
✅ vite-stable 126 0 25
✅ 🐘 Local Postgres
App Passed Failed Skipped
✅ astro-stable 125 0 26
✅ express-stable 125 0 26
✅ fastify-stable 125 0 26
✅ hono-stable 125 0 26
✅ nextjs-turbopack-canary 131 0 20
✅ nextjs-turbopack-stable-lazy-discovery-disabled 150 0 1
✅ nextjs-turbopack-stable-lazy-discovery-enabled 150 0 1
✅ nextjs-webpack-canary 131 0 20
✅ nextjs-webpack-stable-lazy-discovery-disabled 150 0 1
✅ nextjs-webpack-stable-lazy-discovery-enabled 150 0 1
✅ nitro-stable 125 0 26
✅ nuxt-stable 125 0 26
✅ sveltekit-stable 144 0 7
✅ vite-stable 125 0 26
✅ 🪟 Windows
App Passed Failed Skipped
✅ nextjs-turbopack 151 0 0
✅ 📋 Other
App Passed Failed Skipped
✅ e2e-local-dev-nest-stable 126 0 25
✅ e2e-local-dev-tanstack-start- 126 0 25
✅ e2e-local-postgres-nest-stable 125 0 26
✅ e2e-local-postgres-tanstack-start- 125 0 26
✅ e2e-local-prod-nest-stable 126 0 25
✅ e2e-local-prod-tanstack-start- 126 0 25
✅ e2e-vercel-prod-tanstack-start 125 0 26

📋 View full workflow run

@VaguelySerious VaguelySerious marked this pull request as ready for review June 15, 2026 13:05
@VaguelySerious VaguelySerious requested a review from a team as a code owner June 15, 2026 13:05
Comment thread .changeset/stream-read-v3-reconnect.md Outdated
Signed-off-by: Peter Wielander <mittgfu@gmail.com>
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.

1 participant