mirror of
				https://github.com/k3s-io/kubernetes.git
				synced 2025-11-03 23:40:03 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			264 lines
		
	
	
		
			5.5 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			264 lines
		
	
	
		
			5.5 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
/*
 | 
						|
Copyright 2016 The Kubernetes Authors.
 | 
						|
 | 
						|
Licensed under the Apache License, Version 2.0 (the "License");
 | 
						|
you may not use this file except in compliance with the License.
 | 
						|
You may obtain a copy of the License at
 | 
						|
 | 
						|
    http://www.apache.org/licenses/LICENSE-2.0
 | 
						|
 | 
						|
Unless required by applicable law or agreed to in writing, software
 | 
						|
distributed under the License is distributed on an "AS IS" BASIS,
 | 
						|
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 | 
						|
See the License for the specific language governing permissions and
 | 
						|
limitations under the License.
 | 
						|
*/
 | 
						|
 | 
						|
package predicates
 | 
						|
 | 
						|
import (
 | 
						|
	"fmt"
 | 
						|
	"reflect"
 | 
						|
	"testing"
 | 
						|
 | 
						|
	"k8s.io/api/core/v1"
 | 
						|
	metav1 "k8s.io/apimachinery/pkg/apis/meta/v1"
 | 
						|
	"k8s.io/apimachinery/pkg/labels"
 | 
						|
)
 | 
						|
 | 
						|
// ExampleUtils is a https://blog.golang.org/examples styled unit test.
 | 
						|
func ExampleFindLabelsInSet() {
 | 
						|
	labelSubset := labels.Set{}
 | 
						|
	labelSubset["label1"] = "value1"
 | 
						|
	labelSubset["label2"] = "value2"
 | 
						|
	// Lets make believe that these pods are on the cluster.
 | 
						|
	// Utility functions will inspect their labels, filter them, and so on.
 | 
						|
	nsPods := []*v1.Pod{
 | 
						|
		{
 | 
						|
			ObjectMeta: metav1.ObjectMeta{
 | 
						|
				Name:      "pod1",
 | 
						|
				Namespace: "ns1",
 | 
						|
				Labels: map[string]string{
 | 
						|
					"label1": "wontSeeThis",
 | 
						|
					"label2": "wontSeeThis",
 | 
						|
					"label3": "will_see_this",
 | 
						|
				},
 | 
						|
			},
 | 
						|
		}, // first pod which will be used via the utilities
 | 
						|
		{
 | 
						|
			ObjectMeta: metav1.ObjectMeta{
 | 
						|
				Name:      "pod2",
 | 
						|
				Namespace: "ns1",
 | 
						|
			},
 | 
						|
		},
 | 
						|
 | 
						|
		{
 | 
						|
			ObjectMeta: metav1.ObjectMeta{
 | 
						|
				Name: "pod3ThatWeWontSee",
 | 
						|
			},
 | 
						|
		},
 | 
						|
	}
 | 
						|
	fmt.Println(FindLabelsInSet([]string{"label1", "label2", "label3"}, nsPods[0].ObjectMeta.Labels)["label3"])
 | 
						|
	AddUnsetLabelsToMap(labelSubset, []string{"label1", "label2", "label3"}, nsPods[0].ObjectMeta.Labels)
 | 
						|
	fmt.Println(labelSubset)
 | 
						|
 | 
						|
	for _, pod := range FilterPodsByNamespace(nsPods, "ns1") {
 | 
						|
		fmt.Print(pod.Name, ",")
 | 
						|
	}
 | 
						|
	// Output:
 | 
						|
	// will_see_this
 | 
						|
	// label1=value1,label2=value2,label3=will_see_this
 | 
						|
	// pod1,pod2,
 | 
						|
}
 | 
						|
 | 
						|
