|
@@ -35,58 +35,47 @@ protected:
|
|
|
ZoneTableTest() : zname1(Name("example.com")),
|
|
|
zname2(Name("example.net")),
|
|
|
zname3(Name("example")),
|
|
|
- zone1(new ZoneData(RRClass::IN(), zname1)),
|
|
|
- zone2(new ZoneData(RRClass::IN(), zname2)),
|
|
|
- zone3(new ZoneData(RRClass::IN(), zname3)),
|
|
|
zone_table(ZoneTable::create(mem_sgmt_))
|
|
|
{}
|
|
|
-
|
|
|
~ZoneTableTest() {
|
|
|
+ if (zone_table != NULL) {
|
|
|
+ ZoneTable::destroy(mem_sgmt_, zone_table);
|
|
|
+ }
|
|
|
+ }
|
|
|
+ void TearDown() {
|
|
|
ZoneTable::destroy(mem_sgmt_, zone_table);
|
|
|
+ zone_table = NULL;
|
|
|
+ EXPECT_TRUE(mem_sgmt_.allMemoryDeallocated());
|
|
|
}
|
|
|
const Name zname1, zname2, zname3;
|
|
|
- ZoneData* zone1;
|
|
|
- ZoneData* zone2;
|
|
|
- ZoneData* zone3;
|
|
|
isc::util::MemorySegmentLocal mem_sgmt_;
|
|
|
ZoneTable* zone_table;
|
|
|
};
|
|
|
|
|
|
TEST_F(ZoneTableTest, addZone) {
|
|
|
- EXPECT_EQ(result::SUCCESS, zone_table->addZone(mem_sgmt_, zname1, zone1));
|
|
|
- EXPECT_EQ(result::EXIST, zone_table->addZone(mem_sgmt_, zname1, zone1));
|
|
|
+ EXPECT_EQ(result::SUCCESS, zone_table->addZone(mem_sgmt_, zname1));
|
|
|
+ EXPECT_EQ(result::EXIST, zone_table->addZone(mem_sgmt_, zname1));
|
|
|
// names are compared in a case insensitive manner.
|
|
|
- EXPECT_EQ(result::EXIST, zone_table->addZone(
|
|
|
- mem_sgmt_, Name("EXAMPLE.COM"),
|
|
|
- new ZoneData(RRClass::IN(), Name("EXAMPLE.COM"))));
|
|
|
-
|
|
|
- EXPECT_EQ(result::SUCCESS, zone_table->addZone(mem_sgmt_, zname2, zone2));
|
|
|
- EXPECT_EQ(result::SUCCESS, zone_table->addZone(mem_sgmt_, zname3, 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(
|
|
|
- mem_sgmt_, Name("example.com"),
|
|
|
- new ZoneData(RRClass::CH(), Name("example.com"))));
|
|
|
-
|
|
|
- /// Bogus zone (NULL)
|
|
|
- EXPECT_THROW(zone_table->addZone(mem_sgmt_, zname1, NULL),
|
|
|
- isc::InvalidParameter);
|
|
|
+ EXPECT_EQ(result::EXIST, zone_table->addZone(mem_sgmt_,
|
|
|
+ Name("EXAMPLE.COM")));
|
|
|
+ // Add some more different ones. Should just succeed.
|
|
|
+ EXPECT_EQ(result::SUCCESS, zone_table->addZone(mem_sgmt_, zname2));
|
|
|
+ EXPECT_EQ(result::SUCCESS, zone_table->addZone(mem_sgmt_, zname3));
|
|
|
}
|
|
|
|
|
|
TEST_F(ZoneTableTest, DISABLED_removeZone) {
|
|
|
- EXPECT_EQ(result::SUCCESS, zone_table->addZone(mem_sgmt_, zname1, zone1));
|
|
|
- EXPECT_EQ(result::SUCCESS, zone_table->addZone(mem_sgmt_, zname2, zone2));
|
|
|
- EXPECT_EQ(result::SUCCESS, zone_table->addZone(mem_sgmt_, zname3, zone3));
|
|
|
+ EXPECT_EQ(result::SUCCESS, zone_table->addZone(mem_sgmt_, zname1));
|
|
|
+ EXPECT_EQ(result::SUCCESS, zone_table->addZone(mem_sgmt_, zname2));
|
|
|
+ EXPECT_EQ(result::SUCCESS, zone_table->addZone(mem_sgmt_, zname3));
|
|
|
|
|
|
EXPECT_EQ(result::SUCCESS, zone_table->removeZone(Name("example.net")));
|
|
|
EXPECT_EQ(result::NOTFOUND, zone_table->removeZone(Name("example.net")));
|
|
|
}
|
|
|
|
|
|
TEST_F(ZoneTableTest, DISABLED_findZone) {
|
|
|
- EXPECT_EQ(result::SUCCESS, zone_table->addZone(mem_sgmt_, zname1, zone1));
|
|
|
- EXPECT_EQ(result::SUCCESS, zone_table->addZone(mem_sgmt_, zname2, zone2));
|
|
|
- EXPECT_EQ(result::SUCCESS, zone_table->addZone(mem_sgmt_, zname3, zone3));
|
|
|
+ EXPECT_EQ(result::SUCCESS, zone_table->addZone(mem_sgmt_, zname1));
|
|
|
+ EXPECT_EQ(result::SUCCESS, zone_table->addZone(mem_sgmt_, zname2));
|
|
|
+ EXPECT_EQ(result::SUCCESS, zone_table->addZone(mem_sgmt_, zname3));
|
|
|
|
|
|
EXPECT_EQ(result::SUCCESS, zone_table->findZone(Name("example.com")).code);
|
|
|
EXPECT_EQ(Name("example.com"),
|
|
@@ -106,10 +95,7 @@ TEST_F(ZoneTableTest, DISABLED_findZone) {
|
|
|
|
|
|
// make sure the partial match is indeed the longest match by adding
|
|
|
// a zone with a shorter origin and query again.
|
|
|
- EXPECT_EQ(result::SUCCESS, zone_table->addZone(mem_sgmt_,
|
|
|
- Name("com"),
|
|
|
- new ZoneData(RRClass::IN(),
|
|
|
- Name("com"))));
|
|
|
+ EXPECT_EQ(result::SUCCESS, zone_table->addZone(mem_sgmt_, Name("com")));
|
|
|
EXPECT_EQ(Name("example.com"),
|
|
|
zone_table->findZone(Name("www.example.com")).zone->getOrigin());
|
|
|
}
|