* chore(main): release 1.684.1 * Apply automatic changes --------- Co-authored-by: rubenfiszel <275584+rubenfiszel@users.noreply.github.com>
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 runtimesnativets— BunNative (no isolation)dedicated,dedicated_nativets— Dedicated worker mode
Flow benchmarks
2steps— 2-step flow (deno + identity)bigscriptinflow— Flow with large raw bash scriptflow_seq_2_bun— 2 sequential bun stepsflow_par_2_bun— 2 parallel bun steps (branchall)flow_seq_3_bun— 3 sequential bun stepsflow:<path>— Custom flow by pathscript:<path>— Custom script by path
WAC v2 benchmarks (workflow-as-code)
wac_seq_2— 2 sequential taskswac_par_2— 2 parallel tasks (Promise.all)wac_seq_3— 3 sequential taskswac_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.