Skip to content

[web] Fix server crash on unmatched routes#1590

Merged
VaguelySerious merged 2 commits into
mainfrom
peter/issue-1556
Apr 2, 2026
Merged

[web] Fix server crash on unmatched routes#1590
VaguelySerious merged 2 commits into
mainfrom
peter/issue-1556

Conversation

@VaguelySerious
Copy link
Copy Markdown
Member

Summary

  • Adds ErrorBoundary export to the root route so React Router renders 404s gracefully instead of failing during SSR
  • Adds Express error-handling middleware as a safety net to catch any errors that escape the React Router error boundary
  • Adds tests for the ErrorBoundary component

Closes #1556

Test plan

  • Unit tests for ErrorBoundary (404 and generic error states)
  • Manual: run workflow web, request /robots.txt — should get a 404 page, not a crash

🤖 Generated with Claude Code

VaguelySerious and others added 2 commits April 2, 2026 09:19
…utes

Fixes workflow web crashing (process.exit(1)) when requests hit URLs
without a matching React Router route (e.g. /robots.txt, /favicon.ico).

- Add root ErrorBoundary so React Router renders 404s gracefully
- Add Express error-handling middleware as a safety net for SSR failures

Co-Authored-By: Claude Opus 4.6 (1M context) <noreply@anthropic.com>
Co-Authored-By: Claude Opus 4.6 (1M context) <noreply@anthropic.com>
@vercel
Copy link
Copy Markdown
Contributor

vercel Bot commented Apr 2, 2026

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 Apr 2, 2026 4:21pm
example-nextjs-workflow-webpack Ready Ready Preview, Comment Apr 2, 2026 4:21pm
example-workflow Ready Ready Preview, Comment Apr 2, 2026 4:21pm
workbench-astro-workflow Ready Ready Preview, Comment Apr 2, 2026 4:21pm
workbench-express-workflow Ready Ready Preview, Comment Apr 2, 2026 4:21pm
workbench-fastify-workflow Ready Ready Preview, Comment Apr 2, 2026 4:21pm
workbench-hono-workflow Ready Ready Preview, Comment Apr 2, 2026 4:21pm
workbench-nitro-workflow Ready Ready Preview, Comment Apr 2, 2026 4:21pm
workbench-nuxt-workflow Ready Ready Preview, Comment Apr 2, 2026 4:21pm
workbench-sveltekit-workflow Ready Ready Preview, Comment Apr 2, 2026 4:21pm
workbench-vite-workflow Ready Ready Preview, Comment Apr 2, 2026 4:21pm
workflow-docs Ready Ready Preview, Comment, Open in v0 Apr 2, 2026 4:21pm
workflow-swc-playground Ready Ready Preview, Comment Apr 2, 2026 4:21pm

@github-actions
Copy link
Copy Markdown
Contributor

github-actions Bot commented Apr 2, 2026

🧪 E2E Test Results

Some tests failed

Summary

Passed Failed Skipped Total
✅ ▲ Vercel Production 857 0 67 924
✅ 💻 Local Development 830 0 178 1008
✅ 📦 Local Production 830 0 178 1008
✅ 🐘 Local Postgres 830 0 178 1008
✅ 🪟 Windows 76 0 8 84
❌ 🌍 Community Worlds 132 60 24 216
✅ 📋 Other 210 0 42 252
Total 3765 60 675 4500

❌ Failed Tests

🌍 Community Worlds (60 failed)

mongodb (3 failed):

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

redis (2 failed):

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

turso (55 failed):

  • addTenWorkflow | wrun_01KN7FZK6P05Q0EM3CKW3AGXGB
  • addTenWorkflow | wrun_01KN7FZK6P05Q0EM3CKW3AGXGB
  • wellKnownAgentWorkflow (.well-known/agent) | wrun_01KN7G170MVDHW319ACNJ2AJ8M
  • should work with react rendering in step
  • promiseAllWorkflow | wrun_01KN7FZT9JGJFN2C20C3PZ6JYB
  • promiseRaceWorkflow | wrun_01KN7FZZDPVNCTT0226G4FDPCK
  • promiseAnyWorkflow | wrun_01KN7G02F8PX0KJZ0W3YDHZGRM
  • importedStepOnlyWorkflow | wrun_01KN7G1KCB52HG9MJ1ZV77N6JK
  • hookWorkflow | wrun_01KN7G0GCJGW0PFWR2SPWB53MQ
  • hookWorkflow is not resumable via public webhook endpoint | wrun_01KN7G0T6JKTX6EEPKVDBBWSR0
  • webhookWorkflow | wrun_01KN7G12QW6ES82AYH5Z0SZMMS
  • sleepingWorkflow | wrun_01KN7G19CYHFXWG3P6WJQ5EJ4Q
  • parallelSleepWorkflow | wrun_01KN7G1N72N181ESV0P6GRKX06
  • nullByteWorkflow | wrun_01KN7G1SGKMPCBXRMFN3ETXAZS
  • workflowAndStepMetadataWorkflow | wrun_01KN7G1VK3F2VAMV083JZFANAD
  • fetchWorkflow | wrun_01KN7G4FX1XR76RWJN1GQYX4QR
  • promiseRaceStressTestWorkflow | wrun_01KN7G4K56H23SJPXF01CVV74S
  • 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()
  • error handling not registered WorkflowNotRegisteredError fails the run when workflow does not exist
  • error handling not registered StepNotRegisteredError fails the step but workflow can catch it
  • error handling not registered StepNotRegisteredError fails the run when not caught in workflow
  • hookCleanupTestWorkflow - hook token reuse after workflow completion | wrun_01KN7G7YR9SF8WZPYFCNEE7RFN
  • concurrent hook token conflict - two workflows cannot use the same hook token simultaneously | wrun_01KN7G8HPN0S85GV5GKYWT45QB
  • hookDisposeTestWorkflow - hook token reuse after explicit disposal while workflow still running | wrun_01KN7G95DT14D4CDT86DHSGW45
  • stepFunctionPassingWorkflow - step function references can be passed as arguments (without closure vars) | wrun_01KN7G9RB88G7BN6SRA8TWC883
  • stepFunctionWithClosureWorkflow - step function with closure variables passed as argument | wrun_01KN7GA04RJH3AAZTYB3BMH5G7
  • closureVariableWorkflow - nested step functions with closure variables | wrun_01KN7GA51NP9NBWCVBF2PTPM18
  • spawnWorkflowFromStepWorkflow - spawning a child workflow using start() inside a step | wrun_01KN7GA6XQGQHEG3WD9RDMA5DP
  • health check (queue-based) - workflow and step endpoints respond to health check messages
  • pathsAliasWorkflow - TypeScript path aliases resolve correctly | wrun_01KN7GAMR2VCA7C029X1EJSD9T
  • Calculator.calculate - static workflow method using static step methods from another class | wrun_01KN7GASK07A74961FYVTZPT7T
  • AllInOneService.processNumber - static workflow method using sibling static step methods | wrun_01KN7GAZF4RA016V4QTPGJ1WZP
  • ChainableService.processWithThis - static step methods using this to reference the class | wrun_01KN7GB59W7FD69D7DH4Y7AD8N
  • thisSerializationWorkflow - step function invoked with .call() and .apply() | wrun_01KN7GBBR53605292QT16BD6P6
  • customSerializationWorkflow - custom class serialization with WORKFLOW_SERIALIZE/WORKFLOW_DESERIALIZE | wrun_01KN7GBHQ0EYE6NENYS8EMDNSH
  • instanceMethodStepWorkflow - instance methods with "use step" directive | wrun_01KN7GBQK6DBQ25AN8RFKSRR8H
  • crossContextSerdeWorkflow - classes defined in step code are deserializable in workflow context | wrun_01KN7GC1MZEKDBGY83Q13N0M30
  • stepFunctionAsStartArgWorkflow - step function reference passed as start() argument | wrun_01KN7GC94AF0353QZKYRM6P0EA
  • cancelRun - cancelling a running workflow | wrun_01KN7GCEYZJ65DVZ4EKK9RJY2Z
  • cancelRun via CLI - cancelling a running workflow | wrun_01KN7GCQPR3R7NJ6S7B3A238JS
  • 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 | wrun_01KN7GD2PY0PMP6MCXQFJEKGXT
  • sleepInLoopWorkflow - sleep inside loop with steps actually delays each iteration | wrun_01KN7GDP36DREGDZ4Z8Z26PE9E
  • sleepWithSequentialStepsWorkflow - sequential steps work with concurrent sleep (control) | wrun_01KN7GE48CB6GZWQHKWK82W62J
  • importMetaUrlWorkflow - import.meta.url is available in step bundles | wrun_01KN7GEA1S92RRK1QY6P3WNZN9

