mirror of
https://gitlab.isc.org/isc-projects/kea
synced 2025-08-31 05:55:28 +00:00
[2892] Test for testServerID function for couple cases
This commit is contained in:
@@ -1,4 +1,4 @@
|
|||||||
// Copyright (C) 2011-2013 Internet Systems Consortium, Inc. ("ISC")
|
// Copyright (C) 2011-2014 Internet Systems Consortium, Inc. ("ISC")
|
||||||
//
|
//
|
||||||
// Permission to use, copy, modify, and/or distribute this software for any
|
// Permission to use, copy, modify, and/or distribute this software for any
|
||||||
// purpose with or without fee is hereby granted, provided that the above
|
// purpose with or without fee is hereby granted, provided that the above
|
||||||
@@ -1073,24 +1073,13 @@ TEST_F(Dhcpv6SrvTest, sanityCheck) {
|
|||||||
EXPECT_THROW(srv.sanityCheck(pkt, Dhcpv6Srv::MANDATORY, Dhcpv6Srv::MANDATORY),
|
EXPECT_THROW(srv.sanityCheck(pkt, Dhcpv6Srv::MANDATORY, Dhcpv6Srv::MANDATORY),
|
||||||
RFCViolation);
|
RFCViolation);
|
||||||
}
|
}
|
||||||
|
// Check that server is testing if received ServerID is equal to one beenig used by server
|
||||||
TEST_F(Dhcpv6SrvTest, testServerid){
|
TEST_F(Dhcpv6SrvTest, testServerID){
|
||||||
NakedDhcpv6Srv srv(0);
|
NakedDhcpv6Srv srv(0);
|
||||||
|
|
||||||
Pkt6Ptr req = Pkt6Ptr(new Pkt6(DHCPV6_REQUEST, 1234));
|
|
||||||
req->setRemoteAddr(IOAddress("fe80::abcd"));
|
|
||||||
boost::shared_ptr<Option6IA> ia = generateIA(D6O_IA_PD, 234, 1500, 3000);
|
|
||||||
|
|
||||||
// with a valid hint
|
Pkt6Ptr req = Pkt6Ptr(new Pkt6(DHCPV6_REQUEST, 1234));
|
||||||
IOAddress hint("2001:db8:1:2:f::");
|
|
||||||
ASSERT_TRUE(subnet_->inPool(Lease::TYPE_PD, hint));
|
|
||||||
OptionPtr hint_opt(new Option6IAPrefix(D6O_IAPREFIX, hint, 64, 300, 500));
|
|
||||||
ia->addOption(hint_opt);
|
|
||||||
req->addOption(ia);
|
|
||||||
OptionPtr clientid = generateClientId();
|
|
||||||
req->addOption(clientid);
|
|
||||||
|
|
||||||
// server-id is mandatory in REQUEST
|
// server-id is MANDATORY in REQUEST
|
||||||
// but add there something else
|
// but add there something else
|
||||||
std::vector<uint8_t> bin;
|
std::vector<uint8_t> bin;
|
||||||
|
|
||||||
@@ -1100,16 +1089,21 @@ TEST_F(Dhcpv6SrvTest, testServerid){
|
|||||||
OptionPtr serverid = OptionPtr(new Option(Option::V6, D6O_SERVERID, bin));
|
OptionPtr serverid = OptionPtr(new Option(Option::V6, D6O_SERVERID, bin));
|
||||||
|
|
||||||
req->addOption(serverid);
|
req->addOption(serverid);
|
||||||
|
|
||||||
// I moved testServerid in src/bin/dhcp6/dhcp6_srv.h
|
//Shoud be dropped
|
||||||
// above the protected part.
|
EXPECT_FALSE(srv.testServerID(req));
|
||||||
EXPECT_THROW(srv.testServerid(req),ServerID_mismatch);
|
|
||||||
|
|
||||||
req->delOption(D6O_SERVERID);
|
req->delOption(D6O_SERVERID);
|
||||||
|
|
||||||
req->addOption(srv.getServerID());
|
req->addOption(srv.getServerID());
|
||||||
|
|
||||||
EXPECT_NO_THROW(srv.testServerid(req));
|
//with proper ServerID we expect true
|
||||||
|
EXPECT_TRUE(srv.testServerID(req));
|
||||||
|
|
||||||
|
// server-id is FORBIDDEN in SOLICIT, so check if server is not
|
||||||
|
// dropping corect message
|
||||||
|
Pkt6Ptr pkt = Pkt6Ptr(new Pkt6(DHCPV6_SOLICIT, 1234));
|
||||||
|
|
||||||
|
EXPECT_TRUE(srv.testServerID(req));
|
||||||
}
|
}
|
||||||
|
|
||||||
// This test verifies if selectSubnet() selects proper subnet for a given
|
// This test verifies if selectSubnet() selects proper subnet for a given
|
||||||
|
Reference in New Issue
Block a user