Skip to content

Version Packages (beta)#1352

Merged
karthikscale3 merged 1 commit intomainfrom
changeset-release/main
Mar 13, 2026
Merged

Version Packages (beta)#1352
karthikscale3 merged 1 commit intomainfrom
changeset-release/main

Conversation

@vercel-release-bot
Copy link
Contributor

@vercel-release-bot vercel-release-bot commented Mar 12, 2026

This PR was opened by the Changesets release GitHub action. When you're ready to do a release, you can merge this and the packages will be published to npm automatically. If you're not ready to do a release yet, that's fine, whenever you add more changesets to main, this PR will be updated.

⚠️⚠️⚠️⚠️⚠️⚠️

main is currently in pre mode so this branch has prereleases rather than normal releases. If you want to exit prereleases, run changeset pre exit on main.

⚠️⚠️⚠️⚠️⚠️⚠️

Releases

@workflow/astro@4.0.0-beta.44

Patch Changes

  • Updated dependencies []:
    • @workflow/builders@4.0.1-beta.61
    • @workflow/rollup@4.0.0-beta.27
    • @workflow/vite@4.0.0-beta.20

@workflow/builders@4.0.1-beta.61

Patch Changes

  • Updated dependencies [7df1385, 58e67ce]:
    • @workflow/core@4.2.0-beta.70

@workflow/cli@4.2.0-beta.70

Patch Changes

@workflow/core@4.2.0-beta.70

Patch Changes

  • #1339 7df1385 Thanks @TooTallNate! - Separate infrastructure vs user code error handling in workflow and step runtimes so transient network errors (ECONNRESET, etc.) propagate to the queue for retry instead of incorrectly marking runs as failed

  • #1345 58e67ce Thanks @TooTallNate! - Suppress stale WORKFLOW_VERCEL_* env var warning when running outside Vercel serverless (e.g. CLI, web observability app)

  • Updated dependencies [9feebee]:

    • @workflow/world-local@4.1.0-beta.43

@workflow/nest@0.0.0-beta.19

Patch Changes

  • #1346 73c12f1 Thanks @TooTallNate! - Fix ERR_UNSUPPORTED_ESM_URL_SCHEME on Windows by converting absolute file paths to file:// URLs before passing them to dynamic import()

  • Updated dependencies []:

    • @workflow/builders@4.0.1-beta.61

@workflow/next@4.0.1-beta.66

Patch Changes

  • Updated dependencies [7df1385, 58e67ce]:
    • @workflow/core@4.2.0-beta.70
    • @workflow/builders@4.0.1-beta.61

@workflow/nitro@4.0.1-beta.65

Patch Changes

  • Updated dependencies [7df1385, 58e67ce]:
    • @workflow/core@4.2.0-beta.70
    • @workflow/builders@4.0.1-beta.61
    • @workflow/rollup@4.0.0-beta.27
    • @workflow/vite@4.0.0-beta.20

@workflow/nuxt@4.0.1-beta.54

Patch Changes

  • Updated dependencies []:
    • @workflow/nitro@4.0.1-beta.65

@workflow/rollup@4.0.0-beta.27

Patch Changes

  • Updated dependencies []:
    • @workflow/builders@4.0.1-beta.61

@workflow/sveltekit@4.0.0-beta.59

Patch Changes

  • Updated dependencies []:
    • @workflow/builders@4.0.1-beta.61
    • @workflow/rollup@4.0.0-beta.27
    • @workflow/vite@4.0.0-beta.20

@workflow/vite@4.0.0-beta.20

Patch Changes

  • Updated dependencies []:
    • @workflow/builders@4.0.1-beta.61

@workflow/vitest@4.0.1-beta.7

Patch Changes

  • #1346 73c12f1 Thanks @TooTallNate! - Fix ERR_UNSUPPORTED_ESM_URL_SCHEME on Windows by converting absolute file paths to file:// URLs before passing them to dynamic import()

  • Updated dependencies [7df1385, 9feebee, 58e67ce]:

    • @workflow/core@4.2.0-beta.70
    • @workflow/world-local@4.1.0-beta.43
    • @workflow/builders@4.0.1-beta.61
    • @workflow/rollup@4.0.0-beta.27

