allocator_test.go 6.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326
  1. package ipallocator
  2. import (
  3. "fmt"
  4. "net"
  5. "testing"
  6. )
  7. func reset() {
  8. allocatedIPs = networkSet{}
  9. }
  10. func TestRequestNewIps(t *testing.T) {
  11. defer reset()
  12. network := &net.IPNet{
  13. IP: []byte{192, 168, 0, 1},
  14. Mask: []byte{255, 255, 255, 0},
  15. }
  16. var ip *net.IP
  17. var err error
  18. for i := 2; i < 10; i++ {
  19. ip, err = RequestIP(network, nil)
  20. if err != nil {
  21. t.Fatal(err)
  22. }
  23. if expected := fmt.Sprintf("192.168.0.%d", i); ip.String() != expected {
  24. t.Fatalf("Expected ip %s got %s", expected, ip.String())
  25. }
  26. }
  27. value := intToIP(ipToInt(ip) + 1).String()
  28. if err := ReleaseIP(network, ip); err != nil {
  29. t.Fatal(err)
  30. }
  31. ip, err = RequestIP(network, nil)
  32. if err != nil {
  33. t.Fatal(err)
  34. }
  35. if ip.String() != value {
  36. t.Fatalf("Expected to receive the next ip %s got %s", value, ip.String())
  37. }
  38. }
  39. func TestReleaseIp(t *testing.T) {
  40. defer reset()
  41. network := &net.IPNet{
  42. IP: []byte{192, 168, 0, 1},
  43. Mask: []byte{255, 255, 255, 0},
  44. }
  45. ip, err := RequestIP(network, nil)
  46. if err != nil {
  47. t.Fatal(err)
  48. }
  49. if err := ReleaseIP(network, ip); err != nil {
  50. t.Fatal(err)
  51. }
  52. }
  53. func TestGetReleasedIp(t *testing.T) {
  54. defer reset()
  55. network := &net.IPNet{
  56. IP: []byte{192, 168, 0, 1},
  57. Mask: []byte{255, 255, 255, 0},
  58. }
  59. ip, err := RequestIP(network, nil)
  60. if err != nil {
  61. t.Fatal(err)
  62. }
  63. value := ip.String()
  64. if err := ReleaseIP(network, ip); err != nil {
  65. t.Fatal(err)
  66. }
  67. for i := 0; i < 252; i++ {
  68. _, err = RequestIP(network, nil)
  69. if err != nil {
  70. t.Fatal(err)
  71. }
  72. err = ReleaseIP(network, ip)
  73. if err != nil {
  74. t.Fatal(err)
  75. }
  76. }
  77. ip, err = RequestIP(network, nil)
  78. if err != nil {
  79. t.Fatal(err)
  80. }
  81. if ip.String() != value {
  82. t.Fatalf("Expected to receive same ip %s got %s", value, ip.String())
  83. }
  84. }
  85. func TestRequesetSpecificIp(t *testing.T) {
  86. defer reset()
  87. network := &net.IPNet{
  88. IP: []byte{192, 168, 0, 1},
  89. Mask: []byte{255, 255, 255, 0},
  90. }
  91. ip := net.ParseIP("192.168.1.5")
  92. if _, err := RequestIP(network, &ip); err != nil {
  93. t.Fatal(err)
  94. }
  95. }
  96. func TestConversion(t *testing.T) {
  97. ip := net.ParseIP("127.0.0.1")
  98. i := ipToInt(&ip)
  99. if i == 0 {
  100. t.Fatal("converted to zero")
  101. }
  102. conv := intToIP(i)
  103. if !ip.Equal(*conv) {
  104. t.Error(conv.String())
  105. }
  106. }
  107. func TestIPAllocator(t *testing.T) {
  108. expectedIPs := []net.IP{
  109. 0: net.IPv4(127, 0, 0, 2),
  110. 1: net.IPv4(127, 0, 0, 3),
  111. 2: net.IPv4(127, 0, 0, 4),
  112. 3: net.IPv4(127, 0, 0, 5),
  113. 4: net.IPv4(127, 0, 0, 6),
  114. }
  115. gwIP, n, _ := net.ParseCIDR("127.0.0.1/29")
  116. network := &net.IPNet{IP: gwIP, Mask: n.Mask}
  117. // Pool after initialisation (f = free, u = used)
  118. // 2(f) - 3(f) - 4(f) - 5(f) - 6(f)
  119. // ↑
  120. // Check that we get 5 IPs, from 127.0.0.2–127.0.0.6, in that
  121. // order.
  122. for i := 0; i < 5; i++ {
  123. ip, err := RequestIP(network, nil)
  124. if err != nil {
  125. t.Fatal(err)
  126. }
  127. assertIPEquals(t, &expectedIPs[i], ip)
  128. }
  129. // Before loop begin
  130. // 2(f) - 3(f) - 4(f) - 5(f) - 6(f)
  131. // ↑
  132. // After i = 0
  133. // 2(u) - 3(f) - 4(f) - 5(f) - 6(f)
  134. // ↑
  135. // After i = 1
  136. // 2(u) - 3(u) - 4(f) - 5(f) - 6(f)
  137. // ↑
  138. // After i = 2
  139. // 2(u) - 3(u) - 4(u) - 5(f) - 6(f)
  140. // ↑
  141. // After i = 3
  142. // 2(u) - 3(u) - 4(u) - 5(u) - 6(f)
  143. // ↑
  144. // After i = 4
  145. // 2(u) - 3(u) - 4(u) - 5(u) - 6(u)
  146. // ↑
  147. // Check that there are no more IPs
  148. ip, err := RequestIP(network, nil)
  149. if err == nil {
  150. t.Fatalf("There shouldn't be any IP addresses at this point, got %s\n", ip)
  151. }
  152. // Release some IPs in non-sequential order
  153. if err := ReleaseIP(network, &expectedIPs[3]); err != nil {
  154. t.Fatal(err)
  155. }
  156. // 2(u) - 3(u) - 4(u) - 5(f) - 6(u)
  157. // ↑
  158. if err := ReleaseIP(network, &expectedIPs[2]); err != nil {
  159. t.Fatal(err)
  160. }
  161. // 2(u) - 3(u) - 4(f) - 5(f) - 6(u)
  162. // ↑
  163. if err := ReleaseIP(network, &expectedIPs[4]); err != nil {
  164. t.Fatal(err)
  165. }
  166. // 2(u) - 3(u) - 4(f) - 5(f) - 6(f)
  167. // ↑
  168. // Make sure that IPs are reused in sequential order, starting
  169. // with the first released IP
  170. newIPs := make([]*net.IP, 3)
  171. for i := 0; i < 3; i++ {
  172. ip, err := RequestIP(network, nil)
  173. if err != nil {
  174. t.Fatal(err)
  175. }
  176. newIPs[i] = ip
  177. }
  178. assertIPEquals(t, &expectedIPs[2], newIPs[0])
  179. assertIPEquals(t, &expectedIPs[3], newIPs[1])
  180. assertIPEquals(t, &expectedIPs[4], newIPs[2])
  181. _, err = RequestIP(network, nil)
  182. if err == nil {
  183. t.Fatal("There shouldn't be any IP addresses at this point")
  184. }
  185. }
  186. func TestAllocateFirstIP(t *testing.T) {
  187. defer reset()
  188. network := &net.IPNet{
  189. IP: []byte{192, 168, 0, 0},
  190. Mask: []byte{255, 255, 255, 0},
  191. }
  192. firstIP := network.IP.To4().Mask(network.Mask)
  193. first := ipToInt(&firstIP) + 1
  194. ip, err := RequestIP(network, nil)
  195. if err != nil {
  196. t.Fatal(err)
  197. }
  198. allocated := ipToInt(ip)
  199. if allocated == first {
  200. t.Fatalf("allocated ip should not equal first ip: %d == %d", first, allocated)
  201. }
  202. }
  203. func TestAllocateAllIps(t *testing.T) {
  204. defer reset()
  205. network := &net.IPNet{
  206. IP: []byte{192, 168, 0, 1},
  207. Mask: []byte{255, 255, 255, 0},
  208. }
  209. var (
  210. current, first *net.IP
  211. err error
  212. isFirst = true
  213. )
  214. for err == nil {
  215. current, err = RequestIP(network, nil)
  216. if isFirst {
  217. first = current
  218. isFirst = false
  219. }
  220. }
  221. if err != ErrNoAvailableIPs {
  222. t.Fatal(err)
  223. }
  224. if _, err := RequestIP(network, nil); err != ErrNoAvailableIPs {
  225. t.Fatal(err)
  226. }
  227. if err := ReleaseIP(network, first); err != nil {
  228. t.Fatal(err)
  229. }
  230. again, err := RequestIP(network, nil)
  231. if err != nil {
  232. t.Fatal(err)
  233. }
  234. assertIPEquals(t, first, again)
  235. }
  236. func TestAllocateDifferentSubnets(t *testing.T) {
  237. defer reset()
  238. network1 := &net.IPNet{
  239. IP: []byte{192, 168, 0, 1},
  240. Mask: []byte{255, 255, 255, 0},
  241. }
  242. network2 := &net.IPNet{
  243. IP: []byte{127, 0, 0, 1},
  244. Mask: []byte{255, 255, 255, 0},
  245. }
  246. expectedIPs := []net.IP{
  247. 0: net.IPv4(192, 168, 0, 2),
  248. 1: net.IPv4(192, 168, 0, 3),
  249. 2: net.IPv4(127, 0, 0, 2),
  250. 3: net.IPv4(127, 0, 0, 3),
  251. }
  252. ip11, err := RequestIP(network1, nil)
  253. if err != nil {
  254. t.Fatal(err)
  255. }
  256. ip12, err := RequestIP(network1, nil)
  257. if err != nil {
  258. t.Fatal(err)
  259. }
  260. ip21, err := RequestIP(network2, nil)
  261. if err != nil {
  262. t.Fatal(err)
  263. }
  264. ip22, err := RequestIP(network2, nil)
  265. if err != nil {
  266. t.Fatal(err)
  267. }
  268. assertIPEquals(t, &expectedIPs[0], ip11)
  269. assertIPEquals(t, &expectedIPs[1], ip12)
  270. assertIPEquals(t, &expectedIPs[2], ip21)
  271. assertIPEquals(t, &expectedIPs[3], ip22)
  272. }
  273. func assertIPEquals(t *testing.T, ip1, ip2 *net.IP) {
  274. if !ip1.Equal(*ip2) {
  275. t.Fatalf("Expected IP %s, got %s", ip1, ip2)
  276. }
  277. }