Skip to content

fix: retry inline completion persistence failures#2666

Merged
NathanColosimo merged 1 commit into
mainfrom
nathanc/inline-completion-persistence-retry
Jun 26, 2026
Merged

fix: retry inline completion persistence failures#2666
NathanColosimo merged 1 commit into
mainfrom
nathanc/inline-completion-persistence-retry

Conversation

@NathanColosimo

@NathanColosimo NathanColosimo commented Jun 26, 2026

Copy link
Copy Markdown
Contributor

Draft split from #2649. Keeps the inline step completion persistence retry fix isolated from the broader streaming investigation.

Problem: when inline step_completed persistence fails with a transient infra/storage error, executeStep could catch that failure in the broad step execution path and record it as a user step retry/failure instead of letting the queue redeliver.

Fix: move step_completed persistence outside the user-code/dehydrate failure path, preserve EntityConflictError as skipped and RunExpiredError as gone, rethrow other completion persistence errors for queue retry, and add regression coverage proving no step_retrying or step_failed event is written for completion write failures.

Validation: Biome focused check, @workflow/core typecheck, step-handler Vitest file, simplify review loop, and autoreview local clean.

@changeset-bot

changeset-bot Bot commented Jun 26, 2026

Copy link
Copy Markdown

🦋 Changeset detected

Latest commit: a67820e

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

This PR includes changesets to release 16 packages
Name Type
@workflow/core Patch
@workflow/builders Patch
@workflow/cli Patch
@workflow/next Patch
@workflow/nitro Patch
@workflow/vitest Patch
@workflow/web-shared Patch
@workflow/web Patch
workflow Patch
@workflow/world-testing 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 26, 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 26, 2026 7:29pm
example-nextjs-workflow-webpack Ready Ready Preview, Comment Jun 26, 2026 7:29pm
example-workflow Ready Ready Preview, Comment Jun 26, 2026 7:29pm
workbench-astro-workflow Ready Ready Preview, Comment Jun 26, 2026 7:29pm
workbench-express-workflow Ready Ready Preview, Comment Jun 26, 2026 7:29pm
workbench-fastify-workflow Ready Ready Preview, Comment Jun 26, 2026 7:29pm
workbench-hono-workflow Ready Ready Preview, Comment Jun 26, 2026 7:29pm
workbench-nitro-workflow Ready Ready Preview, Comment Jun 26, 2026 7:29pm
workbench-nuxt-workflow Ready Ready Preview, Comment Jun 26, 2026 7:29pm
workbench-sveltekit-workflow Ready Ready Preview, Comment Jun 26, 2026 7:29pm
workbench-tanstack-start-workflow Ready Ready Preview, Comment Jun 26, 2026 7:29pm
workbench-vite-workflow Ready Ready Preview, Comment Jun 26, 2026 7:29pm
workflow-docs Ready Ready Preview, Comment, Open in v0 Jun 26, 2026 7:29pm
workflow-swc-playground Ready Ready Preview, Comment Jun 26, 2026 7:29pm
workflow-tarballs Ready Ready Preview, Comment Jun 26, 2026 7:29pm
workflow-web Ready Ready Preview, Comment Jun 26, 2026 7:29pm

@github-actions

github-actions Bot commented Jun 26, 2026

Copy link
Copy Markdown
Contributor

🧪 E2E Test Results

All tests passed

Summary

Passed Failed Skipped Total
✅ ▲ Vercel Production 1442 0 230 1672
✅ 💻 Local Development 1605 0 219 1824
✅ 📦 Local Production 1605 0 219 1824
✅ 🐘 Local Postgres 1593 0 231 1824
✅ 🪟 Windows 152 0 0 152
✅ 📋 Other 885 0 179 1064
Total 7282 0 1078 8360

Details by Category

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

📋 View full workflow run

@github-actions

github-actions Bot commented Jun 26, 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 🥇 Express 0.045s (-4.3%) 1.006s (~) 0.961s 10 1.00x
💻 Local Nitro 0.048s (+1.5%) 1.006s (~) 0.958s 10 1.06x
💻 Local Next.js (Turbopack) 0.050s (-5.3% 🟢) 1.007s (~) 0.957s 10 1.12x
🐘 Postgres Next.js (Turbopack) 0.072s (+25.2% 🔺) 1.018s (+0.7%) 0.946s 10 1.60x
🐘 Postgres Express 0.072s (+6.2% 🔺) 1.012s (~) 0.939s 10 1.60x
🐘 Postgres Nitro 0.078s (+16.9% 🔺) 1.017s (+0.5%) 0.940s 10 1.72x

▲ Production (Vercel)