@workflow/web@4.1.0-beta.42

Patch Changes

  • #1346 73c12f1 Thanks @TooTallNate! - Fix ERR_UNSUPPORTED_ESM_URL_SCHEME on Windows by converting absolute file paths to file:// URLs before passing them to dynamic import()

  • #1358 5c6ae60 Thanks @karthikscale3! - Improve workflow observability UX with decoupled pagination, stream virtualization, and decrypt actions

  • #1366 d6da7ec Thanks @karthikscale3! - Fix stale encryptionKey closure in events list data hook in web

@workflow/web-shared@4.1.0-beta.65

Patch Changes

  • #1358 5c6ae60 Thanks @karthikscale3! - Improve workflow observability UX with decoupled pagination, stream virtualization, and decrypt actions

  • Updated dependencies [7df1385, 58e67ce]:

    • @workflow/core@4.2.0-beta.70

workflow@4.2.0-beta.70

Patch Changes

  • Updated dependencies [3c3f80a, 7df1385, 73c12f1, 58e67ce, 9f3551c]:
    • @workflow/cli@4.2.0-beta.70
    • @workflow/core@4.2.0-beta.70
    • @workflow/nest@0.0.0-beta.19
    • @workflow/next@4.0.1-beta.66
    • @workflow/nitro@4.0.1-beta.65
    • @workflow/typescript-plugin@4.0.1-beta.5
    • @workflow/astro@4.0.0-beta.44
    • @workflow/rollup@4.0.0-beta.27
    • @workflow/sveltekit@4.0.0-beta.59
    • @workflow/nuxt@4.0.1-beta.54

@workflow/world-local@4.1.0-beta.43

Patch Changes

@workflow/world-postgres@4.1.0-beta.45

Patch Changes

  • Updated dependencies [9feebee]:
    • @workflow/world-local@4.1.0-beta.43

@workflow/world-testing@4.1.0-beta.71

Patch Changes

  • Updated dependencies [3c3f80a, 7df1385, 58e67ce, 9f3551c]:
    • @workflow/cli@4.2.0-beta.70
    • @workflow/core@4.2.0-beta.70
    • workflow@4.2.0-beta.70

@vercel-release-bot vercel-release-bot requested review from a team and ijjk as code owners March 12, 2026 19:01
@vercel
Copy link
Contributor

vercel bot commented Mar 12, 2026

@github-actions
Copy link
Contributor

github-actions bot commented Mar 12, 2026

📊 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.026s (-17.7% 🟢) 1.005s (~) 0.979s 10 1.00x
💻 Local Nitro 0.033s (~) 1.007s (~) 0.974s 10 1.24x
🌐 Redis Next.js (Turbopack) 0.039s 1.005s 0.966s 10 1.46x
🐘 Postgres Nitro 0.040s (-25.8% 🟢) 1.011s (~) 0.971s 10 1.49x
💻 Local Next.js (Turbopack) 0.041s 1.005s 0.965s 10 1.53x
🐘 Postgres Express 0.051s (-8.4% 🟢) 1.011s (~) 0.960s 10 1.92x
🌐 MongoDB Next.js (Turbopack) 0.054s 1.007s 0.953s 10 2.05x
🐘 Postgres Next.js (Turbopack) 0.057s 1.013s 0.956s 10 2.15x

▲ Production (Vercel)

World Framework Workflow Time Wall Time Overhead Samples vs Fastest
▲ Vercel 🥇 Next.js (Turbopack) 0.434s (-12.7% 🟢) 2.212s (+7.8% 🔺) 1.779s 10 1.00x
▲ Vercel Express 0.435s (+1.3%) 2.462s (+2.7%) 2.026s 10 1.00x
▲ Vercel Nitro 0.463s (+0.8%) 2.280s (-4.9%) 1.817s 10 1.07x

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

workflow with 1 step

💻 Local Development

