Skip to content

[docs] Fix image link in NestJS getting started guide#941

Merged
VaguelySerious merged 1 commit intomainfrom
peter/fix-nestjs-doc-image
Feb 5, 2026
Merged

[docs] Fix image link in NestJS getting started guide#941
VaguelySerious merged 1 commit intomainfrom
peter/fix-nestjs-doc-image

Conversation

@VaguelySerious
Copy link
Copy Markdown
Member

also adds an "Experimental" badge to the NestJS card in the framework list

Signed-off-by: Peter Wielander <mittgfu@gmail.com>
@vercel
Copy link
Copy Markdown
Contributor

vercel Bot commented Feb 5, 2026

@changeset-bot
Copy link
Copy Markdown

changeset-bot Bot commented Feb 5, 2026

⚠️ No Changeset found

Latest commit: 8da0aa5

Merging this PR will not cause a version bump for any packages. If these changes should not result in a new version, you're good to go. If these changes should result in a version bump, you need to add a changeset.

This PR includes no changesets

When changesets are added to this PR, you'll see the packages that this PR includes changesets for and the associated semver types

Click here to learn what changesets are, and how to add one.

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

@github-actions
Copy link
Copy Markdown
Contributor

github-actions Bot commented Feb 5, 2026

🧪 E2E Test Results

Some tests failed

Summary

Passed Failed Skipped Total
✅ ▲ Vercel Production 479 0 38 517
❌ 💻 Local Development 436 2 32 470
✅ 📦 Local Production 438 0 32 470
✅ 🐘 Local Postgres 438 0 32 470
✅ 🪟 Windows 47 0 0 47
❌ 🌍 Community Worlds 31 169 0 200
✅ 📋 Other 129 0 12 141
Total 1998 171 146 2315

❌ Failed Tests

💻 Local Development (2 failed)

astro-stable (2 failed):

  • 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
🌍 Community Worlds (169 failed)

mongodb (42 failed):

  • addTenWorkflow
  • addTenWorkflow
  • should work with react rendering in step
  • promiseAllWorkflow
  • promiseRaceWorkflow
  • promiseAnyWorkflow
  • readableStreamWorkflow
  • hookWorkflow
  • webhookWorkflow
  • sleepingWorkflow
  • nullByteWorkflow
  • workflowAndStepMetadataWorkflow
  • outputStreamWorkflow
  • outputStreamInsideStepWorkflow - getWritable() called inside step functions
  • 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
  • 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
  • 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
  • pages router addTenWorkflow via pages router
  • pages router promiseAllWorkflow via pages router
  • pages router sleepingWorkflow via pages router

redis (42 failed):

  • addTenWorkflow
  • addTenWorkflow
  • should work with react rendering in step
  • promiseAllWorkflow
  • promiseRaceWorkflow
  • promiseAnyWorkflow
  • readableStreamWorkflow
  • hookWorkflow
  • webhookWorkflow
  • sleepingWorkflow
  • nullByteWorkflow
  • workflowAndStepMetadataWorkflow
  • outputStreamWorkflow
  • outputStreamInsideStepWorkflow - getWritable() called inside step functions
  • 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
  • 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
  • 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
  • pages router addTenWorkflow via pages router
  • pages router promiseAllWorkflow via pages router
  • pages router sleepingWorkflow via pages router

starter (43 failed):

  • addTenWorkflow
  • addTenWorkflow
  • should work with react rendering in step
  • promiseAllWorkflow
  • promiseRaceWorkflow
  • promiseAnyWorkflow
  • readableStreamWorkflow
  • hookWorkflow
  • webhookWorkflow
  • sleepingWorkflow
  • nullByteWorkflow
  • workflowAndStepMetadataWorkflow
  • outputStreamWorkflow
  • outputStreamInsideStepWorkflow - getWritable() called inside step functions
  • 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
  • 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 (CLI) - workflow health command reports healthy endpoints
  • 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
  • pages router addTenWorkflow via pages router
  • pages router promiseAllWorkflow via pages router
  • pages router sleepingWorkflow via pages router

