diff options
author | Loïc Hoguin <[email protected]> | 2020-02-05 18:06:00 +0100 |
---|---|---|
committer | Loïc Hoguin <[email protected]> | 2020-02-05 18:06:00 +0100 |
commit | 47ecfd73181dc888f01479069cb7e076352da9ca (patch) | |
tree | 1f7160d53c9e2993aa4723b0cdf84855b96868dc /test/rfc7540_SUITE.erl | |
parent | 752297b1539b4f74c9329c873f78485a52b5b8bd (diff) | |
download | cowboy-47ecfd73181dc888f01479069cb7e076352da9ca.tar.gz cowboy-47ecfd73181dc888f01479069cb7e076352da9ca.tar.bz2 cowboy-47ecfd73181dc888f01479069cb7e076352da9ca.zip |
Add a test confirming push requests have no body
Diffstat (limited to 'test/rfc7540_SUITE.erl')
-rw-r--r-- | test/rfc7540_SUITE.erl | 12 |
1 files changed, 12 insertions, 0 deletions
diff --git a/test/rfc7540_SUITE.erl b/test/rfc7540_SUITE.erl index 17ac319..aec0aa1 100644 --- a/test/rfc7540_SUITE.erl +++ b/test/rfc7540_SUITE.erl @@ -4044,6 +4044,18 @@ reject_duplicate_content_length_header(Config) -> % PUSH_PROMISE frame as a connection error (Section 5.4.1) of type % PROTOCOL_ERROR. +push_has_no_request_body(Config) -> + doc("PUSH_PROMISE frames include the complete set of request headers " + "and the request can never include a body. (RFC7540 8.2.1)"), + ConnPid = gun_open(Config), + Ref = gun:get(ConnPid, "/resp/push/read_body"), + {push, PushRef, <<"GET">>, _, _} = gun:await(ConnPid, Ref), + {response, fin, 200, _} = gun:await(ConnPid, Ref), + %% We should not get a body in the pushed resource + %% since there was no body in the request. + {response, fin, 200, _} = gun:await(ConnPid, PushRef), + ok. + %% (RFC7540 8.2.1) % The header fields in PUSH_PROMISE and any subsequent CONTINUATION % frames MUST be a valid and complete set of request header fields |