World Framework Workflow Time Wall Time Overhead Samples vs Fastest
💻 Local 🥇 Express 1.070s (-3.1%) 2.006s (~) 0.936s 10 1.00x
🌐 Redis Next.js (Turbopack) 1.079s 2.007s 0.928s 10 1.01x
🐘 Postgres Nitro 1.091s (-2.2%) 2.012s (~) 0.921s 10 1.02x
💻 Local Next.js (Turbopack) 1.100s 2.006s 0.906s 10 1.03x
💻 Local Nitro 1.101s (~) 2.006s (~) 0.905s 10 1.03x
🐘 Postgres Express 1.119s (-0.7%) 2.011s (~) 0.892s 10 1.05x
🐘 Postgres Next.js (Turbopack) 1.132s 2.013s 0.881s 10 1.06x
🌐 MongoDB Next.js (Turbopack) 1.285s 2.008s 0.723s 10 1.20x

▲ Production (Vercel)

World Framework Workflow Time Wall Time Overhead Samples vs Fastest
▲ Vercel 🥇 Next.js (Turbopack) 1.976s (+1.8%) 3.421s (+12.0% 🔺) 1.445s 10 1.00x
▲ Vercel Express 1.992s (-7.1% 🟢) 3.577s (-2.4%) 1.586s 10 1.01x
▲ Vercel Nitro 2.067s (-4.8%) 3.854s (+4.0%) 1.787s 10 1.05x

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

workflow with 10 sequential steps

💻 Local Development

World Framework Workflow Time Wall Time Overhead Samples vs Fastest
💻 Local 🥇 Express 10.499s (-2.7%) 11.022s (~) 0.523s 3 1.00x
🌐 Redis Next.js (Turbopack) 10.519s 11.023s 0.505s 3 1.00x
🐘 Postgres Nitro 10.575s (-2.0%) 11.038s (~) 0.463s 3 1.01x
💻 Local Next.js (Turbopack) 10.662s 11.024s 0.362s 3 1.02x
💻 Local Nitro 10.769s (~) 11.023s (~) 0.255s 3 1.03x
🐘 Postgres Express 10.805s (~) 11.042s (~) 0.237s 3 1.03x
🐘 Postgres Next.js (Turbopack) 10.881s 11.047s 0.166s 3 1.04x
🌐 MongoDB Next.js (Turbopack) 12.154s 13.014s 0.860s 3 1.16x

▲ Production (Vercel)

World Framework Workflow Time Wall Time Overhead Samples vs Fastest
▲ Vercel 🥇 Next.js (Turbopack) 16.388s (-1.0%) 17.701s (-1.7%) 1.313s 2 1.00x
▲ Vercel Nitro 16.409s (-2.4%) 18.699s (+1.6%) 2.290s 2 1.00x
▲ Vercel Express 17.115s (+2.8%) 18.991s (+4.3%) 1.876s 2 1.04x

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

workflow with 25 sequential steps

💻 Local Development

World Framework Workflow Time Wall Time Overhead Samples vs Fastest
🌐 Redis 🥇 Next.js (Turbopack) 26.211s 27.050s 0.839s 3 1.00x
🐘 Postgres Nitro 26.361s (-1.8%) 27.060s (~) 0.699s 3 1.01x
💻 Local Express 26.462s (-2.8%) 27.050s (-3.6%) 0.589s 3 1.01x
💻 Local Next.js (Turbopack) 26.848s 27.050s 0.202s 3 1.02x
🐘 Postgres Express 26.949s (~) 27.061s (~) 0.111s 3 1.03x
🐘 Postgres Next.js (Turbopack) 26.977s 27.409s 0.432s 3 1.03x
💻 Local Nitro 27.164s (~) 28.051s (~) 0.887s 3 1.04x
🌐 MongoDB Next.js (Turbopack) 30.267s 31.027s 0.761s 2 1.15x

▲ Production (Vercel)

World Framework Workflow Time Wall Time Overhead Samples vs Fastest
▲ Vercel 🥇 Nitro 43.440s (~) 45.615s (+2.1%) 2.175s 2 1.00x
▲ Vercel Express 43.907s (+2.3%) 45.932s (+3.9%) 2.025s 2 1.01x
▲ Vercel Next.js (Turbopack) 44.559s (+3.2%) 46.742s (+4.9%) 2.183s 2 1.03x

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

