2018-07-08 14:08:26 -04:00
|
|
|
# ruby/benchmark
|
|
|
|
|
|
|
|
This directory has benchmark definitions to be run with
|
|
|
|
[benchmark\_driver.gem](https://github.com/benchmark-driver/benchmark-driver).
|
|
|
|
|
|
|
|
## Normal usage
|
|
|
|
|
|
|
|
Execute `gem install benchmark-driver` and run a command like:
|
|
|
|
|
2018-07-08 14:10:14 -04:00
|
|
|
```bash
|
2018-07-08 14:08:26 -04:00
|
|
|
# Run a benchmark script with the ruby in the $PATH
|
|
|
|
benchmark-driver benchmark/erb_render.yml
|
|
|
|
|
|
|
|
# Run all benchmark scripts with multiple Ruby executables or options
|
2018-07-09 12:43:42 -04:00
|
|
|
benchmark-driver benchmark/*.yml -e /path/to/ruby -e '/path/to/ruby --jit'
|
2018-07-08 14:08:26 -04:00
|
|
|
|
|
|
|
# Or compare Ruby versions managed by rbenv
|
2018-07-09 12:43:42 -04:00
|
|
|
benchmark-driver benchmark/*.yml --rbenv '2.5.1;2.6.0-preview2 --jit'
|
2018-07-08 14:08:26 -04:00
|
|
|
```
|
|
|
|
|
|
|
|
## make benchmark
|
|
|
|
|
|
|
|
Using `make benchmark`, `make update-benchmark-driver` automatically downloads
|
|
|
|
the supported version of benchmark-driver, and it runs benchmarks with the downloaded
|
|
|
|
benchmark-driver.
|
|
|
|
|
2018-07-08 14:10:14 -04:00
|
|
|
```bash
|
2018-07-08 14:08:26 -04:00
|
|
|
# Run all benchmarks with the ruby in the $PATH and the built ruby
|
|
|
|
make benchmark
|
|
|
|
|
|
|
|
# Or compare with specific ruby binary
|
|
|
|
make benchmark COMPARE_RUBY="/path/to/ruby --jit"
|
|
|
|
|
2018-07-09 12:31:35 -04:00
|
|
|
# Run vm1 benchmarks
|
|
|
|
make benchmark ITEM=vm1
|
2018-07-08 14:08:26 -04:00
|
|
|
|
2018-07-09 12:31:35 -04:00
|
|
|
# Run some limited benchmarks in ITEM-matched files
|
|
|
|
make benchmark ITEM=vm1 OPTS=--filter=block
|
2018-07-08 14:08:26 -04:00
|
|
|
|
2018-07-10 09:05:29 -04:00
|
|
|
# You can specify the benchmark by an exact filename instead of using the default argument:
|
|
|
|
# ARGS = $$(find $(srcdir)/benchmark -maxdepth 1 -name '*$(ITEM)*.yml' -o -name '*$(ITEM)*.rb')
|
2018-07-09 12:31:35 -04:00
|
|
|
make benchmark ARGS=../benchmark/erb_render.yml
|
2018-07-08 14:08:26 -04:00
|
|
|
|
2018-07-09 12:31:35 -04:00
|
|
|
# You can specify any option via $OPTS
|
|
|
|
make benchmark OPTS="--help"
|
2018-07-10 08:14:04 -04:00
|
|
|
|
|
|
|
# With `make benchmark`, some special runner plugins are available:
|
|
|
|
# -r peak, -r size
|
|
|
|
make benchmark ITEM=vm2_bigarray OPTS="-r peak"
|
2018-07-08 14:08:26 -04:00
|
|
|
```
|