cidr6_radix_test.go 2.1 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677
  1. package nebula
  2. import (
  3. "net"
  4. "testing"
  5. "github.com/stretchr/testify/assert"
  6. )
  7. func TestCIDR6Tree_MostSpecificContains(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.1/24"), "4a")
  13. tree.AddCIDR(getCIDR("4.1.1.1/30"), "4b")
  14. tree.AddCIDR(getCIDR("4.1.1.1/32"), "4c")
  15. tree.AddCIDR(getCIDR("254.0.0.0/4"), "5")
  16. tree.AddCIDR(getCIDR("1:2:0:4:5:0:0:0/64"), "6a")
  17. tree.AddCIDR(getCIDR("1:2:0:4:5:0:0:0/80"), "6b")
  18. tree.AddCIDR(getCIDR("1:2:0:4:5:0:0:0/96"), "6c")
  19. tests := []struct {
  20. Result interface{}
  21. IP string
  22. }{
  23. {"1", "1.0.0.0"},
  24. {"1", "1.255.255.255"},
  25. {"2", "2.1.0.0"},
  26. {"2", "2.1.255.255"},
  27. {"3", "3.1.1.0"},
  28. {"3", "3.1.1.255"},
  29. {"4a", "4.1.1.255"},
  30. {"4b", "4.1.1.2"},
  31. {"4c", "4.1.1.1"},
  32. {"5", "240.0.0.0"},
  33. {"5", "255.255.255.255"},
  34. {"6a", "1:2:0:4:1:1:1:1"},
  35. {"6b", "1:2:0:4:5:1:1:1"},
  36. {"6c", "1:2:0:4:5:0:0:0"},
  37. {nil, "239.0.0.0"},
  38. {nil, "4.1.2.2"},
  39. }
  40. for _, tt := range tests {
  41. assert.Equal(t, tt.Result, tree.MostSpecificContains(net.ParseIP(tt.IP)))
  42. }
  43. tree = NewCIDR6Tree()
  44. tree.AddCIDR(getCIDR("1.1.1.1/0"), "cool")
  45. tree.AddCIDR(getCIDR("::/0"), "cool6")
  46. assert.Equal(t, "cool", tree.MostSpecificContains(net.ParseIP("0.0.0.0")))
  47. assert.Equal(t, "cool", tree.MostSpecificContains(net.ParseIP("255.255.255.255")))
  48. assert.Equal(t, "cool6", tree.MostSpecificContains(net.ParseIP("::")))
  49. assert.Equal(t, "cool6", tree.MostSpecificContains(net.ParseIP("1:2:3:4:5:6:7:8")))
  50. }
  51. func TestCIDR6Tree_MostSpecificContainsIpV6(t *testing.T) {
  52. tree := NewCIDR6Tree()
  53. tree.AddCIDR(getCIDR("1:2:0:4:5:0:0:0/64"), "6a")
  54. tree.AddCIDR(getCIDR("1:2:0:4:5:0:0:0/80"), "6b")
  55. tree.AddCIDR(getCIDR("1:2:0:4:5:0:0:0/96"), "6c")
  56. tests := []struct {
  57. Result interface{}
  58. IP string
  59. }{
  60. {"6a", "1:2:0:4:1:1:1:1"},
  61. {"6b", "1:2:0:4:5:1:1:1"},
  62. {"6c", "1:2:0:4:5:0:0:0"},
  63. }
  64. for _, tt := range tests {
  65. ip := NewIp6AndPort(net.ParseIP(tt.IP), 0)
  66. assert.Equal(t, tt.Result, tree.MostSpecificContainsIpV6(ip.Hi, ip.Lo))
  67. }
  68. }