turso (42 failed):

  • addTenWorkflow
  • addTenWorkflow
  • should work with react rendering in step
  • promiseAllWorkflow
  • promiseRaceWorkflow
  • promiseAnyWorkflow
  • readableStreamWorkflow
  • hookWorkflow
  • webhookWorkflow
  • sleepingWorkflow
  • nullByteWorkflow
  • workflowAndStepMetadataWorkflow
  • outputStreamWorkflow
  • outputStreamInsideStepWorkflow - getWritable() called inside step functions
  • 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
  • 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
  • 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
  • pages router addTenWorkflow via pages router
  • pages router promiseAllWorkflow via pages router
  • pages router sleepingWorkflow via pages router

Details by Category

✅ ▲ Vercel Production
App Passed Failed Skipped
✅ astro 43 0 4
✅ example 43 0 4
✅ express 43 0 4
✅ fastify 43 0 4
✅ hono 43 0 4
✅ nextjs-turbopack 46 0 1
✅ nextjs-webpack 46 0 1
✅ nitro 43 0 4
✅ nuxt 43 0 4
✅ sveltekit 43 0 4
✅ vite 43 0 4
❌ 💻 Local Development
App Passed Failed Skipped
❌ astro-stable 41 2 4
✅ express-stable 43 0 4
✅ fastify-stable 43 0 4
✅ hono-stable 43 0 4
✅ nextjs-turbopack-stable 47 0 0
✅ nextjs-webpack-stable 47 0 0
✅ nitro-stable 43 0 4
✅ nuxt-stable 43 0 4
✅ sveltekit-stable 43 0 4
✅ vite-stable 43 0 4
✅ 📦 Local Production
App Passed Failed Skipped
✅ astro-stable 43 0 4
✅ express-stable 43 0 4
✅ fastify-stable 43 0 4
✅ hono-stable 43 0 4
✅ nextjs-turbopack-stable 47 0 0
✅ nextjs-webpack-stable 47 0 0
✅ nitro-stable 43 0 4
✅ nuxt-stable 43 0 4
✅ sveltekit-stable 43 0 4
✅ vite-stable 43 0 4
✅ 🐘 Local Postgres
App Passed Failed Skipped
✅ astro-stable 43 0 4
✅ express-stable 43 0 4
✅ fastify-stable 43 0 4
✅ hono-stable 43 0 4
✅ nextjs-turbopack-stable 47 0 0
✅ nextjs-webpack-stable 47 0 0
✅ nitro-stable 43 0 4
✅ nuxt-stable 43 0 4
✅ sveltekit-stable 43 0 4
✅ vite-stable 43 0 4
✅ 🪟 Windows
App Passed Failed Skipped
✅ nextjs-turbopack 47 0 0
❌ 🌍 Community Worlds
App Passed Failed Skipped
✅ mongodb-dev 3 0 0
❌ mongodb 5 42 0
✅ redis-dev 3 0 0
❌ redis 5 42 0
✅ starter-dev 3 0 0
❌ starter 4 43 0
✅ turso-dev 3 0 0
❌ turso 5 42 0
✅ 📋 Other
App Passed Failed Skipped
✅ e2e-local-dev-nest-stable 43 0 4
✅ e2e-local-postgres-nest-stable 43 0 4
✅ e2e-local-prod-nest-stable 43 0 4

📋 View full workflow run


Some E2E test jobs failed:

  • Vercel Prod: success
  • Local Dev: failure
  • Local Prod: success
  • Local Postgres: success
  • Windows: success

Check the workflow run for details.

@github-actions
Copy link
Copy Markdown
Contributor

github-actions Bot commented Feb 5, 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 🥇 Next.js (Turbopack) 0.036s (-7.6% 🟢) 1.019s (~) 0.982s 10 1.00x
💻 Local Express 0.043s (+1.7%) 1.007s (~) 0.965s 10 1.17x
💻 Local Nitro 0.043s (-1.6%) 1.007s (~) 0.964s 10 1.17x
🐘 Postgres Nitro 0.138s (-39.4% 🟢) 1.015s (~) 0.877s 10 3.79x
🐘 Postgres Express 0.178s (-36.1% 🟢) 1.021s (+0.6%) 0.843s 10 4.87x
🐘 Postgres Next.js (Turbopack) 0.311s (+11.3% 🔺) 1.030s (+0.8%) 0.718s 10 8.53x

▲ Production (Vercel)

