NAME

App::plackbench - programmatic interface to plackbench

See plackbench for the command line tool.

SYNOPSIS

my $bench = App::plackbench->new(
    psgi_path => $psgi_path,
    count     => 5,
    uri       => '/some/path',
);
my $stats = $bench->run();

printf("Averaged %8.3f seconds over %d requests\n", $stats->mean(), $stats->count());

DESCRIPTION

Class for executing requests on a Plack application and recording stats.

ATTRIBUTES

app

Defaults to a Plack app loaded from psgi_path, using "load_psgi" in Plack::Util.

count

Number of times to execute the request. Defaults to 1.

warm

If true, an initial request will be made which won't be included in the stats. Defaults to false.

fixup

An arrayref of subroutine references to do any preprocessing of the request. Each subroutine reference will be called in order (though you shouldn't rely on that) and passed a reference to the HTTP::Request object.

Each sub will be called once for every unique request. Under a normal GET request, there will only be one unique request. However if "post_data" is being used there will be one unique request for request body.

The return value from the subs is ignored.

post_data

An arrayref of request bodies. If set, POST requests will be made instead of GET requests.

If multiple request bodies are set they will be rotated through. This can be useful, for instance, to cycle through possible values for a field.

psgi_path

The path to the Plack application to be tested.

uri

The URI to request on the app.

CONSTRUCTOR

new(%attributes)

Returns a new instance of App::plackbench. Any arguments will be used a attribute settings.

METHODS

run()

Executes the requests (using the current attribute settings), and returns an App::plackbench::Stats object. Takes no arguments.

add_fixup_from_file($file)

Evaluates $file and appends the returned subroutine reference to "fixups". If the file can't be parsed, or if it doesn't return a subroutine reference the method will die.

SEE ALSO

plackbench, Plack