Details by Category

✅ ▲ Vercel Production
App Passed Failed Skipped
✅ astro 77 0 7
✅ example 77 0 7
✅ express 77 0 7
✅ fastify 77 0 7
✅ hono 77 0 7
✅ nextjs-turbopack 82 0 2
✅ nextjs-webpack 82 0 2
✅ nitro 77 0 7
✅ nuxt 77 0 7
✅ sveltekit 77 0 7
✅ vite 77 0 7
✅ 💻 Local Development
App Passed Failed Skipped
✅ astro-stable 70 0 14
✅ express-stable 70 0 14
✅ fastify-stable 70 0 14
✅ hono-stable 70 0 14
✅ nextjs-turbopack-canary 59 0 25
✅ nextjs-turbopack-stable 76 0 8
✅ nextjs-webpack-canary 59 0 25
✅ nextjs-webpack-stable 76 0 8
✅ nitro-stable 70 0 14
✅ nuxt-stable 70 0 14
✅ sveltekit-stable 70 0 14
✅ vite-stable 70 0 14
✅ 📦 Local Production
App Passed Failed Skipped
✅ astro-stable 70 0 14
✅ express-stable 70 0 14
✅ fastify-stable 70 0 14
✅ hono-stable 70 0 14
✅ nextjs-turbopack-canary 59 0 25
✅ nextjs-turbopack-stable 76 0 8
✅ nextjs-webpack-canary 59 0 25
✅ nextjs-webpack-stable 76 0 8
✅ nitro-stable 70 0 14
✅ nuxt-stable 70 0 14
✅ sveltekit-stable 70 0 14
✅ vite-stable 70 0 14
✅ 🐘 Local Postgres
App Passed Failed Skipped
✅ astro-stable 70 0 14
✅ express-stable 70 0 14
✅ fastify-stable 70 0 14
✅ hono-stable 70 0 14
✅ nextjs-turbopack-canary 59 0 25
✅ nextjs-turbopack-stable 76 0 8
✅ nextjs-webpack-canary 59 0 25
✅ nextjs-webpack-stable 76 0 8
✅ nitro-stable 70 0 14
✅ nuxt-stable 70 0 14
✅ sveltekit-stable 70 0 14
✅ vite-stable 70 0 14
✅ 🪟 Windows
App Passed Failed Skipped
✅ nextjs-turbopack 76 0 8
❌ 🌍 Community Worlds
App Passed Failed Skipped
✅ mongodb-dev 5 0 0
❌ mongodb 56 3 8
✅ redis-dev 5 0 0
❌ redis 57 2 8
✅ turso-dev 5 0 0
❌ turso 4 55 8
✅ 📋 Other
App Passed Failed Skipped
✅ e2e-local-dev-nest-stable 70 0 14
✅ e2e-local-postgres-nest-stable 70 0 14
✅ e2e-local-prod-nest-stable 70 0 14

📋 View full workflow run

@github-actions
Copy link
Copy Markdown
Contributor

github-actions Bot commented Apr 2, 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.042s (-6.0% 🟢) 1.005s (~) 0.963s 10 1.00x
💻 Local Nitro 0.042s (-4.5%) 1.005s (~) 0.963s 10 1.00x
🌐 Redis Next.js (Turbopack) 0.053s (+20.1% 🔺) 1.005s (~) 0.952s 10 1.25x
🐘 Postgres Next.js (Turbopack) 0.058s (-13.0% 🟢) 1.011s (~) 0.953s 10 1.38x
🐘 Postgres Express 0.059s (-14.6% 🟢) 1.010s (~) 0.951s 10 1.39x
🐘 Postgres Nitro 0.062s (-11.5% 🟢) 1.011s (~) 0.949s 10 1.46x
🌐 MongoDB Next.js (Turbopack) 0.104s (-17.3% 🟢) 1.009s (~) 0.904s 10 2.46x
💻 Local Next.js (Turbopack) ⚠️ missing - - - -