workflow with 50 sequential steps

💻 Local Development

World Framework Workflow Time Wall Time Overhead Samples vs Fastest
🌐 Redis 🥇 Next.js (Turbopack) 52.377s 53.099s 0.722s 2 1.00x
🐘 Postgres Nitro 52.650s (-2.1%) 53.091s (-1.8%) 0.441s 2 1.01x
🐘 Postgres Express 53.894s (~) 54.100s (~) 0.206s 2 1.03x
🐘 Postgres Next.js (Turbopack) 54.031s 54.114s 0.084s 2 1.03x
💻 Local Express 54.371s (-3.1%) 55.100s (-2.6%) 0.729s 2 1.04x
💻 Local Next.js (Turbopack) 55.407s 56.100s 0.693s 2 1.06x
💻 Local Nitro 55.958s (~) 56.104s (-0.9%) 0.146s 2 1.07x
🌐 MongoDB Next.js (Turbopack) 60.478s 61.045s 0.567s 2 1.15x

▲ Production (Vercel)

World Framework Workflow Time Wall Time Overhead Samples vs Fastest
▲ Vercel 🥇 Next.js (Turbopack) 97.482s (+7.4% 🔺) 99.971s (+9.2% 🔺) 2.489s 1 1.00x
▲ Vercel Express 97.865s (+4.5%) 99.942s (+4.7%) 2.077s 1 1.00x
▲ Vercel Nitro 102.889s (+12.8% 🔺) 105.394s (+13.1% 🔺) 2.505s 1 1.06x

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

Promise.all with 10 concurrent steps

💻 Local Development

World Framework Workflow Time Wall Time Overhead Samples vs Fastest
🌐 Redis 🥇 Next.js (Turbopack) 1.191s 2.006s 0.815s 15 1.00x
🐘 Postgres Nitro 1.267s (-5.5% 🟢) 2.011s (~) 0.743s 15 1.06x
💻 Local Express 1.336s (-5.7% 🟢) 2.006s (~) 0.670s 15 1.12x
🐘 Postgres Express 1.342s (-2.2%) 2.011s (~) 0.669s 15 1.13x
🐘 Postgres Next.js (Turbopack) 1.401s 2.012s 0.611s 15 1.18x
💻 Local Nitro 1.413s (~) 2.005s (~) 0.592s 15 1.19x
💻 Local Next.js (Turbopack) 1.414s 2.005s 0.591s 15 1.19x
🌐 MongoDB Next.js (Turbopack) 2.187s 3.007s 0.821s 10 1.84x

▲ Production (Vercel)

World Framework Workflow Time Wall Time Overhead Samples vs Fastest
▲ Vercel 🥇 Express 2.421s (+4.6%) 4.044s (+7.7% 🔺) 1.624s 8 1.00x
▲ Vercel Nitro 2.502s (-11.1% 🟢) 3.913s (-10.4% 🟢) 1.411s 8 1.03x
▲ Vercel Next.js (Turbopack) 2.836s (+12.9% 🔺) 3.949s (+15.3% 🔺) 1.112s 8 1.17x

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

Promise.all with 25 concurrent steps

💻 Local Development

World Framework Workflow Time Wall Time Overhead Samples vs Fastest
💻 Local 🥇 Express 2.224s (-15.4% 🟢) 3.008s (~) 0.784s 10 1.00x
💻 Local Next.js (Turbopack) 2.379s 3.008s 0.628s 10 1.07x
🌐 Redis Next.js (Turbopack) 2.401s 3.008s 0.607s 10 1.08x
🐘 Postgres Nitro 2.423s (-2.6%) 3.011s (~) 0.588s 10 1.09x
🐘 Postgres Express 2.465s (~) 3.013s (~) 0.548s 10 1.11x
💻 Local Nitro 2.615s (-2.6%) 3.007s (~) 0.393s 10 1.18x
🐘 Postgres Next.js (Turbopack) 2.673s 3.014s 0.341s 10 1.20x
🌐 MongoDB Next.js (Turbopack) 4.598s 5.176s 0.578s 6 2.07x

