Scroll to navigation

Test::Async::HTTP(3pm) User Contributed Perl Documentation Test::Async::HTTP(3pm)

NAME

"Test::Async::HTTP" - unit test code that uses "Net::Async::HTTP"

DESCRIPTION

This module implements a mock version of Net::Async::HTTP suitable for unit tests that virtualises the actual HTTP request/response cycle, allowing the unit test script to inspect the requests made and provide responses to them.

METHODS

$f = $http->do_request( %args )

Implements the actual Net::Async::HTTP request API.

The following arguments are handled specially:

  • timeout

    The value of a "timeout" argument is captured as an extra header on the request object called "X-NaHTTP-Timeout".

  • stall_timeout
  • expect_continue
  • SSL

    These arguments are entirely ignored.

$response = $http->GET( $uri, %args )->get

$response = $http->HEAD( $uri, %args )->get

$response = $http->PUT( $uri, $content, %args )->get

$response = $http->POST( $uri, $content, %args )->get

Convenient wrappers for using the "GET", "HEAD", "PUT" or "POST" methods with a "URI" object and few if any other arguments, returning a "Future".

Remember that "POST" with non-form data (as indicated by a plain scalar instead of an "ARRAY" reference of form data name/value pairs) needs a "content_type" key in %args.

$p = $http->next_pending

Returns the next pending request wrapper object if one is outstanding (due to an earlier call to "do_request"), or "undef".

PENDING REQUEST OBJECTS

Objects returned by "next_pending" respond to the following methods:

$request = $p->request

Returns the HTTP::Request object underlying this pending request.

$p->respond( $resp )

Makes the request complete with the given HTTP::Response response. This response is given to the Future that had been returned by the "do_request" method.

$p->respond_header( $header )

$p->respond_more( $data )

$p->respond_done

Alternative to the single "respond" method, to allow an equivalent of chunked encoding response. "respond_header" responds with the header and initial content, followed by multiple calls to "respond_more" to provide more body content, until a final "respond_done" call finishes the request.

AUTHOR

Paul Evans <leonerd@leonerd.org.uk>

2022-06-30 perl v5.34.0