Files
Ruben Fiszel a98f5b9dfd chore(main): release 1.684.1 (#8834)
* chore(main): release 1.684.1

* Apply automatic changes

---------

Co-authored-by: rubenfiszel <275584+rubenfiszel@users.noreply.github.com>
2026-04-14 21:48:03 +00:00
..
2023-10-28 19:02:49 +02:00
2023-09-07 15:45:08 +02:00
2025-02-24 01:20:20 +01:00
2023-08-03 15:59:38 +02:00
2023-11-29 10:13:32 +01:00
2026-04-14 21:48:03 +00:00

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.