%% 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.