World Framework Workflow Time Wall Time Overhead Samples vs Fastest
▲ Vercel 🥇 Nitro 0.280s (+7.4% 🔺) 1.976s (-14.7% 🟢) 1.697s 10 1.00x
▲ Vercel Express 0.300s (+34.5% 🔺) 2.165s (+28.3% 🔺) 1.865s 10 1.07x
▲ Vercel Next.js (Turbopack) 0.656s (-19.0% 🟢) 2.580s (+7.3% 🔺) 1.923s 10 2.34x

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

workflow with 1 step

💻 Local Development

World Framework Workflow Time Wall Time Overhead Samples vs Fastest
💻 Local 🥇 Express 1.081s (~) 2.006s (~) 0.926s 10 1.00x
💻 Local Nitro 1.082s (~) 2.006s (~) 0.924s 10 1.00x
💻 Local Next.js (Turbopack) 1.084s (~) 2.007s (~) 0.923s 10 1.00x
🐘 Postgres Nitro 1.102s (~) 2.010s (~) 0.908s 10 1.02x
🐘 Postgres Express 1.102s (~) 2.009s (~) 0.908s 10 1.02x
🐘 Postgres Next.js (Turbopack) 1.148s (+5.0% 🔺) 2.049s (+2.0%) 0.901s 10 1.06x

▲ Production (Vercel)

World Framework Workflow Time Wall Time Overhead Samples vs Fastest
▲ Vercel 🥇 Express 1.448s (~) 3.236s (-9.4% 🟢) 1.788s 10 1.00x
▲ Vercel Nitro 1.555s (+9.1% 🔺) 3.410s (+11.8% 🔺) 1.855s 10 1.07x
▲ Vercel Next.js (Turbopack) 2.510s (+12.5% 🔺) 4.361s (+14.6% 🔺) 1.852s 10 1.73x

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

workflow with 10 sequential steps

💻 Local Development

World Framework Workflow Time Wall Time Overhead Samples vs Fastest
💻 Local 🥇 Nitro 10.440s (~) 11.021s (~) 0.581s 3 1.00x
💻 Local Express 10.442s (~) 11.021s (~) 0.578s 3 1.00x
🐘 Postgres Express 10.497s (~) 11.024s (~) 0.528s 3 1.01x
💻 Local Next.js (Turbopack) 10.514s (~) 11.023s (~) 0.509s 3 1.01x
🐘 Postgres Nitro 10.516s (~) 11.022s (~) 0.505s 3 1.01x
🐘 Postgres Next.js (Turbopack) 10.997s (+4.8%) 11.385s (+3.3%) 0.388s 3 1.05x

▲ Production (Vercel)

World Framework Workflow Time Wall Time Overhead Samples vs Fastest
▲ Vercel 🥇 Nitro 12.099s (+3.5%) 13.869s (~) 1.769s 3 1.00x
▲ Vercel Next.js (Turbopack) 12.867s (+3.2%) 15.155s (+5.2% 🔺) 2.288s 2 1.06x
▲ Vercel Express 12.876s (+7.8% 🔺) 15.273s (+9.6% 🔺) 2.397s 2 1.06x

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

workflow with 25 sequential steps

💻 Local Development

World Framework Workflow Time Wall Time Overhead Samples vs Fastest
💻 Local 🥇 Express 13.611s (~) 14.028s (~) 0.417s 5 1.00x
🐘 Postgres Nitro 13.612s (~) 14.020s (~) 0.408s 5 1.00x
💻 Local Nitro 13.616s (-0.6%) 14.028s (~) 0.412s 5 1.00x
💻 Local Next.js (Turbopack) 13.652s (~) 14.028s (~) 0.376s 5 1.00x
🐘 Postgres Express 13.657s (-0.9%) 14.017s (~) 0.360s 5 1.00x
🐘 Postgres Next.js (Turbopack) 14.108s (+2.6%) 14.820s (+5.7% 🔺) 0.712s 5 1.04x

▲ Production (Vercel)

World Framework Workflow Time Wall Time Overhead Samples vs Fastest
▲ Vercel 🥇 Express 17.686s (-2.1%) 19.719s (-3.6%) 2.033s 4 1.00x
▲ Vercel Nitro 18.539s (+12.6% 🔺) 20.347s (+8.8% 🔺) 1.808s 3 1.05x
▲ Vercel Next.js (Turbopack) 19.953s (+8.8% 🔺) 22.492s (+11.0% 🔺) 2.539s 3 1.13x

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

workflow with 50 sequential steps

💻 Local Development