▲ Production (Vercel)

World Framework Workflow Time Wall Time Overhead Samples vs Fastest
▲ Vercel 🥇 Next.js (Turbopack) 2.513s (-6.6% 🟢) 3.798s (-1.3%) 1.285s 8 1.00x
▲ Vercel Nitro 2.634s (-4.5%) 4.156s (-4.3%) 1.523s 8 1.05x
▲ Vercel Express 2.647s (+6.9% 🔺) 4.066s (+0.8%) 1.419s 8 1.05x

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

Promise.all with 50 concurrent steps

💻 Local Development

World Framework Workflow Time Wall Time Overhead Samples vs Fastest
🐘 Postgres 🥇 Nitro 3.694s (-9.2% 🟢) 4.139s (-6.9% 🟢) 0.444s 8 1.00x
🌐 Redis Next.js (Turbopack) 3.837s 4.009s 0.172s 8 1.04x
🐘 Postgres Express 3.957s (-1.5%) 4.591s (~) 0.634s 7 1.07x
🐘 Postgres Next.js (Turbopack) 4.285s 5.018s 0.732s 6 1.16x
💻 Local Express 5.968s (-23.1% 🟢) 6.412s (-22.5% 🟢) 0.445s 5 1.62x
💻 Local Next.js (Turbopack) 7.075s 7.765s 0.691s 4 1.92x
💻 Local Nitro 7.418s (-4.7%) 8.021s (~) 0.603s 4 2.01x
🌐 MongoDB Next.js (Turbopack) 9.933s 10.351s 0.418s 3 2.69x

▲ Production (Vercel)

World Framework Workflow Time Wall Time Overhead Samples vs Fastest
▲ Vercel 🥇 Nitro 3.014s (-4.8%) 4.660s (+8.6% 🔺) 1.645s 7 1.00x
▲ Vercel Express 3.244s (-13.9% 🟢) 4.317s (-15.8% 🟢) 1.073s 7 1.08x
▲ Vercel Next.js (Turbopack) 3.357s (-7.5% 🟢) 4.684s (-8.0% 🟢) 1.327s 7 1.11x

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

Promise.race with 10 concurrent steps

💻 Local Development

World Framework Workflow Time Wall Time Overhead Samples vs Fastest
🌐 Redis 🥇 Next.js (Turbopack) 1.183s 2.006s 0.823s 15 1.00x
🐘 Postgres Nitro 1.284s (-5.6% 🟢) 2.011s (~) 0.727s 15 1.09x
🐘 Postgres Express 1.360s (~) 2.011s (~) 0.651s 15 1.15x
💻 Local Express 1.365s (-6.3% 🟢) 2.006s (~) 0.641s 15 1.15x
🐘 Postgres Next.js (Turbopack) 1.400s 2.012s 0.613s 15 1.18x
💻 Local Next.js (Turbopack) 1.431s 2.005s 0.574s 15 1.21x
💻 Local Nitro 1.446s (~) 2.005s (~) 0.559s 15 1.22x
🌐 MongoDB Next.js (Turbopack) 2.161s 3.008s 0.847s 10 1.83x

▲ Production (Vercel)

World Framework Workflow Time Wall Time Overhead Samples vs Fastest
▲ Vercel 🥇 Next.js (Turbopack) 2.127s (-2.4%) 3.448s (+1.7%) 1.321s 9 1.00x
▲ Vercel Nitro 2.185s (+6.0% 🔺) 3.770s (+4.7%) 1.585s 8 1.03x
▲ Vercel Express 2.287s (-2.6%) 3.911s (+3.1%) 1.624s 8 1.07x

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

Promise.race with 25 concurrent steps

💻 Local Development

