mirror of
https://github.com/ninenines/cowboy.git
synced 2025-07-14 12:20:24 +00:00
Add sendfile support to cowboy_req:stream_body
It is now possible to stream one or more sendfile tuples. A simple example of what can now be done would be for example to build a tar file on the fly using the sendfile syscall for sending the files, or to support Range requests with more than one range with the sendfile syscall. When using cowboy_compress_h unfortunately we have to read the file in order to send it. More options will be added at a later time to make sure users don't read too much into memory. This is a new feature however so existing code is not affected. Also rework cowboy_http's data sending to be flatter.
This commit is contained in:
parent
29043aa7b4
commit
d7b7580b39
12 changed files with 219 additions and 100 deletions
|
@ -121,6 +121,24 @@ gzip_stream_reply(Config) ->
|
|||
_ = zlib:gunzip(GzBody),
|
||||
ok.
|
||||
|
||||
gzip_stream_reply_sendfile(Config) ->
|
||||
doc("Stream reply using sendfile for some chunks; get a gzipped response."),
|
||||
{200, Headers, GzBody} = do_get("/stream_reply/sendfile",
|
||||
[{<<"accept-encoding">>, <<"gzip">>}], Config),
|
||||
{_, <<"gzip">>} = lists:keyfind(<<"content-encoding">>, 1, Headers),
|
||||
file:write_file("/tmp/test.gz", GzBody),
|
||||
_ = zlib:gunzip(GzBody),
|
||||
ok.
|
||||
|
||||
gzip_stream_reply_sendfile_fin(Config) ->
|
||||
doc("Stream reply using sendfile for some chunks; get a gzipped response."),
|
||||
{200, Headers, GzBody} = do_get("/stream_reply/sendfile_fin",
|
||||
[{<<"accept-encoding">>, <<"gzip">>}], Config),
|
||||
{_, <<"gzip">>} = lists:keyfind(<<"content-encoding">>, 1, Headers),
|
||||
file:write_file("/tmp/test.gz", GzBody),
|
||||
_ = zlib:gunzip(GzBody),
|
||||
ok.
|
||||
|
||||
gzip_stream_reply_content_encoding(Config) ->
|
||||
doc("Stream reply with content-encoding header; get an uncompressed response."),
|
||||
{200, Headers, Body} = do_get("/stream_reply/content-encoding",
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue