Drill is a HTTP load testing application written in Rust. The main goal for this project is to build a really lightweight tool as alternative to other that require JVM and other stuff.
You can write benchmark files, in YAML format, describing all the stuff you want to test.
It was inspired by Ansible syntax because it is really easy to use and extend.
Here is an example for benchmark.yml:
concurrency: 4 base: 'http://localhost:9000' iterations: 5 rampup: 2
plan: - name: Include comments include: comments.yml
name: Fetch users request: url: /api/users.json
name: Fetch organizations request: url: /api/organizations
name: Fetch account request: url: /api/account assign: foo
name: Fetch manager user request: url: /api/users/{{ foo.body.manager_id }}
name: Assert request response code assert: key: foo.status value: 200
name: Assign values assign: key: bar value: "2"
name: Assert values assert: key: bar value: "2"
name: Fetch user from assign request: url: /api/users/{{ bar }}
name: Fetch some users request: url: /api/users/{{ item }} with_items:
name: Tagged user request request: url: /api/users/70 tags:
name: Fetch some users by hash request: url: /api/users/{{ item.id }} with_items:
name: Fetch some users by range, index {{ index }} request: url: /api/users/{{ item }} withitemsrange: start: 70 step: 5 stop: 75
name: Fetch some users from CSV, index {{ index }} request: url: /api/users/contacts/{{ item.id }} withitemsfrom_csv: ./fixtures/users.csv shuffle: true
name: POST some crafted JSONs stored in CSV, index {{ index }} request: url: /api/transactions method: POST body: '{{ item.txn }}' headers: Content-Type: 'application/json' withitemsfromcsv: filename: ./fixtures/transactions.csv quote_char: "\'"
name: Fetch no relative url request: url: http://localhost:9000/api/users.json
name: Interpolate environment variables request: url: http://localhost:9000/api/{{ EDITOR }}
name: Support for POST method request: url: /api/users method: POST body: foo=bar&arg={{ bar }}
name: Login user request: url: /login?user=example&password=3x4mpl3
name: Fetch counter request: url: /counter assign: memory
name: Fetch counter request: url: /counter assign: memory
name: Fetch endpoint request: url: /?counter={{ memory.body.counter }}
name: Reset counter request: method: DELETE url: /
name: Exec external commands exec: command: "echo '{{ foo.body }}' | jq .phones[0] | tr -d '\"'" assign: baz
name: Custom headers request: url: /admin headers: Authorization: Basic aHR0cHdhdGNoOmY= X-Foo: Bar X-Bar: Bar {{ memory.headers.token }}
name: One request with a random item request: url: /api/users/{{ item }} with_items:
As you can see, you can play with interpolations in different ways. This will let you specify a benchmark with different requests and dependencies between them.
If you want to know more about the benchmark file syntax, read this
Right now, the easiest way to get drill
is to go to the
latest release
page and download the binary file for your platform.
Another way to install drill
, if you have Rust available in
your system, is with cargo:
cargo install drill
drill --benchmark benchmark.yml --stats
or download the source code and compile it:
git clone git@github.com:fcsonline/drill.git && cd drill
cargo build --release
./target/release/drill --benchmark benchmark.yml --stats
OpenSSL is needed in order to compile Drill, whether it is through cargo install
or when compiling from source with cargo build
.
Depending on your platform, the name of the dependencies may differ.
Install libssl-dev
and pkg-config
packages with your favorite package manager
(if libssl-dev
is not found, try other names like openssl
or openssl-devel
).
First, install the Homebrew package manager.
And then install openssl
with Homebrew.
First, install vcpkg.
And then run vcpkg install openssl:x64-windows-static-md
.
This is the list of all features supported by the current version of drill
:
drill
to start all iterations./api/users/{{ item }}
/api/users/{{ EDITOR }}
assign
and url interpolations.Go to the example
directory and you'll find a README how
to test it in a safe environment.
Disclaimer: We really recommend not to run intensive benchmarks against production environments.
Full list of cli options, which is available under drill --help
``` drill 0.8.2 HTTP load testing application written in Rust inspired by Ansible syntax
USAGE:
drill [FLAGS] [OPTIONS] --benchmark
FLAGS: -h, --help Prints help information --list-tags List all benchmark tags --list-tasks List benchmark tasks (executes --tags/--skip-tags filter) -n, --nanosec Shows statistics in nanoseconds --no-check-certificate Disables SSL certification check. (Not recommended) -q, --quiet Disables output --relaxed-interpolations Do not panic if an interpolation is not present. (Not recommended) -s, --stats Shows request statistics -V, --version Prints version information -v, --verbose Toggle verbose output
OPTIONS:
-b, --benchmark
If you appreciate all the job done in this project, a small donation is always welcome:
This project started as a side project to learn Rust, so I'm sure that is full of mistakes and areas to be improve. If you think you can tweak the code to make it better, I'll really appreciate a pull request. ;)