World Framework Workflow Time Wall Time Overhead Samples vs Fastest
🌐 Redis 🥇 Next.js (Turbopack) 2.384s 3.008s 0.625s 10 1.00x
💻 Local Express 2.401s (-16.4% 🟢) 3.007s (-3.3%) 0.606s 10 1.01x
🐘 Postgres Nitro 2.404s (-5.2% 🟢) 3.011s (-3.3%) 0.607s 10 1.01x
🐘 Postgres Express 2.495s (+0.9%) 3.012s (~) 0.518s 10 1.05x
🐘 Postgres Next.js (Turbopack) 2.596s 3.013s 0.417s 10 1.09x
💻 Local Next.js (Turbopack) 2.600s 3.008s 0.408s 10 1.09x
💻 Local Nitro 2.722s (-2.1%) 3.008s (-3.2%) 0.286s 10 1.14x
🌐 MongoDB Next.js (Turbopack) 4.691s 5.177s 0.486s 6 1.97x

▲ Production (Vercel)

World Framework Workflow Time Wall Time Overhead Samples vs Fastest
▲ Vercel 🥇 Next.js (Turbopack) 2.403s (-12.8% 🟢) 3.304s (-14.7% 🟢) 0.902s 10 1.00x
▲ Vercel Nitro 2.562s (+4.3%) 4.258s (+10.0% 🔺) 1.696s 8 1.07x
▲ Vercel Express 2.819s (+2.2%) 4.602s (+5.3% 🔺) 1.783s 7 1.17x

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

Promise.race with 50 concurrent steps

💻 Local Development

World Framework Workflow Time Wall Time Overhead Samples vs Fastest
🐘 Postgres 🥇 Nitro 3.659s (-9.6% 🟢) 4.015s (-12.5% 🟢) 0.356s 8 1.00x
🌐 Redis Next.js (Turbopack) 3.849s 4.009s 0.160s 8 1.05x
🐘 Postgres Express 4.014s (+0.7%) 4.447s (~) 0.433s 7 1.10x
🐘 Postgres Next.js (Turbopack) 4.312s 5.016s 0.705s 6 1.18x
💻 Local Express 6.845s (-17.1% 🟢) 7.214s (-20.1% 🟢) 0.369s 5 1.87x
💻 Local Next.js (Turbopack) 7.112s 7.766s 0.655s 4 1.94x
💻 Local Nitro 7.899s (-6.9% 🟢) 8.022s (-11.0% 🟢) 0.124s 4 2.16x
🌐 MongoDB Next.js (Turbopack) 9.934s 10.348s 0.414s 3 2.72x

▲ Production (Vercel)

World Framework Workflow Time Wall Time Overhead Samples vs Fastest
▲ Vercel 🥇 Express 2.788s (-1.0%) 4.161s (+2.6%) 1.373s 8 1.00x
▲ Vercel Next.js (Turbopack) 3.101s (-0.9%) 4.374s (+1.0%) 1.273s 7 1.11x
▲ Vercel Nitro 3.395s (+10.1% 🔺) 4.848s (+7.5% 🔺) 1.454s 7 1.22x

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

Stream Benchmarks (includes TTFB metrics)
workflow with stream

💻 Local Development

World Framework Workflow Time TTFB Slurp Wall Time Overhead Samples vs Fastest
💻 Local 🥇 Express 0.107s (-38.5% 🟢) 1.003s (~) 0.010s (-15.4% 🟢) 1.016s (~) 0.908s 10 1.00x
🌐 Redis Next.js (Turbopack) 0.113s 1.000s 0.001s 1.007s 0.894s 10 1.05x
🐘 Postgres Nitro 0.127s (-32.9% 🟢) 0.999s (+0.6%) 0.001s (-13.3% 🟢) 1.011s (~) 0.884s 10 1.18x
💻 Local Next.js (Turbopack) 0.144s 1.002s 0.011s 1.017s 0.873s 10 1.34x
💻 Local Nitro 0.169s (-2.3%) 1.003s (~) 0.011s (-2.6%) 1.017s (~) 0.848s 10 1.57x
🐘 Postgres Express 0.183s (-3.3%) 0.996s (~) 0.002s (~) 1.012s (~) 0.829s 10 1.70x
🐘 Postgres Next.js (Turbopack) 0.193s 1.001s 0.002s 1.015s 0.822s 10 1.80x
🌐 MongoDB Next.js (Turbopack) 0.452s 0.988s 0.002s 1.008s 0.557s 10 4.20x

