From: Otto Moerbeek Date: Tue, 22 Sep 2020 15:19:41 +0000 (+0200) Subject: Test for potential NS loop. X-Git-Tag: auth-4.4.0-alpha2~62^2~1 X-Git-Url: http://git.ipfire.org/?a=commitdiff_plain;h=303ff4f69354473d0800a0852ea7a3bd4fda6de0;p=thirdparty%2Fpdns.git Test for potential NS loop. We succeed (that is do not go into an endlesss loop) and we need to keep it that way. --- diff --git a/pdns/recursordist/test-syncres_cc2.cc b/pdns/recursordist/test-syncres_cc2.cc index d8c1c5c320..b886200021 100644 --- a/pdns/recursordist/test-syncres_cc2.cc +++ b/pdns/recursordist/test-syncres_cc2.cc @@ -96,6 +96,62 @@ BOOST_AUTO_TEST_CASE(test_referral_depth_ok) do_test_referral_depth(false); } +BOOST_AUTO_TEST_CASE(test_glueless_referral_loop) +{ + std::unique_ptr sr; + initSR(sr); + + primeHints(); + + const DNSName target1("powerdns.com."); + const DNSName target2("powerdns.org."); + + sr->setAsyncCallback([target1, target2](const ComboAddress& ip, const DNSName& domain, int type, bool doTCP, bool sendRDQuery, int EDNS0Level, struct timeval* now, boost::optional& srcmask, boost::optional context, LWResult* res, bool* chained) { + if (isRootServer(ip)) { + setLWResult(res, 0, false, false, true); + + if (domain.isPartOf(DNSName("com."))) { + addRecordToLW(res, "com.", QType::NS, "a.gtld-servers.net.", DNSResourceRecord::AUTHORITY, 172800); + } + else if (domain.isPartOf(DNSName("org."))) { + addRecordToLW(res, "org.", QType::NS, "a.gtld-servers.net.", DNSResourceRecord::AUTHORITY, 172800); + } + else { + setLWResult(res, RCode::NXDomain, false, false, true); + return 1; + } + + addRecordToLW(res, "a.gtld-servers.net.", QType::A, "192.0.2.1", DNSResourceRecord::ADDITIONAL, 3600); + addRecordToLW(res, "a.gtld-servers.net.", QType::AAAA, "2001:DB8::1", DNSResourceRecord::ADDITIONAL, 3600); + return 1; + } + else if (ip == ComboAddress("192.0.2.1:53") || ip == ComboAddress("[2001:DB8::1]:53")) { + if (domain.isPartOf(target1)) { + setLWResult(res, 0, false, false, true); + addRecordToLW(res, "powerdns.com.", QType::NS, "ns1.powerdns.org.", DNSResourceRecord::AUTHORITY, 172800); + addRecordToLW(res, "powerdns.com.", QType::NS, "ns2.powerdns.org.", DNSResourceRecord::AUTHORITY, 172800); + return 1; + } + else if (domain.isPartOf(target2)) { + setLWResult(res, 0, false, false, true); + addRecordToLW(res, "powerdns.org.", QType::NS, "ns1.powerdns.com.", DNSResourceRecord::AUTHORITY, 172800); + addRecordToLW(res, "powerdns.org.", QType::NS, "ns2.powerdns.com.", DNSResourceRecord::AUTHORITY, 172800); + return 1; + } + setLWResult(res, RCode::NXDomain, false, false, true); + return 1; + } + else { + return 0; + } + }); + + vector ret; + int res = sr->beginResolve(target1, QType(QType::A), QClass::IN, ret); + BOOST_CHECK_EQUAL(res, RCode::ServFail); + BOOST_REQUIRE_EQUAL(ret.size(), 0U); +} + BOOST_AUTO_TEST_CASE(test_cname_qperq) { std::unique_ptr sr;