World Framework Workflow Time Wall Time Overhead Samples vs Fastest
💻 Local 🥇 Express 12.142s (-1.7%) 13.024s (~) 0.883s 7 1.00x
🐘 Postgres Express 12.151s (-0.9%) 13.019s (~) 0.868s 7 1.00x
💻 Local Nitro 12.163s (-1.4%) 13.026s (~) 0.863s 7 1.00x
🐘 Postgres Nitro 12.213s (~) 13.019s (~) 0.805s 7 1.01x
💻 Local Next.js (Turbopack) 12.269s (~) 13.026s (~) 0.757s 7 1.01x
🐘 Postgres Next.js (Turbopack) 12.480s (+1.9%) 13.016s (~) 0.536s 7 1.03x

▲ Production (Vercel)

World Framework Workflow Time Wall Time Overhead Samples vs Fastest
▲ Vercel 🥇 Express 24.463s (+31.3% 🔺) 27.229s (+29.3% 🔺) 2.766s 4 1.00x
▲ Vercel Nitro 24.956s (+36.6% 🔺) 26.747s (+30.9% 🔺) 1.791s 4 1.02x
▲ Vercel Next.js (Turbopack) 27.855s (+31.3% 🔺) 30.169s (+30.9% 🔺) 2.314s 3 1.14x

🔍 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 🥇 Express 1.188s (+0.6%) 2.008s (~) 0.820s 15 1.00x
🐘 Postgres Nitro 1.215s (+3.0%) 2.008s (~) 0.793s 15 1.02x
🐘 Postgres Next.js (Turbopack) 1.302s (+10.4% 🔺) 2.020s (+0.6%) 0.718s 15 1.10x
💻 Local Nitro 1.426s (+1.1%) 2.007s (~) 0.581s 15 1.20x
💻 Local Next.js (Turbopack) 1.428s (-6.4% 🟢) 2.007s (-3.2%) 0.579s 15 1.20x
💻 Local Express 1.458s (-9.7% 🟢) 2.006s (-6.7% 🟢) 0.548s 15 1.23x

▲ Production (Vercel)

World Framework Workflow Time Wall Time Overhead Samples vs Fastest
▲ Vercel 🥇 Express 2.278s (-38.0% 🟢) 4.079s (-25.9% 🟢) 1.801s 8 1.00x
▲ Vercel Nitro 2.325s (+11.3% 🔺) 3.934s (~) 1.609s 8 1.02x
▲ Vercel Next.js (Turbopack) 3.498s (-1.6%) 5.296s (+6.8% 🔺) 1.798s 6 1.54x

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

Promise.all with 25 concurrent steps

💻 Local Development

World Framework Workflow Time Wall Time Overhead Samples vs Fastest
🐘 Postgres 🥇 Nitro 1.296s (-1.9%) 2.591s (-3.1%) 1.295s 12 1.00x
🐘 Postgres Express 1.334s (~) 2.393s (-7.7% 🟢) 1.059s 13 1.03x
🐘 Postgres Next.js (Turbopack) 1.586s (+19.5% 🔺) 2.827s (-6.1% 🟢) 1.240s 11 1.22x
💻 Local Express 2.580s (+8.6% 🔺) 2.918s (-3.0%) 0.337s 11 1.99x
💻 Local Nitro 2.590s (+4.2%) 3.009s (-3.2%) 0.419s 10 2.00x
💻 Local Next.js (Turbopack) 2.729s (~) 3.343s (+11.1% 🔺) 0.614s 9 2.11x

▲ Production (Vercel)

World Framework Workflow Time Wall Time Overhead Samples vs Fastest
▲ Vercel 🥇 Nitro 3.198s (+15.9% 🔺) 5.035s (+14.5% 🔺) 1.837s 6 1.00x
▲ Vercel Express 3.406s (-16.9% 🟢) 5.152s (-15.6% 🟢) 1.745s 6 1.07x
▲ Vercel Next.js (Turbopack) 5.012s (-21.2% 🟢) 6.785s (-16.4% 🟢) 1.772s 5 1.57x

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

Promise.all with 50 concurrent steps

💻 Local Development

World Framework Workflow Time Wall Time Overhead Samples vs Fastest
🐘 Postgres 🥇 Nitro 1.601s (+1.1%) 4.017s (-2.9%) 2.416s 8 1.00x
🐘 Postgres Express 1.660s (+2.5%) 4.015s (-2.9%) 2.355s 8 1.04x
🐘 Postgres Next.js (Turbopack) 3.392s (+25.5% 🔺) 5.738s (+1.0%) 2.346s 6 2.12x
💻 Local Nitro 5.716s (-16.0% 🟢) 6.213s (-16.2% 🟢) 0.498s 5 3.57x
💻 Local Express 5.923s (-4.6%) 6.615s (-3.0%) 0.692s 5 3.70x
💻 Local Next.js (Turbopack) 7.471s (-2.8%) 8.267s (-3.0%) 0.797s 4 4.67x

