Local

@workflow/world-local

Zero-config world bundled with Workflow for local development. No external services required.

The Local World is bundled with workflow and used automatically during local development. No installation or configuration required.

To explicitly use the local world in any environment, set the environment variable:

WORKFLOW_TARGET_WORLD=local

Observability

The workflow CLI uses the local world by default. Running these commands inside your workflow project will show your local development workflows:

# List recent workflow runs
npx workflow inspect runs

# Launch the web UI
npx workflow web

Learn more in the Observability documentation.

Testing & Performance

E2E Tests

Passing100% passing

Spec compliance is tested against Next.js (Turbopack) built in production mode and started with `next start`. View CI run →

341
Passed
0
Failed
74
Skipped
415
Total
View comprehensive E2E test results against all frameworks/configurations
1849
Passed
0
Failed
392
Skipped
2241
Total

Benchmarks

Click on a benchmark to view performance history over the last 30 commits.

Benchmark
Time
MinMaxSamples
Promise.all with 10 concurrent steps
1.52s1.47s1.65s15
Promise.all with 25 concurrent steps
2.91s2.70s3.43s10
Promise.all with 50 concurrent steps
7.57s7.34s7.93s4
Promise.race with 10 concurrent steps
1.53s1.44s1.67s15
Promise.race with 25 concurrent steps
2.81s2.54s3.08s10
Promise.race with 50 concurrent steps
7.88s7.21s8.29s4
workflow with 1 step
1.13s1.12s1.16s10
workflow with 10 concurrent data payload steps (10KB)
565ms461ms689ms60
workflow with 10 sequential data payload steps (10KB)
1.01s985ms1.08s35
workflow with 10 sequential steps
10.93s10.92s10.94s3
workflow with 25 concurrent data payload steps (10KB)
2.32s2.10s2.51s30
workflow with 25 sequential data payload steps (10KB)
3.05s2.97s3.30s25
workflow with 25 sequential steps
14.92s14.89s14.95s4
workflow with 50 concurrent data payload steps (10KB)
10.35s9.76s10.82s12
workflow with 50 sequential data payload steps (10KB)
8.92s8.72s9.12s13
workflow with 50 sequential steps
16.39s16.27s16.54s6
workflow with no steps
53ms39ms139ms10

Stream Benchmarks

Benchmark
Time
TTFB
Slurp
MinMaxSamples
10 parallel streams (1MB each)1.22s2.02s0ms1.15s1.31s30
fan-out fan-in 10 streams (1MB each)3.40s3.97s1ms2.99s3.97s16
stream pipeline with 5 transform steps (1MB)754ms1.01s10ms729ms791ms59
workflow with stream208ms1.00s10ms201ms221ms10

Last updated: 3/27/2026, 6:59:55 PM · Commit: bfb1a60

Configuration

The local world works with zero configuration, but you can customize behavior through environment variables or programmatically via createLocalWorld().

WORKFLOW_LOCAL_DATA_DIR

Directory for storing workflow data as JSON files. Default: .workflow-data/

PORT

The application dev server port. Used to enqueue steps and workflows. Default: auto-detected

WORKFLOW_LOCAL_BASE_URL

Full base URL override for HTTPS or custom hostnames. Default: http://localhost:{port}

Port resolution priority: baseUrl > port > PORT > auto-detected

WORKFLOW_LOCAL_QUEUE_CONCURRENCY

Maximum number of concurrent queue workers. Default: 100

Programmatic configuration

workflow.config.ts
import { createLocalWorld } from "@workflow/world-local";

const world = createLocalWorld({
  dataDir: "./custom-workflow-data",
  port: 5173,
  // baseUrl overrides port if set
  baseUrl: "https://local.example.com:3000",
});

Limitations

The local world is designed for development, not production:

  • In-memory queue - Steps are queued in memory and do not persist across server restarts
  • Filesystem storage - Data is stored in local JSON files
  • Single instance - Cannot handle distributed deployments
  • No authentication - Suitable only for local development

For production deployments, use the Vercel World or Postgres World.