1 /* This Source Code Form is subject to the terms of the Mozilla Public
2 * License, v. 2.0. If a copy of the MPL was not distributed with this
3 * file, You can obtain one at http://mozilla.org/MPL/2.0/. */
9 const certOverrideService
= Cc
[
10 "@mozilla.org/security/certoverride;1"
11 ].getService(Ci
.nsICertOverrideService
);
13 add_setup(async
function setup() {
16 Services
.prefs
.setIntPref("network.trr.mode", Ci
.nsIDNSService
.MODE_TRRFIRST
);
17 Services
.prefs
.setBoolPref("network.dns.upgrade_with_https_rr", true);
18 Services
.prefs
.setBoolPref("network.dns.use_https_rr_as_altsvc", true);
19 Services
.prefs
.setBoolPref("network.dns.echconfig.enabled", true);
21 // An arbitrary, non-ECH server.
22 await
asyncStartTLSTestServer(
23 "DelegatedCredentialsServer",
24 "../../../security/manager/ssl/tests/unit/test_delegated_credentials"
27 let nssComponent
= Cc
["@mozilla.org/psm;1"].getService(Ci
.nsINSSComponent
);
28 await nssComponent
.asyncClearSSLExternalAndInternalSessionCache();
31 registerCleanupFunction(async () => {
33 Services
.prefs
.clearUserPref("network.dns.upgrade_with_https_rr");
34 Services
.prefs
.clearUserPref("network.dns.use_https_rr_as_altsvc");
35 Services
.prefs
.clearUserPref("network.dns.echconfig.enabled");
36 Services
.prefs
.clearUserPref(
37 "network.dns.echconfig.fallback_to_origin_when_all_failed"
40 await trrServer
.stop();
44 function makeChan(url
) {
45 let chan
= NetUtil
.newChannel({
47 loadUsingSystemPrincipal
: true,
48 contentPolicyType
: Ci
.nsIContentPolicy
.TYPE_DOCUMENT
,
49 }).QueryInterface(Ci
.nsIHttpChannel
);
53 function channelOpenPromise(chan
, flags
) {
54 return new Promise(resolve
=> {
55 function finish(req
, buffer
) {
56 certOverrideService
.setDisableAllSecurityChecksAndLetAttackersInterceptMyData(
59 resolve([req
, buffer
]);
61 certOverrideService
.setDisableAllSecurityChecksAndLetAttackersInterceptMyData(
64 chan
.asyncOpen(new ChannelListener(finish
, null, flags
));
68 add_task(async
function testRetryWithoutECH() {
69 const ECH_CONFIG_FIXED
=
70 "AEn+DQBFTQAgACCKB1Y5SfrGIyk27W82xPpzWTDs3q72c04xSurDWlb9CgAEAAEAA2QWZWNoLXB1YmxpYy5leGFtcGxlLmNvbQAA";
71 trrServer
= new TRRServer();
72 await trrServer
.start();
74 Services
.prefs
.setIntPref("network.trr.mode", 3);
75 Services
.prefs
.setCharPref(
77 `https://foo.example.com:${trrServer.port()}/dns-query`
79 Services
.prefs
.setBoolPref(
80 "network.dns.echconfig.fallback_to_origin_when_all_failed",
84 // Only the last record is valid to use.
85 await trrServer
.registerDoHAnswers(
86 "delegated-disabled.example.com",
91 name
: "delegated-disabled.example.com",
97 name
: "delegated-disabled.example.com",
101 value
: ECH_CONFIG_FIXED
,
102 needBase64Decode
: true,
111 await trrServer
.registerDoHAnswers("delegated-disabled.example.com", "A", {
114 name
: "delegated-disabled.example.com",
123 await
new TRRDNSListener("delegated-disabled.example.com", {
124 type
: Ci
.nsIDNSService
.RESOLVE_TYPE_HTTPSSVC
,
127 let chan
= makeChan(`https://delegated-disabled.example.com:8443`);
128 await
channelOpenPromise(chan
, CL_ALLOW_UNKNOWN_CL
);
129 let securityInfo
= chan
.securityInfo
;
132 !securityInfo
.isAcceptedEch
,
133 "This host should not have accepted ECH"
135 await trrServer
.stop();