▲ Production (Vercel)

World Framework Workflow Time Wall Time Overhead Samples vs Fastest
▲ Vercel 🥇 Nitro 5.477s (+70.1% 🔺) 7.486s (+45.6% 🔺) 2.008s 5 1.00x
▲ Vercel Express 5.561s (+70.0% 🔺) 8.569s (+65.8% 🔺) 3.008s 4 1.02x
▲ Vercel Next.js (Turbopack) 8.435s (+69.8% 🔺) 10.950s (+57.5% 🔺) 2.515s 3 1.54x

🔍 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 🥇 Express 1.189s (~) 2.006s (~) 0.817s 15 1.00x
🐘 Postgres Nitro 1.205s (+1.3%) 2.007s (~) 0.802s 15 1.01x
🐘 Postgres Next.js (Turbopack) 1.333s (+12.9% 🔺) 2.027s (+0.8%) 0.693s 15 1.12x
💻 Local Nitro 1.413s (-4.7%) 2.006s (~) 0.594s 15 1.19x
💻 Local Next.js (Turbopack) 1.457s (-1.5%) 2.006s (~) 0.549s 15 1.23x
💻 Local Express 1.471s (+4.0%) 2.006s (~) 0.535s 15 1.24x

▲ Production (Vercel)

World Framework Workflow Time Wall Time Overhead Samples vs Fastest
▲ Vercel 🥇 Nitro 2.705s (+24.8% 🔺) 4.549s (+9.2% 🔺) 1.844s 7 1.00x
▲ Vercel Express 2.711s (+31.1% 🔺) 5.044s (+31.2% 🔺) 2.333s 6 1.00x
▲ Vercel Next.js (Turbopack) 3.775s (+10.7% 🔺) 5.456s (+2.1%) 1.681s 6 1.40x

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

Promise.race with 25 concurrent steps

💻 Local Development

World Framework Workflow Time Wall Time Overhead Samples vs Fastest
🐘 Postgres 🥇 Nitro 1.315s (+1.6%) 2.596s (+16.8% 🔺) 1.282s 12 1.00x
🐘 Postgres Express 1.323s (-0.5%) 2.315s (~) 0.992s 13 1.01x
🐘 Postgres Next.js (Turbopack) 1.722s (+31.5% 🔺) 2.606s (-10.7% 🟢) 0.884s 12 1.31x
💻 Local Nitro 2.644s (+12.0% 🔺) 3.209s (+6.6% 🔺) 0.564s 10 2.01x
💻 Local Next.js (Turbopack) 2.707s (+6.4% 🔺) 3.009s (~) 0.302s 10 2.06x
💻 Local Express 2.747s (+4.0%) 3.108s (~) 0.361s 10 2.09x

▲ Production (Vercel)

World Framework Workflow Time Wall Time Overhead Samples vs Fastest
▲ Vercel 🥇 Nitro 2.903s (+24.3% 🔺) 4.799s (+19.4% 🔺) 1.897s 7 1.00x
▲ Vercel Express 3.137s (+36.8% 🔺) 4.980s (+26.0% 🔺) 1.842s 7 1.08x
▲ Vercel Next.js (Turbopack) 5.315s (+41.1% 🔺) 7.112s (+36.8% 🔺) 1.797s 5 1.83x

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

Promise.race with 50 concurrent steps

💻 Local Development

World Framework Workflow Time Wall Time Overhead Samples vs Fastest
🐘 Postgres 🥇 Nitro 1.584s (-2.2%) 4.135s (+3.1%) 2.551s 8 1.00x
🐘 Postgres Express 1.623s (-5.4% 🟢) 4.136s (-3.0%) 2.513s 8 1.02x
🐘 Postgres Next.js (Turbopack) 3.811s (+32.6% 🔺) 6.482s (+7.8% 🔺) 2.671s 5 2.41x
💻 Local Next.js (Turbopack) 6.008s (-12.9% 🟢) 6.614s (-13.2% 🟢) 0.606s 5 3.79x
💻 Local Express 6.839s (-2.9%) 7.416s (-4.5%) 0.576s 5 4.32x
💻 Local Nitro 7.349s (+4.3%) 8.023s (+6.7% 🔺) 0.673s 4 4.64x

▲ Production (Vercel)