World Framework Workflow Time Wall Time Overhead Samples vs Fastest
▲ Vercel 🥇 Nitro 0.642s (-4.1%) 1.685s (+5.6% 🔺) 1.043s 10 1.00x
▲ Vercel Next.js (Turbopack) 0.655s (-25.5% 🟢) 1.435s (-26.7% 🟢) 0.780s 10 1.02x
▲ Vercel Express 0.682s (-7.9% 🟢) 1.563s (-2.8%) 0.881s 10 1.06x

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

workflow with 1 step

💻 Local Development

World Framework Workflow Time Wall Time Overhead Samples vs Fastest
💻 Local 🥇 Next.js (Turbopack) 1.075s (-2.4%) 2.013s (~) 0.939s 10 1.00x
💻 Local Nitro 1.115s (~) 2.007s (~) 0.892s 10 1.04x
💻 Local Express 1.116s (~) 2.008s (~) 0.892s 10 1.04x
🐘 Postgres Express 1.874s (-13.2% 🟢) 2.316s (-23.2% 🟢) 0.442s 10 1.74x
🐘 Postgres Next.js (Turbopack) 2.018s (+9.2% 🔺) 2.417s (+19.9% 🔺) 0.398s 10 1.88x
🐘 Postgres Nitro 2.467s (+12.7% 🔺) 3.017s (~) 0.549s 10 2.30x

▲ Production (Vercel)

World Framework Workflow Time Wall Time Overhead Samples vs Fastest
▲ Vercel 🥇 Nitro 2.884s (~) 3.723s (+0.6%) 0.839s 10 1.00x
▲ Vercel Express 2.983s (+1.4%) 3.709s (+4.2%) 0.726s 10 1.03x
▲ Vercel Next.js (Turbopack) 3.001s (+3.1%) 3.707s (-3.1%) 0.706s 10 1.04x

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

workflow with 10 sequential steps

💻 Local Development

World Framework Workflow Time Wall Time Overhead Samples vs Fastest
💻 Local 🥇 Next.js (Turbopack) 10.580s (-1.2%) 11.022s (~) 0.442s 3 1.00x
💻 Local Nitro 10.831s (~) 11.023s (~) 0.192s 3 1.02x
💻 Local Express 10.838s (~) 11.011s (~) 0.172s 3 1.02x
🐘 Postgres Next.js (Turbopack) 15.000s (-1.5%) 15.539s (-3.1%) 0.539s 2 1.42x
🐘 Postgres Express 15.460s (-24.5% 🟢) 16.035s (-23.8% 🟢) 0.575s 2 1.46x
🐘 Postgres Nitro 20.332s (-0.7%) 21.039s (~) 0.706s 2 1.92x

▲ Production (Vercel)

World Framework Workflow Time Wall Time Overhead Samples vs Fastest
▲ Vercel 🥇 Nitro 23.115s (+2.2%) 23.577s (+1.0%) 0.462s 2 1.00x
▲ Vercel Next.js (Turbopack) 23.487s (+3.4%) 24.430s (+4.2%) 0.943s 2 1.02x
▲ Vercel Express 23.529s (+0.9%) 24.084s (-1.7%) 0.556s 2 1.02x

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

workflow with 25 sequential steps

💻 Local Development

World Framework Workflow Time Wall Time Overhead Samples vs Fastest
💻 Local 🥇 Next.js (Turbopack) 26.872s (-1.4%) 27.038s (-3.6%) 0.166s 3 1.00x
💻 Local Express 27.445s (~) 28.028s (~) 0.582s 3 1.02x
💻 Local Nitro 27.477s (~) 28.023s (~) 0.547s 3 1.02x
🐘 Postgres Next.js (Turbopack) 37.919s (+0.7%) 38.572s (+1.4%) 0.653s 2 1.41x
🐘 Postgres Express 38.639s (-23.3% 🟢) 39.060s (-23.5% 🟢) 0.421s 2 1.44x
🐘 Postgres Nitro 50.181s (~) 51.089s (~) 0.908s 2 1.87x

▲ Production (Vercel)

World Framework Workflow Time Wall Time Overhead Samples vs Fastest
▲ Vercel 🥇 Next.js (Turbopack) 58.010s (+0.6%) 58.462s (~) 0.452s 2 1.00x
▲ Vercel Express 58.093s (+1.5%) 58.591s (+1.1%) 0.497s 2 1.00x
▲ Vercel Nitro 59.352s (+4.5%) 60.385s (+5.5% 🔺) 1.033s 2 1.02x

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