▲ Production (Vercel)

World Framework Workflow Time TTFB Slurp Wall Time Overhead Samples vs Fastest
▲ Vercel 🥇 Nitro 1.534s (+1.4%) 2.293s (-7.2% 🟢) 0.004s (-2.3%) 2.959s (-1.8%) 1.425s 10 1.00x
▲ Vercel Next.js (Turbopack) 1.553s (+4.0%) 2.213s (-14.6% 🟢) 0.004s (-10.2% 🟢) 2.697s (-10.7% 🟢) 1.144s 10 1.01x
▲ Vercel Express 1.648s (+3.3%) 2.320s (+2.0%) 0.005s (+8.5% 🔺) 2.858s (+2.1%) 1.211s 10 1.07x

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

Summary

Fastest Framework by World

Winner determined by most benchmark wins

World 🥇 Fastest Framework Wins
💻 Local Express 12/12
🐘 Postgres Nitro 12/12
▲ Vercel Next.js (Turbopack) 7/12
Fastest World by Framework

Winner determined by most benchmark wins

Framework 🥇 Fastest World Wins
Express 💻 Local 8/12
Next.js (Turbopack) 🌐 Redis 9/12
Nitro 🐘 Postgres 9/12
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)

📋 View full workflow run

@github-actions
Copy link
Contributor

github-actions bot commented Mar 12, 2026

🧪 E2E Test Results

Some tests failed

Summary

Passed Failed Skipped Total
✅ ▲ Vercel Production 560 0 67 627
✅ 💻 Local Development 600 0 84 684
✅ 📦 Local Production 600 0 84 684
✅ 🐘 Local Postgres 600 0 84 684
✅ 🪟 Windows 54 0 3 57
❌ 🌍 Community Worlds 116 55 15 186
✅ 📋 Other 144 0 27 171
Total 2674 55 364 3093

❌ Failed Tests

🌍 Community Worlds (55 failed)

mongodb (3 failed):

  • hookWorkflow is not resumable via public webhook endpoint
  • webhookWorkflow
  • concurrent hook token conflict - two workflows cannot use the same hook token simultaneously

redis (2 failed):

  • hookWorkflow is not resumable via public webhook endpoint
  • concurrent hook token conflict - two workflows cannot use the same hook token simultaneously

turso (50 failed):

  • addTenWorkflow
  • addTenWorkflow
  • wellKnownAgentWorkflow (.well-known/agent)
  • should work with react rendering in step
  • promiseAllWorkflow
  • promiseRaceWorkflow
  • promiseAnyWorkflow
  • importedStepOnlyWorkflow
  • hookWorkflow
  • hookWorkflow is not resumable via public webhook endpoint
  • webhookWorkflow
  • sleepingWorkflow
  • parallelSleepWorkflow
  • nullByteWorkflow
  • workflowAndStepMetadataWorkflow
  • fetchWorkflow
  • promiseRaceStressTestWorkflow
  • error handling error propagation workflow errors nested function calls preserve message and stack trace
  • error handling error propagation workflow errors cross-file imports preserve message and stack trace
  • error handling error propagation step errors basic step error preserves message and stack trace
  • error handling error propagation step errors cross-file step error preserves message and function names in stack
  • error handling retry behavior regular Error retries until success
  • error handling retry behavior FatalError fails immediately without retries
  • error handling retry behavior RetryableError respects custom retryAfter delay
  • error handling retry behavior maxRetries=0 disables retries
  • error handling catchability FatalError can be caught and detected with FatalError.is()
  • hookCleanupTestWorkflow - hook token reuse after workflow completion
  • concurrent hook token conflict - two workflows cannot use the same hook token simultaneously
  • hookDisposeTestWorkflow - hook token reuse after explicit disposal while workflow still running
  • stepFunctionPassingWorkflow - step function references can be passed as arguments (without closure vars)
  • stepFunctionWithClosureWorkflow - step function with closure variables passed as argument
  • closureVariableWorkflow - nested step functions with closure variables
  • spawnWorkflowFromStepWorkflow - spawning a child workflow using start() inside a step
  • health check (queue-based) - workflow and step endpoints respond to health check messages
  • pathsAliasWorkflow - TypeScript path aliases resolve correctly
  • Calculator.calculate - static workflow method using static step methods from another class
  • AllInOneService.processNumber - static workflow method using sibling static step methods
  • ChainableService.processWithThis - static step methods using this to reference the class
  • thisSerializationWorkflow - step function invoked with .call() and .apply()
  • customSerializationWorkflow - custom class serialization with WORKFLOW_SERIALIZE/WORKFLOW_DESERIALIZE
  • instanceMethodStepWorkflow - instance methods with "use step" directive
  • crossContextSerdeWorkflow - classes defined in step code are deserializable in workflow context
  • stepFunctionAsStartArgWorkflow - step function reference passed as start() argument
  • cancelRun - cancelling a running workflow
  • cancelRun via CLI - cancelling a running workflow
  • pages router addTenWorkflow via pages router
  • pages router promiseAllWorkflow via pages router
  • pages router sleepingWorkflow via pages router
  • hookWithSleepWorkflow - hook payloads delivered correctly with concurrent sleep
  • sleepWithSequentialStepsWorkflow - sequential steps work with concurrent sleep (control)