World Framework Workflow Time Wall Time Overhead Samples vs Fastest
▲ Vercel 🥇 Nitro 4.831s (+29.6% 🔺) 6.531s (+13.3% 🔺) 1.700s 5 1.00x
▲ Vercel Express 5.371s (+59.0% 🔺) 7.449s (+42.0% 🔺) 2.078s 5 1.11x
▲ Vercel Next.js (Turbopack) 6.276s (+42.4% 🔺) 8.383s (+39.6% 🔺) 2.107s 4 1.30x

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

workflow with 10 sequential data payload steps (10KB)

💻 Local Development

World Framework Workflow Time Wall Time Overhead Samples vs Fastest
💻 Local 🥇 Express 0.546s (-9.2% 🟢) 1.005s (~) 0.460s 60 1.00x
🐘 Postgres Express 0.556s (-6.7% 🟢) 1.023s (~) 0.467s 59 1.02x
🐘 Postgres Nitro 0.584s (+10.2% 🔺) 1.059s (+5.3% 🔺) 0.475s 57 1.07x
💻 Local Next.js (Turbopack) 0.595s (-2.9%) 1.005s (~) 0.410s 60 1.09x
💻 Local Nitro 0.634s (+7.2% 🔺) 1.040s (+1.7%) 0.406s 58 1.16x
🐘 Postgres Next.js (Turbopack) 0.805s (+47.3% 🔺) 1.172s (+16.4% 🔺) 0.367s 52 1.48x

▲ Production (Vercel)

World Framework Workflow Time Wall Time Overhead Samples vs Fastest
▲ Vercel 🥇 Express 3.842s (+36.5% 🔺) 5.666s (+24.9% 🔺) 1.824s 11 1.00x
▲ Vercel Nitro 4.216s (+52.8% 🔺) 5.819s (+29.6% 🔺) 1.602s 11 1.10x
▲ Vercel Next.js (Turbopack) 4.859s (+14.8% 🔺) 6.619s (+10.8% 🔺) 1.760s 10 1.26x

🔍 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 🥇 Nitro 1.238s (-4.9%) 2.007s (~) 0.770s 45 1.00x
🐘 Postgres Express 1.320s (~) 2.007s (~) 0.687s 45 1.07x
💻 Local Express 1.401s (-5.6% 🟢) 2.028s (+1.1%) 0.627s 45 1.13x
💻 Local Nitro 1.436s (-1.0%) 2.006s (~) 0.570s 45 1.16x
💻 Local Next.js (Turbopack) 1.510s (-2.0%) 2.006s (-1.1%) 0.496s 45 1.22x
🐘 Postgres Next.js (Turbopack) 1.694s (+31.9% 🔺) 2.292s (+14.2% 🔺) 0.598s 40 1.37x

▲ Production (Vercel)

World Framework Workflow Time Wall Time Overhead Samples vs Fastest
▲ Vercel 🥇 Express 8.980s (+20.1% 🔺) 11.359s (+23.7% 🔺) 2.379s 8 1.00x
▲ Vercel Nitro 9.443s (+45.8% 🔺) 11.327s (+38.2% 🔺) 1.884s 8 1.05x
▲ Vercel Next.js (Turbopack) 12.266s (+26.6% 🔺) 14.658s (+28.2% 🔺) 2.391s 7 1.37x

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

workflow with 50 sequential data payload steps (10KB)

💻 Local Development

World Framework Workflow Time Wall Time Overhead Samples vs Fastest
🐘 Postgres 🥇 Nitro 2.515s (-2.3%) 3.085s (-0.8%) 0.570s 39 1.00x
🐘 Postgres Express 2.521s (-6.7% 🟢) 3.034s (-2.5%) 0.513s 40 1.00x
💻 Local Express 3.066s (-6.7% 🟢) 3.596s (-11.1% 🟢) 0.531s 34 1.22x
💻 Local Nitro 3.181s (+1.6%) 3.880s (-1.6%) 0.699s 31 1.26x
💻 Local Next.js (Turbopack) 3.325s (+0.5%) 4.009s (~) 0.684s 30 1.32x
🐘 Postgres Next.js (Turbopack) 3.714s (+40.0% 🔺) 4.199s (+37.3% 🔺) 0.485s 29 1.48x

▲ Production (Vercel)

World Framework Workflow Time Wall Time Overhead Samples vs Fastest
▲ Vercel 🥇 Express 18.124s (+6.3% 🔺) 21.179s (+11.8% 🔺) 3.055s 6 1.00x
▲ Vercel Nitro 20.282s (+38.0% 🔺) 23.138s (+38.5% 🔺) 2.856s 6 1.12x
▲ Vercel Next.js (Turbopack) 25.983s (+23.6% 🔺) 28.734s (+26.5% 🔺) 2.751s 5 1.43x

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

workflow with 10 concurrent data payload steps (10KB)