▲ Production (Vercel)

World Framework Workflow Time Wall Time Overhead Samples vs Fastest
▲ Vercel 🥇 Next.js (Turbopack) 0.483s (-18.6% 🟢) 2.203s (-10.6% 🟢) 1.719s 10 1.00x
▲ Vercel Nitro 0.510s (-2.8%) 2.459s (-10.5% 🟢) 1.950s 10 1.06x
▲ Vercel Express 0.513s (+1.8%) 2.672s (-0.8%) 2.159s 10 1.06x

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

workflow with 1 step

💻 Local Development

World Framework Workflow Time Wall Time Overhead Samples vs Fastest
🌐 Redis 🥇 Next.js (Turbopack) 1.122s (+0.8%) 2.007s (~) 0.885s 10 1.00x
💻 Local Nitro 1.128s (~) 2.005s (~) 0.877s 10 1.01x
💻 Local Express 1.131s (~) 2.006s (~) 0.875s 10 1.01x
🐘 Postgres Next.js (Turbopack) 1.138s (-0.6%) 2.011s (~) 0.873s 10 1.01x
🐘 Postgres Express 1.148s (~) 2.011s (~) 0.863s 10 1.02x
🐘 Postgres Nitro 1.160s (+0.7%) 2.012s (~) 0.852s 10 1.03x
🌐 MongoDB Next.js (Turbopack) 1.322s (~) 2.010s (~) 0.687s 10 1.18x
💻 Local Next.js (Turbopack) ⚠️ missing - - - -

▲ Production (Vercel)

World Framework Workflow Time Wall Time Overhead Samples vs Fastest
▲ Vercel 🥇 Next.js (Turbopack) 2.121s (+1.4%) 3.442s (-11.8% 🟢) 1.322s 10 1.00x
▲ Vercel Nitro 2.219s (+6.6% 🔺) 4.002s (+2.7%) 1.783s 10 1.05x
▲ Vercel Express 2.222s (-1.9%) 3.898s (-1.5%) 1.677s 10 1.05x

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

workflow with 10 sequential steps

💻 Local Development

World Framework Workflow Time Wall Time Overhead Samples vs Fastest
🌐 Redis 🥇 Next.js (Turbopack) 10.741s (+1.4%) 11.022s (~) 0.281s 3 1.00x
🐘 Postgres Next.js (Turbopack) 10.849s (-0.7%) 11.017s (~) 0.168s 3 1.01x
🐘 Postgres Express 10.860s (-0.8%) 11.024s (~) 0.165s 3 1.01x
🐘 Postgres Nitro 10.890s (~) 11.020s (~) 0.130s 3 1.01x
💻 Local Nitro 10.921s (~) 11.023s (~) 0.102s 3 1.02x
💻 Local Express 10.922s (~) 11.022s (~) 0.100s 3 1.02x
🌐 MongoDB Next.js (Turbopack) 12.261s (~) 13.023s (~) 0.762s 3 1.14x
💻 Local Next.js (Turbopack) ⚠️ missing - - - -

▲ Production (Vercel)

World Framework Workflow Time Wall Time Overhead Samples vs Fastest
▲ Vercel 🥇 Nitro 17.762s (-22.9% 🟢) 20.148s (-20.7% 🟢) 2.386s 2 1.00x
▲ Vercel Next.js (Turbopack) 17.861s (+4.5%) 19.086s (~) 1.225s 2 1.01x
▲ Vercel Express 20.633s (+17.6% 🔺) 21.940s (+11.6% 🔺) 1.307s 2 1.16x

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

workflow with 25 sequential steps

💻 Local Development

World Framework Workflow Time Wall Time Overhead Samples vs Fastest
🌐 Redis 🥇 Next.js (Turbopack) 14.271s (+2.8%) 15.028s (+5.6% 🔺) 0.757s 4 1.00x
🐘 Postgres Next.js (Turbopack) 14.393s (-0.6%) 15.025s (~) 0.631s 4 1.01x
🐘 Postgres Express 14.480s (-0.9%) 15.024s (~) 0.544s 4 1.01x
🐘 Postgres Nitro 14.579s (~) 15.023s (~) 0.444s 4 1.02x
💻 Local Nitro 14.941s (~) 15.029s (~) 0.088s 4 1.05x
💻 Local Express 14.956s (~) 15.028s (~) 0.072s 4 1.05x
🌐 MongoDB Next.js (Turbopack) 17.897s (~) 18.028s (~) 0.130s 4 1.25x
💻 Local Next.js (Turbopack) ⚠️ missing - - - -

▲ Production (Vercel)

World Framework Workflow Time Wall Time Overhead Samples vs Fastest
▲ Vercel 🥇 Express 30.305s (-13.4% 🟢) 32.123s (-12.8% 🟢) 1.817s 2 1.00x
▲ Vercel Nitro 31.764s (-1.2%) 33.422s (-2.1%) 1.658s 2 1.05x
▲ Vercel Next.js (Turbopack) 32.917s (-0.7%) 34.224s (-2.4%) 1.307s 2 1.09x

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

workflow with 50 sequential steps

💻 Local Development

World Framework Workflow Time Wall Time Overhead Samples vs Fastest
🌐 Redis 🥇 Next.js (Turbopack) 13.374s (+6.0% 🔺) 14.025s (+7.7% 🔺) 0.651s 7 1.00x
🐘 Postgres Next.js (Turbopack) 13.654s (-2.1%) 14.024s (-1.0%) 0.370s 7 1.02x
🐘 Postgres Express 13.927s (-3.3%) 14.307s (-4.8%) 0.381s 7 1.04x
🐘 Postgres Nitro 14.026s (-0.5%) 14.450s (-1.9%) 0.424s 7 1.05x
💻 Local Nitro 16.656s (+0.6%) 17.031s (~) 0.375s 6 1.25x
💻 Local Express 16.796s (+1.0%) 17.197s (+1.0%) 0.401s 6 1.26x
🌐 MongoDB Next.js (Turbopack) 20.483s (~) 21.034s (~) 0.551s 5 1.53x
💻 Local Next.js (Turbopack) ⚠️ missing - - - -

▲ Production (Vercel)

