mirror of
https://gitlab.isc.org/isc-projects/kea
synced 2025-09-01 06:25:34 +00:00
[master] Merge remote-tracking branch 'github/master'
Merged in change made to GitHub for ticket trac4111.
This commit is contained in:
@@ -38,13 +38,13 @@ using boost::scoped_ptr;
|
|||||||
namespace {
|
namespace {
|
||||||
class Option6AddrLstTest : public ::testing::Test {
|
class Option6AddrLstTest : public ::testing::Test {
|
||||||
public:
|
public:
|
||||||
Option6AddrLstTest(): buf_(255), outBuf_(255) {
|
Option6AddrLstTest(): buf_(255), out_buf_(255) {
|
||||||
for (unsigned i = 0; i < 255; i++) {
|
for (unsigned i = 0; i < 255; i++) {
|
||||||
buf_[i] = 255 - i;
|
buf_[i] = 255 - i;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
OptionBuffer buf_;
|
OptionBuffer buf_;
|
||||||
OutputBuffer outBuf_;
|
OutputBuffer out_buf_;
|
||||||
};
|
};
|
||||||
|
|
||||||
TEST_F(Option6AddrLstTest, basic) {
|
TEST_F(Option6AddrLstTest, basic) {
|
||||||
@@ -129,10 +129,10 @@ TEST_F(Option6AddrLstTest, basic) {
|
|||||||
EXPECT_EQ("2001:db8:1::dead:beef", addr.toText());
|
EXPECT_EQ("2001:db8:1::dead:beef", addr.toText());
|
||||||
|
|
||||||
// Pack this option
|
// Pack this option
|
||||||
opt1->pack(outBuf_);
|
opt1->pack(out_buf_);
|
||||||
|
|
||||||
EXPECT_EQ(20, outBuf_.getLength());
|
EXPECT_EQ(20, out_buf_.getLength());
|
||||||
EXPECT_EQ(0, memcmp(expected1, outBuf_.getData(), 20));
|
EXPECT_EQ(0, memcmp(expected1, out_buf_.getData(), 20));
|
||||||
|
|
||||||
// Two addresses
|
// Two addresses
|
||||||
scoped_ptr<Option6AddrLst> opt2;
|
scoped_ptr<Option6AddrLst> opt2;
|
||||||
@@ -148,11 +148,11 @@ TEST_F(Option6AddrLstTest, basic) {
|
|||||||
EXPECT_EQ("ff02::face:b00c", addrs[1].toText());
|
EXPECT_EQ("ff02::face:b00c", addrs[1].toText());
|
||||||
|
|
||||||
// Pack this option
|
// Pack this option
|
||||||
outBuf_.clear();
|
out_buf_.clear();
|
||||||
opt2->pack(outBuf_);
|
opt2->pack(out_buf_);
|
||||||
|
|
||||||
EXPECT_EQ(36, outBuf_.getLength() );
|
EXPECT_EQ(36, out_buf_.getLength() );
|
||||||
EXPECT_EQ(0, memcmp(expected2, outBuf_.getData(), 36));
|
EXPECT_EQ(0, memcmp(expected2, out_buf_.getData(), 36));
|
||||||
|
|
||||||
// Three addresses
|
// Three addresses
|
||||||
scoped_ptr<Option6AddrLst> opt3;
|
scoped_ptr<Option6AddrLst> opt3;
|
||||||
@@ -170,11 +170,11 @@ TEST_F(Option6AddrLstTest, basic) {
|
|||||||
EXPECT_EQ("ffff:ffff:ffff:ffff:ffff:ffff:ffff:ffff", addrs[2].toText());
|
EXPECT_EQ("ffff:ffff:ffff:ffff:ffff:ffff:ffff:ffff", addrs[2].toText());
|
||||||
|
|
||||||
// Pack this option
|
// Pack this option
|
||||||
outBuf_.clear();
|
out_buf_.clear();
|
||||||
opt3->pack(outBuf_);
|
opt3->pack(out_buf_);
|
||||||
|
|
||||||
EXPECT_EQ(52, outBuf_.getLength());
|
EXPECT_EQ(52, out_buf_.getLength());
|
||||||
EXPECT_EQ(0, memcmp(expected3, outBuf_.getData(), 52));
|
EXPECT_EQ(0, memcmp(expected3, out_buf_.getData(), 52));
|
||||||
|
|
||||||
EXPECT_NO_THROW(opt1.reset());
|
EXPECT_NO_THROW(opt1.reset());
|
||||||
EXPECT_NO_THROW(opt2.reset());
|
EXPECT_NO_THROW(opt2.reset());
|
||||||
@@ -251,4 +251,34 @@ TEST_F(Option6AddrLstTest, toText) {
|
|||||||
"2001:db8:1::4 2001:db8:1::5", opt.toText());
|
"2001:db8:1::4 2001:db8:1::5", opt.toText());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// A helper for the 'empty' test. Exercise public interfaces of an empty
|
||||||
|
// Option6AddrLst. It assumes the option type is D6O_DHCPV4_O_DHCPV6_SERVER.
|
||||||
|
void
|
||||||
|
checkEmpty(Option6AddrLst& addrs) {
|
||||||
|
const uint8_t expected[] = {
|
||||||
|
D6O_DHCPV4_O_DHCPV6_SERVER/256, D6O_DHCPV4_O_DHCPV6_SERVER%256,
|
||||||
|
0, 0
|
||||||
|
};
|
||||||
|
EXPECT_EQ(4, addrs.len()); // just 2-byte type and 2-byte len fields
|
||||||
|
EXPECT_EQ("type=00088, len=00000:", addrs.toText());
|
||||||
|
|
||||||
|
OutputBuffer out_buf(255);
|
||||||
|
addrs.pack(out_buf);
|
||||||
|
EXPECT_EQ(4, out_buf.getLength());
|
||||||
|
EXPECT_EQ(0, memcmp(expected, out_buf.getData(), 4));
|
||||||
|
}
|
||||||
|
|
||||||
|
// Confirms no disruption happens for an empty set of addresses.
|
||||||
|
TEST_F(Option6AddrLstTest, empty) {
|
||||||
|
boost::scoped_ptr<Option6AddrLst> addrs(
|
||||||
|
new Option6AddrLst(D6O_DHCPV4_O_DHCPV6_SERVER,
|
||||||
|
Option6AddrLst::AddressContainer()));
|
||||||
|
checkEmpty(*addrs);
|
||||||
|
|
||||||
|
const OptionBuffer empty_buf;
|
||||||
|
addrs.reset(new Option6AddrLst(D6O_DHCPV4_O_DHCPV6_SERVER,
|
||||||
|
empty_buf.begin(), empty_buf.end()));
|
||||||
|
checkEmpty(*addrs);
|
||||||
|
}
|
||||||
|
|
||||||
} // namespace
|
} // namespace
|
||||||
|
@@ -913,6 +913,23 @@ TEST_F(ParseConfigTest, optionDataMinimalWithOptionDef) {
|
|||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// This test verifies an empty option data configuration is supported.
|
||||||
|
TEST_F(ParseConfigTest, emptyOptionData) {
|
||||||
|
// Configuration string.
|
||||||
|
const std::string config =
|
||||||
|
"{ \"option-data\": [ {"
|
||||||
|
" \"name\": \"dhcp4o6-server-addr\""
|
||||||
|
" } ]"
|
||||||
|
"}";
|
||||||
|
|
||||||
|
int rcode = 0;
|
||||||
|
ASSERT_NO_THROW(rcode = parseConfiguration(config));
|
||||||
|
const Option6AddrLstPtr opt = boost::dynamic_pointer_cast<
|
||||||
|
Option6AddrLst>(getOptionPtr("dhcp6", D6O_DHCPV4_O_DHCPV6_SERVER));
|
||||||
|
ASSERT_TRUE(opt);
|
||||||
|
ASSERT_EQ(0, opt->getAddresses().size());
|
||||||
|
}
|
||||||
|
|
||||||
}; // Anonymous namespace
|
}; // Anonymous namespace
|
||||||
|
|
||||||
/// The next set of tests check basic operation of the HooksLibrariesParser.
|
/// The next set of tests check basic operation of the HooksLibrariesParser.
|
||||||
|
Reference in New Issue
Block a user