💻 Local Development

World Framework Workflow Time Wall Time Overhead Samples vs Fastest
🐘 Postgres 🥇 Express 0.212s (-1.2%) 1.006s (~) 0.794s 60 1.00x
🐘 Postgres Nitro 0.215s (+1.4%) 1.007s (~) 0.792s 60 1.01x
🐘 Postgres Next.js (Turbopack) 0.309s (+65.6% 🔺) 1.032s (+2.6%) 0.723s 59 1.45x
💻 Local Express 0.435s (-4.5%) 1.004s (~) 0.569s 60 2.05x
💻 Local Nitro 0.451s (+3.5%) 1.004s (~) 0.554s 60 2.12x
💻 Local Next.js (Turbopack) 0.628s (+1.3%) 1.005s (~) 0.377s 60 2.96x

▲ Production (Vercel)

World Framework Workflow Time Wall Time Overhead Samples vs Fastest
▲ Vercel 🥇 Express 1.668s (-3.0%) 3.615s (+1.8%) 1.947s 17 1.00x
▲ Vercel Nitro 1.686s (+2.7%) 3.368s (-1.7%) 1.682s 18 1.01x
▲ Vercel Next.js (Turbopack) 3.341s (+52.8% 🔺) 5.471s (+41.2% 🔺) 2.130s 12 2.00x

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

workflow with 25 concurrent data payload steps (10KB)

💻 Local Development

World Framework Workflow Time Wall Time Overhead Samples vs Fastest
🐘 Postgres 🥇 Nitro 0.313s (-3.2%) 1.007s (-1.1%) 0.693s 90 1.00x
🐘 Postgres Express 0.333s (~) 1.006s (~) 0.673s 90 1.06x
🐘 Postgres Next.js (Turbopack) 0.479s (+73.3% 🔺) 1.107s (+10.0% 🔺) 0.628s 83 1.53x
💻 Local Nitro 2.079s (-0.8%) 2.637s (-3.6%) 0.558s 35 6.64x
💻 Local Express 2.088s (-3.5%) 2.686s (-4.0%) 0.598s 34 6.67x
💻 Local Next.js (Turbopack) 2.813s (-2.1%) 3.343s (-2.2%) 0.530s 27 8.98x

▲ Production (Vercel)

World Framework Workflow Time Wall Time Overhead Samples vs Fastest
▲ Vercel 🥇 Nitro 2.631s (+64.5% 🔺) 4.509s (+38.6% 🔺) 1.878s 21 1.00x
▲ Vercel Express 2.964s (+62.9% 🔺) 5.037s (+43.6% 🔺) 2.073s 18 1.13x
▲ Vercel Next.js (Turbopack) 4.778s (+69.4% 🔺) 7.155s (+61.4% 🔺) 2.378s 13 1.82x

🔍 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.519s (-1.0%) 1.041s (-0.8%) 0.522s 116 1.00x
🐘 Postgres Express 0.521s (-2.1%) 1.097s (+2.7%) 0.576s 110 1.00x
🐘 Postgres Next.js (Turbopack) 0.927s (+83.8% 🔺) 2.591s (-13.9% 🟢) 1.664s 47 1.79x
💻 Local Express 9.259s (-7.5% 🟢) 10.361s (-6.9% 🟢) 1.101s 12 17.83x
💻 Local Nitro 10.027s (+2.9%) 11.118s (+2.3%) 1.091s 11 19.31x
💻 Local Next.js (Turbopack) 11.546s (+13.5% 🔺) 12.431s (+8.3% 🔺) 0.885s 10 22.24x

▲ Production (Vercel)

World Framework Workflow Time Wall Time Overhead Samples vs Fastest
▲ Vercel 🥇 Nitro 4.437s (+89.8% 🔺) 6.918s (+65.6% 🔺) 2.481s 18 1.00x
▲ Vercel Express 4.536s (+98.2% 🔺) 7.164s (+69.0% 🔺) 2.628s 17 1.02x
▲ Vercel Next.js (Turbopack) 5.052s (+29.6% 🔺) 7.393s (+31.5% 🔺) 2.341s 17 1.14x

