/* This Source Code Form is subject to the terms of the Mozilla Public
* License, v. 2.0. If a copy of the MPL was not distributed with this
* file, You can obtain one at http://mozilla.org/MPL/2.0/. */
"use strict";
/* import-globals-from head_cache.js */
/* import-globals-from head_cookies.js */
/* import-globals-from head_channels.js */
/* import-globals-from head_servers.js */
function makeChan(uri) {
let chan = NetUtil.newChannel({
uri,
loadUsingSystemPrincipal:
true,
}).QueryInterface(Ci.nsIHttpChannel);
chan.loadFlags = Ci.nsIChannel.LOAD_INITIAL_DOCUMENT_URI;
return chan;
}
async
function test_cert_failure(server_or_proxy, server_cert) {
let server =
new server_or_proxy();
await server.start();
registerCleanupFunction(async () => {
await server.stop();
});
let chan = makeChan(`https:
//localhost:${server.port()}/test`);
let req = await
new Promise(resolve => {
chan.asyncOpen(
new ChannelListener(resolve,
null, CL_EXPECT_FAILURE));
});
equal(req.status, 0x805a1ff3);
// SEC_ERROR_UNKNOWN_ISSUER
let secinfo = req.securityInfo;
secinfo.QueryInterface(Ci.nsITransportSecurityInfo);
if (server_cert) {
Assert.equal(secinfo.serverCert.commonName,
" HTTP2 Test Cert");
}
else {
Assert.equal(secinfo.serverCert.commonName,
" Proxy Test Cert");
}
}
add_task(async
function test_https() {
await test_cert_failure(NodeHTTPSServer,
true);
});
add_task(async
function test_http2() {
await test_cert_failure(NodeHTTP2Server,
true);
});
add_task(async
function test_https_proxy() {
let proxy =
new NodeHTTPSProxyServer();
await proxy.start();
registerCleanupFunction(() => {
proxy.stop();
});
await test_cert_failure(NodeHTTPSServer,
false);
});
add_task(async
function test_http2_proxy() {
let proxy =
new NodeHTTP2ProxyServer();
await proxy.start();
registerCleanupFunction(() => {
proxy.stop();
});
await test_cert_failure(NodeHTTPSServer,
false);
});