workflow with 50 sequential steps

💻 Local Development

World Framework Workflow Time Wall Time Overhead Samples vs Fastest
💻 Local 🥇 Next.js (Turbopack) 55.700s (-1.6%) 56.069s (-1.7%) 0.369s 2 1.00x
💻 Local Express 57.144s (~) 58.049s (~) 0.905s 2 1.03x
💻 Local Nitro 57.252s (~) 58.038s (+0.9%) 0.786s 2 1.03x
🐘 Postgres Express 75.481s (-24.7% 🟢) 76.122s (-24.7% 🟢) 0.641s 2 1.36x
🐘 Postgres Next.js (Turbopack) 75.740s (-4.5%) 76.138s (-4.4%) 0.399s 2 1.36x
🐘 Postgres Nitro 100.466s (~) 101.151s (~) 0.685s 1 1.80x

▲ Production (Vercel)

World Framework Workflow Time Wall Time Overhead Samples vs Fastest
▲ Vercel 🥇 Nitro 126.763s (+4.8%) 128.030s (+4.6%) 1.267s 1 1.00x
▲ Vercel Next.js (Turbopack) 140.804s (+8.2% 🔺) 141.911s (+8.7% 🔺) 1.107s 1 1.11x
▲ Vercel Express 142.177s (+16.2% 🔺) 142.883s (+15.9% 🔺) 0.706s 1 1.12x

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

Promise.all with 10 concurrent steps

💻 Local Development

World Framework Workflow Time Wall Time Overhead Samples vs Fastest
💻 Local 🥇 Next.js (Turbopack) 1.368s (-1.8%) 2.012s (~) 0.644s 15 1.00x
💻 Local Nitro 1.419s (+1.2%) 2.006s (~) 0.587s 15 1.04x
💻 Local Express 1.421s (~) 2.007s (~) 0.586s 15 1.04x
🐘 Postgres Next.js (Turbopack) 2.113s (+12.5% 🔺) 2.762s (+9.5% 🔺) 0.649s 11 1.55x
🐘 Postgres Express 2.256s (-5.6% 🟢) 2.596s (-13.8% 🟢) 0.341s 12 1.65x
🐘 Postgres Nitro 2.448s (+3.8%) 3.016s (~) 0.568s 10 1.79x

▲ Production (Vercel)

World Framework Workflow Time Wall Time Overhead Samples vs Fastest
▲ Vercel 🥇 Nitro 2.904s (+2.1%) 4.079s (+10.4% 🔺) 1.176s 8 1.00x
▲ Vercel Express 3.384s (+12.6% 🔺) 4.150s (+6.5% 🔺) 0.766s 8 1.17x
▲ Vercel Next.js (Turbopack) 3.464s (+14.9% 🔺) 4.153s (+3.9%) 0.689s 8 1.19x

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

Promise.all with 25 concurrent steps

💻 Local Development

World Framework Workflow Time Wall Time Overhead Samples vs Fastest
💻 Local 🥇 Next.js (Turbopack) 2.364s (-8.5% 🟢) 3.362s (+11.1% 🔺) 0.998s 9 1.00x
💻 Local Express 2.552s (-1.7%) 3.013s (~) 0.461s 10 1.08x
💻 Local Nitro 2.564s (+2.4%) 3.020s (~) 0.456s 10 1.08x
🐘 Postgres Nitro 8.352s (+6.2% 🔺) 9.039s (+5.7% 🔺) 0.687s 4 3.53x
🐘 Postgres Express 10.558s (+23.1% 🔺) 11.021s (+18.2% 🔺) 0.464s 3 4.47x
🐘 Postgres Next.js (Turbopack) 12.547s (+8.9% 🔺) 13.062s (+8.6% 🔺) 0.514s 3 5.31x

▲ Production (Vercel)

World Framework Workflow Time Wall Time Overhead Samples vs Fastest
▲ Vercel 🥇 Next.js (Turbopack) 3.772s (-2.5%) 4.483s (-3.3%) 0.710s 7 1.00x
▲ Vercel Express 3.954s (+24.4% 🔺) 4.667s (+21.4% 🔺) 0.713s 7 1.05x
▲ Vercel Nitro 4.915s (+59.4% 🔺) 5.594s (+46.4% 🔺) 0.678s 7 1.30x

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

Promise.all with 50 concurrent steps

