|
@@ -14,6 +14,8 @@
|
|
|
|
|
|
#include <exceptions/exceptions.h>
|
|
|
|
|
|
+#include <util/memory_segment_local.h>
|
|
|
+
|
|
|
#include <dns/name.h>
|
|
|
#include <dns/rrclass.h>
|
|
|
|
|
@@ -40,7 +42,7 @@ TEST(ZoneTest, init) {
|
|
|
TEST(ZoneTest, find) {
|
|
|
InMemoryZoneFinder zone(RRClass::IN(), Name("example.com"));
|
|
|
EXPECT_EQ(ZoneFinder::NXDOMAIN,
|
|
|
- zone.find(Name("www.example.com"), RRType::A()).code);
|
|
|
+ zone.find(Name("www.example.com"), RRType::A())->code);
|
|
|
}
|
|
|
|
|
|
class ZoneTableTest : public ::testing::Test {
|
|
@@ -50,68 +52,74 @@ protected:
|
|
|
zone2(new InMemoryZoneFinder(RRClass::IN(),
|
|
|
Name("example.net"))),
|
|
|
zone3(new InMemoryZoneFinder(RRClass::IN(),
|
|
|
- Name("example")))
|
|
|
+ Name("example"))),
|
|
|
+ zone_table(ZoneTable::create(local_mem_sgmt_))
|
|
|
{}
|
|
|
- ZoneTable zone_table;
|
|
|
+
|
|
|
+ ~ZoneTableTest() {
|
|
|
+ ZoneTable::destroy(local_mem_sgmt_, zone_table);
|
|
|
+ }
|
|
|
ZoneFinderPtr zone1, zone2, zone3;
|
|
|
+ isc::util::MemorySegmentLocal local_mem_sgmt_;
|
|
|
+ ZoneTable* zone_table;
|
|
|
};
|
|
|
|
|
|
TEST_F(ZoneTableTest, addZone) {
|
|
|
- EXPECT_EQ(result::SUCCESS, zone_table.addZone(zone1));
|
|
|
- EXPECT_EQ(result::EXIST, zone_table.addZone(zone1));
|
|
|
+ EXPECT_EQ(result::SUCCESS, zone_table->addZone(zone1));
|
|
|
+ EXPECT_EQ(result::EXIST, zone_table->addZone(zone1));
|
|
|
// names are compared in a case insensitive manner.
|
|
|
- EXPECT_EQ(result::EXIST, zone_table.addZone(
|
|
|
+ EXPECT_EQ(result::EXIST, zone_table->addZone(
|
|
|
ZoneFinderPtr(new InMemoryZoneFinder(RRClass::IN(),
|
|
|
Name("EXAMPLE.COM")))));
|
|
|
|
|
|
- EXPECT_EQ(result::SUCCESS, zone_table.addZone(zone2));
|
|
|
- EXPECT_EQ(result::SUCCESS, zone_table.addZone(zone3));
|
|
|
+ EXPECT_EQ(result::SUCCESS, zone_table->addZone(zone2));
|
|
|
+ EXPECT_EQ(result::SUCCESS, zone_table->addZone(zone3));
|
|
|
|
|
|
// Zone table is indexed only by name. Duplicate origin name with
|
|
|
// different zone class isn't allowed.
|
|
|
- EXPECT_EQ(result::EXIST, zone_table.addZone(
|
|
|
+ EXPECT_EQ(result::EXIST, zone_table->addZone(
|
|
|
ZoneFinderPtr(new InMemoryZoneFinder(RRClass::CH(),
|
|
|
Name("example.com")))));
|
|
|
|
|
|
/// Bogus zone (NULL)
|
|
|
- EXPECT_THROW(zone_table.addZone(ZoneFinderPtr()), isc::InvalidParameter);
|
|
|
+ EXPECT_THROW(zone_table->addZone(ZoneFinderPtr()), isc::InvalidParameter);
|
|
|
}
|
|
|
|
|
|
TEST_F(ZoneTableTest, DISABLED_removeZone) {
|
|
|
- EXPECT_EQ(result::SUCCESS, zone_table.addZone(zone1));
|
|
|
- EXPECT_EQ(result::SUCCESS, zone_table.addZone(zone2));
|
|
|
- EXPECT_EQ(result::SUCCESS, zone_table.addZone(zone3));
|
|
|
+ EXPECT_EQ(result::SUCCESS, zone_table->addZone(zone1));
|
|
|
+ EXPECT_EQ(result::SUCCESS, zone_table->addZone(zone2));
|
|
|
+ EXPECT_EQ(result::SUCCESS, zone_table->addZone(zone3));
|
|
|
|
|
|
- EXPECT_EQ(result::SUCCESS, zone_table.removeZone(Name("example.net")));
|
|
|
- EXPECT_EQ(result::NOTFOUND, zone_table.removeZone(Name("example.net")));
|
|
|
+ EXPECT_EQ(result::SUCCESS, zone_table->removeZone(Name("example.net")));
|
|
|
+ EXPECT_EQ(result::NOTFOUND, zone_table->removeZone(Name("example.net")));
|
|
|
}
|
|
|
|
|
|
TEST_F(ZoneTableTest, findZone) {
|
|
|
- EXPECT_EQ(result::SUCCESS, zone_table.addZone(zone1));
|
|
|
- EXPECT_EQ(result::SUCCESS, zone_table.addZone(zone2));
|
|
|
- EXPECT_EQ(result::SUCCESS, zone_table.addZone(zone3));
|
|
|
+ EXPECT_EQ(result::SUCCESS, zone_table->addZone(zone1));
|
|
|
+ EXPECT_EQ(result::SUCCESS, zone_table->addZone(zone2));
|
|
|
+ EXPECT_EQ(result::SUCCESS, zone_table->addZone(zone3));
|
|
|
|
|
|
- EXPECT_EQ(result::SUCCESS, zone_table.findZone(Name("example.com")).code);
|
|
|
+ EXPECT_EQ(result::SUCCESS, zone_table->findZone(Name("example.com")).code);
|
|
|
EXPECT_EQ(Name("example.com"),
|
|
|
- zone_table.findZone(Name("example.com")).zone->getOrigin());
|
|
|
+ zone_table->findZone(Name("example.com")).zone->getOrigin());
|
|
|
|
|
|
EXPECT_EQ(result::NOTFOUND,
|
|
|
- zone_table.findZone(Name("example.org")).code);
|
|
|
+ zone_table->findZone(Name("example.org")).code);
|
|
|
EXPECT_EQ(ConstZoneFinderPtr(),
|
|
|
- zone_table.findZone(Name("example.org")).zone);
|
|
|
+ zone_table->findZone(Name("example.org")).zone);
|
|
|
|
|
|
// there's no exact match. the result should be the longest match,
|
|
|
// and the code should be PARTIALMATCH.
|
|
|
EXPECT_EQ(result::PARTIALMATCH,
|
|
|
- zone_table.findZone(Name("www.example.com")).code);
|
|
|
+ zone_table->findZone(Name("www.example.com")).code);
|
|
|
EXPECT_EQ(Name("example.com"),
|
|
|
- zone_table.findZone(Name("www.example.com")).zone->getOrigin());
|
|
|
+ zone_table->findZone(Name("www.example.com")).zone->getOrigin());
|
|
|
|
|
|
// make sure the partial match is indeed the longest match by adding
|
|
|
// a zone with a shorter origin and query again.
|
|
|
ZoneFinderPtr zone_com(new InMemoryZoneFinder(RRClass::IN(), Name("com")));
|
|
|
- EXPECT_EQ(result::SUCCESS, zone_table.addZone(zone_com));
|
|
|
+ EXPECT_EQ(result::SUCCESS, zone_table->addZone(zone_com));
|
|
|
EXPECT_EQ(Name("example.com"),
|
|
|
- zone_table.findZone(Name("www.example.com")).zone->getOrigin());
|
|
|
+ zone_table->findZone(Name("www.example.com")).zone->getOrigin());
|
|
|
}
|
|
|
}
|