pool_unittest.cc 6.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181
  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 <iostream>
  16. #include <vector>
  17. #include <sstream>
  18. #include <gtest/gtest.h>
  19. #include <dhcp/pool.h>
  20. #include <asiolink/io_address.h>
  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(Pool6::TYPE_IA, IOAddress("2001:db8::1"),
  33. IOAddress("192.168.0.5")), BadValue);
  34. EXPECT_THROW(Pool6(Pool6::TYPE_IA, 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(Pool6::TYPE_IA, 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(Pool6::TYPE_IA, IOAddress("2001:db8:1::"),
  83. IOAddress("2001:db8:1::ffff:ffff:ffff:ffff"));
  84. EXPECT_EQ(Pool6::TYPE_IA, 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(Pool6::TYPE_IA, IOAddress("2001:db8::1"),
  90. IOAddress("192.168.0.5")), BadValue);
  91. EXPECT_THROW(Pool6(Pool6::TYPE_IA, 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(Pool6::TYPE_IA, 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(Pool6::TYPE_IA, IOAddress("2001:db8:1::"), 96);
  101. EXPECT_EQ(Pool6::TYPE_IA, 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(Pool6::TYPE_IA, IOAddress("2001:db8::"), 130),
  106. BadValue);
  107. // /0 prefix does not make sense
  108. EXPECT_THROW(Pool6(Pool6::TYPE_IA, IOAddress("2001:db8::"), 0),
  109. BadValue);
  110. // This is Pool6, IPv4 addresses do not belong here
  111. EXPECT_THROW(Pool6(Pool6::TYPE_IA, IOAddress("192.168.0.2"), 96),
  112. BadValue);
  113. }
  114. TEST(Pool6Test, in_range) {
  115. Pool6 pool1(Pool6::TYPE_IA, IOAddress("2001:db8:1::1"),
  116. IOAddress("2001:db8:1::f"));
  117. EXPECT_FALSE(pool1.inRange(IOAddress("2001:db8:1::")));
  118. EXPECT_TRUE(pool1.inRange(IOAddress("2001:db8:1::1")));
  119. EXPECT_TRUE(pool1.inRange(IOAddress("2001:db8:1::7")));
  120. EXPECT_TRUE(pool1.inRange(IOAddress("2001:db8:1::f")));
  121. EXPECT_FALSE(pool1.inRange(IOAddress("2001:db8:1::10")));
  122. EXPECT_FALSE(pool1.inRange(IOAddress("::")));
  123. }
  124. // This test creates 100 pools and verifies that their IDs are unique.
  125. TEST(Pool6Test, unique_id) {
  126. const int num_pools = 100;
  127. std::vector<Pool6Ptr> pools;
  128. for (int i = 0; i < num_pools; ++i) {
  129. pools.push_back(Pool6Ptr(new Pool6(Pool6::TYPE_IA, IOAddress("2001:db8:1::"),
  130. IOAddress("2001:db8:1::ffff:ffff:ffff:ffff"))));
  131. }
  132. for (int i = 0; i < num_pools; ++i) {
  133. for (int j = i + 1; j < num_pools; ++j) {
  134. if (pools[i]->getId() == pools[j]->getId()) {
  135. FAIL() << "Pool-ids must be unique";
  136. }
  137. }
  138. }
  139. }
  140. }; // end of anonymous namespace