cidr6_radix_test.go 3.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134
  1. package nebula
  2. import (
  3. "net"
  4. "testing"
  5. "github.com/stretchr/testify/assert"
  6. )
  7. func TestCIDR6Tree_Contains(t *testing.T) {
  8. tree := NewCIDR6Tree()
  9. tree.AddCIDR(getCIDR("1.0.0.0/8"), "1")
  10. tree.AddCIDR(getCIDR("2.1.0.0/16"), "2")
  11. tree.AddCIDR(getCIDR("3.1.1.0/24"), "3")
  12. tree.AddCIDR(getCIDR("4.1.1.0/24"), "4a")
  13. tree.AddCIDR(getCIDR("4.1.1.1/32"), "4b")
  14. tree.AddCIDR(getCIDR("4.1.2.1/32"), "4c")
  15. tree.AddCIDR(getCIDR("254.0.0.0/4"), "5")
  16. tree.AddCIDR(getCIDR("2800::FFFF:1/128"), "a")
  17. tree.AddCIDR(getCIDR("2800:1:2:3::0/64"), "b")
  18. tests := []struct {
  19. Result interface{}
  20. IP string
  21. }{
  22. {"1", "1.0.0.0"},
  23. {"1", "1.255.255.255"},
  24. {"2", "2.1.0.0"},
  25. {"2", "2.1.255.255"},
  26. {"3", "3.1.1.0"},
  27. {"3", "3.1.1.255"},
  28. {"4a", "4.1.1.255"},
  29. {"4a", "4.1.1.1"},
  30. {"5", "240.0.0.0"},
  31. {"5", "255.255.255.255"},
  32. {nil, "239.0.0.0"},
  33. {nil, "4.1.2.2"},
  34. {"a", "2800::FFFF:1"},
  35. {"b", "2800:1:2:3::1"},
  36. {"b", "2800:1:2:3::6"},
  37. }
  38. for _, tt := range tests {
  39. assert.Equal(t, tt.Result, tree.Contains(net.ParseIP(tt.IP)))
  40. }
  41. tree = NewCIDR6Tree()
  42. tree.AddCIDR(getCIDR("1.1.1.1/0"), "cool")
  43. tree.AddCIDR(getCIDR("::/0"), "cool6")
  44. assert.Equal(t, "cool", tree.Contains(net.ParseIP("0.0.0.0")))
  45. assert.Equal(t, "cool", tree.Contains(net.ParseIP("255.255.255.255")))
  46. assert.Equal(t, "cool6", tree.Contains(net.ParseIP("::")))
  47. assert.Equal(t, "cool6", tree.Contains(net.ParseIP("1:2:3:4:5:6:7:8")))
  48. }
  49. func TestCIDR6Tree_MostSpecificContains(t *testing.T) {
  50. tree := NewCIDR6Tree()
  51. tree.AddCIDR(getCIDR("1.0.0.0/8"), "1")
  52. tree.AddCIDR(getCIDR("2.1.0.0/16"), "2")
  53. tree.AddCIDR(getCIDR("3.1.1.0/24"), "3")
  54. tree.AddCIDR(getCIDR("4.1.1.1/24"), "4a")
  55. tree.AddCIDR(getCIDR("4.1.1.1/30"), "4b")
  56. tree.AddCIDR(getCIDR("4.1.1.1/32"), "4c")
  57. tree.AddCIDR(getCIDR("254.0.0.0/4"), "5")
  58. tree.AddCIDR(getCIDR("1:2:0:4:5:0:0:0/64"), "6a")
  59. tree.AddCIDR(getCIDR("1:2:0:4:5:0:0:0/80"), "6b")
  60. tree.AddCIDR(getCIDR("1:2:0:4:5:0:0:0/96"), "6c")
  61. tests := []struct {
  62. Result interface{}
  63. IP string
  64. }{
  65. {"1", "1.0.0.0"},
  66. {"1", "1.255.255.255"},
  67. {"2", "2.1.0.0"},
  68. {"2", "2.1.255.255"},
  69. {"3", "3.1.1.0"},
  70. {"3", "3.1.1.255"},
  71. {"4a", "4.1.1.255"},
  72. {"4b", "4.1.1.2"},
  73. {"4c", "4.1.1.1"},
  74. {"5", "240.0.0.0"},
  75. {"5", "255.255.255.255"},
  76. {"6a", "1:2:0:4:1:1:1:1"},
  77. {"6b", "1:2:0:4:5:1:1:1"},
  78. {"6c", "1:2:0:4:5:0:0:0"},
  79. {nil, "239.0.0.0"},
  80. {nil, "4.1.2.2"},
  81. }
  82. for _, tt := range tests {
  83. assert.Equal(t, tt.Result, tree.MostSpecificContains(net.ParseIP(tt.IP)))
  84. }
  85. tree = NewCIDR6Tree()
  86. tree.AddCIDR(getCIDR("1.1.1.1/0"), "cool")
  87. tree.AddCIDR(getCIDR("::/0"), "cool6")
  88. assert.Equal(t, "cool", tree.MostSpecificContains(net.ParseIP("0.0.0.0")))
  89. assert.Equal(t, "cool", tree.MostSpecificContains(net.ParseIP("255.255.255.255")))
  90. assert.Equal(t, "cool6", tree.Contains(net.ParseIP("::")))
  91. assert.Equal(t, "cool6", tree.Contains(net.ParseIP("1:2:3:4:5:6:7:8")))
  92. }
  93. func TestCIDR6Tree_Match(t *testing.T) {
  94. tree := NewCIDR6Tree()
  95. tree.AddCIDR(getCIDR("4.1.1.0/32"), "1a")
  96. tree.AddCIDR(getCIDR("4.1.1.1/32"), "1b")
  97. tree.AddCIDR(getCIDR("1:2:3:4:5:6:7:8/128"), "2a")
  98. tree.AddCIDR(getCIDR("1:2:3:4:5:6:7:0/128"), "2b")
  99. tests := []struct {
  100. Result interface{}
  101. IP string
  102. }{
  103. {"1a", "4.1.1.0"},
  104. {"1b", "4.1.1.1"},
  105. {nil, "4.1.1.2"},
  106. {"2a", "1:2:3:4:5:6:7:8"},
  107. {"2b", "1:2:3:4:5:6:7:0"},
  108. {nil, "1:2:3:4:5:6:7:9"},
  109. }
  110. for _, tt := range tests {
  111. assert.Equal(t, tt.Result, tree.Match(net.ParseIP(tt.IP)))
  112. }
  113. tree = NewCIDR6Tree()
  114. tree.AddCIDR(getCIDR("1.1.1.1/0"), "cool")
  115. tree.AddCIDR(getCIDR("1:2:3:4:5:6:7:8/0"), "cool6")
  116. assert.Equal(t, "cool", tree.Contains(net.ParseIP("0.0.0.0")))
  117. assert.Equal(t, "cool", tree.Contains(net.ParseIP("255.255.255.255")))
  118. assert.Equal(t, "cool6", tree.Contains(net.ParseIP("::")))
  119. assert.Equal(t, "cool6", tree.Contains(net.ParseIP("1:2:3:4:5:6:7:8")))
  120. }