World Framework Workflow Time Wall Time Overhead Samples vs Fastest
▲ Vercel 🥇 Next.js (Turbopack) 52.950s (-11.5% 🟢) 54.492s (-11.5% 🟢) 1.541s 2 1.00x
▲ Vercel Nitro 53.743s (-6.6% 🟢) 55.996s (-6.6% 🟢) 2.253s 2 1.01x
▲ Vercel Express 54.846s (-2.3%) 57.173s (-1.7%) 2.326s 2 1.04x

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

Promise.all with 10 concurrent steps

💻 Local Development

World Framework Workflow Time Wall Time Overhead Samples vs Fastest
🐘 Postgres 🥇 Next.js (Turbopack) 1.241s (~) 2.009s (~) 0.768s 15 1.00x
🐘 Postgres Express 1.268s (~) 2.010s (~) 0.742s 15 1.02x
🐘 Postgres Nitro 1.281s (+1.4%) 2.011s (~) 0.730s 15 1.03x
🌐 Redis Next.js (Turbopack) 1.309s (+6.9% 🔺) 2.006s (~) 0.697s 15 1.05x
💻 Local Express 1.505s (-2.2%) 2.006s (~) 0.500s 15 1.21x
💻 Local Nitro 1.525s (-0.6%) 2.005s (~) 0.480s 15 1.23x
🌐 MongoDB Next.js (Turbopack) 2.215s (+2.5%) 3.009s (~) 0.794s 10 1.78x
💻 Local Next.js (Turbopack) ⚠️ missing - - - -

▲ Production (Vercel)

World Framework Workflow Time Wall Time Overhead Samples vs Fastest
▲ Vercel 🥇 Nitro 3.104s (+27.4% 🔺) 4.660s (+15.4% 🔺) 1.555s 7 1.00x
▲ Vercel Next.js (Turbopack) 3.192s (+22.7% 🔺) 4.618s (+13.7% 🔺) 1.427s 7 1.03x
▲ Vercel Express 3.239s (+25.1% 🔺) 4.831s (+7.8% 🔺) 1.592s 7 1.04x

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

Promise.all with 25 concurrent steps

💻 Local Development

World Framework Workflow Time Wall Time Overhead Samples vs Fastest
🐘 Postgres 🥇 Express 2.321s (-1.9%) 3.011s (~) 0.690s 10 1.00x
🐘 Postgres Nitro 2.335s (-0.6%) 3.010s (~) 0.675s 10 1.01x
🐘 Postgres Next.js (Turbopack) 2.388s (-2.2%) 3.012s (~) 0.624s 10 1.03x
🌐 Redis Next.js (Turbopack) 2.537s (+5.4% 🔺) 3.008s (~) 0.471s 10 1.09x
💻 Local Express 2.886s (-1.4%) 3.107s (+3.3%) 0.221s 10 1.24x
💻 Local Nitro 2.924s (-1.4%) 3.208s (-7.1% 🟢) 0.284s 10 1.26x
🌐 MongoDB Next.js (Turbopack) 8.649s (+81.6% 🔺) 9.267s (+78.9% 🔺) 0.618s 4 3.73x
💻 Local Next.js (Turbopack) ⚠️ missing - - - -

▲ Production (Vercel)

World Framework Workflow Time Wall Time Overhead Samples vs Fastest
▲ Vercel 🥇 Nitro 2.527s (-11.2% 🟢) 4.199s (-1.6%) 1.671s 8 1.00x
▲ Vercel Express 3.310s (+26.0% 🔺) 4.857s (+11.3% 🔺) 1.547s 7 1.31x
▲ Vercel Next.js (Turbopack) 5.393s (+48.4% 🔺) 6.654s (+30.6% 🔺) 1.261s 5 2.13x

🔍 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 🥇 Express 3.468s (-0.6%) 4.012s (~) 0.544s 8 1.00x
🐘 Postgres Nitro 3.471s (~) 4.011s (~) 0.541s 8 1.00x
🐘 Postgres Next.js (Turbopack) 3.658s (~) 4.010s (~) 0.352s 8 1.05x
🌐 Redis Next.js (Turbopack) 4.092s (+4.7%) 4.868s (+17.7% 🔺) 0.776s 7 1.18x
💻 Local Express 8.102s (-0.7%) 8.772s (-2.8%) 0.670s 4 2.34x
💻 Local Nitro 8.127s (+1.1%) 9.021s (+5.8% 🔺) 0.893s 4 2.34x
🌐 MongoDB Next.js (Turbopack) 19.700s (+95.8% 🔺) 20.530s (+92.2% 🔺) 0.830s 2 5.68x
💻 Local Next.js (Turbopack) ⚠️ missing - - - -

▲ Production (Vercel)

World Framework Workflow Time Wall Time Overhead Samples vs Fastest
▲ Vercel 🥇 Express 3.012s (-17.6% 🟢) 4.873s (-14.2% 🟢) 1.861s 7 1.00x
▲ Vercel Nitro 3.285s (+8.2% 🔺) 5.032s (~) 1.747s 7 1.09x
▲ Vercel Next.js (Turbopack) 3.870s (+1.2%) 5.358s (-8.4% 🟢) 1.487s 6 1.29x

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

Promise.race with 10 concurrent steps

💻 Local Development

World Framework Workflow Time Wall Time Overhead Samples vs Fastest
🐘 Postgres 🥇 Next.js (Turbopack) 1.221s (-1.1%) 2.011s (~) 0.790s 15 1.00x
🐘 Postgres Nitro 1.257s (-0.9%) 2.010s (~) 0.753s 15 1.03x
🐘 Postgres Express 1.258s (~) 2.010s (~) 0.752s 15 1.03x
🌐 Redis Next.js (Turbopack) 1.313s (+6.6% 🔺) 2.006s (~) 0.693s 15 1.08x
💻 Local Nitro 1.520s (-3.5%) 2.006s (~) 0.486s 15 1.24x
💻 Local Express 1.544s (-0.8%) 2.005s (~) 0.462s 15 1.26x
🌐 MongoDB Next.js (Turbopack) 3.330s (+54.3% 🔺) 3.760s (+25.0% 🔺) 0.430s 8 2.73x
💻 Local Next.js (Turbopack) ⚠️ missing - - - -

▲ Production (Vercel)

