diff options
author | Loïc Hoguin <[email protected]> | 2013-04-24 20:28:44 +0200 |
---|---|---|
committer | Loïc Hoguin <[email protected]> | 2013-04-24 20:28:44 +0200 |
commit | ad91aaf81aa7fddba016262f1c8001d479a76be5 (patch) | |
tree | 160cc2d94af30d73172cefe32be7ea5d8a9b0a4f /test/http_SUITE_data/http_multipart.erl | |
parent | 282e532ba9e1b0e0f1867e43dd60d1118a36c12f (diff) | |
download | cowboy-ad91aaf81aa7fddba016262f1c8001d479a76be5.tar.gz cowboy-ad91aaf81aa7fddba016262f1c8001d479a76be5.tar.bz2 cowboy-ad91aaf81aa7fddba016262f1c8001d479a76be5.zip |
Reorganize the http test suite
Diffstat (limited to 'test/http_SUITE_data/http_multipart.erl')
-rw-r--r-- | test/http_SUITE_data/http_multipart.erl | 29 |
1 files changed, 29 insertions, 0 deletions
diff --git a/test/http_SUITE_data/http_multipart.erl b/test/http_SUITE_data/http_multipart.erl new file mode 100644 index 0000000..c94739f --- /dev/null +++ b/test/http_SUITE_data/http_multipart.erl @@ -0,0 +1,29 @@ +%% Feel free to use, reuse and abuse the code in this file. + +-module(http_multipart). +-behaviour(cowboy_http_handler). +-export([init/3, handle/2, terminate/3]). + +init({_Transport, http}, Req, []) -> + {ok, Req, {}}. + +handle(Req, State) -> + {Result, Req2} = acc_multipart(Req), + {ok, Req3} = cowboy_req:reply(200, [], term_to_binary(Result), Req2), + {ok, Req3, State}. + +terminate(_, _, _) -> + ok. + +acc_multipart(Req) -> + acc_multipart(cowboy_req:multipart_data(Req), []). + +acc_multipart({headers, Headers, Req}, Acc) -> + acc_multipart(cowboy_req:multipart_data(Req), [{Headers, []}|Acc]); +acc_multipart({body, Data, Req}, [{Headers, BodyAcc}|Acc]) -> + acc_multipart(cowboy_req:multipart_data(Req), [{Headers, [Data|BodyAcc]}|Acc]); +acc_multipart({end_of_part, Req}, [{Headers, BodyAcc}|Acc]) -> + acc_multipart(cowboy_req:multipart_data(Req), + [{Headers, list_to_binary(lists:reverse(BodyAcc))}|Acc]); +acc_multipart({eof, Req}, Acc) -> + {lists:reverse(Acc), Req}. |