💻 Local Development

World Framework Workflow Time Wall Time Overhead Samples vs Fastest
💻 Local 🥇 Next.js (Turbopack) 5.955s (-19.4% 🟢) 6.689s (-21.0% 🟢) 0.734s 5 1.00x
💻 Local Express 7.481s (+3.0%) 8.460s (+2.5%) 0.978s 4 1.26x
💻 Local Nitro 7.495s (+7.6% 🔺) 8.448s (+12.6% 🔺) 0.952s 4 1.26x
🐘 Postgres Express 49.612s (+1.2%) 50.184s (+1.7%) 0.572s 1 8.33x
🐘 Postgres Nitro 50.112s (+10.9% 🔺) 50.353s (+9.0% 🔺) 0.241s 1 8.41x
🐘 Postgres Next.js (Turbopack) 56.215s (+10.0% 🔺) 56.281s (+9.8% 🔺) 0.066s 1 9.44x

▲ Production (Vercel)

World Framework Workflow Time Wall Time Overhead Samples vs Fastest
▲ Vercel 🥇 Express 4.705s (+40.7% 🔺) 5.497s (+45.5% 🔺) 0.792s 7 1.00x
▲ Vercel Next.js (Turbopack) 5.542s (+48.1% 🔺) 6.678s (+50.4% 🔺) 1.137s 6 1.18x
▲ Vercel Nitro 11.123s (+171.9% 🔺) 11.947s (+159.8% 🔺) 0.824s 3 2.36x

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

Promise.race with 10 concurrent steps

💻 Local Development

World Framework Workflow Time Wall Time Overhead Samples vs Fastest
💻 Local 🥇 Next.js (Turbopack) 1.402s (-2.1%) 2.010s (~) 0.607s 15 1.00x
💻 Local Express 1.427s (~) 2.006s (~) 0.578s 15 1.02x
💻 Local Nitro 1.448s (~) 2.006s (~) 0.558s 15 1.03x
🐘 Postgres Express 2.079s (-1.0%) 2.520s (~) 0.441s 12 1.48x
🐘 Postgres Nitro 2.119s (-7.9% 🟢) 2.691s (~) 0.572s 12 1.51x
🐘 Postgres Next.js (Turbopack) 2.227s (+23.9% 🔺) 2.516s (+25.0% 🔺) 0.290s 12 1.59x

▲ Production (Vercel)

World Framework Workflow Time Wall Time Overhead Samples vs Fastest
▲ Vercel 🥇 Nitro 3.300s (+19.8% 🔺) 4.185s (+13.5% 🔺) 0.885s 8 1.00x
▲ Vercel Express 4.852s (+70.5% 🔺) 5.489s (+45.9% 🔺) 0.637s 6 1.47x
▲ Vercel Next.js (Turbopack) 7.281s (+153.5% 🔺) 8.315s (+117.6% 🔺) 1.034s 4 2.21x

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

Promise.race with 25 concurrent steps

💻 Local Development

World Framework Workflow Time Wall Time Overhead Samples vs Fastest
💻 Local 🥇 Next.js (Turbopack) 2.442s (-9.2% 🟢) 3.146s (+4.1%) 0.704s 10 1.00x
💻 Local Nitro 2.658s (+1.6%) 3.012s (~) 0.354s 10 1.09x
💻 Local Express 2.749s (+2.2%) 3.024s (~) 0.276s 10 1.13x
🐘 Postgres Nitro 10.681s (-0.9%) 11.064s (~) 0.383s 3 4.37x
🐘 Postgres Express 12.305s (+13.4% 🔺) 12.697s (+14.5% 🔺) 0.393s 3 5.04x
🐘 Postgres Next.js (Turbopack) 13.339s (+21.5% 🔺) 13.727s (+17.4% 🔺) 0.388s 3 5.46x

▲ Production (Vercel)

World Framework Workflow Time Wall Time Overhead Samples vs Fastest
▲ Vercel 🥇 Next.js (Turbopack) 3.373s (+11.3% 🔺) 3.901s (+2.4%) 0.528s 8 1.00x
▲ Vercel Express 3.703s (+25.3% 🔺) 4.343s (+19.0% 🔺) 0.640s 7 1.10x
▲ Vercel Nitro 6.385s (+103.6% 🔺) 7.238s (+89.5% 🔺) 0.853s 5 1.89x

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

