mirror of
https://github.com/nodejs/node.git
synced 2025-05-06 01:43:00 +00:00

When building --without-ssl and running the tests some of the http2 test fail with the following error message: internal/util.js:82 throw new errors.Error('ERR_NO_CRYPTO'); ^ Error [ERR_NO_CRYPTO]: Node.js is not compiled with OpenSSL crypto support at Object.assertCrypto (internal/util.js:82:11) at internal/http2/core.js:5:26 at NativeModule.compile (bootstrap_node.js:586:7) at NativeModule.require (bootstrap_node.js:531:18) at http2.js:17:5 at NativeModule.compile (bootstrap_node.js:586:7) at Function.NativeModule.require (bootstrap_node.js:531:18) at Function.Module._load (module.js:449:25) at Module.require (module.js:517:17) at require (internal/module.js:11:18) This commit adds hasCrypto checks and skips the tests if there is no crypto support. PR-URL: https://github.com/nodejs/node/pull/14657 Reviewed-By: Rich Trott <rtrott@gmail.com> Reviewed-By: Luigi Pinca <luigipinca@gmail.com> Reviewed-By: Tobias Nießen <tniessen@tnie.de> Reviewed-By: Colin Ihrig <cjihrig@gmail.com> Reviewed-By: Anna Henningsen <anna@addaleax.net> Reviewed-By: Refael Ackermann <refack@gmail.com> Reviewed-By: James M Snell <jasnell@gmail.com>
91 lines
2.3 KiB
JavaScript
91 lines
2.3 KiB
JavaScript
// Flags: --expose-http2
|
|
'use strict';
|
|
|
|
// Tests http2.connect()
|
|
|
|
const common = require('../common');
|
|
if (!common.hasCrypto)
|
|
common.skip('missing crypto');
|
|
const fs = require('fs');
|
|
const h2 = require('http2');
|
|
const path = require('path');
|
|
const url = require('url');
|
|
const URL = url.URL;
|
|
|
|
{
|
|
const server = h2.createServer();
|
|
server.listen(0);
|
|
|
|
server.on('listening', common.mustCall(function() {
|
|
const port = this.address().port;
|
|
|
|
const items = [
|
|
[`http://localhost:${port}`],
|
|
[new URL(`http://localhost:${port}`)],
|
|
[url.parse(`http://localhost:${port}`)],
|
|
[{ port: port }, { protocol: 'http:' }],
|
|
[{ port: port, hostname: '127.0.0.1' }, { protocol: 'http:' }]
|
|
];
|
|
|
|
let count = items.length;
|
|
|
|
const maybeClose = common.mustCall((client) => {
|
|
client.destroy();
|
|
if (--count === 0) {
|
|
setImmediate(() => server.close());
|
|
}
|
|
}, items.length);
|
|
|
|
items.forEach((i) => {
|
|
const client =
|
|
h2.connect.apply(null, i)
|
|
.on('connect', common.mustCall(() => maybeClose(client)));
|
|
});
|
|
|
|
// Will fail because protocol does not match the server.
|
|
h2.connect({ port: port, protocol: 'https:' })
|
|
.on('socketError', common.mustCall());
|
|
}));
|
|
}
|
|
|
|
|
|
{
|
|
|
|
const options = {
|
|
key: fs.readFileSync(path.join(common.fixturesDir, 'keys/agent3-key.pem')),
|
|
cert: fs.readFileSync(path.join(common.fixturesDir, 'keys/agent3-cert.pem'))
|
|
};
|
|
|
|
const server = h2.createSecureServer(options);
|
|
server.listen(0);
|
|
|
|
server.on('listening', common.mustCall(function() {
|
|
const port = this.address().port;
|
|
|
|
const opts = { rejectUnauthorized: false };
|
|
|
|
const items = [
|
|
[`https://localhost:${port}`, opts],
|
|
[new URL(`https://localhost:${port}`), opts],
|
|
[url.parse(`https://localhost:${port}`), opts],
|
|
[{ port: port, protocol: 'https:' }, opts],
|
|
[{ port: port, hostname: '127.0.0.1', protocol: 'https:' }, opts]
|
|
];
|
|
|
|
let count = items.length;
|
|
|
|
const maybeClose = common.mustCall((client) => {
|
|
client.destroy();
|
|
if (--count === 0) {
|
|
setImmediate(() => server.close());
|
|
}
|
|
}, items.length);
|
|
|
|
items.forEach((i) => {
|
|
const client =
|
|
h2.connect.apply(null, i)
|
|
.on('connect', common.mustCall(() => maybeClose(client)));
|
|
});
|
|
}));
|
|
}
|