World Framework Workflow Time Wall Time Overhead Samples vs Fastest
▲ Vercel 🥇 Nitro 2.237s (-8.6% 🟢) 4.033s (+0.9%) 1.796s 8 1.00x
▲ Vercel Express 2.329s (~) 4.171s (+4.1%) 1.843s 8 1.04x
▲ Vercel Next.js (Turbopack) 2.369s (~) 3.835s (-3.9%) 1.466s 8 1.06x

🔍 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 🥇 Express 2.331s (+0.5%) 3.011s (~) 0.680s 10 1.00x
🐘 Postgres Nitro 2.378s (+0.9%) 3.010s (~) 0.633s 10 1.02x
🐘 Postgres Next.js (Turbopack) 2.389s (~) 3.010s (~) 0.621s 10 1.02x
🌐 Redis Next.js (Turbopack) 2.570s (+6.4% 🔺) 3.008s (~) 0.439s 10 1.10x
💻 Local Express 3.027s (-3.1%) 3.759s (-3.3%) 0.732s 8 1.30x
💻 Local Nitro 3.140s (+3.0%) 3.886s (~) 0.745s 8 1.35x
🌐 MongoDB Next.js (Turbopack) 9.466s (+98.7% 🔺) 10.016s (+93.5% 🔺) 0.550s 3 4.06x
💻 Local Next.js (Turbopack) ⚠️ missing - - - -

▲ Production (Vercel)

World Framework Workflow Time Wall Time Overhead Samples vs Fastest
▲ Vercel 🥇 Express 2.863s (-2.1%) 4.163s (-8.4% 🟢) 1.300s 8 1.00x
▲ Vercel Nitro 3.002s (+3.6%) 4.698s (+8.9% 🔺) 1.696s 7 1.05x
▲ Vercel Next.js (Turbopack) 3.137s (+0.7%) 4.576s (-2.1%) 1.439s 7 1.10x

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

Promise.race with 50 concurrent steps

💻 Local Development

World Framework Workflow Time Wall Time Overhead Samples vs Fastest
🐘 Postgres 🥇 Express 3.466s (~) 4.010s (~) 0.544s 8 1.00x
🐘 Postgres Nitro 3.475s (-0.6%) 4.012s (~) 0.538s 8 1.00x
🐘 Postgres Next.js (Turbopack) 3.653s (-1.0%) 4.015s (~) 0.362s 8 1.05x
🌐 Redis Next.js (Turbopack) 4.119s (+5.2% 🔺) 5.011s (+12.9% 🔺) 0.892s 6 1.19x
💻 Local Nitro 8.897s (+3.2%) 9.274s (+2.8%) 0.377s 4 2.57x
💻 Local Express 8.923s (+0.8%) 9.273s (~) 0.349s 4 2.57x
🌐 MongoDB Next.js (Turbopack) 20.239s (+101.4% 🔺) 21.026s (+96.8% 🔺) 0.787s 2 5.84x
💻 Local Next.js (Turbopack) ⚠️ missing - - - -

▲ Production (Vercel)

World Framework Workflow Time Wall Time Overhead Samples vs Fastest
▲ Vercel 🥇 Nitro 3.563s (+6.9% 🔺) 5.258s (+9.6% 🔺) 1.695s 6 1.00x
▲ Vercel Next.js (Turbopack) 3.673s (-3.3%) 5.216s (-8.4% 🟢) 1.542s 6 1.03x
▲ Vercel Express 3.823s (+29.6% 🔺) 5.668s (+27.1% 🔺) 1.845s 6 1.07x

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

workflow with 10 sequential data payload steps (10KB)

💻 Local Development

World Framework Workflow Time Wall Time Overhead Samples vs Fastest
🌐 Redis 🥇 Next.js (Turbopack) 0.702s (+22.6% 🔺) 1.005s (-1.6%) 0.302s 60 1.00x
🐘 Postgres Next.js (Turbopack) 0.753s (-6.6% 🟢) 1.007s (~) 0.253s 60 1.07x
🐘 Postgres Express 0.819s (-2.6%) 1.007s (~) 0.187s 60 1.17x
🐘 Postgres Nitro 0.847s (~) 1.024s (+1.7%) 0.177s 59 1.21x
💻 Local Express 0.979s (~) 1.136s (-3.8%) 0.157s 53 1.39x
💻 Local Nitro 0.991s (~) 1.204s (+2.0%) 0.214s 50 1.41x
🌐 MongoDB Next.js (Turbopack) 2.147s (+0.5%) 3.008s (~) 0.861s 20 3.06x
💻 Local Next.js (Turbopack) ⚠️ missing - - - -

▲ Production (Vercel)

World Framework Workflow Time Wall Time Overhead Samples vs Fastest
▲ Vercel 🥇 Nitro 10.936s (+6.6% 🔺) 12.544s (+2.5%) 1.608s 5 1.00x
▲ Vercel Next.js (Turbopack) 11.179s (-2.0%) 12.483s (-7.0% 🟢) 1.304s 6 1.02x
▲ Vercel Express 11.403s (+13.6% 🔺) 13.328s (+9.9% 🔺) 1.925s 5 1.04x

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

workflow with 25 sequential data payload steps (10KB)

💻 Local Development

World Framework Workflow Time Wall Time Overhead Samples vs Fastest
🌐 Redis 🥇 Next.js (Turbopack) 1.713s (+32.2% 🔺) 2.028s (+1.1%) 0.316s 45 1.00x
🐘 Postgres Next.js (Turbopack) 1.839s (-6.6% 🟢) 2.008s (-11.1% 🟢) 0.169s 45 1.07x
🐘 Postgres Nitro 1.987s (-2.1%) 2.404s (-11.5% 🟢) 0.417s 38 1.16x
🐘 Postgres Express 2.006s (-0.7%) 2.495s (-5.4% 🟢) 0.489s 37 1.17x
💻 Local Express 2.994s (-1.3%) 3.509s (-2.2%) 0.515s 26 1.75x
💻 Local Nitro 3.027s (~) 3.649s (+1.1%) 0.622s 25 1.77x
🌐 MongoDB Next.js (Turbopack) 5.274s (+1.1%) 6.013s (~) 0.739s 15 3.08x
💻 Local Next.js (Turbopack) ⚠️ missing - - - -

▲ Production (Vercel)

