NAME
Plack::Test - Test PSGI applications with various backends
SYNOPSIS
use
Plack::Test;
# Simple OO interface
my
$app
=
sub
{
return
[ 200, [], [
"Hello"
] ] };
my
$test
= Plack::Test->create(
$app
);
my
$res
=
$test
->request(GET
"/"
);
is
$res
->content,
"Hello"
;
# traditional - named params
test_psgi
app
=>
sub
{
my
$env
=
shift
;
return
[ 200, [
'Content-Type'
=>
'text/plain'
], [
"Hello World"
] ],
},
client
=>
sub
{
my
$cb
=
shift
;
my
$res
=
$cb
->(
$req
);
like
$res
->content,
qr/Hello World/
;
};
# positional params (app, client)
my
$app
=
sub
{
return
[ 200, [], [
"Hello"
] ] };
test_psgi
$app
,
sub
{
my
$cb
=
shift
;
my
$res
=
$cb
->(GET
"/"
);
is
$res
->content,
"Hello"
;
};
DESCRIPTION
Plack::Test is a unified interface to test PSGI applications using HTTP::Request and HTTP::Response objects. It also allows you to run PSGI applications in various ways. The default backend is Plack::Test::MockHTTP
, but you may also use any Plack::Handler implementation to run live HTTP requests against a web server.
METHODS
- create
-
$test
= Plack::Test->create(
$app
,
%options
);
creates an instance of Plack::Test implementation class.
$app
has to be a valid PSGI application code reference. - request
-
$res
=
$test
->request(
$request
);
takes an HTTP::Request object, runs it through the PSGI application to test and returns an HTTP::Response object.
FUNCTIONS
Plack::Test also provides a functional interface that takes two callbacks, each of which represents PSGI application and HTTP client code that tests the application.
- test_psgi
-
test_psgi
$app
,
$client
;
test_psgi
app
=>
$app
,
client
=>
$client
;
Runs the client test code
$client
against a PSGI application$app
. The client callback gets one argument$cb
, a callback that accepts anHTTP::Request
object and returns anHTTP::Response
object.Use HTTP::Request::Common to import shortcuts for creating requests for
GET
,POST
,DELETE
, andPUT
operations.For your convenience, the
HTTP::Request
given to the callback automatically uses the HTTP protocol and the localhost (127.0.0.1 by default), so the following code just works:Note that however, it is not a good idea to pass an arbitrary (i.e. user-input) string to
GET
or evenHTTP::Request->new
by assuming that it always represents a path, because:my
$req
= GET
"//foo/bar"
;
would represent a request for a URL that has no scheme, has a hostname foo and a path /bar, instead of a path //foo/bar which you might actually want.
OPTIONS
Specify the Plack::Test backend using the environment variable PLACK_TEST_IMPL
or $Plack::Test::Impl
package variable.
The available values for the backend are:
- MockHTTP
-
(Default) Creates a PSGI env hash out of HTTP::Request object, runs the PSGI application in-process and returns HTTP::Response.
- Server
-
Runs one of Plack::Handler backends (
Standalone
by default) and sends live HTTP requests to test. - ExternalServer
-
Runs tests against an external server specified in the
PLACK_TEST_EXTERNALSERVER_URI
environment variable instead of spawning the application in a server locally.
For instance, test your application with the HTTP::Server::ServerSimple
server backend with:
> env PLACK_TEST_IMPL=Server PLACK_SERVER=HTTP::Server::ServerSimple \
prove -l t/test.t
AUTHOR
Tatsuhiko Miyagawa