diff options
author | James M Snell <jasnell@gmail.com> | 2017-12-12 11:34:17 -0800 |
---|---|---|
committer | James M Snell <jasnell@gmail.com> | 2017-12-18 10:19:21 -0800 |
commit | 0babd181a0c5d775e62a12b3b04fe4d7654fe80a (patch) | |
tree | cf02bdb6a71b8d346109d1ab66e18c559dbf5a23 /test/parallel/test-http2-server-sessionerror.js | |
parent | 18ca0b64422337cc6844949b9b97f39fef82f512 (diff) | |
download | android-node-v8-0babd181a0c5d775e62a12b3b04fe4d7654fe80a.tar.gz android-node-v8-0babd181a0c5d775e62a12b3b04fe4d7654fe80a.tar.bz2 android-node-v8-0babd181a0c5d775e62a12b3b04fe4d7654fe80a.zip |
http2: cleanup Http2Stream/Http2Session destroy
PR-URL: https://github.com/nodejs/node/pull/17406
Reviewed-By: Matteo Collina <matteo.collina@gmail.com>
Reviewed-By: Anna Henningsen <anna@addaleax.net>
Reviewed-By: Anatoli Papirovski <apapirovski@mac.com>
This is a significant cleanup and refactoring of the
cleanup/close/destroy logic for Http2Stream and Http2Session.
There are significant changes here in the timing and ordering
of cleanup logic, JS apis. and various related necessary edits.
Diffstat (limited to 'test/parallel/test-http2-server-sessionerror.js')
-rw-r--r-- | test/parallel/test-http2-server-sessionerror.js | 48 |
1 files changed, 48 insertions, 0 deletions
diff --git a/test/parallel/test-http2-server-sessionerror.js b/test/parallel/test-http2-server-sessionerror.js new file mode 100644 index 0000000000..525eb2e6ef --- /dev/null +++ b/test/parallel/test-http2-server-sessionerror.js @@ -0,0 +1,48 @@ +// Flags: --expose-internals + +'use strict'; + +const common = require('../common'); +if (!common.hasCrypto) + common.skip('missing crypto'); +const http2 = require('http2'); +const { kSocket } = require('internal/http2/util'); + +const server = http2.createServer(); +server.on('stream', common.mustNotCall()); + +let test = 0; + +server.on('session', common.mustCall((session) => { + switch (++test) { + case 1: + server.on('error', common.mustNotCall()); + session.on('error', common.expectsError({ + type: Error, + message: 'test' + })); + session[kSocket].emit('error', new Error('test')); + break; + case 2: + // If the server does not have a socketError listener, + // error will be silent on the server but will close + // the session + session[kSocket].emit('error', new Error('test')); + break; + } +}, 2)); + +server.listen(0, common.mustCall(() => { + const url = `http://localhost:${server.address().port}`; + http2.connect(url) + // An ECONNRESET error may occur depending on the platform (due largely + // to differences in the timing of socket closing). Do not wrap this in + // a common must call. + .on('error', () => {}) + .on('close', () => { + server.removeAllListeners('error'); + http2.connect(url) + .on('error', () => {}) + .on('close', () => server.close()); + }); +})); |