123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218 |
- // Copyright (C) 2011 Internet Systems Consortium, Inc. ("ISC")
- //
- // Permission to use, copy, modify, and/or distribute this software for any
- // purpose with or without fee is hereby granted, provided that the above
- // copyright notice and this permission notice appear in all copies.
- //
- // THE SOFTWARE IS PROVIDED "AS IS" AND ISC DISCLAIMS ALL WARRANTIES WITH
- // REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY
- // AND FITNESS. IN NO EVENT SHALL ISC BE LIABLE FOR ANY SPECIAL, DIRECT,
- // INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM
- // LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE
- // OR OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR
- // PERFORMANCE OF THIS SOFTWARE.
- #include "faked_nsec3.h"
- #include <dns/name.h>
- #include <testutils/dnsmessage_test.h>
- #include <map>
- #include <gtest/gtest.h>
- using namespace std;
- using namespace isc::dns;
- using namespace isc::testutils;
- namespace isc {
- namespace datasrc {
- namespace test {
- // Constant data definitions
- const char* const nsec3_common = " 300 IN NSEC3 1 1 12 aabbccdd "
- "2T7B4G4VSA5SMI47K61MV5BV1A22BOJR A RRSIG";
- const char* const nsec3_rrsig_common = " 300 IN RRSIG NSEC3 5 3 3600 "
- "20000101000000 20000201000000 12345 example.org. FAKEFAKEFAKE";
- const char* const nsec3_rrsig_common2 = " 300 IN RRSIG NSEC3 5 4 7200 "
- "20100410172647 20100311172647 63192 example.org. gNIVj4T8t51fEU6k"
- "OPpvK7HOGBFZGbalN5ZKmInyrww6UWZsUNdw07ge6/U6HfG+/s61RZ/Lis2M6yUWH"
- "yXbNbj/QqwqgadG5dhxTArfuR02xP600x0fWX8LXzW4yLMdKVxGbzYT+vvGz71o8g"
- "HSY5vYTtothcZQa4BMKhmGQEk=";
- const char* const apex_hash = "0P9MHAVEQVM6T7VBL5LOP2U3T2RP3TOM";
- const char* const apex_hash_lower = "0p9mhaveqvm6t7vbl5lop2u3t2rp3tom";
- const char* const ns1_hash = "2T7B4G4VSA5SMI47K61MV5BV1A22BOJR";
- const char* const w_hash = "01UDEMVP1J2F7EG6JEBPS17VP3N8I58H";
- const char* const xyw_hash = "2vptu5timamqttgl4luu9kg21e0aor3s";
- const char* const zzz_hash = "R53BQ7CC2UVMUBFU5OCMM6PERS9TK9EN";
- class TestNSEC3HashCreator::TestNSEC3Hash : public NSEC3Hash {
- private:
- typedef map<Name, string> NSEC3HashMap;
- typedef NSEC3HashMap::value_type NSEC3HashPair;
- NSEC3HashMap map_;
- public:
- TestNSEC3Hash() {
- // Build pre-defined hash
- map_[Name("example.org")] = apex_hash;
- map_[Name("www.example.org")] = "2S9MHAVEQVM6T7VBL5LOP2U3T2RP3TOM";
- map_[Name("xxx.example.org")] = "Q09MHAVEQVM6T7VBL5LOP2U3T2RP3TOM";
- map_[Name("yyy.example.org")] = "0A9MHAVEQVM6T7VBL5LOP2U3T2RP3TOM";
- map_[Name("x.y.w.example.org")] =
- "2VPTU5TIMAMQTTGL4LUU9KG21E0AOR3S";
- map_[Name("y.w.example.org")] = "K8UDEMVP1J2F7EG6JEBPS17VP3N8I58H";
- map_[Name("w.example.org")] = w_hash;
- map_[Name("zzz.example.org")] = zzz_hash;
- map_[Name("smallest.example.org")] =
- "00000000000000000000000000000000";
- map_[Name("largest.example.org")] =
- "UUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUU";
- }
- virtual string calculate(const Name& name) const {
- const NSEC3HashMap::const_iterator found = map_.find(name);
- if (found != map_.end()) {
- return (found->second);
- }
- isc_throw(isc::Unexpected, "unexpected name for NSEC3 test: "
- << name);
- }
- virtual bool match(const rdata::generic::NSEC3PARAM&) const {
- return (true);
- }
- virtual bool match(const rdata::generic::NSEC3&) const {
- return (true);
- }
- };
- NSEC3Hash* TestNSEC3HashCreator::create(const rdata::generic::NSEC3PARAM&)
- const
- {
- return (new TestNSEC3Hash);
- }
- NSEC3Hash* TestNSEC3HashCreator::create(const rdata::generic::NSEC3&) const {
- return (new TestNSEC3Hash);
- }
- void
- findNSEC3Check(bool expected_matched, uint8_t expected_labels,
- const string& expected_closest,
- const string& expected_next,
- const ZoneFinder::FindNSEC3Result& result)
- {
- EXPECT_EQ(expected_matched, result.matched);
- // Convert to int so the error messages would be more readable:
- EXPECT_EQ(static_cast<int>(expected_labels),
- static_cast<int>(result.closest_labels));
- vector<ConstRRsetPtr> actual_rrsets;
- ASSERT_TRUE(result.closest_proof);
- actual_rrsets.push_back(result.closest_proof);
- rrsetsCheck(expected_closest, actual_rrsets.begin(),
- actual_rrsets.end());
- actual_rrsets.clear();
- if (expected_next.empty()) {
- EXPECT_FALSE(result.next_proof);
- } else {
- ASSERT_TRUE(result.next_proof);
- actual_rrsets.push_back(result.next_proof);
- rrsetsCheck(expected_next, actual_rrsets.begin(),
- actual_rrsets.end());
- }
- }
- void
- performNSEC3Test(ZoneFinder &finder, bool rrsigs_exist) {
- // Parameter validation: the query name must be in or below the zone
- EXPECT_THROW(finder.findNSEC3(Name("example.com"), false), OutOfZone);
- EXPECT_THROW(finder.findNSEC3(Name("org"), true), OutOfZone);
- const Name origin("example.org");
- string apex_nsec3_text = string(apex_hash) + ".example.org." +
- string(nsec3_common);
- string ns1_nsec3_text = string(ns1_hash) + ".example.org." +
- string(nsec3_common);
- string w_nsec3_text = string(w_hash) + ".example.org." +
- string(nsec3_common);
- string zzz_nsec3_text = string(zzz_hash) + ".example.org." +
- string(nsec3_common);
- if (rrsigs_exist) {
- apex_nsec3_text += "\n" + string(apex_hash) + ".example.org." +
- string(nsec3_rrsig_common2);
- ns1_nsec3_text += "\n" + string(ns1_hash) + ".example.org." +
- string(nsec3_rrsig_common2);
- w_nsec3_text += "\n" + string(w_hash) + ".example.org." +
- string(nsec3_rrsig_common2);
- zzz_nsec3_text += "\n" + string(zzz_hash) + ".example.org." +
- string(nsec3_rrsig_common2);
- }
- // Apex name. It should have a matching NSEC3.
- {
- SCOPED_TRACE("apex, non recursive mode");
- findNSEC3Check(true, origin.getLabelCount(), apex_nsec3_text, "",
- finder.findNSEC3(origin, false));
- }
- // Recursive mode doesn't change the result in this case.
- {
- SCOPED_TRACE("apex, recursive mode");
- findNSEC3Check(true, origin.getLabelCount(), apex_nsec3_text, "",
- finder.findNSEC3(origin, true));
- }
- // Non existent name (in the NSEC3 namespace -- the findNSEC3 does
- // not look into the normal data). Disabling recursion, a covering
- // NSEC3 should be returned.
- const Name www_name("www.example.org");
- {
- SCOPED_TRACE("non existent name, non recursive mode");
- findNSEC3Check(false, www_name.getLabelCount(), apex_nsec3_text, "",
- finder.findNSEC3(www_name, false));
- }
- // Non existent name. The closest provable encloser is the apex,
- // and next closer is the query name itself (which NSEC3 for ns1
- // covers)
- // H(ns1) = 2T... < H(xxx) = Q0... < H(zzz) = R5...
- {
- SCOPED_TRACE("non existent name, recursive mode");
- findNSEC3Check(true, origin.getLabelCount(), apex_nsec3_text,
- ns1_nsec3_text,
- finder.findNSEC3(Name("xxx.example.org"), true));
- }
- // Similar to the previous case, but next closer name is different
- // from the query name. The closet encloser is w.example.org, and
- // next closer is y.w.example.org.
- // H(ns1) = 2T.. < H(y.w) = K8.. < H(zzz) = R5
- {
- SCOPED_TRACE("non existent name, non qname next closer");
- findNSEC3Check(true, Name("w.example.org").getLabelCount(),
- w_nsec3_text, ns1_nsec3_text,
- finder.findNSEC3(Name("x.y.w.example.org"),
- true));
- }
- // In the rest of test we check hash comparison for wrap around cases.
- {
- SCOPED_TRACE("very small hash");
- const Name smallest_name("smallest.example.org");
- findNSEC3Check(false, smallest_name.getLabelCount(),
- zzz_nsec3_text, "",
- finder.findNSEC3(smallest_name, false));
- }
- {
- SCOPED_TRACE("very large hash");
- const Name largest_name("largest.example.org");
- findNSEC3Check(false, largest_name.getLabelCount(),
- zzz_nsec3_text, "",
- finder.findNSEC3(largest_name, false));
- }
- }
- }
- }
- }
|