mirror of
				https://github.com/optim-enterprises-bv/kubernetes.git
				synced 2025-11-04 04:08:16 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			215 lines
		
	
	
		
			6.9 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			215 lines
		
	
	
		
			6.9 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
/*
 | 
						|
Copyright 2015 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 replicationcontroller
 | 
						|
 | 
						|
import (
 | 
						|
	"strings"
 | 
						|
	"testing"
 | 
						|
 | 
						|
	metav1 "k8s.io/apimachinery/pkg/apis/meta/v1"
 | 
						|
	genericapirequest "k8s.io/apiserver/pkg/endpoints/request"
 | 
						|
	"k8s.io/kubernetes/pkg/api"
 | 
						|
	apitesting "k8s.io/kubernetes/pkg/api/testing"
 | 
						|
 | 
						|
	// install all api groups for testing
 | 
						|
	_ "k8s.io/kubernetes/pkg/api/testapi"
 | 
						|
)
 | 
						|
 | 
						|
func TestControllerStrategy(t *testing.T) {
 | 
						|
	ctx := genericapirequest.NewDefaultContext()
 | 
						|
	if !Strategy.NamespaceScoped() {
 | 
						|
		t.Errorf("ReplicationController must be namespace scoped")
 | 
						|
	}
 | 
						|
	if Strategy.AllowCreateOnUpdate() {
 | 
						|
		t.Errorf("ReplicationController should not allow create on update")
 | 
						|
	}
 | 
						|
 | 
						|
	validSelector := map[string]string{"a": "b"}
 | 
						|
	validPodTemplate := api.PodTemplate{
 | 
						|
		Template: api.PodTemplateSpec{
 | 
						|
			ObjectMeta: metav1.ObjectMeta{
 | 
						|
				Labels: validSelector,
 | 
						|
			},
 | 
						|
			Spec: api.PodSpec{
 | 
						|
				RestartPolicy: api.RestartPolicyAlways,
 | 
						|
				DNSPolicy:     api.DNSClusterFirst,
 | 
						|
				Containers:    []api.Container{{Name: "abc", Image: "image", ImagePullPolicy: "IfNotPresent", TerminationMessagePolicy: api.TerminationMessageReadFile}},
 | 
						|
			},
 | 
						|
		},
 | 
						|
	}
 | 
						|
	rc := &api.ReplicationController{
 | 
						|
		ObjectMeta: metav1.ObjectMeta{Name: "abc", Namespace: metav1.NamespaceDefault},
 | 
						|
		Spec: api.ReplicationControllerSpec{
 | 
						|
			Selector: validSelector,
 | 
						|
			Template: &validPodTemplate.Template,
 | 
						|
		},
 | 
						|
		Status: api.ReplicationControllerStatus{
 | 
						|
			Replicas:           1,
 | 
						|
			ObservedGeneration: int64(10),
 | 
						|
		},
 | 
						|
	}
 | 
						|
 | 
						|
	Strategy.PrepareForCreate(ctx, rc)
 | 
						|
	if rc.Status.Replicas != 0 {
 | 
						|
		t.Error("ReplicationController should not allow setting status.replicas on create")
 | 
						|
	}
 | 
						|
	if rc.Status.ObservedGeneration != int64(0) {
 | 
						|
		t.Error("ReplicationController should not allow setting status.observedGeneration on create")
 | 
						|
	}
 | 
						|
	errs := Strategy.Validate(ctx, rc)
 | 
						|
	if len(errs) != 0 {
 | 
						|
		t.Errorf("Unexpected error validating %v", errs)
 | 
						|
	}
 | 
						|
 | 
						|
	invalidRc := &api.ReplicationController{
 | 
						|
		ObjectMeta: metav1.ObjectMeta{Name: "bar", ResourceVersion: "4"},
 | 
						|
	}
 | 
						|
	Strategy.PrepareForUpdate(ctx, invalidRc, rc)
 | 
						|
	errs = Strategy.ValidateUpdate(ctx, invalidRc, rc)
 | 
						|
	if len(errs) == 0 {
 | 
						|
		t.Errorf("Expected a validation error")
 | 
						|
	}
 | 
						|
	if invalidRc.ResourceVersion != "4" {
 | 
						|
		t.Errorf("Incoming resource version on update should not be mutated")
 | 
						|
	}
 | 
						|
}
 | 
						|
 | 
						|
func TestControllerStatusStrategy(t *testing.T) {
 | 
						|
	ctx := genericapirequest.NewDefaultContext()
 | 
						|
	if !StatusStrategy.NamespaceScoped() {
 | 
						|
		t.Errorf("ReplicationController must be namespace scoped")
 | 
						|
	}
 | 
						|
	if StatusStrategy.AllowCreateOnUpdate() {
 | 
						|
		t.Errorf("ReplicationController should not allow create on update")
 | 
						|
	}
 | 
						|
	validSelector := map[string]string{"a": "b"}
 | 
						|
	validPodTemplate := api.PodTemplate{
 | 
						|
		Template: api.PodTemplateSpec{
 | 
						|
			ObjectMeta: metav1.ObjectMeta{
 | 
						|
				Labels: validSelector,
 | 
						|
			},
 | 
						|
			Spec: api.PodSpec{
 | 
						|
				RestartPolicy: api.RestartPolicyAlways,
 | 
						|
				DNSPolicy:     api.DNSClusterFirst,
 | 
						|
				Containers:    []api.Container{{Name: "abc", Image: "image", ImagePullPolicy: "IfNotPresent", TerminationMessagePolicy: "File"}},
 | 
						|
			},
 | 
						|
		},
 | 
						|
	}
 | 
						|
	oldController := &api.ReplicationController{
 | 
						|
		ObjectMeta: metav1.ObjectMeta{Name: "abc", Namespace: metav1.NamespaceDefault, ResourceVersion: "10"},
 | 
						|
		Spec: api.ReplicationControllerSpec{
 | 
						|
			Replicas: 3,
 | 
						|
			Selector: validSelector,
 | 
						|
			Template: &validPodTemplate.Template,
 | 
						|
		},
 | 
						|
		Status: api.ReplicationControllerStatus{
 | 
						|
			Replicas:           1,
 | 
						|
			ObservedGeneration: int64(10),
 | 
						|
		},
 | 
						|
	}
 | 
						|
	newController := &api.ReplicationController{
 | 
						|
		ObjectMeta: metav1.ObjectMeta{Name: "abc", Namespace: metav1.NamespaceDefault, ResourceVersion: "9"},
 | 
						|
		Spec: api.ReplicationControllerSpec{
 | 
						|
			Replicas: 1,
 | 
						|
			Selector: validSelector,
 | 
						|
			Template: &validPodTemplate.Template,
 | 
						|
		},
 | 
						|
		Status: api.ReplicationControllerStatus{
 | 
						|
			Replicas:           3,
 | 
						|
			ObservedGeneration: int64(11),
 | 
						|
		},
 | 
						|
	}
 | 
						|
	StatusStrategy.PrepareForUpdate(ctx, newController, oldController)
 | 
						|
	if newController.Status.Replicas != 3 {
 | 
						|
		t.Errorf("Replication controller status updates should allow change of replicas: %v", newController.Status.Replicas)
 | 
						|
	}
 | 
						|
	if newController.Spec.Replicas != 3 {
 | 
						|
		t.Errorf("PrepareForUpdate should have preferred spec")
 | 
						|
	}
 | 
						|
	errs := StatusStrategy.ValidateUpdate(ctx, newController, oldController)
 | 
						|
	if len(errs) != 0 {
 | 
						|
		t.Errorf("Unexpected error %v", errs)
 | 
						|
	}
 | 
						|
}
 | 
						|
 | 
						|
func TestSelectableFieldLabelConversions(t *testing.T) {
 | 
						|
	apitesting.TestSelectableFieldLabelConversionsOfKind(t,
 | 
						|
		api.Registry.GroupOrDie(api.GroupName).GroupVersion.String(),
 | 
						|
		"ReplicationController",
 | 
						|
		ControllerToSelectableFields(&api.ReplicationController{}),
 | 
						|
		nil,
 | 
						|
	)
 | 
						|
}
 | 
						|
 | 
						|
func TestValidateUpdate(t *testing.T) {
 | 
						|
	ctx := genericapirequest.NewDefaultContext()
 | 
						|
	validSelector := map[string]string{"a": "b"}
 | 
						|
	validPodTemplate := api.PodTemplate{
 | 
						|
		Template: api.PodTemplateSpec{
 | 
						|
			ObjectMeta: metav1.ObjectMeta{
 | 
						|
				Labels: validSelector,
 | 
						|
			},
 | 
						|
			Spec: api.PodSpec{
 | 
						|
				RestartPolicy: api.RestartPolicyAlways,
 | 
						|
				DNSPolicy:     api.DNSClusterFirst,
 | 
						|
				Containers:    []api.Container{{Name: "abc", Image: "image", ImagePullPolicy: "IfNotPresent", TerminationMessagePolicy: "File"}},
 | 
						|
			},
 | 
						|
		},
 | 
						|
	}
 | 
						|
	oldController := &api.ReplicationController{
 | 
						|
		ObjectMeta: metav1.ObjectMeta{Name: "abc", Namespace: api.NamespaceDefault, ResourceVersion: "10", Annotations: make(map[string]string)},
 | 
						|
		Spec: api.ReplicationControllerSpec{
 | 
						|
			Replicas: 3,
 | 
						|
			Selector: validSelector,
 | 
						|
			Template: &validPodTemplate.Template,
 | 
						|
		},
 | 
						|
		Status: api.ReplicationControllerStatus{
 | 
						|
			Replicas:           1,
 | 
						|
			ObservedGeneration: int64(10),
 | 
						|
		},
 | 
						|
	}
 | 
						|
	// Conversion sets this annotation
 | 
						|
	oldController.Annotations[api.NonConvertibleAnnotationPrefix+"/"+"spec.selector"] = "no way"
 | 
						|
 | 
						|
	// Deep-copy so we won't mutate both selectors.
 | 
						|
	newController := oldController.DeepCopy()
 | 
						|
 | 
						|
	// Irrelevant (to the selector) update for the replication controller.
 | 
						|
	newController.Spec.Replicas = 5
 | 
						|
 | 
						|
	// If they didn't try to update the selector then we should not return any error.
 | 
						|
	errs := Strategy.ValidateUpdate(ctx, newController, oldController)
 | 
						|
	if len(errs) > 0 {
 | 
						|
		t.Fatalf("unexpected errors: %v", errs)
 | 
						|
	}
 | 
						|
 | 
						|
	// Update the selector - validation should return an error.
 | 
						|
	newController.Spec.Selector["shiny"] = "newlabel"
 | 
						|
	newController.Spec.Template.Labels["shiny"] = "newlabel"
 | 
						|
 | 
						|
	errs = Strategy.ValidateUpdate(ctx, newController, oldController)
 | 
						|
	for _, err := range errs {
 | 
						|
		t.Logf("%#v\n", err)
 | 
						|
	}
 | 
						|
	if len(errs) != 1 {
 | 
						|
		t.Fatalf("expected a validation error")
 | 
						|
	}
 | 
						|
	if !strings.Contains(errs[0].Error(), "selector") {
 | 
						|
		t.Fatalf("expected error related to the selector")
 | 
						|
	}
 | 
						|
}
 |