add tests in ipvs/ipset_test.go
This commit is contained in:
		@@ -18,6 +18,9 @@ package ipvs
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
import (
 | 
					import (
 | 
				
			||||||
	"testing"
 | 
						"testing"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						utilipset "k8s.io/kubernetes/pkg/util/ipset"
 | 
				
			||||||
 | 
						fakeipset "k8s.io/kubernetes/pkg/util/ipset/testing"
 | 
				
			||||||
)
 | 
					)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
func TestCheckIPSetVersion(t *testing.T) {
 | 
					func TestCheckIPSetVersion(t *testing.T) {
 | 
				
			||||||
@@ -47,3 +50,133 @@ func TestCheckIPSetVersion(t *testing.T) {
 | 
				
			|||||||
		}
 | 
							}
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					const testIPSetVersion = "v6.19"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					func TestSyncIPSetEntries(t *testing.T) {
 | 
				
			||||||
 | 
						testCases := []struct {
 | 
				
			||||||
 | 
							setName         string
 | 
				
			||||||
 | 
							setType         utilipset.Type
 | 
				
			||||||
 | 
							ipv6            bool
 | 
				
			||||||
 | 
							activeEntries   []string
 | 
				
			||||||
 | 
							currentEntries  []string
 | 
				
			||||||
 | 
							expectedEntries []string
 | 
				
			||||||
 | 
						}{
 | 
				
			||||||
 | 
							{ // case 0
 | 
				
			||||||
 | 
								setName:         "foo",
 | 
				
			||||||
 | 
								setType:         utilipset.HashIPPort,
 | 
				
			||||||
 | 
								ipv6:            false,
 | 
				
			||||||
 | 
								activeEntries:   []string{"172.17.0.4,tcp:80"},
 | 
				
			||||||
 | 
								currentEntries:  nil,
 | 
				
			||||||
 | 
								expectedEntries: []string{"172.17.0.4,tcp:80"},
 | 
				
			||||||
 | 
							},
 | 
				
			||||||
 | 
							{ // case 1
 | 
				
			||||||
 | 
								setName:         "abz",
 | 
				
			||||||
 | 
								setType:         utilipset.HashIPPort,
 | 
				
			||||||
 | 
								ipv6:            true,
 | 
				
			||||||
 | 
								activeEntries:   []string{"FE80::0202:B3FF:FE1E:8329,tcp:80"},
 | 
				
			||||||
 | 
								currentEntries:  []string{"FE80::0202:B3FF:FE1E:8329,tcp:80"},
 | 
				
			||||||
 | 
								expectedEntries: []string{"FE80::0202:B3FF:FE1E:8329,tcp:80"},
 | 
				
			||||||
 | 
							},
 | 
				
			||||||
 | 
							{ // case 2
 | 
				
			||||||
 | 
								setName:         "bca",
 | 
				
			||||||
 | 
								setType:         utilipset.HashIPPort,
 | 
				
			||||||
 | 
								ipv6:            false,
 | 
				
			||||||
 | 
								activeEntries:   []string{"172.17.0.4,tcp:80", "172.17.0.5,tcp:80"},
 | 
				
			||||||
 | 
								currentEntries:  []string{"172.17.0.5,udp:53"},
 | 
				
			||||||
 | 
								expectedEntries: []string{"172.17.0.4,tcp:80", "172.17.0.5,tcp:80"},
 | 
				
			||||||
 | 
							},
 | 
				
			||||||
 | 
							{ // case 3
 | 
				
			||||||
 | 
								setName:         "bar",
 | 
				
			||||||
 | 
								setType:         utilipset.HashIPPortIP,
 | 
				
			||||||
 | 
								ipv6:            false,
 | 
				
			||||||
 | 
								activeEntries:   []string{"172.17.0.4,tcp:80:172.17.0.4"},
 | 
				
			||||||
 | 
								currentEntries:  []string{"172.17.0.4,tcp:80:172.17.0.4"},
 | 
				
			||||||
 | 
								expectedEntries: []string{"172.17.0.4,tcp:80:172.17.0.4"},
 | 
				
			||||||
 | 
							},
 | 
				
			||||||
 | 
							{ // case 4
 | 
				
			||||||
 | 
								setName:         "baz",
 | 
				
			||||||
 | 
								setType:         utilipset.HashIPPortIP,
 | 
				
			||||||
 | 
								ipv6:            true,
 | 
				
			||||||
 | 
								activeEntries:   []string{"FE80:0000:0000:0000:0202:B3FF:FE1E:8329,tcp:8080:FE80:0000:0000:0000:0202:B3FF:FE1E:8329"},
 | 
				
			||||||
 | 
								currentEntries:  []string{"1111:0000:0000:0000:0202:B3FF:FE1E:8329,tcp:8081:1111:0000:0000:0000:0202:B3FF:FE1E:8329:8081"},
 | 
				
			||||||
 | 
								expectedEntries: []string{"FE80:0000:0000:0000:0202:B3FF:FE1E:8329,tcp:8080:FE80:0000:0000:0000:0202:B3FF:FE1E:8329"},
 | 
				
			||||||
 | 
							},
 | 
				
			||||||
 | 
							{ // case 5
 | 
				
			||||||
 | 
								setName:         "NOPE",
 | 
				
			||||||
 | 
								setType:         utilipset.HashIPPortIP,
 | 
				
			||||||
 | 
								ipv6:            false,
 | 
				
			||||||
 | 
								activeEntries:   []string{"172.17.0.4,tcp:80,172.17.0.9", "172.17.0.5,tcp:80,172.17.0.10"},
 | 
				
			||||||
 | 
								currentEntries:  nil,
 | 
				
			||||||
 | 
								expectedEntries: []string{"172.17.0.4,tcp:80,172.17.0.9", "172.17.0.5,tcp:80,172.17.0.10"},
 | 
				
			||||||
 | 
							},
 | 
				
			||||||
 | 
							{ // case 6
 | 
				
			||||||
 | 
								setName:         "ABC-DEF",
 | 
				
			||||||
 | 
								setType:         utilipset.HashIPPortNet,
 | 
				
			||||||
 | 
								ipv6:            false,
 | 
				
			||||||
 | 
								activeEntries:   []string{"172.17.0.4,tcp:80,172.17.0.0/16", "172.17.0.5,tcp:80,172.17.0.0/16"},
 | 
				
			||||||
 | 
								currentEntries:  nil,
 | 
				
			||||||
 | 
								expectedEntries: []string{"172.17.0.4,tcp:80,172.17.0.0/16", "172.17.0.5,tcp:80,172.17.0.0/16"},
 | 
				
			||||||
 | 
							},
 | 
				
			||||||
 | 
							{ // case 7
 | 
				
			||||||
 | 
								setName:         "zar",
 | 
				
			||||||
 | 
								setType:         utilipset.HashIPPortNet,
 | 
				
			||||||
 | 
								ipv6:            true,
 | 
				
			||||||
 | 
								activeEntries:   []string{"FE80::8329,tcp:8800,2001:db8::/32"},
 | 
				
			||||||
 | 
								currentEntries:  []string{"FE80::8329,tcp:8800,2001:db8::/32"},
 | 
				
			||||||
 | 
								expectedEntries: []string{"FE80::8329,tcp:8800,2001:db8::/32"},
 | 
				
			||||||
 | 
							},
 | 
				
			||||||
 | 
							{ // case 8
 | 
				
			||||||
 | 
								setName:         "bbb",
 | 
				
			||||||
 | 
								setType:         utilipset.HashIPPortNet,
 | 
				
			||||||
 | 
								ipv6:            true,
 | 
				
			||||||
 | 
								activeEntries:   nil,
 | 
				
			||||||
 | 
								currentEntries:  []string{"FE80::8329,udp:8801,2001:db8::/32"},
 | 
				
			||||||
 | 
								expectedEntries: nil,
 | 
				
			||||||
 | 
							},
 | 
				
			||||||
 | 
							{ // case 9
 | 
				
			||||||
 | 
								setName:         "AAA",
 | 
				
			||||||
 | 
								setType:         utilipset.BitmapPort,
 | 
				
			||||||
 | 
								activeEntries:   nil,
 | 
				
			||||||
 | 
								currentEntries:  []string{"80"},
 | 
				
			||||||
 | 
								expectedEntries: nil,
 | 
				
			||||||
 | 
							},
 | 
				
			||||||
 | 
							{ // case 10
 | 
				
			||||||
 | 
								setName:         "c-c-c",
 | 
				
			||||||
 | 
								setType:         utilipset.BitmapPort,
 | 
				
			||||||
 | 
								activeEntries:   []string{"8080", "9090"},
 | 
				
			||||||
 | 
								currentEntries:  []string{"80"},
 | 
				
			||||||
 | 
								expectedEntries: []string{"8080", "9090"},
 | 
				
			||||||
 | 
							},
 | 
				
			||||||
 | 
							{ // case 11
 | 
				
			||||||
 | 
								setName:         "NODE-PORT",
 | 
				
			||||||
 | 
								setType:         utilipset.BitmapPort,
 | 
				
			||||||
 | 
								activeEntries:   []string{"8080"},
 | 
				
			||||||
 | 
								currentEntries:  []string{"80", "9090", "8081", "8082"},
 | 
				
			||||||
 | 
								expectedEntries: []string{"8080"},
 | 
				
			||||||
 | 
							},
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						for i := range testCases {
 | 
				
			||||||
 | 
							set := NewIPSet(fakeipset.NewFake(testIPSetVersion), testCases[i].setName, testCases[i].setType, testCases[i].ipv6)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							if err := set.handle.CreateSet(&set.IPSet, true); err != nil {
 | 
				
			||||||
 | 
								t.Errorf("Unexpected error: %v", err)
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
 | 
							for _, entry := range testCases[i].expectedEntries {
 | 
				
			||||||
 | 
								set.handle.AddEntry(entry, testCases[i].setName, true)
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							set.activeEntries.Insert(testCases[i].activeEntries...)
 | 
				
			||||||
 | 
							set.syncIPSetEntries()
 | 
				
			||||||
 | 
							for _, entry := range testCases[i].expectedEntries {
 | 
				
			||||||
 | 
								found, err := set.handle.TestEntry(entry, testCases[i].setName)
 | 
				
			||||||
 | 
								if err != nil {
 | 
				
			||||||
 | 
									t.Errorf("Unexpected error: %v", err)
 | 
				
			||||||
 | 
								}
 | 
				
			||||||
 | 
								if !found {
 | 
				
			||||||
 | 
									t.Errorf("Unexpected entry 172.17.0.4,tcp:80 not found in set foo")
 | 
				
			||||||
 | 
								}
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 
 | 
				
			|||||||
		Reference in New Issue
	
	Block a user