🔍 Observability: Nitro | Express | 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 🥇 Next.js (Turbopack) 1.142s (~) 1.966s (~) 0.012s (-1.7%) 2.019s (~) 0.877s 10 1.00x
🐘 Postgres Nitro 1.147s (-0.5%) 1.997s (~) 0.001s (-21.4% 🟢) 2.010s (~) 0.863s 10 1.00x
💻 Local Express 1.149s (-3.5%) 2.004s (~) 0.010s (-20.6% 🟢) 2.017s (~) 0.868s 10 1.01x
💻 Local Nitro 1.155s (~) 2.004s (~) 0.012s (-4.8%) 2.019s (~) 0.864s 10 1.01x
🐘 Postgres Express 1.163s (-0.9%) 1.994s (~) 0.001s (-37.5% 🟢) 2.009s (~) 0.847s 10 1.02x
🐘 Postgres Next.js (Turbopack) 1.286s (+11.4% 🔺) 1.991s (~) 0.054s (+4827.3% 🔺) 2.062s (+2.6%) 0.776s 10 1.13x

▲ Production (Vercel)

World Framework Workflow Time TTFB Slurp Wall Time Overhead Samples vs Fastest
▲ Vercel 🥇 Nitro 2.215s (+1.2%) 3.245s (-7.8% 🟢) 3.032s (+57.0% 🔺) 6.719s (+12.4% 🔺) 4.504s 10 1.00x
▲ Vercel Express 2.466s (+23.5% 🔺) 3.531s (-7.7% 🟢) 2.996s (+19.6% 🔺) 7.214s (+5.6% 🔺) 4.748s 10 1.11x
▲ Vercel Next.js (Turbopack) 4.345s (+23.1% 🔺) 4.679s (+1.7%) 2.443s (~) 8.509s (+2.2%) 4.165s 10 1.96x

🔍 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.526s (-3.0%) 2.009s (~) 0.012s (+7.5% 🔺) 2.025s (~) 0.499s 30 1.00x
🐘 Postgres Express 1.550s (-3.1%) 2.002s (~) 0.005s (+1.3%) 2.025s (~) 0.475s 30 1.02x
🐘 Postgres Nitro 1.557s (+0.5%) 2.001s (~) 0.005s (+5.3% 🔺) 2.026s (~) 0.469s 30 1.02x
💻 Local Nitro 1.559s (-1.4%) 2.011s (~) 0.012s (-0.8%) 2.026s (~) 0.467s 30 1.02x
💻 Local Next.js (Turbopack) 1.593s (~) 1.971s (~) 0.012s (+7.1% 🔺) 2.026s (~) 0.433s 30 1.04x
🐘 Postgres Next.js (Turbopack) 2.264s (+42.0% 🔺) 2.815s (+40.1% 🔺) 0.004s (-13.9% 🟢) 2.847s (+40.6% 🔺) 0.583s 22 1.48x

▲ Production (Vercel)

World Framework Workflow Time TTFB Slurp Wall Time Overhead Samples vs Fastest
▲ Vercel 🥇 Express 7.607s (+30.4% 🔺) 9.247s (+26.1% 🔺) 0.386s (+20.9% 🔺) 10.385s (+27.4% 🔺) 2.778s 6 1.00x
▲ Vercel Nitro 8.229s (+45.4% 🔺) 9.672s (+30.4% 🔺) 0.447s (+5.2% 🔺) 10.889s (+29.8% 🔺) 2.660s 6 1.08x
▲ Vercel Next.js (Turbopack) 11.353s (+24.4% 🔺) 12.459s (+23.4% 🔺) 0.169s (-27.0% 🟢) 13.916s (+26.6% 🔺) 2.563s 5 1.49x

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

10 parallel streams (1MB each)

💻 Local Development

World Framework Workflow Time TTFB Slurp Wall Time Overhead Samples vs Fastest
🐘 Postgres 🥇 Express 0.763s (-2.9%) 1.028s (-5.1% 🟢) 0.000s (-3.5%) 1.059s (-3.6%) 0.295s 57 1.00x
🐘 Postgres Nitro 0.775s (-0.8%) 1.065s (-3.2%) 0.000s (-1.8%) 1.079s (-3.3%) 0.304s 56 1.02x
💻 Local Express 1.241s (-5.3% 🟢) 1.982s (-1.6%) 0.001s (+229.0% 🔺) 1.985s (-1.6%) 0.743s 31 1.63x
💻 Local Nitro 1.252s (+3.5%) 1.982s (-1.6%) 0.000s (+38.2% 🔺) 1.984s (-1.6%) 0.732s 31 1.64x
🐘 Postgres Next.js (Turbopack) 1.360s (+40.5% 🔺) 1.907s (+40.7% 🔺) 0.000s (-100.0% 🟢) 1.930s (+41.5% 🔺) 0.570s 32 1.78x
💻 Local Next.js (Turbopack) 1.396s (+1.5%) 1.978s (~) 0.000s (-29.4% 🟢) 2.016s (~) 0.620s 30 1.83x

▲ Production (Vercel)

