summaryrefslogtreecommitdiff
path: root/test/parallel/test-http2-client-unescaped-path.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-client-unescaped-path.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-client-unescaped-path.js')
-rw-r--r--test/parallel/test-http2-client-unescaped-path.js37
1 files changed, 37 insertions, 0 deletions
diff --git a/test/parallel/test-http2-client-unescaped-path.js b/test/parallel/test-http2-client-unescaped-path.js
new file mode 100644
index 0000000000..d92d40492e
--- /dev/null
+++ b/test/parallel/test-http2-client-unescaped-path.js
@@ -0,0 +1,37 @@
+// Flags: --expose-http2
+'use strict';
+
+const common = require('../common');
+const http2 = require('http2');
+
+const server = http2.createServer();
+
+server.on('stream', common.mustNotCall());
+
+const count = 32;
+
+server.listen(0, common.mustCall(() => {
+ const client = http2.connect(`http://localhost:${server.address().port}`);
+
+ let remaining = count;
+ function maybeClose() {
+ if (--remaining === 0) {
+ server.close();
+ client.destroy();
+ }
+ }
+
+ // nghttp2 will catch the bad header value for us.
+ function doTest(i) {
+ const req = client.request({ ':path': `bad${String.fromCharCode(i)}path` });
+ req.on('error', common.expectsError({
+ code: 'ERR_HTTP2_STREAM_ERROR',
+ type: Error,
+ message: 'Stream closed with error code 1'
+ }));
+ req.on('streamClosed', common.mustCall(maybeClose));
+ }
+
+ for (let i = 0; i <= count; i += 1)
+ doTest(i);
+}));