| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157 | 
							- package nebula
 
- import (
 
- 	"net"
 
- 	"testing"
 
- 	"github.com/stretchr/testify/assert"
 
- )
 
- func TestCIDRTree_Contains(t *testing.T) {
 
- 	tree := NewCIDRTree()
 
- 	tree.AddCIDR(getCIDR("1.0.0.0/8"), "1")
 
- 	tree.AddCIDR(getCIDR("2.1.0.0/16"), "2")
 
- 	tree.AddCIDR(getCIDR("3.1.1.0/24"), "3")
 
- 	tree.AddCIDR(getCIDR("4.1.1.0/24"), "4a")
 
- 	tree.AddCIDR(getCIDR("4.1.1.1/32"), "4b")
 
- 	tree.AddCIDR(getCIDR("4.1.2.1/32"), "4c")
 
- 	tree.AddCIDR(getCIDR("254.0.0.0/4"), "5")
 
- 	tests := []struct {
 
- 		Result interface{}
 
- 		IP     string
 
- 	}{
 
- 		{"1", "1.0.0.0"},
 
- 		{"1", "1.255.255.255"},
 
- 		{"2", "2.1.0.0"},
 
- 		{"2", "2.1.255.255"},
 
- 		{"3", "3.1.1.0"},
 
- 		{"3", "3.1.1.255"},
 
- 		{"4a", "4.1.1.255"},
 
- 		{"4a", "4.1.1.1"},
 
- 		{"5", "240.0.0.0"},
 
- 		{"5", "255.255.255.255"},
 
- 		{nil, "239.0.0.0"},
 
- 		{nil, "4.1.2.2"},
 
- 	}
 
- 	for _, tt := range tests {
 
- 		assert.Equal(t, tt.Result, tree.Contains(ip2int(net.ParseIP(tt.IP))))
 
- 	}
 
- 	tree = NewCIDRTree()
 
- 	tree.AddCIDR(getCIDR("1.1.1.1/0"), "cool")
 
- 	assert.Equal(t, "cool", tree.Contains(ip2int(net.ParseIP("0.0.0.0"))))
 
- 	assert.Equal(t, "cool", tree.Contains(ip2int(net.ParseIP("255.255.255.255"))))
 
- }
 
- func TestCIDRTree_MostSpecificContains(t *testing.T) {
 
- 	tree := NewCIDRTree()
 
- 	tree.AddCIDR(getCIDR("1.0.0.0/8"), "1")
 
- 	tree.AddCIDR(getCIDR("2.1.0.0/16"), "2")
 
- 	tree.AddCIDR(getCIDR("3.1.1.0/24"), "3")
 
- 	tree.AddCIDR(getCIDR("4.1.1.0/24"), "4a")
 
- 	tree.AddCIDR(getCIDR("4.1.1.0/30"), "4b")
 
- 	tree.AddCIDR(getCIDR("4.1.1.1/32"), "4c")
 
- 	tree.AddCIDR(getCIDR("254.0.0.0/4"), "5")
 
- 	tests := []struct {
 
- 		Result interface{}
 
- 		IP     string
 
- 	}{
 
- 		{"1", "1.0.0.0"},
 
- 		{"1", "1.255.255.255"},
 
- 		{"2", "2.1.0.0"},
 
- 		{"2", "2.1.255.255"},
 
- 		{"3", "3.1.1.0"},
 
- 		{"3", "3.1.1.255"},
 
- 		{"4a", "4.1.1.255"},
 
- 		{"4b", "4.1.1.2"},
 
- 		{"4c", "4.1.1.1"},
 
- 		{"5", "240.0.0.0"},
 
- 		{"5", "255.255.255.255"},
 
- 		{nil, "239.0.0.0"},
 
- 		{nil, "4.1.2.2"},
 
- 	}
 
- 	for _, tt := range tests {
 
- 		assert.Equal(t, tt.Result, tree.MostSpecificContains(ip2int(net.ParseIP(tt.IP))))
 
- 	}
 
- 	tree = NewCIDRTree()
 
- 	tree.AddCIDR(getCIDR("1.1.1.1/0"), "cool")
 
- 	assert.Equal(t, "cool", tree.MostSpecificContains(ip2int(net.ParseIP("0.0.0.0"))))
 
- 	assert.Equal(t, "cool", tree.MostSpecificContains(ip2int(net.ParseIP("255.255.255.255"))))
 
- }
 
- func TestCIDRTree_Match(t *testing.T) {
 
- 	tree := NewCIDRTree()
 
- 	tree.AddCIDR(getCIDR("4.1.1.0/32"), "1a")
 
- 	tree.AddCIDR(getCIDR("4.1.1.1/32"), "1b")
 
- 	tests := []struct {
 
- 		Result interface{}
 
- 		IP     string
 
- 	}{
 
- 		{"1a", "4.1.1.0"},
 
- 		{"1b", "4.1.1.1"},
 
- 	}
 
- 	for _, tt := range tests {
 
- 		assert.Equal(t, tt.Result, tree.Match(ip2int(net.ParseIP(tt.IP))))
 
- 	}
 
- 	tree = NewCIDRTree()
 
- 	tree.AddCIDR(getCIDR("1.1.1.1/0"), "cool")
 
- 	assert.Equal(t, "cool", tree.Contains(ip2int(net.ParseIP("0.0.0.0"))))
 
- 	assert.Equal(t, "cool", tree.Contains(ip2int(net.ParseIP("255.255.255.255"))))
 
- }
 
- func BenchmarkCIDRTree_Contains(b *testing.B) {
 
- 	tree := NewCIDRTree()
 
- 	tree.AddCIDR(getCIDR("1.1.0.0/16"), "1")
 
- 	tree.AddCIDR(getCIDR("1.2.1.1/32"), "1")
 
- 	tree.AddCIDR(getCIDR("192.2.1.1/32"), "1")
 
- 	tree.AddCIDR(getCIDR("172.2.1.1/32"), "1")
 
- 	ip := ip2int(net.ParseIP("1.2.1.1"))
 
- 	b.Run("found", func(b *testing.B) {
 
- 		for i := 0; i < b.N; i++ {
 
- 			tree.Contains(ip)
 
- 		}
 
- 	})
 
- 	ip = ip2int(net.ParseIP("1.2.1.255"))
 
- 	b.Run("not found", func(b *testing.B) {
 
- 		for i := 0; i < b.N; i++ {
 
- 			tree.Contains(ip)
 
- 		}
 
- 	})
 
- }
 
- func BenchmarkCIDRTree_Match(b *testing.B) {
 
- 	tree := NewCIDRTree()
 
- 	tree.AddCIDR(getCIDR("1.1.0.0/16"), "1")
 
- 	tree.AddCIDR(getCIDR("1.2.1.1/32"), "1")
 
- 	tree.AddCIDR(getCIDR("192.2.1.1/32"), "1")
 
- 	tree.AddCIDR(getCIDR("172.2.1.1/32"), "1")
 
- 	ip := ip2int(net.ParseIP("1.2.1.1"))
 
- 	b.Run("found", func(b *testing.B) {
 
- 		for i := 0; i < b.N; i++ {
 
- 			tree.Match(ip)
 
- 		}
 
- 	})
 
- 	ip = ip2int(net.ParseIP("1.2.1.255"))
 
- 	b.Run("not found", func(b *testing.B) {
 
- 		for i := 0; i < b.N; i++ {
 
- 			tree.Match(ip)
 
- 		}
 
- 	})
 
- }
 
- func getCIDR(s string) *net.IPNet {
 
- 	_, c, _ := net.ParseCIDR(s)
 
- 	return c
 
- }
 
 
  |