func Test_decode(t *testing.T) {
 | 
						|
	tests := []struct {
 | 
						|
		name string
 | 
						|
		args string
 | 
						|
		want *hostPortInfo
 | 
						|
	}{
 | 
						|
		{
 | 
						|
			name: "test1",
 | 
						|
			args: "UDP/127.0.0.1/80",
 | 
						|
			want: &hostPortInfo{
 | 
						|
				protocol: "UDP",
 | 
						|
				hostIP:   "127.0.0.1",
 | 
						|
				hostPort: "80",
 | 
						|
			},
 | 
						|
		},
 | 
						|
		{
 | 
						|
			name: "test2",
 | 
						|
			args: "TCP/127.0.0.1/80",
 | 
						|
			want: &hostPortInfo{
 | 
						|
				protocol: "TCP",
 | 
						|
				hostIP:   "127.0.0.1",
 | 
						|
				hostPort: "80",
 | 
						|
			},
 | 
						|
		},
 | 
						|
		{
 | 
						|
			name: "test3",
 | 
						|
			args: "TCP/0.0.0.0/80",
 | 
						|
			want: &hostPortInfo{
 | 
						|
				protocol: "TCP",
 | 
						|
				hostIP:   "0.0.0.0",
 | 
						|
				hostPort: "80",
 | 
						|
			},
 | 
						|
		},
 | 
						|
	}
 | 
						|
 | 
						|
	for _, tt := range tests {
 | 
						|
		if got := decode(tt.args); !reflect.DeepEqual(got, tt.want) {
 | 
						|
			t.Errorf("test name = %v, decode() = %v, want %v", tt.name, got, tt.want)
 | 
						|
		}
 | 
						|
 | 
						|
	}
 | 
						|
}
 | 
						|
 | 
						|
func Test_specialPortConflictCheck(t *testing.T) {
 | 
						|
	type args struct {
 | 
						|
		specialHostPort string
 | 
						|
		otherHostPorts  map[string]bool
 | 
						|
	}
 | 
						|
	tests := []struct {
 | 
						|
		name string
 | 
						|
		args args
 | 
						|
		want bool
 | 
						|
	}{
 | 
						|
		{
 | 
						|
			name: "test-1",
 | 
						|
			args: args{
 | 
						|
				specialHostPort: "TCP/0.0.0.0/80",
 | 
						|
				otherHostPorts: map[string]bool{
 | 
						|
					"TCP/127.0.0.2/8080": true,
 | 
						|
					"TCP/127.0.0.1/80":   true,
 | 
						|
					"UDP/127.0.0.2/8080": true,
 | 
						|
				},
 | 
						|
			},
 | 
						|
			want: true,
 | 
						|
		},
 | 
						|
		{
 | 
						|
			name: "test-2",
 | 
						|
			args: args{
 | 
						|
				specialHostPort: "TCP/0.0.0.0/80",
 | 
						|
				otherHostPorts: map[string]bool{
 | 
						|
					"TCP/127.0.0.2/8080": true,
 | 
						|
					"UDP/127.0.0.1/80":   true,
 | 
						|
					"UDP/127.0.0.2/8080": true,
 | 
						|
				},
 | 
						|
			},
 | 
						|
			want: false,
 | 
						|
		},
 | 
						|
		{
 | 
						|
			name: "test-3",
 | 
						|
			args: args{
 | 
						|
				specialHostPort: "TCP/0.0.0.0/80",
 | 
						|
				otherHostPorts: map[string]bool{
 | 
						|
					"TCP/127.0.0.2/8080": true,
 | 
						|
					"TCP/127.0.0.1/8090": true,
 | 
						|
					"UDP/127.0.0.2/8080": true,
 | 
						|
				},
 | 
						|
			},
 | 
						|
			want: false,
 | 
						|
		},
 | 
						|
		{
 | 
						|
			name: "test-4",
 | 
						|
			args: args{
 | 
						|
				specialHostPort: "TCP/0.0.0.0/80",
 | 
						|
				otherHostPorts: map[string]bool{
 | 
						|
					"UDP/127.0.0.2/8080": true,
 | 
						|
					"UDP/127.0.0.1/8090": true,
 | 
						|
					"TCP/127.0.0.2/8080": true,
 | 
						|
				},
 | 
						|
			},
 | 
						|
			want: false,
 | 
						|
		},
 | 
						|
	}
 | 
						|
	for _, tt := range tests {
 | 
						|
		t.Run(tt.name, func(t *testing.T) {
 | 
						|
			if got := specialPortConflictCheck(tt.args.specialHostPort, tt.args.otherHostPorts); got != tt.want {
 | 
						|
				t.Errorf("specialPortConflictCheck() = %v, want %v", got, tt.want)
 | 
						|
			}
 | 
						|
		})
 | 
						|
	}
 | 
						|
}
 | 
						|
 | 
						|
