'use strict'; const common = require('../common'); if (!common.hasCrypto) common.skip('missing crypto'); const http2 = require('http2'); const Countdown = require('../common/countdown'); 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}`); client.setMaxListeners(33); const countdown = new Countdown(count + 1, () => { server.close(); client.close(); }); // 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 NGHTTP2_PROTOCOL_ERROR' })); req.on('close', common.mustCall(() => countdown.dec())); } for (let i = 0; i <= count; i += 1) doTest(i); }));