Details by Category

✅ ▲ Vercel Production
App Passed Failed Skipped
✅ astro 50 0 7
✅ example 50 0 7
✅ express 50 0 7
✅ fastify 50 0 7
✅ hono 50 0 7
✅ nextjs-turbopack 55 0 2
✅ nextjs-webpack 55 0 2
✅ nitro 50 0 7
✅ nuxt 50 0 7
✅ sveltekit 50 0 7
✅ vite 50 0 7
✅ 💻 Local Development
App Passed Failed Skipped
✅ astro-stable 48 0 9
✅ express-stable 48 0 9
✅ fastify-stable 48 0 9
✅ hono-stable 48 0 9
✅ nextjs-turbopack-canary 54 0 3
✅ nextjs-turbopack-stable 54 0 3
✅ nextjs-webpack-canary 54 0 3
✅ nextjs-webpack-stable 54 0 3
✅ nitro-stable 48 0 9
✅ nuxt-stable 48 0 9
✅ sveltekit-stable 48 0 9
✅ vite-stable 48 0 9
✅ 📦 Local Production
App Passed Failed Skipped
✅ astro-stable 48 0 9
✅ express-stable 48 0 9
✅ fastify-stable 48 0 9
✅ hono-stable 48 0 9
✅ nextjs-turbopack-canary 54 0 3
✅ nextjs-turbopack-stable 54 0 3
✅ nextjs-webpack-canary 54 0 3
✅ nextjs-webpack-stable 54 0 3
✅ nitro-stable 48 0 9
✅ nuxt-stable 48 0 9
✅ sveltekit-stable 48 0 9
✅ vite-stable 48 0 9
✅ 🐘 Local Postgres
App Passed Failed Skipped
✅ astro-stable 48 0 9
✅ express-stable 48 0 9
✅ fastify-stable 48 0 9
✅ hono-stable 48 0 9
✅ nextjs-turbopack-canary 54 0 3
✅ nextjs-turbopack-stable 54 0 3
✅ nextjs-webpack-canary 54 0 3
✅ nextjs-webpack-stable 54 0 3
✅ nitro-stable 48 0 9
✅ nuxt-stable 48 0 9
✅ sveltekit-stable 48 0 9
✅ vite-stable 48 0 9
✅ 🪟 Windows
App Passed Failed Skipped
✅ nextjs-turbopack 54 0 3
❌ 🌍 Community Worlds
App Passed Failed Skipped
✅ mongodb-dev 3 0 2
❌ mongodb 51 3 3
✅ redis-dev 3 0 2
❌ redis 52 2 3
✅ turso-dev 3 0 2
❌ turso 4 50 3
✅ 📋 Other
App Passed Failed Skipped
✅ e2e-local-dev-nest-stable 48 0 9
✅ e2e-local-postgres-nest-stable 48 0 9
✅ e2e-local-prod-nest-stable 48 0 9

📋 View full workflow run

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