diff --git a/lib/internal/http2/core.js b/lib/internal/http2/core.js index 8c05ff626792d7..871f876599359f 100644 --- a/lib/internal/http2/core.js +++ b/lib/internal/http2/core.js @@ -2774,7 +2774,16 @@ function connect(authority, options, listener) { const protocol = authority.protocol || options.protocol || 'https:'; const port = '' + (authority.port !== '' ? authority.port : (authority.protocol === 'http:' ? 80 : 443)); - const host = authority.hostname || authority.host || 'localhost'; + let host = 'localhost'; + + if (authority.hostname) { + host = authority.hostname; + + if (host[0] === '[') + host = host.slice(1, -1); + } else if (authority.host) { + host = authority.host; + } let socket; if (typeof options.createConnection === 'function') { diff --git a/test/parallel/test-http2-connect.js b/test/parallel/test-http2-connect.js index a2f30f974e9329..2137ef28926726 100644 --- a/test/parallel/test-http2-connect.js +++ b/test/parallel/test-http2-connect.js @@ -1,6 +1,12 @@ 'use strict'; -const { mustCall, hasCrypto, skip, expectsError } = require('../common'); +const { + mustCall, + hasCrypto, + hasIPv6, + skip, + expectsError +} = require('../common'); if (!hasCrypto) skip('missing crypto'); const { createServer, connect } = require('http2'); @@ -73,3 +79,25 @@ const { connect: netConnect } = require('net'); type: Error }); } + +// Check for literal IPv6 addresses in URL's +if (hasIPv6) { + const server = createServer(); + server.listen(0, '::1', mustCall(() => { + const { port } = server.address(); + const clients = new Set(); + + clients.add(connect(`http://[::1]:${port}`)); + clients.add(connect(new URL(`http://[::1]:${port}`))); + + for (const client of clients) { + client.once('connect', mustCall(() => { + client.close(); + clients.delete(client); + if (clients.size === 0) { + server.close(); + } + })); + } + })); +}