blob: 9fd23acab6f2146f594f0c636992617587fc6478 [file] [log] [blame]
%% Copyright (c) 2008-2009 Nick Gerakines <nick@gerakines.net>
%%
%% Permission is hereby granted, free of charge, to any person
%% obtaining a copy of this software and associated documentation
%% files (the "Software"), to deal in the Software without
%% restriction, including without limitation the rights to use,
%% copy, modify, merge, publish, distribute, sublicense, and/or sell
%% copies of the Software, and to permit persons to whom the
%% Software is furnished to do so, subject to the following
%% conditions:
%%
%% The above copyright notice and this permission notice shall be
%% included in all copies or substantial portions of the Software.
%%
%% THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
%% EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES
%% OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
%% NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT
%% HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY,
%% WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
%% FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
%% OTHER DEALINGS IN THE SOFTWARE.
%%
%% @doc Provides test functionality against a specific web request. Many of
%% the exported methods can be used to build your own more complex tests.
-module(etap_request, [Method, Url, InHeaders, InBody, Status, OutHeaders, OutBody]).
-export([status_is/2]).
-export([
method/0, url/0, status/0, status_code/0, status_line/0, rheaders/0,
has_rheader/1, rheader/1, rbody/0, header_is/3, body_is/2,
body_has_string/2
]).
% ---
% Tests
%% @doc Assert that response status code is the given status code.
status_is(Code, Desc) ->
etap:is(status_code(), Code, Desc).
header_is(Name, Value, Desc) ->
etap:is(rheader(Name), Value, Desc).
body_is(Value, Desc) ->
etap:is(rbody(), Value, Desc).
body_has_string(String, Desc) when is_list(OutBody), is_list(String) ->
etap_string:contains_ok(OutBody, String, Desc).
% ---
% Accessor functions
%% @doc Access a request's method.
method() -> Method.
%% @doc Access a request's URL.
url() -> Url.
%% @doc Access a request's status.
status() -> Status.
%% @doc Access a request's status code.
status_code() ->
{_, Code, _} = Status,
Code.
%% @doc Access a request's status line.
status_line() ->
{_, _, Line} = Status,
Line.
%% @doc Access a request's headers.
rheaders() -> OutHeaders.
%% @doc Dertermine if a specific request header exists.
has_rheader(Key) ->
lists:keymember(Key, 1, OutHeaders).
%% @doc Return a specific request header.
rheader(Key) ->
case lists:keysearch(Key, 1, OutHeaders) of
false -> undefined;
{value, {Key, Value}} -> Value
end.
%% @doc Access the request's body.
rbody() -> OutBody.