World Framework Workflow Time Wall Time Overhead Samples vs Fastest
▲ Vercel 🥇 Express 30.296s (-10.8% 🟢) 32.068s (-9.9% 🟢) 1.772s 3 1.00x
▲ Vercel Next.js (Turbopack) 33.857s (-1.4%) 35.336s (-1.9%) 1.479s 3 1.12x
▲ Vercel Nitro 35.587s (+3.8%) 37.416s (+3.1%) 1.830s 3 1.17x

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

workflow with 50 sequential data payload steps (10KB)

💻 Local Development

World Framework Workflow Time Wall Time Overhead Samples vs Fastest
🌐 Redis 🥇 Next.js (Turbopack) 3.348s (+27.8% 🔺) 4.009s (+31.1% 🔺) 0.660s 30 1.00x
🐘 Postgres Next.js (Turbopack) 3.724s (-5.3% 🟢) 4.010s (-5.7% 🟢) 0.287s 30 1.11x
🐘 Postgres Nitro 4.020s (-2.0%) 4.456s (-7.4% 🟢) 0.436s 27 1.20x
🐘 Postgres Express 4.042s (-2.0%) 4.627s (-4.6%) 0.585s 26 1.21x
💻 Local Express 9.116s (-0.9%) 9.710s (-3.1%) 0.593s 13 2.72x
💻 Local Nitro 9.265s (+1.2%) 9.941s (+1.6%) 0.676s 13 2.77x
🌐 MongoDB Next.js (Turbopack) 10.816s (+0.6%) 11.109s (~) 0.294s 11 3.23x
💻 Local Next.js (Turbopack) ⚠️ missing - - - -

▲ Production (Vercel)

World Framework Workflow Time Wall Time Overhead Samples vs Fastest
▲ Vercel 🥇 Express 77.420s (-10.5% 🟢) 79.315s (-10.4% 🟢) 1.895s 2 1.00x
▲ Vercel Nitro 78.010s (-11.1% 🟢) 79.578s (-11.3% 🟢) 1.568s 2 1.01x
▲ Vercel Next.js (Turbopack) 78.933s (-14.3% 🟢) 80.751s (-13.9% 🟢) 1.819s 2 1.02x

🔍 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 🥇 Next.js (Turbopack) 0.250s (-4.9%) 1.008s (~) 0.757s 60 1.00x
🐘 Postgres Nitro 0.279s (-5.7% 🟢) 1.008s (~) 0.729s 60 1.11x
🌐 Redis Next.js (Turbopack) 0.280s (+5.1% 🔺) 1.004s (~) 0.724s 60 1.12x
🐘 Postgres Express 0.281s (-5.0%) 1.008s (~) 0.727s 60 1.12x
💻 Local Express 0.575s (-5.8% 🟢) 1.004s (-1.7%) 0.430s 60 2.29x
💻 Local Nitro 0.618s (+6.6% 🔺) 1.005s (~) 0.387s 60 2.47x
🌐 MongoDB Next.js (Turbopack) 3.221s (+90.0% 🔺) 3.884s (+80.6% 🔺) 0.663s 16 12.86x
💻 Local Next.js (Turbopack) ⚠️ missing - - - -

▲ Production (Vercel)

World Framework Workflow Time Wall Time Overhead Samples vs Fastest
▲ Vercel 🥇 Express 1.635s (-6.2% 🟢) 3.076s (-7.2% 🟢) 1.442s 21 1.00x
▲ Vercel Nitro 1.915s (+13.4% 🔺) 3.643s (+7.2% 🔺) 1.728s 17 1.17x
▲ Vercel Next.js (Turbopack) 2.212s (+10.4% 🔺) 3.693s (+0.9%) 1.481s 17 1.35x

🔍 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 🥇 Next.js (Turbopack) 0.468s (-6.3% 🟢) 1.007s (~) 0.539s 90 1.00x
🐘 Postgres Nitro 0.491s (-4.9%) 1.008s (~) 0.517s 90 1.05x
🐘 Postgres Express 0.507s (-3.2%) 1.008s (~) 0.501s 90 1.08x
🌐 Redis Next.js (Turbopack) 1.140s (+5.6% 🔺) 2.006s (+7.7% 🔺) 0.866s 45 2.44x
💻 Local Express 2.495s (-1.5%) 3.009s (~) 0.514s 30 5.33x
💻 Local Nitro 2.538s (-0.6%) 3.009s (~) 0.470s 30 5.42x
🌐 MongoDB Next.js (Turbopack) 9.594s (+101.7% 🔺) 10.126s (+93.5% 🔺) 0.532s 9 20.49x
💻 Local Next.js (Turbopack) ⚠️ missing - - - -

▲ Production (Vercel)

World Framework Workflow Time Wall Time Overhead Samples vs Fastest
▲ Vercel 🥇 Nitro 3.091s (-23.9% 🟢) 4.749s (-15.9% 🟢) 1.658s 19 1.00x
▲ Vercel Express 3.210s (+2.2%) 4.777s (-2.1%) 1.567s 20 1.04x
▲ Vercel Next.js (Turbopack) 4.081s (-92.7% 🟢) 5.486s (-90.5% 🟢) 1.405s 17 1.32x

🔍 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 🥇 Next.js (Turbopack) 0.741s (-3.2%) 1.007s (~) 0.266s 120 1.00x
🐘 Postgres Nitro 0.785s (-2.1%) 1.008s (~) 0.224s 119 1.06x
🐘 Postgres Express 0.791s (-3.8%) 1.009s (~) 0.218s 119 1.07x
🌐 Redis Next.js (Turbopack) 2.717s (+4.7%) 3.033s (+0.8%) 0.316s 40 3.67x
💻 Local Express 11.122s (-1.2%) 11.663s (-1.5%) 0.542s 11 15.01x
💻 Local Nitro 11.140s (~) 11.939s (+1.6%) 0.799s 11 15.03x
🌐 MongoDB Next.js (Turbopack) 20.208s (+102.2% 🔺) 20.526s (+95.2% 🔺) 0.318s 6 27.27x
💻 Local Next.js (Turbopack) ⚠️ missing - - - -

▲ Production (Vercel)

