Plack::Test - Test PSGI applications with various backends
use Plack::Test; test_psgi app => sub { my $env = shift; return [ 200, [ 'Content-Type' => 'text/plain' ], [ "Hello World" ] ], }, client => sub { my $cb = shift; my $req = HTTP::Request->new(GET => "http://localhost/hello"); my $res = $cb->($req); like $res->content, qr/Hello World/; };
Plack::Test is an unified interface to test PSGI applications using standard HTTP::Request and HTTP::Response objects. It also allows you to run PSGI applications in various ways, by default using MockHTTP backend but can also use Server backend, which uses one of Plack::Server implementations to run the web server to do live HTTP requests.
MockHTTP
Server
You can specify the Plack::Test backend using the environment variable PLACK_TEST_IMPL or $Plack::Test::Impl package variable.
PLACK_TEST_IMPL
$Plack::Test::Impl
The available values for the backend are:
(Default) Creates a PSGI env hash out of HTTP::Request object, runs the PSGI application in-process and returns HTTP::Response.
Runs one of Plack::Server backends (Standalone by default) and sends live HTTP requests to test.
Standalone
For instance, you can test your application with ServerSimple server backends with:
ServerSimple
> env PLACK_TEST_IMPL=Server PLACK_SERVER=ServerSimple prove -l t/test.t
Tatsuhiko Miyagawa
To install Plack, copy and paste the appropriate command in to your terminal.
cpanm
cpanm Plack
CPAN shell
perl -MCPAN -e shell install Plack
For more information on module installation, please visit the detailed CPAN module installation guide.