Skip to main content
Deno 2 is finally here πŸŽ‰οΈ
Learn more

Benchmarks

Deno/TS benchmark suite for measuring Windmill job and flow execution throughput.

Quick Start

# Install Deno
curl -fsSL https://deno.land/install.sh | sh

# Run a single benchmark
deno run -A benchmark_oneoff.ts --kind noop --jobs 10000

# Run the full suite
deno run -A benchmark_suite.ts -c suite_config.json

# Run WAC v2 benchmarks (workflow-as-code vs flow comparison)
deno run -A benchmark_suite.ts -c suite_wac.json

Benchmark Kinds

Script benchmarks

  • noop β€” Empty jobs (measures pure scheduling overhead)
  • deno, bun, python, go, bash β€” Language runtimes
  • nativets β€” BunNative (no isolation)
  • dedicated, dedicated_nativets β€” Dedicated worker mode

Flow benchmarks

  • 2steps β€” 2-step flow (deno + identity)
  • bigscriptinflow β€” Flow with large raw bash script
  • flow_seq_2_bun β€” 2 sequential bun steps
  • flow_par_2_bun β€” 2 parallel bun steps (branchall)
  • flow_seq_3_bun β€” 3 sequential bun steps
  • flow:<path> β€” Custom flow by path
  • script:<path> β€” Custom script by path

WAC v2 benchmarks (workflow-as-code)

  • wac_seq_2 β€” 2 sequential tasks
  • wac_par_2 β€” 2 parallel tasks (Promise.all)
  • wac_seq_3 β€” 3 sequential tasks
  • wac_inline_2 β€” 2 inline steps (no child jobs)

Suite Configs

File Description
suite_config.json Main benchmark suite (noop, languages, flows)
suite_dedicated.json Dedicated worker benchmarks
suite_dedicated_nativets.json Dedicated NativeTS benchmarks
suite_wac.json WAC v2 vs flow comparison benchmarks

Interactive Benchmark Tool

deno run -A main.ts -e admin@windmill.dev -p changeme --host http://localhost:8000

Options: --workers, --seconds, --maximum-throughput, --use-flows, --script-pattern, --export-json, --export-csv

Graph Generation

deno run -A benchmark_graphs.ts -c graphs_config.json

Generates SVG graphs from *_benchmark.json data files.

CI

The GitHub Actions workflow (.github/workflows/benchmark.yml) runs hourly with 1/4/8 worker configurations plus WAC benchmarks. Results are committed to the benchmarks branch.