pool_unittest.cc 9.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247
  1. // Copyright (C) 2012 Internet Systems Consortium, Inc. ("ISC")
  2. //
  3. // Permission to use, copy, modify, and/or distribute this software for any
  4. // purpose with or without fee is hereby granted, provided that the above
  5. // copyright notice and this permission notice appear in all copies.
  6. //
  7. // THE SOFTWARE IS PROVIDED "AS IS" AND ISC DISCLAIMS ALL WARRANTIES WITH
  8. // REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY
  9. // AND FITNESS. IN NO EVENT SHALL ISC BE LIABLE FOR ANY SPECIAL, DIRECT,
  10. // INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM
  11. // LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE
  12. // OR OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR
  13. // PERFORMANCE OF THIS SOFTWARE.
  14. #include <config.h>
  15. #include <asiolink/io_address.h>
  16. #include <dhcpsrv/pool.h>
  17. #include <gtest/gtest.h>
  18. #include <iostream>
  19. #include <vector>
  20. #include <sstream>
  21. using boost::scoped_ptr;
  22. using namespace isc;
  23. using namespace isc::dhcp;
  24. using namespace isc::asiolink;
  25. namespace {
  26. TEST(Pool4Test, constructor_first_last) {
  27. // let's construct 192.0.2.1-192.0.2.255 pool
  28. Pool4 pool1(IOAddress("192.0.2.1"), IOAddress("192.0.2.255"));
  29. EXPECT_EQ(IOAddress("192.0.2.1"), pool1.getFirstAddress());
  30. EXPECT_EQ(IOAddress("192.0.2.255"), pool1.getLastAddress());
  31. // This is Pool4, IPv6 addresses do not belong here
  32. EXPECT_THROW(Pool6(Lease::TYPE_NA, IOAddress("2001:db8::1"),
  33. IOAddress("192.168.0.5")), BadValue);
  34. EXPECT_THROW(Pool6(Lease::TYPE_NA, IOAddress("192.168.0.2"),
  35. IOAddress("2001:db8::1")), BadValue);
  36. // Should throw. Range should be 192.0.2.1-192.0.2.2, not
  37. // the other way around.
  38. EXPECT_THROW(Pool6(Lease::TYPE_NA, IOAddress("192.0.2.2"),
  39. IOAddress("192.0.2.1")), BadValue);
  40. }
  41. TEST(Pool4Test, constructor_prefix_len) {
  42. // let's construct 2001:db8:1::/96 pool
  43. Pool4 pool1(IOAddress("192.0.2.0"), 25);
  44. EXPECT_EQ("192.0.2.0", pool1.getFirstAddress().toText());
  45. EXPECT_EQ("192.0.2.127", pool1.getLastAddress().toText());
  46. // No such thing as /33 prefix
  47. EXPECT_THROW(Pool4(IOAddress("192.0.2.1"), 33), BadValue);
  48. // /0 prefix does not make sense
  49. EXPECT_THROW(Pool4(IOAddress("192.0.2.0"), 0), BadValue);
  50. // This is Pool6, IPv4 addresses do not belong here
  51. EXPECT_THROW(Pool4(IOAddress("2001:db8::1"), 20), BadValue);
  52. }
  53. TEST(Pool4Test, in_range) {
  54. Pool4 pool1(IOAddress("192.0.2.10"), IOAddress("192.0.2.20"));
  55. EXPECT_FALSE(pool1.inRange(IOAddress("192.0.2.0")));
  56. EXPECT_TRUE(pool1.inRange(IOAddress("192.0.2.10")));
  57. EXPECT_TRUE(pool1.inRange(IOAddress("192.0.2.17")));
  58. EXPECT_TRUE(pool1.inRange(IOAddress("192.0.2.20")));
  59. EXPECT_FALSE(pool1.inRange(IOAddress("192.0.2.21")));
  60. EXPECT_FALSE(pool1.inRange(IOAddress("192.0.2.255")));
  61. EXPECT_FALSE(pool1.inRange(IOAddress("255.255.255.255")));
  62. EXPECT_FALSE(pool1.inRange(IOAddress("0.0.0.0")));
  63. }
  64. // This test creates 100 pools and verifies that their IDs are unique.
  65. TEST(Pool4Test, unique_id) {
  66. const int num_pools = 100;
  67. std::vector<Pool4Ptr> pools;
  68. for (int i = 0; i < num_pools; ++i) {
  69. pools.push_back(Pool4Ptr(new Pool4(IOAddress("192.0.2.0"),
  70. IOAddress("192.0.2.255"))));
  71. }
  72. for (int i = 0; i < num_pools; ++i) {
  73. for (int j = i + 1; j < num_pools; ++j) {
  74. if (pools[i]->getId() == pools[j]->getId()) {
  75. FAIL() << "Pool-ids must be unique";
  76. }
  77. }
  78. }
  79. }
  80. TEST(Pool6Test, constructor_first_last) {
  81. // let's construct 2001:db8:1:: - 2001:db8:1::ffff:ffff:ffff:ffff pool
  82. Pool6 pool1(Lease::TYPE_NA, IOAddress("2001:db8:1::"),
  83. IOAddress("2001:db8:1::ffff:ffff:ffff:ffff"));
  84. EXPECT_EQ(Lease::TYPE_NA, pool1.getType());
  85. EXPECT_EQ(IOAddress("2001:db8:1::"), pool1.getFirstAddress());
  86. EXPECT_EQ(IOAddress("2001:db8:1::ffff:ffff:ffff:ffff"),
  87. pool1.getLastAddress());
  88. // This is Pool6, IPv4 addresses do not belong here
  89. EXPECT_THROW(Pool6(Lease::TYPE_NA, IOAddress("2001:db8::1"),
  90. IOAddress("192.168.0.5")), BadValue);
  91. EXPECT_THROW(Pool6(Lease::TYPE_NA, IOAddress("192.168.0.2"),
  92. IOAddress("2001:db8::1")), BadValue);
  93. // Should throw. Range should be 2001:db8::1 - 2001:db8::2, not
  94. // the other way around.
  95. EXPECT_THROW(Pool6(Lease::TYPE_NA, IOAddress("2001:db8::2"),
  96. IOAddress("2001:db8::1")), BadValue);
  97. }
  98. TEST(Pool6Test, constructor_prefix_len) {
  99. // let's construct 2001:db8:1::/96 pool
  100. Pool6 pool1(Lease::TYPE_NA, IOAddress("2001:db8:1::"), 96);
  101. EXPECT_EQ(Lease::TYPE_NA, pool1.getType());
  102. EXPECT_EQ("2001:db8:1::", pool1.getFirstAddress().toText());
  103. EXPECT_EQ("2001:db8:1::ffff:ffff", pool1.getLastAddress().toText());
  104. // No such thing as /130 prefix
  105. EXPECT_THROW(Pool6(Lease::TYPE_NA, IOAddress("2001:db8::"), 130),
  106. BadValue);
  107. // /0 prefix does not make sense
  108. EXPECT_THROW(Pool6(Lease::TYPE_NA, IOAddress("2001:db8::"), 0),
  109. BadValue);
  110. // This is Pool6, IPv4 addresses do not belong here
  111. EXPECT_THROW(Pool6(Lease::TYPE_NA, IOAddress("192.168.0.2"), 96),
  112. BadValue);
  113. // Delegated prefix length for addresses must be /128
  114. EXPECT_THROW(Pool6(Lease::TYPE_NA, IOAddress("2001:db8:1::"), 96, 125),
  115. BadValue);
  116. }
  117. TEST(Pool6Test, in_range) {
  118. Pool6 pool1(Lease::TYPE_NA, IOAddress("2001:db8:1::1"),
  119. IOAddress("2001:db8:1::f"));
  120. EXPECT_FALSE(pool1.inRange(IOAddress("2001:db8:1::")));
  121. EXPECT_TRUE(pool1.inRange(IOAddress("2001:db8:1::1")));
  122. EXPECT_TRUE(pool1.inRange(IOAddress("2001:db8:1::7")));
  123. EXPECT_TRUE(pool1.inRange(IOAddress("2001:db8:1::f")));
  124. EXPECT_FALSE(pool1.inRange(IOAddress("2001:db8:1::10")));
  125. EXPECT_FALSE(pool1.inRange(IOAddress("::")));
  126. }
  127. // Checks that Prefix Delegation pools are handled properly
  128. TEST(Pool6Test, PD) {
  129. // Let's construct 2001:db8:1::/96 PD pool, split into /112 prefixes
  130. Pool6 pool1(Lease::TYPE_PD, IOAddress("2001:db8:1::"), 96, 112);
  131. EXPECT_EQ(Lease::TYPE_PD, pool1.getType());
  132. EXPECT_EQ(112, pool1.getLength());
  133. EXPECT_EQ("2001:db8:1::", pool1.getFirstAddress().toText());
  134. EXPECT_EQ("2001:db8:1::ffff:ffff", pool1.getLastAddress().toText());
  135. // Check that it's not possible to have min-max range for PD
  136. EXPECT_THROW(Pool6 pool2(Lease::TYPE_PD, IOAddress("2001:db8:1::1"),
  137. IOAddress("2001:db8:1::f")), BadValue);
  138. // Check that it's not allowed to delegate bigger prefix than the pool
  139. // Let's try to split /64 prefix into /56 chunks (should be impossible)
  140. EXPECT_THROW(Pool6 pool3(Lease::TYPE_PD, IOAddress("2001:db8:1::"),
  141. 64, 56), BadValue);
  142. // It should be possible to have a pool split into just a single chunk
  143. // Let's try to split 2001:db8:1::/77 into a single /77 delegated prefix
  144. EXPECT_NO_THROW(Pool6 pool4(Lease::TYPE_PD, IOAddress("2001:db8:1::"),
  145. 77, 77));
  146. }
  147. // Checks that temporary address pools are handled properly
  148. TEST(Pool6Test, TA) {
  149. // Note: since we defined TA pool types during PD work, we can test it
  150. // now. Although the configuration to take advantage of it is not
  151. // planned for now, we will support it some day.
  152. // Let's construct 2001:db8:1::/96 temporary addresses
  153. Pool6Ptr pool1;
  154. EXPECT_NO_THROW(pool1.reset(new Pool6(Lease::TYPE_TA,
  155. IOAddress("2001:db8:1::"), 96)));
  156. // Check that TA range can be only defined for single addresses
  157. EXPECT_THROW(Pool6(Lease::TYPE_TA, IOAddress("2001:db8:1::"), 96, 127),
  158. BadValue);
  159. ASSERT_TRUE(pool1);
  160. EXPECT_EQ(Lease::TYPE_TA, pool1->getType());
  161. EXPECT_EQ(128, pool1->getLength()); // singular addresses, not prefixes
  162. EXPECT_EQ("2001:db8:1::", pool1->getFirstAddress().toText());
  163. EXPECT_EQ("2001:db8:1::ffff:ffff", pool1->getLastAddress().toText());
  164. // Check that it's possible to have min-max range for TA
  165. Pool6Ptr pool2;
  166. EXPECT_NO_THROW(pool2.reset(new Pool6(Lease::TYPE_TA,
  167. IOAddress("2001:db8:1::1"),
  168. IOAddress("2001:db8:1::f"))));
  169. ASSERT_TRUE(pool2);
  170. EXPECT_EQ(Lease::TYPE_TA, pool2->getType());
  171. EXPECT_EQ(128, pool2->getLength()); // singular addresses, not prefixes
  172. EXPECT_EQ("2001:db8:1::1", pool2->getFirstAddress().toText());
  173. EXPECT_EQ("2001:db8:1::f", pool2->getLastAddress().toText());
  174. }
  175. // This test creates 100 pools and verifies that their IDs are unique.
  176. TEST(Pool6Test, unique_id) {
  177. const int num_pools = 100;
  178. std::vector<Pool6Ptr> pools;
  179. for (int i = 0; i < num_pools; ++i) {
  180. pools.push_back(Pool6Ptr(new Pool6(Lease::TYPE_NA, IOAddress("2001:db8:1::"),
  181. IOAddress("2001:db8:1::ffff:ffff:ffff:ffff"))));
  182. }
  183. for (int i = 0; i < num_pools; ++i) {
  184. for (int j = i + 1; j < num_pools; ++j) {
  185. if (pools[i]->getId() == pools[j]->getId()) {
  186. FAIL() << "Pool-ids must be unique";
  187. }
  188. }
  189. }
  190. }
  191. }; // end of anonymous namespace