Project

autobench

0.0
No commit activity in last 3 years
No release in over 3 years
Autobench is a ruby based web page benchmarking tool, wrapping other popular utiliies. Namely: httperf, yslow.js and phantomas.
2005
2006
2007
2008
2009
2010
2011
2012
2013
2014
2015
2016
2017
2018
2019
2020
2021
2022
2023
2024
2025
 Dependencies

Development

~> 5.0.5
~> 10.1.0

Runtime

~> 0.3.11
 Project Readme

Autobench [alpha release]

Gem Version  Build Status

Autobench, as follow up to Autoperf, was created to allow for benchmarking web pages in three different ways.

  1. Render Metrics -- using httperf and HTTPerf.rb, it grabs a snapshot of how long it takes to access, (server side) render and download your page. You can set thresholds in your configuration for almost all of httperf's output. Additionally, if you use my version of httperf you'll get percentile support as well.
  2. Client Metrics -- using phantomas, a sweet PhantomJS script that grabs all kinds of useful DOM information from loading your page. See phantomas for more details.
  3. YSlow Metrics -- using yslow.js, a PhantomJS script written to inspect your page and give you all kinds of useful grading and information. See YSlow for more details.

Autobench is based around a pass / fail mentality and let's you set as many or as few thresholds as you would like through it's extensive, but hopefully simple configuration. You can easily generate a template configuration for your web page by running autobench-config -o ./path/to/write/config.yml -s example.com -u /path/to/page (see usage notes below for details).

For sample configurations, see: github.com/jmervine/autobench/tree/master/config.

Why Alpha

Mostly because I haven't use this in thre real world yet. I don't like to final release my gems until I've had a change to fully vet them in real world senarios. Additionally, I have some additional features in mind, like being able to pass a padding value in to autobench-config to pad thresholds by a percentage and perhaps allowing autobench to take a run only flag for benchmarks.

Lastly, and more importantly, I want to make sure it's actually useful. Currently when running autobench, either via cli or in a test framework, I get a high failure rate do to network latency and other factors.

That said, help me out. Install it, try it, submit issues or fork it and send me pull requests.

Installation

:::shell
gem install autobench --pre
# or...
bundle init
echo "gem 'autobench', '0.0.1alpha1'" >> Gemfile
bundle install --path vendor/bundle

Dependencies

The following three dependencies must either be in your PATH, or specified in your configuration like so:

:::yaml
paths:
    httperf: /path/to/httperf
    phantomjs: /path/to/phantomjs
    node: /path/to/node

HTTPerf

It's recommended that you install my version of httperf, however, if you choose not to, any version will give you most of the thresholds available.

:::shell
# Ubuntu
sudo apt-get install httperf
# CentOS
sudo yum install httperf
# Mac
sudo port install httperf # I think? Anyone, confirm!

PhantomJS

See: phantomjs.org.

NodeJS

See: Installing Node.js from Source or nodejs.org.

Usage

With Minitest

:::ruby
require "minitest/autorun"
require "autobench"

class TestBenchmarks < Minitest::Test
    def setup
        @autobench = Autobench.new("./config/mervine.yml")
    end
    def test_autobench_render
        @autobench.render.benchmark
        assert @autobench.render.passed?,
            "Passed:\n#{@autobench.render.successes}\nFailed:\n#{@autobench.render.failures}"
    end
    def test_autobench_client
        @autobench.client.benchmark
        assert @autobench.client.passed?,
            "Passed:\n#{@autobench.client.successes}\nFailed:\n#{@autobench.client.failures}"
    end
    def test_autobench_yslow
        @autobench.yslow.benchmark
        assert @autobench.yslow.passed?,
            "Passed:\n#{@autobench.yslow.successes}\nFailed:\n#{@autobench.yslow.failures}"
    end
end

See github.com/jmervine/autobench/tree/master/examples for more test framework examples.

CLI

autobench

Usage: autobench [options]

Required Arguments:
    -c, --config FILENAME            configuration file

Optional Arguments:

  Note: server, port, uri and runs overide what's in
  your configuation file.

    -s, --server SERVER              target server
    -p, --port PORT                  target port
    -u, --uri URI                    target uri
    -i, --runs RUNS                  itterations against target
    -f, --format [json|yaml|csv]     raw output format
    -r, --results [dirname]          results directory (default: /tmp)

Module Exclusion:
    -R, --without-render             Do not include render (httperf).
    -Y, --without-yslow              Do not include yslow (yslow.js).
    -C, --without-client             Do not include client (phantomas).

Misc. Arguments:
    -q, --quiet                      Print no things.
    -h, --help                       Show this message

autobench-config

The purpose of this is to generate a base configuration for your page, containing all possible values in their current state.

Note: I recommend looking over each configuration and removing those you don't care about. Also, you should bump most up just a bit to account for standard network variance.

Usage: autobench-config [options]

Required Arguments:
    -o, --output FILENAME            configuration output file

Optional Arguments:

  Note: server, port, uri and runs overide defaults:
  - server: 'localhost'
  - port:   80
  - uri:    '/'
  - runs:   9

    -s, --server SERVER              target server
    -p, --port PORT                  target port
    -u, --uri URI                    target uri
    -i, --runs RUNS                  itterations against target

Module Exclusion:
    -R, --without-render             Do not include render (httperf).
    -Y, --without-yslow              Do not include yslow (yslow.js).
    -C, --without-client             Do not include client (phantomas).

Misc. Arguments:
    -h, --help                       Show this message