Goose

Have you ever been attacked by a goose?

Overview

Goose is a Rust load testing tool based on Locust. User behavior is defined with standard Rust code.

Goose load tests are built using Cargo to build a new application with a dependency on the Goose library.

Passing the included simple example the -h flag you can see the run-time configuration options available to Goose load tests:

`` $ cargo run --release --example simple -- -h Finished release [optimized] target(s) in 0.05s Runningtarget/release/examples/simple -h` client 0.4.0 Configuration options required for launching a Goose loadtest

USAGE: simple [FLAGS] [OPTIONS]

FLAGS: -h, --help Prints help information -l, --list Shows list of all possible Goose tasks and exits -g, --log-level Log level (-g, -gg, -ggg, etc.) --only-summary Only prints summary stats --print-stats Prints stats in the console --reset-stats Resets statistics once hatching has been completed --status-codes Includes status code counts in console stats -V, --version Prints version information -v, --verbose Debug level (-v, -vv, -vvv, etc.)

OPTIONS: -c, --clients Number of concurrent Goose users (defaults to available CPUs) -r, --hatch-rate How many users to spawn per second (defaults to available CPUs) -H, --host Host to load test in the following format: http://10.21.32.33 [default: ] --log-file [default: goose.log] -t, --run-time Stop after the specified amount of time, e.g. (300s, 20m, 3h, 1h30m, etc.) [default: ] ```

Examples

Simple

The examples/simple.rs example copies the simple load test documented on the locust.io web page, rewritten in Goose. It uses minimal advanced functionality, but demonstrates how to GET and POST pages. It defines a single Task Set which has the client log in and then load a couple of pages.

Goose can make use of all available CPU cores. By default, it will launch 1 client per core, and it can be configured to launch many more. The following was configured instead to launch 1,024 clients. Each client randomly pauses 5 to 15 seconds after each task is loaded, so it's possible to spin up a large number of clients. Here is a snapshot of top on an 8-core VM that ran this example with 10G of available RAM -- there were ample resources to launch considerably more "clients", though ulimit had to be reasied:

``` top - 11:14:57 up 16 days, 4:40, 2 users, load average: 0.00, 0.04, 0.01 Tasks: 129 total, 1 running, 128 sleeping, 0 stopped, 0 zombie %Cpu(s): 0.3 us, 0.3 sy, 0.0 ni, 99.2 id, 0.0 wa, 0.0 hi, 0.2 si, 0.0 st MiB Mem : 9993.6 total, 6695.1 free, 1269.3 used, 2029.2 buff/cache MiB Swap: 10237.0 total, 10234.7 free, 2.3 used. 8401.5 avail Mem

PID USER PR NI VIRT RES SHR S %CPU %MEM TIME+ COMMAND
19776 goose 20 0 9.8g 874688 8252 S 6.3 8.5 0:42.90 simple
```

Here's the output of running the loadtest. The -v flag sends INFO and higher messages to stdout (in addition to the log file). The c1024 tells Goose to spin up 1,024 clients. The -r32 option tells Goose to spin up 32 clients per second. The -t 10m option tells Goose to run the load test for 10 minutes, or 600 seconds. The --print-stats flag tells Goose to collect statistics during the load test, and the --status-codes flag tells it to include statistics about HTTP Status codes returned by the server. Finally, the --only-summary flag tells Goose to only display the statistics when the load test finishes, otherwise it would display running statistics every 15 seconds for the duration of the test.

`` $ cargo run --release --example simple -- --host http://apache.fosciana -v -c1024 -r32 -t 10m --print-stats --status-codes --only-summary Finished release [optimized] target(s) in 0.05s Runningtarget/release/examples/simple --host 'http://apache.fosciana' -v -c1024 -r32 -t 10m --print-stats --status-codes --only-summary` 18:42:48 [ INFO] Output verbosity level: INFO 18:42:48 [ INFO] Logfile verbosity level: INFO 18:42:48 [ INFO] Writing to log file: goose.log 18:42:48 [ INFO] run_time = 600 18:42:48 [ INFO] global host configured: http://apache.fosciana 18:42:53 [ INFO] launching client 1 from WebsiteUser... 18:42:53 [ INFO] launching client 2 from WebsiteUser... 18:42:53 [ INFO] launching client 3 from WebsiteUser... 18:42:53 [ INFO] launching client 4 from WebsiteUser... 18:42:53 [ INFO] launching client 5 from WebsiteUser... 18:42:53 [ INFO] launching client 6 from WebsiteUser... 18:42:53 [ INFO] launching client 7 from WebsiteUser... 18:42:53 [ INFO] launching client 8 from WebsiteUser...

... 18:43:25 [ INFO] launching client 1022 from WebsiteUser... 18:43:25 [ INFO] launching client 1023 from WebsiteUser... 18:43:25 [ INFO] launching client 1024 from WebsiteUser... 18:43:25 [ INFO] launched 1024 clients... 18:53:26 [ INFO] stopping after 600 seconds...

18:53:26 [ INFO] waiting for clients to exit

Name | # reqs | # fails | req/s | fail/s


GET / | 34,077 | 582 (1.7%) | 53 | 0
GET /about/ | 34,044 | 610 (1.8%) | 53 | 0
POST /login | 1,024 | 0 (0%) | 1 | 0
------------------------+----------------+----------------+-------+----------

Aggregated | 69,145 | 1,192 (1.7%) | 107 | 1

Name | Avg (ms) | Min | Max | Mean


GET / | 12.38 | 0.01 | 1001.10 | 0.09
GET /about/ | 12.80 | 0.01 | 1001.10 | 0.08
POST /login | 0.21 | 0.15 | 1.82 | 0.20
------------------------+------------+------------+------------+-------------

Aggregated | 12.41 | 0.01 | 1001.10 | 0.02

Slowest page load within specified percentile of requests (in ms):


Name | 50% | 75% | 98% | 99% | 99.9% | 99.99%


GET / | 0.09 | 0.10 | 345.18 | 500.60 | 1000.93 | 1001.09 GET /about/ | 0.08 | 0.10 | 356.65 | 500.61 | 1000.94 | 1001.08 POST /login | 0.20 | 0.22 | 0.27 | 0.34 | 1.36 | 1.82 ------------------------+------------+------------+------------+-------------

Aggregated | 0.08 | 0.10 | 349.40 | 500.60 | 1000.93 | 1001.09

Name | Status codes


GET / | 33,495 [200]
GET /about/ | 33,434 [200]

POST /login | 1,024 [200]

Aggregated | 67,953 [200]
```

Roadmap

The Goose project roadmap is documented in TODO.md.