'use strict'; const common = require('../common'); if (!common.hasCrypto) common.skip('missing crypto'); const assert = require('assert'); const http2 = require('http2'); const server = http2.createServer(); server.on('session', common.mustCall((session) => { // Verify that the settings disabling push is received session.on('remoteSettings', common.mustCall((settings) => { assert.strictEqual(settings.enablePush, false); })); })); server.on('stream', common.mustCall((stream) => { // The client has disabled push streams, so pushAllowed must be false, // and pushStream() must throw. assert.strictEqual(stream.pushAllowed, false); common.expectsError(() => { stream.pushStream({ ':scheme': 'http', ':path': '/foobar', ':authority': `localhost:${server.address().port}`, }, common.mustNotCall()); }, { code: 'ERR_HTTP2_PUSH_DISABLED', type: Error }); stream.respond({ ':status': 200 }); stream.end('test'); })); server.listen(0, common.mustCall(() => { const options = { settings: { enablePush: false } }; const client = http2.connect(`http://localhost:${server.address().port}`, options); const req = client.request({ ':path': '/' }); // Because push streams are disabled, this must not be called. client.on('stream', common.mustNotCall()); req.resume(); req.on('end', common.mustCall(() => { server.close(); client.close(); })); req.end(); }));