Promise.race with 50 concurrent steps

💻 Local Development

World Framework Workflow Time Wall Time Overhead Samples vs Fastest
💻 Local 🥇 Next.js (Turbopack) 6.511s (-14.9% 🟢) 7.204s (-16.4% 🟢) 0.693s 5 1.00x
💻 Local Express 7.730s (-1.2%) 8.691s (-1.3%) 0.961s 4 1.19x
💻 Local Nitro 7.755s (+2.0%) 8.731s (+1.6%) 0.977s 4 1.19x
🐘 Postgres Nitro 49.704s (-3.4%) 50.140s (-3.8%) 0.436s 1 7.63x
🐘 Postgres Express 55.007s (+6.8% 🔺) 55.237s (+6.0% 🔺) 0.230s 1 8.45x
🐘 Postgres Next.js (Turbopack) 55.908s (+2.9%) 56.285s (+2.1%) 0.377s 1 8.59x

▲ Production (Vercel)

World Framework Workflow Time Wall Time Overhead Samples vs Fastest
▲ Vercel 🥇 Next.js (Turbopack) 13.828s (+289.4% 🔺) 14.804s (+241.3% 🔺) 0.976s 3 1.00x
▲ Vercel Express 16.358s (+388.6% 🔺) 16.938s (+330.0% 🔺) 0.580s 2 1.18x
▲ Vercel Nitro 18.335s (+490.9% 🔺) 19.158s (+408.0% 🔺) 0.823s 2 1.33x

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

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) 0.113s (-22.9% 🟢) 1.004s (~) 0.013s (-24.6% 🟢) 1.024s (-0.8%) 0.911s 10 1.00x
💻 Local Express 0.181s (-3.3%) 0.993s (~) 0.014s (-2.1%) 1.021s (~) 0.840s 10 1.60x
💻 Local Nitro 0.182s (+2.8%) 0.993s (~) 0.014s (+1.5%) 1.021s (~) 0.838s 10 1.61x
🐘 Postgres Next.js (Turbopack) 1.068s (+49.3% 🔺) 1.720s (+75.9% 🔺) 0.006s (+Infinity% 🔺) 1.826s (+63.8% 🔺) 0.758s 10 9.43x
🐘 Postgres Express 1.405s (-42.4% 🟢) 1.634s (-37.3% 🟢) 0.000s (+Infinity% 🔺) 2.016s (-33.2% 🟢) 0.611s 10 12.41x
🐘 Postgres Nitro 2.156s (+44.9% 🔺) 2.892s (+74.5% 🔺) 0.000s (NaN%) 3.017s (+49.9% 🔺) 0.861s 10 19.04x

▲ Production (Vercel)

World Framework Workflow Time TTFB Slurp Wall Time Overhead Samples vs Fastest
▲ Vercel 🥇 Nitro 3.000s (-2.2%) 3.392s (~) 0.160s (+12.3% 🔺) 4.065s (+0.9%) 1.065s 10 1.00x
▲ Vercel Express 3.047s (-0.6%) 3.285s (-2.2%) 0.214s (~) 4.001s (-1.8%) 0.954s 10 1.02x
▲ Vercel Next.js (Turbopack) 3.102s (~) 3.325s (+1.3%) 0.250s (+36.2% 🔺) 4.073s (+2.3%) 0.971s 10 1.03x

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

Summary

Fastest Framework by World

Winner determined by most benchmark wins

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

Winner determined by most benchmark wins

Framework 🥇 Fastest World Wins
Express 💻 Local 11/12
Next.js (Turbopack) 💻 Local 11/12
Nitro 💻 Local 12/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
  • 🌐 Starter: Community world (local development)
  • 🌐 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 February 5, 2026 02:37
@VaguelySerious VaguelySerious merged commit 4712931 into main Feb 5, 2026
97 of 98 checks passed
@VaguelySerious VaguelySerious deleted the peter/fix-nestjs-doc-image branch February 5, 2026 17:44
pranaygp added a commit that referenced this pull request Feb 6, 2026
…-parallelization

* origin/main:
  Remove "beads" config (#952)
  Upload Next.js server logs as artifact for Windows E2E (#946)
  Pass class as `this` context to custom serializer/deserializer methods (#947)
  [docs] Fix image link in NestJS getting started guide (#941)
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