summaryrefslogtreecommitdiff
path: root/test/parallel/test-http2-compat-serverresponse-end.js
diff options
context:
space:
mode:
authorJames M Snell <jasnell@gmail.com>2017-07-17 10:29:42 -0700
committerJames M Snell <jasnell@gmail.com>2017-08-04 12:55:58 -0700
commitb1e055696fbcd4b8829630d0be787cfc74fe913b (patch)
treed0d5be3a2e46ff5a38e139eb519e3aa5322a2d71 /test/parallel/test-http2-compat-serverresponse-end.js
parente71e71b5138c3dfee080f4215dd957dc7a6cbdaf (diff)
downloadandroid-node-v8-b1e055696fbcd4b8829630d0be787cfc74fe913b.tar.gz
android-node-v8-b1e055696fbcd4b8829630d0be787cfc74fe913b.tar.bz2
android-node-v8-b1e055696fbcd4b8829630d0be787cfc74fe913b.zip
http2: add tests and benchmarks
PR-URL: https://github.com/nodejs/node/pull/14239 Reviewed-By: Anna Henningsen <anna@addaleax.net> Reviewed-By: Colin Ihrig <cjihrig@gmail.com> Reviewed-By: Matteo Collina <matteo.collina@gmail.com>
Diffstat (limited to 'test/parallel/test-http2-compat-serverresponse-end.js')
-rw-r--r--test/parallel/test-http2-compat-serverresponse-end.js77
1 files changed, 77 insertions, 0 deletions
diff --git a/test/parallel/test-http2-compat-serverresponse-end.js b/test/parallel/test-http2-compat-serverresponse-end.js
new file mode 100644
index 0000000000..1274f3d6b3
--- /dev/null
+++ b/test/parallel/test-http2-compat-serverresponse-end.js
@@ -0,0 +1,77 @@
+// Flags: --expose-http2
+'use strict';
+
+const { strictEqual } = require('assert');
+const { mustCall, mustNotCall } = require('../common');
+const {
+ createServer,
+ connect,
+ constants: {
+ HTTP2_HEADER_STATUS,
+ HTTP_STATUS_OK
+ }
+} = require('http2');
+
+{
+ // Http2ServerResponse.end callback is called only the first time,
+ // but may be invoked repeatedly without throwing errors.
+ const server = createServer(mustCall((request, response) => {
+ response.end(mustCall(() => {
+ server.close();
+ }));
+ response.end(mustNotCall());
+ }));
+ server.listen(0, mustCall(() => {
+ const { port } = server.address();
+ const url = `http://localhost:${port}`;
+ const client = connect(url, mustCall(() => {
+ const headers = {
+ ':path': '/',
+ ':method': 'GET',
+ ':scheme': 'http',
+ ':authority': `localhost:${port}`
+ };
+ const request = client.request(headers);
+ request.on('data', mustNotCall());
+ request.on('end', mustCall(() => client.destroy()));
+ request.end();
+ request.resume();
+ }));
+ }));
+}
+
+{
+ // Http2ServerResponse.end is not necessary on HEAD requests since the stream
+ // is already closed. Headers, however, can still be sent to the client.
+ const server = createServer(mustCall((request, response) => {
+ strictEqual(response.finished, true);
+ response.writeHead(HTTP_STATUS_OK, { foo: 'bar' });
+ response.flushHeaders();
+ response.end(mustNotCall());
+ }));
+ server.listen(0, mustCall(() => {
+ const { port } = server.address();
+ const url = `http://localhost:${port}`;
+ const client = connect(url, mustCall(() => {
+ const headers = {
+ ':path': '/',
+ ':method': 'HEAD',
+ ':scheme': 'http',
+ ':authority': `localhost:${port}`
+ };
+ const request = client.request(headers);
+ request.on('response', mustCall((headers, flags) => {
+ strictEqual(headers[HTTP2_HEADER_STATUS], HTTP_STATUS_OK);
+ strictEqual(flags, 5); // the end of stream flag is set
+ strictEqual(headers.foo, 'bar');
+ }));
+ request.on('data', mustNotCall());
+ request.on('end', mustCall(() => {
+ client.destroy();
+ server.close();
+ }));
+ request.end();
+ request.resume();
+ }));
+ }));
+}