func Test_portsConflict(t *testing.T) {
 | 
						|
	type args struct {
 | 
						|
		existingPorts map[string]bool
 | 
						|
		wantPorts     map[string]bool
 | 
						|
	}
 | 
						|
	tests := []struct {
 | 
						|
		name string
 | 
						|
		args args
 | 
						|
		want bool
 | 
						|
	}{
 | 
						|
		{
 | 
						|
			name: "test1",
 | 
						|
			args: args{
 | 
						|
				existingPorts: map[string]bool{
 | 
						|
					"UDP/127.0.0.1/8080": true,
 | 
						|
				},
 | 
						|
				wantPorts: map[string]bool{
 | 
						|
					"UDP/127.0.0.1/8080": true,
 | 
						|
				},
 | 
						|
			},
 | 
						|
			want: true,
 | 
						|
		},
 | 
						|
		{
 | 
						|
			name: "test2",
 | 
						|
			args: args{
 | 
						|
				existingPorts: map[string]bool{
 | 
						|
					"UDP/127.0.0.2/8080": true,
 | 
						|
				},
 | 
						|
				wantPorts: map[string]bool{
 | 
						|
					"UDP/127.0.0.1/8080": true,
 | 
						|
				},
 | 
						|
			},
 | 
						|
			want: false,
 | 
						|
		},
 | 
						|
		{
 | 
						|
			name: "test3",
 | 
						|
			args: args{
 | 
						|
				existingPorts: map[string]bool{
 | 
						|
					"TCP/127.0.0.1/8080": true,
 | 
						|
				},
 | 
						|
				wantPorts: map[string]bool{
 | 
						|
					"UDP/127.0.0.1/8080": true,
 | 
						|
				},
 | 
						|
			},
 | 
						|
			want: false,
 | 
						|
		},
 | 
						|
		{
 | 
						|
			name: "test4",
 | 
						|
			args: args{
 | 
						|
				existingPorts: map[string]bool{
 | 
						|
					"TCP/0.0.0.0/8080": true,
 | 
						|
				},
 | 
						|
				wantPorts: map[string]bool{
 | 
						|
					"TCP/127.0.0.1/8080": true,
 | 
						|
				},
 | 
						|
			},
 | 
						|
			want: true,
 | 
						|
		},
 | 
						|
		{
 | 
						|
			name: "test5",
 | 
						|
			args: args{
 | 
						|
				existingPorts: map[string]bool{
 | 
						|
					"TCP/127.0.0.1/8080": true,
 | 
						|
				},
 | 
						|
				wantPorts: map[string]bool{
 | 
						|
					"TCP/0.0.0.0/8080": true,
 | 
						|
				},
 | 
						|
			},
 | 
						|
			want: true,
 | 
						|
		},
 | 
						|
	}
 | 
						|
	for _, tt := range tests {
 | 
						|
		t.Run(tt.name, func(t *testing.T) {
 | 
						|
			if got := portsConflict(tt.args.existingPorts, tt.args.wantPorts); got != tt.want {
 | 
						|
				t.Errorf("portsConflict() = %v, want %v", got, tt.want)
 | 
						|
			}
 | 
						|
		})
 | 
						|
	}
 | 
						|
}
 |