forked from mirrors/gecko-dev
* DNSPacket::Decode now returns an error code for NS responses with a non-zero RCODE. Previously, when we'd do the check for the parent domain, we'd treat any DoH response as a valid NS, making the entire check for parents useless. * Changes the documentation for this feature to mention the prefs used by this feature. * I don't think we need to worry about clearing the blocklist when the DNS cache is cleared. For testing we can simply disable the blocklist. In real life the blocklist is only 60 seconds and it's unlikely to cause problems for users. Depends on D136530 Differential Revision: https://phabricator.services.mozilla.com/D136531
81 lines
2.5 KiB
JavaScript
81 lines
2.5 KiB
JavaScript
/* 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";
|
|
|
|
const dns = Cc["@mozilla.org/network/dns-service;1"].getService(
|
|
Ci.nsIDNSService
|
|
);
|
|
const override = Cc["@mozilla.org/network/native-dns-override;1"].getService(
|
|
Ci.nsINativeDNSResolverOverride
|
|
);
|
|
|
|
function setup() {
|
|
trr_test_setup();
|
|
Services.prefs.setBoolPref("network.trr.temp_blocklist", true);
|
|
}
|
|
setup();
|
|
|
|
add_task(async function checkBlocklisting() {
|
|
let trrServer = new TRRServer();
|
|
registerCleanupFunction(async () => {
|
|
await trrServer.stop();
|
|
});
|
|
await trrServer.start();
|
|
info(`port = ${trrServer.port}\n`);
|
|
|
|
dns.clearCache(true);
|
|
Services.prefs.setCharPref(
|
|
"network.trr.uri",
|
|
`https://foo.example.com:${trrServer.port}/dns-query`
|
|
);
|
|
Services.prefs.setIntPref("network.trr.mode", Ci.nsIDNSService.MODE_TRRFIRST);
|
|
|
|
await trrServer.registerDoHAnswers("top.test.com", "NS", {});
|
|
|
|
override.addIPOverride("sub.top.test.com", "2.2.2.2");
|
|
override.addIPOverride("sub2.top.test.com", "2.2.2.2");
|
|
await new TRRDNSListener("sub.top.test.com", {
|
|
expectedAnswer: "2.2.2.2",
|
|
});
|
|
equal(await trrServer.requestCount("sub.top.test.com", "A"), 1);
|
|
|
|
// Clear the cache so that we need to consult the blocklist and not simply
|
|
// return the cached DNS record.
|
|
dns.clearCache(true);
|
|
await new TRRDNSListener("sub.top.test.com", {
|
|
expectedAnswer: "2.2.2.2",
|
|
});
|
|
equal(
|
|
await trrServer.requestCount("sub.top.test.com", "A"),
|
|
1,
|
|
"Request should go directly to native because result is still in blocklist"
|
|
);
|
|
|
|
// XXX(valentin): if this ever starts intermittently failing we need to add
|
|
// a sleep here. But the check for the parent NS should normally complete
|
|
// before the second subdomain request.
|
|
equal(
|
|
await trrServer.requestCount("top.test.com", "NS"),
|
|
1,
|
|
"Should have checked parent domain"
|
|
);
|
|
await new TRRDNSListener("sub2.top.test.com", {
|
|
expectedAnswer: "2.2.2.2",
|
|
});
|
|
equal(await trrServer.requestCount("sub2.top.test.com", "A"), 0);
|
|
|
|
// The blocklist should instantly expire.
|
|
Services.prefs.setIntPref("network.trr.temp_blocklist_duration_sec", 0);
|
|
dns.clearCache(true);
|
|
await new TRRDNSListener("sub.top.test.com", {
|
|
expectedAnswer: "2.2.2.2",
|
|
});
|
|
// blocklist expired. Do another check.
|
|
equal(
|
|
await trrServer.requestCount("sub.top.test.com", "A"),
|
|
2,
|
|
"We should do another TRR request because the bloclist expired"
|
|
);
|
|
});
|