NAME
Test::HTTP - Test HTTP interactions.
SYNOPSIS
use Test::HTTP tests => 9;
{
my $uri = "$BASE/data/page/Foo_Bar_Baz";
my $type = 'text/x.waki-wiki';
my $test = Test::HTTP->new('HTTP page creation and deletion');
$test->get($uri, {Accept => $type});
$test->status_code_is(404, "Page not yet there.");
$test->put($uri, {'Content-type' => $type}, 'xyzzy');
$test->status_code_is(201, "PUT returns 201."); # Created
$test->header_is(
'Content-type' => $type,
"Content-type matches on PUT.");
$test->header_like(
Location => qr{^$BASE/data/page/},
"Created page location makes sense.");
$test->body_is('xyzzy');
$test->get($uri, {Accept => $type});
$test->status_code_is(200, "Page is now there.");
$test->header_is(
'Content-type' => $type,
"Content-type matches on GET.");
$test->body_is('xyzzy');
$test->delete($uri);
$test->status_code_is(204, "DELETE returns 204."); # No content
}
DESCRIPTION
Test::HTTP is designed to make it easier to write tests which are mainly about HTTP-level things, such as REST-type services.
Each Test::HTTP
object can contain state about a current request and its response. This allows convenient shorthands for sending requests, checking status codes, headers, and message bodies.
CONSTRUCTOR
Test::HTTP->new($name);
$name
is a name for the test, used to help write test descriptions when you don't specify them.
OBJECT FIELDS
You can get/set any of these by saying $test->foo
or $test->foo(5)
, respectively.
$test->name
The name for the test.
$test->request
The current HTTP::Request being constructed or most recently sent.
$test->response
The most recently received HTTP::Response.
$test->ua
The User Agent object (usually an LWP::UserAgent).
$test->username
$test->password
A username and password to be used for HTTP basic auth. Default to the values of $Test::HTTP::BasicUsername
and $Test::HTTP::BasicPassword
, respectively. If both are undef, then authentication is not attempted.
REQUEST METHODS
head, get, put, post, and delete
Any of these methods may be used to do perform the expected HTTP request. They are all equivalent to
$obj->run_request(METHOD => ARGS);
$test->run_request([METHOD => $uri [, $headers [, $content]]]);
If there are any arguments, they are all passed to the HTTP::Request constructor to create a new $test->request
.
$test->request
is then executed, and $test->response
will hold the resulting HTTP::Response.
$test->new_request(METHOD => $uri [, $headers [, $content]]);
Set up a new request object as in run_request, but do not execute it yet. This is handy if you want to call assorted methods on the request to tweak it before running it with $test->run_request
.
TEST METHODS
$test->status_code_is($code [, $description]);
Compares the last response status code with the given code using Test::Builder-
is>.
$test->header_is($header_name, $value [, $description]);
Compares the response header $header_name
with the value $value
using Test::Builder-
is>.
$test->header_like($header_name, $regex, [, $description]);
Compares the response header $header_name
with the regex $regex
using Test::Builder-
like>.
$test->body_is($expected_body [, $description]);
Verifies that the HTTP response body is exactly $expected_body
.
$test->body_like($regex [, $description]);
Compares the HTTP response body with $regex
.
USER AGENT GENERATION
The user agent (UA) is created when the Test::HTTP
object is constructed. By default, LWP::UserAgent is used to create this object, but it may be handy to test your HTTP handlers without going through an actual HTTP server (for speed, e.g.), so there are a couple of ways to override the chosen class.
If the environment variable TEST_HTTP_UA_CLASS
is set, this value is used instead. If not, then the current value of $Test::HTTP::UaClass
(LWP::UserAgent
by default) is used. Thus, the incantation below may prove useful.
{
local $Test::HTTP::UaClass = 'MyCorp::REST::FakeUserAgent';
my $test = Test::HTTP->new("widget HTTP access");
# ...
}
SEE ALSO
http://www.w3.org/Protocols/rfc2616/rfc2616.html, LWP::UserAgent, HTTP::Request, HTTP::Response, Test::More, prove(1)
AUTHOR
Matt Liggett <mml@pobox.com>
COPYRIGHT & LICENSE
Copyright 2006 Socialtext, Inc.
Same terms as Perl.