summaryrefslogtreecommitdiff
path: root/test/parallel/test-http2-window-size.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-window-size.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-window-size.js')
-rw-r--r--test/parallel/test-http2-window-size.js102
1 files changed, 102 insertions, 0 deletions
diff --git a/test/parallel/test-http2-window-size.js b/test/parallel/test-http2-window-size.js
new file mode 100644
index 0000000000..d914e99f6a
--- /dev/null
+++ b/test/parallel/test-http2-window-size.js
@@ -0,0 +1,102 @@
+// Flags: --expose-http2
+'use strict';
+
+// This test ensures that servers are able to send data independent of window
+// size.
+// TODO: This test makes large buffer allocations (128KiB) and should be tested
+// on smaller / IoT platforms in case this poses problems for these targets.
+
+const assert = require('assert');
+const common = require('../common');
+const h2 = require('http2');
+
+// Given a list of buffers and an initial window size, have a server write
+// each buffer to the HTTP2 Writable stream, and let the client verify that
+// all of the bytes were sent correctly
+function run(buffers, initialWindowSize) {
+ return new Promise((resolve, reject) => {
+ const expectedBuffer = Buffer.concat(buffers);
+
+ const server = h2.createServer();
+ server.on('stream', (stream) => {
+ let i = 0;
+ const writeToStream = () => {
+ const cont = () => {
+ i++;
+ if (i < buffers.length) {
+ setImmediate(writeToStream);
+ } else {
+ stream.end();
+ }
+ };
+ const drained = stream.write(buffers[i]);
+ if (drained) {
+ cont();
+ } else {
+ stream.once('drain', cont);
+ }
+ };
+ writeToStream();
+ });
+ server.listen(0);
+
+ server.on('listening', common.mustCall(function() {
+ const port = this.address().port;
+
+ const client =
+ h2.connect({
+ authority: 'localhost',
+ protocol: 'http:',
+ port
+ }, {
+ settings: {
+ initialWindowSize
+ }
+ }).on('connect', common.mustCall(() => {
+ const req = client.request({
+ ':method': 'GET',
+ ':path': '/'
+ });
+ const responses = [];
+ req.on('data', (data) => {
+ responses.push(data);
+ });
+ req.on('end', common.mustCall(() => {
+ const actualBuffer = Buffer.concat(responses);
+ assert.strictEqual(Buffer.compare(actualBuffer, expectedBuffer), 0);
+ // shut down
+ client.destroy();
+ server.close(() => {
+ resolve();
+ });
+ }));
+ req.end();
+ }));
+ }));
+ });
+}
+
+const bufferValueRange = [0, 1, 2, 3];
+const buffersList = [
+ bufferValueRange.map((a) => Buffer.alloc(1 << 4, a)),
+ bufferValueRange.map((a) => Buffer.alloc((1 << 8) - 1, a)),
+// Specifying too large of a value causes timeouts on some platforms
+// bufferValueRange.map((a) => Buffer.alloc(1 << 17, a))
+];
+const initialWindowSizeList = [
+ 1 << 4,
+ (1 << 8) - 1,
+ 1 << 8,
+ 1 << 17,
+ undefined // use default window size which is (1 << 16) - 1
+];
+
+// Call `run` on each element in the cartesian product of buffersList and
+// initialWindowSizeList.
+let p = Promise.resolve();
+for (const buffers of buffersList) {
+ for (const initialWindowSize of initialWindowSizeList) {
+ p = p.then(() => run(buffers, initialWindowSize));
+ }
+}
+p.then(common.mustCall(() => {}));