World Framework Workflow Time Wall Time Overhead Samples vs Fastest
▲ Vercel 🥇 Express 7.258s (-6.7% 🟢) 9.142s (-1.9%) 1.884s 14 1.00x
▲ Vercel Nitro 7.403s (-10.5% 🟢) 9.389s (-7.2% 🟢) 1.986s 13 1.02x
▲ Vercel Next.js (Turbopack) 10.621s (+34.6% 🔺) 12.095s (+25.7% 🔺) 1.474s 10 1.46x

🔍 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
🌐 Redis 🥇 Next.js (Turbopack) 0.177s (+25.9% 🔺) 1.000s (~) 0.001s (+7.7% 🔺) 1.008s (~) 0.831s 10 1.00x
🐘 Postgres Next.js (Turbopack) 0.194s (-2.6%) 1.001s (~) 0.001s (~) 1.010s (~) 0.817s 10 1.09x
💻 Local Express 0.200s (-3.8%) 1.003s (~) 0.011s (-8.3% 🟢) 1.017s (~) 0.817s 10 1.13x
💻 Local Nitro 0.206s (+1.6%) 1.004s (~) 0.012s (+7.3% 🔺) 1.017s (~) 0.811s 10 1.17x
🐘 Postgres Express 0.208s (-5.8% 🟢) 0.993s (~) 0.002s (+14.3% 🔺) 1.011s (~) 0.803s 10 1.17x
🐘 Postgres Nitro 0.210s (-1.0%) 0.995s (~) 0.002s (+25.0% 🔺) 1.010s (~) 0.800s 10 1.19x
🌐 MongoDB Next.js (Turbopack) 0.503s (~) 0.956s (~) 0.001s (-23.5% 🟢) 1.009s (~) 0.507s 10 2.84x
💻 Local Next.js (Turbopack) ⚠️ missing - - - - -

▲ Production (Vercel)

World Framework Workflow Time TTFB Slurp Wall Time Overhead Samples vs Fastest
▲ Vercel 🥇 Next.js (Turbopack) 1.617s (-2.9%) 2.792s (-1.9%) 0.649s (+4.5%) 3.931s (-5.5% 🟢) 2.314s 10 1.00x
▲ Vercel Nitro 2.024s (+22.0% 🔺) 3.181s (+10.8% 🔺) 0.393s (-29.9% 🟢) 4.242s (+3.3%) 2.217s 10 1.25x
▲ Vercel Express 2.086s (+20.1% 🔺) 3.341s (+7.3% 🔺) 0.288s (-54.9% 🟢) 4.270s (-6.5% 🟢) 2.184s 10 1.29x

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

stream pipeline with 5 transform steps (1MB)

💻 Local Development

World Framework Workflow Time TTFB Slurp Wall Time Overhead Samples vs Fastest
🌐 Redis 🥇 Next.js (Turbopack) 0.490s (+28.9% 🔺) 1.001s (~) 0.005s (+65.9% 🔺) 1.013s (~) 0.523s 60 1.00x
🐘 Postgres Next.js (Turbopack) 0.597s (-2.6%) 1.008s (~) 0.006s (+66.2% 🔺) 1.025s (~) 0.428s 59 1.22x
🐘 Postgres Express 0.615s (-1.2%) 1.004s (~) 0.004s (~) 1.023s (~) 0.408s 59 1.26x
🐘 Postgres Nitro 0.617s (-1.0%) 1.004s (~) 0.004s (-8.2% 🟢) 1.026s (~) 0.408s 59 1.26x
💻 Local Express 0.726s (~) 1.010s (~) 0.009s (+10.8% 🔺) 1.022s (~) 0.297s 59 1.48x
💻 Local Nitro 0.733s (+0.7%) 1.010s (~) 0.010s (+17.5% 🔺) 1.024s (~) 0.291s 59 1.50x
🌐 MongoDB Next.js (Turbopack) 1.325s (~) 1.954s (~) 0.002s (-24.0% 🟢) 2.013s (~) 0.687s 30 2.71x
💻 Local Next.js (Turbopack) ⚠️ missing - - - - -

▲ Production (Vercel)

World Framework Workflow Time TTFB Slurp Wall Time Overhead Samples vs Fastest
▲ Vercel 🥇 Nitro 4.263s (+3.2%) 5.819s (+9.1% 🔺) 0.294s (+24.6% 🔺) 6.785s (+8.1% 🔺) 2.522s 9 1.00x
▲ Vercel Express 4.328s (+2.7%) 5.560s (+1.3%) 0.243s (-50.7% 🟢) 6.555s (-1.1%) 2.227s 10 1.02x
▲ Vercel Next.js (Turbopack) 7.113s (+16.9% 🔺) 7.969s (+3.9%) 0.353s (+54.5% 🔺) 9.127s (+5.9% 🔺) 2.015s 7 1.67x

🔍 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
🌐 Redis 🥇 Next.js (Turbopack) 0.902s (+7.2% 🔺) 1.017s (+1.7%) 0.000s (+154.2% 🔺) 1.021s (+1.7%) 0.120s 59 1.00x
🐘 Postgres Next.js (Turbopack) 0.925s (-5.5% 🟢) 1.110s (-15.0% 🟢) 0.000s (+67.3% 🔺) 1.117s (-14.9% 🟢) 0.192s 55 1.03x
🐘 Postgres Nitro 0.943s (-5.8% 🟢) 1.125s (-17.0% 🟢) 0.000s (-37.7% 🟢) 1.141s (-17.3% 🟢) 0.198s 53 1.05x
🐘 Postgres Express 0.960s (-0.8%) 1.125s (-8.1% 🟢) 0.000s (+171.7% 🔺) 1.146s (-8.4% 🟢) 0.186s 53 1.07x
💻 Local Express 1.241s (~) 2.020s (~) 0.000s (+71.4% 🔺) 2.023s (~) 0.782s 30 1.38x
💻 Local Nitro 1.260s (+1.0%) 2.022s (~) 0.000s (-36.4% 🟢) 2.025s (~) 0.765s 30 1.40x
🌐 MongoDB Next.js (Turbopack) 2.350s (-1.2%) 2.954s (~) 0.000s (~) 3.008s (~) 0.658s 20 2.61x
💻 Local Next.js (Turbopack) ⚠️ missing - - - - -

▲ Production (Vercel)