World Framework Workflow Time TTFB Slurp Wall Time Overhead Samples vs Fastest
▲ Vercel 🥇 Express 3.648s (+13.7% 🔺) 5.153s (+11.5% 🔺) 0.000s (+Infinity% 🔺) 5.722s (+10.8% 🔺) 2.074s 11 1.00x
▲ Vercel Nitro 4.040s (+17.5% 🔺) 5.412s (+8.1% 🔺) 0.000s (NaN%) 5.844s (+6.4% 🔺) 1.803s 11 1.11x
▲ Vercel Next.js (Turbopack) 5.913s (+32.0% 🔺) 6.551s (+20.8% 🔺) 0.000s (+Infinity% 🔺) 7.606s (+20.8% 🔺) 1.692s 8 1.62x

🔍 Observability: Express | Nitro | 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 🥇 Express 1.681s (-7.7% 🟢) 2.391s (~) 0.000s (NaN%) 2.409s (~) 0.729s 25 1.00x
🐘 Postgres Nitro 1.972s (+18.4% 🔺) 2.538s (+12.6% 🔺) 0.000s (-100.0% 🟢) 2.552s (+12.2% 🔺) 0.580s 24 1.17x
💻 Local Nitro 3.348s (-8.6% 🟢) 3.963s (-6.2% 🟢) 0.001s (-6.2% 🟢) 3.967s (-6.2% 🟢) 0.618s 16 1.99x
💻 Local Express 3.382s (+0.6%) 3.837s (-3.2%) 0.001s (-50.0% 🟢) 3.843s (-3.2%) 0.461s 16 2.01x
🐘 Postgres Next.js (Turbopack) 3.401s (+23.4% 🔺) 3.873s (+16.2% 🔺) 0.000s (-100.0% 🟢) 3.929s (+17.5% 🔺) 0.528s 16 2.02x
💻 Local Next.js (Turbopack) 3.642s (-1.0%) 4.195s (+1.7%) 0.001s (+71.4% 🔺) 4.234s (+1.6%) 0.592s 15 2.17x

▲ Production (Vercel)

World Framework Workflow Time TTFB Slurp Wall Time Overhead Samples vs Fastest
▲ Vercel 🥇 Nitro 5.918s (+3.2%) 7.297s (+3.2%) 0.000s (-100.0% 🟢) 7.752s (+1.9%) 1.834s 8 1.00x
▲ Vercel Express 6.154s (+16.1% 🔺) 7.863s (+20.7% 🔺) 0.000s (NaN%) 8.380s (+19.6% 🔺) 2.226s 8 1.04x
▲ Vercel Next.js (Turbopack) 7.514s (-1.7%) 8.446s (+1.6%) 0.012s (+Infinity% 🔺) 9.499s (~) 1.985s 7 1.27x

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

Summary

Fastest Framework by World

Winner determined by most benchmark wins

World 🥇 Fastest Framework Wins
💻 Local Express 12/21
🐘 Postgres Nitro 11/21
▲ Vercel Nitro 11/21
Fastest World by Framework

Winner determined by most benchmark wins

Framework 🥇 Fastest World Wins
Express 🐘 Postgres 13/21
Next.js (Turbopack) 🐘 Postgres 11/21
Nitro 🐘 Postgres 17/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)
  • 🌐 Platformatic: Community world (local development)

📋 View full workflow run

@NathanColosimo NathanColosimo marked this pull request as ready for review June 26, 2026 20:19
@NathanColosimo NathanColosimo requested review from a team and ijjk as code owners June 26, 2026 20:19
@NathanColosimo NathanColosimo enabled auto-merge (squash) June 26, 2026 20:19
@VaguelySerious

Copy link
Copy Markdown
Member

Possibly related to #2445?

@NathanColosimo NathanColosimo merged commit b180270 into main Jun 26, 2026
179 of 184 checks passed
@NathanColosimo NathanColosimo deleted the nathanc/inline-completion-persistence-retry branch June 26, 2026 22:00
@github-actions

Copy link
Copy Markdown
Contributor

No backport to stable for b180270 (AI decision).

This fix targets packages/core/src/runtime/step-executor.ts and the executeStep function, neither of which exist on stable (step execution there lives in a differently-structured step-handler.ts monolith with no step-executor.ts). The bug being fixed is specific to the inline sequential execution path (sinceCursor/inlineDelta threading inside executeStep's try/catch), and the accompanying test changes rely on executeStep/baseParams/inline-delta test scaffolding that is entirely main-only, so the change builds on main-only behavior and does not apply to stable.

To override, re-run the Backport to stable workflow manually via workflow_dispatch and paste this commit SHA into the ref input:

b1802700e42955ae31105a8c4adce87e7965a219

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.

3 participants