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 brenchmark 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:
threads: 4 base: 'http://localhost:9000' iterations: 5
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.manager_id }}
name: Assign values assign: 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: Fetch some users by hash request: url: /api/users/{{ item.id }} with_items:
name: Fetch some users from CSV request: url: /api/users/contacts/{{ item.id }} withitemsfrom_csv: ./fixtures/users.csv
name: Fetch no relative url request: url: http://localhost:9000/api/users.json
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.counter }}
name: Reset counter request: method: DELETE url: /
name: Custom headers request: url: /admin headers: Authorization: Basic aHR0cHdhdGNoOmY= X-Foo: Bar ```
As you can see, you can play with interpolations in different ways. This will let you specify a benchmank with different requests and dependencies between them.
If you want to know more about the benchmank file syntax, read this
The easiest way right now is to install 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
This is the list of all features supported by the current version of drill
:
/api/users/{{ item }}
assign
and url interpolations.Go to the example
directorty and you'll find a README how
to test it in a safe environment.
Disclaimer: We really recommend not to run intensive benchmanks against production environments.
Full list of cli options, which is available under drill --help
``` drill 0.3.7 HTTP load testing application written in Rust inspired by Ansible syntax
USAGE:
drill [OPTIONS] --benchmark
FLAGS: -h, --help Prints help information -s, --stats Shows request statistics -V, --version Prints version information
OPTIONS:
-b, --benchmark
```
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 appreaciate a pull request. ;)