World Framework Workflow Time TTFB Slurp Wall Time Overhead Samples vs Fastest
▲ Vercel 🥇 Express 2.808s (-20.7% 🟢) 3.797s (-15.7% 🟢) 0.000s (-100.0% 🟢) 4.448s (-14.5% 🟢) 1.640s 14 1.00x
▲ Vercel Nitro 3.144s (-6.4% 🟢) 4.072s (-5.1% 🟢) 0.001s (+Infinity% 🔺) 4.718s (-5.7% 🟢) 1.575s 13 1.12x
▲ Vercel Next.js (Turbopack) 3.827s (+21.2% 🔺) 4.756s (+10.6% 🔺) 0.000s (-91.0% 🟢) 5.304s (+7.3% 🔺) 1.477s 12 1.36x

🔍 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
🌐 Redis 🥇 Next.js (Turbopack) 1.600s (+3.2%) 2.035s (~) 0.000s (~) 2.040s (~) 0.440s 30 1.00x
🐘 Postgres Express 1.774s (~) 2.172s (+2.5%) 0.000s (NaN%) 2.189s (+1.1%) 0.416s 28 1.11x
🐘 Postgres Next.js (Turbopack) 1.776s (-7.3% 🟢) 2.104s (-1.9%) 0.000s (-100.0% 🟢) 2.123s (-1.4%) 0.347s 29 1.11x
🐘 Postgres Nitro 1.780s (-0.8%) 2.139s (~) 0.000s (-100.0% 🟢) 2.162s (~) 0.382s 28 1.11x
💻 Local Express 3.612s (+4.3%) 4.234s (+5.0%) 0.000s (-40.0% 🟢) 4.238s (+5.0%) 0.626s 15 2.26x
💻 Local Nitro 3.735s (+3.4%) 4.234s (+3.3%) 0.000s (-22.2% 🟢) 4.237s (+3.2%) 0.502s 15 2.33x
🌐 MongoDB Next.js (Turbopack) 4.423s (~) 4.938s (~) 0.000s (+Infinity% 🔺) 5.011s (~) 0.588s 12 2.76x
💻 Local Next.js (Turbopack) ⚠️ missing - - - - -

▲ Production (Vercel)

World Framework Workflow Time TTFB Slurp Wall Time Overhead Samples vs Fastest
▲ Vercel 🥇 Express 3.770s (-14.4% 🟢) 4.785s (-13.0% 🟢) 0.002s (+Infinity% 🔺) 5.461s (-11.4% 🟢) 1.691s 12 1.00x
▲ Vercel Nitro 3.928s (-14.5% 🟢) 5.143s (-8.6% 🟢) 0.000s (-100.0% 🟢) 5.812s (-7.8% 🟢) 1.884s 11 1.04x
▲ Vercel Next.js (Turbopack) 4.400s (-7.9% 🟢) 5.398s (-8.5% 🟢) 0.000s (-54.5% 🟢) 5.901s (-10.7% 🟢) 1.500s 11 1.17x

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

Summary

Fastest Framework by World

Winner determined by most benchmark wins

World 🥇 Fastest Framework Wins
💻 Local Express 15/21
🐘 Postgres Next.js (Turbopack) 16/21
▲ Vercel Express 9/21
Fastest World by Framework

Winner determined by most benchmark wins

Framework 🥇 Fastest World Wins
Express 🐘 Postgres 17/21
Next.js (Turbopack) 🌐 Redis 12/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)

📋 View full workflow run

@VaguelySerious VaguelySerious marked this pull request as ready for review April 2, 2026 17:44
@VaguelySerious VaguelySerious requested a review from a team as a code owner April 2, 2026 17:44
Copy link
Copy Markdown
Contributor

@karthikscale3 karthikscale3 left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

AI review: Approve — correct fix, proper defense-in-depth, no regression risk.

  1. Two-layer approach is solid: Root ErrorBoundary handles the primary case (React Router renders 404s gracefully), Express error middleware catches anything that escapes SSR. Standard patterns for both.

  2. ErrorBoundary renders outside theme/nav context since it's the root boundary — the minimal fallback styling is appropriate here.

  3. Tests cover the important shapes: 404 route error, generic Error, 500 route error, and link target verification.

Copy link
Copy Markdown
Contributor

@karthikscale3 karthikscale3 left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

LGTM

@VaguelySerious VaguelySerious merged commit 74c4cdb into main Apr 2, 2026
104 of 105 checks passed
@VaguelySerious VaguelySerious deleted the peter/issue-1556 branch April 2, 2026 17:57
@ghost ghost mentioned this pull request Apr 2, 2026
pranaygp added a commit that referenced this pull request Apr 3, 2026
…1-refresh

* origin/main: (21 commits)
  Fix node-module-error plugin matching identifiers in multi-line comments (#1554)
  fix(swc-plugin): use binding name for class expression method registrations (#1599)
  fix(builders): override `sideEffects: false` for discovered workflow/step/serde entries (#1598)
  [world-vercel] align header names to `x-vercel-workflow-*` convention (#1602)
  [docs] Add vercel world consumer function security documentation (#1543)
  Make `start()` types `unknown` when `deploymentId` is provided (#1367)
  fix(next): stop force-setting WORKFLOW_PUBLIC_MANIFEST=1 during next dev (#1597)
  Version Packages (beta) (#1593)
  [docs] Tidy world API docs and document new stream helpers (#1581)
  Rename 'Workflow Development Kit' / 'DevKit' to 'Workflow SDK' (#1595)
  [world] Use zod/v4 in queue files to match @workflow/world schemas (#1588)
  [ai] Fix fatal stream errors surfacing as [object Object] (#1589)
  [web] Fix server crash on unmatched routes (#1590)
  docs: rename 'Complex Example' to 'Instance Methods as Steps' (#1592)
  Version Packages (beta) (#1563)
  [core] Extend flow route duration to "max" and fail runs where replay takes too long (#1567)
  fix: check target run capabilities before encrypting hook payloads (#1572)
  [core] Combine initial run fetch, event fetch, and run_started event creation (#1569)
  [docs] Split World API docs into sub-pages, update skill.md (#1457)
  [nitro] Preserve workflow step registration side effects (#1386)
  ...

# Conflicts:
#	skills/workflow/SKILL.md
@ghost ghost mentioned this pull request Apr 7, 2026
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.

workflow web crashes on unmatched routes (e.g. /robots.txt, /favicon.ico)

2 participants