123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183 |
- /*
- Copyright 2014 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 api_test
- import (
- "reflect"
- "testing"
- "github.com/google/gofuzz"
- "k8s.io/kubernetes/pkg/api"
- "k8s.io/kubernetes/pkg/api/meta"
- "k8s.io/kubernetes/pkg/api/meta/metatypes"
- "k8s.io/kubernetes/pkg/api/testapi"
- "k8s.io/kubernetes/pkg/api/unversioned"
- "k8s.io/kubernetes/pkg/runtime"
- "k8s.io/kubernetes/pkg/util/uuid"
- )
- var _ meta.Object = &api.ObjectMeta{}
- // TestFillObjectMetaSystemFields validates that system populated fields are set on an object
- func TestFillObjectMetaSystemFields(t *testing.T) {
- ctx := api.NewDefaultContext()
- resource := api.ObjectMeta{}
- api.FillObjectMetaSystemFields(ctx, &resource)
- if resource.CreationTimestamp.Time.IsZero() {
- t.Errorf("resource.CreationTimestamp is zero")
- } else if len(resource.UID) == 0 {
- t.Errorf("resource.UID missing")
- }
- // verify we can inject a UID
- uid := uuid.NewUUID()
- ctx = api.WithUID(ctx, uid)
- resource = api.ObjectMeta{}
- api.FillObjectMetaSystemFields(ctx, &resource)
- if resource.UID != uid {
- t.Errorf("resource.UID expected: %v, actual: %v", uid, resource.UID)
- }
- }
- // TestHasObjectMetaSystemFieldValues validates that true is returned if and only if all fields are populated
- func TestHasObjectMetaSystemFieldValues(t *testing.T) {
- ctx := api.NewDefaultContext()
- resource := api.ObjectMeta{}
- if api.HasObjectMetaSystemFieldValues(&resource) {
- t.Errorf("the resource does not have all fields yet populated, but incorrectly reports it does")
- }
- api.FillObjectMetaSystemFields(ctx, &resource)
- if !api.HasObjectMetaSystemFieldValues(&resource) {
- t.Errorf("the resource does have all fields populated, but incorrectly reports it does not")
- }
- }
- func getObjectMetaAndOwnerReferences() (objectMeta api.ObjectMeta, metaOwnerReferences []metatypes.OwnerReference) {
- fuzz.New().NilChance(.5).NumElements(1, 5).Fuzz(&objectMeta)
- references := objectMeta.OwnerReferences
- metaOwnerReferences = make([]metatypes.OwnerReference, 0)
- for i := 0; i < len(references); i++ {
- metaOwnerReferences = append(metaOwnerReferences, metatypes.OwnerReference{
- Kind: references[i].Kind,
- Name: references[i].Name,
- UID: references[i].UID,
- APIVersion: references[i].APIVersion,
- Controller: references[i].Controller,
- })
- }
- if len(references) == 0 {
- objectMeta.OwnerReferences = make([]api.OwnerReference, 0)
- }
- return objectMeta, metaOwnerReferences
- }
- func testGetOwnerReferences(t *testing.T) {
- meta, expected := getObjectMetaAndOwnerReferences()
- refs := meta.GetOwnerReferences()
- if !reflect.DeepEqual(refs, expected) {
- t.Errorf("expect %v\n got %v", expected, refs)
- }
- }
- func testSetOwnerReferences(t *testing.T) {
- expected, newRefs := getObjectMetaAndOwnerReferences()
- objectMeta := &api.ObjectMeta{}
- objectMeta.SetOwnerReferences(newRefs)
- if !reflect.DeepEqual(expected.OwnerReferences, objectMeta.OwnerReferences) {
- t.Errorf("expect: %#v\n got: %#v", expected.OwnerReferences, objectMeta.OwnerReferences)
- }
- }
- func TestAccessOwnerReferences(t *testing.T) {
- fuzzIter := 5
- for i := 0; i < fuzzIter; i++ {
- testGetOwnerReferences(t)
- testSetOwnerReferences(t)
- }
- }
- func TestAccessorImplementations(t *testing.T) {
- for _, group := range testapi.Groups {
- for _, gv := range []unversioned.GroupVersion{*group.GroupVersion(), group.InternalGroupVersion()} {
- for kind, knownType := range api.Scheme.KnownTypes(gv) {
- value := reflect.New(knownType)
- obj := value.Interface()
- if _, ok := obj.(runtime.Object); !ok {
- t.Errorf("%v (%v) does not implement runtime.Object", gv.WithKind(kind), knownType)
- }
- lm, isLM := obj.(meta.ListMetaAccessor)
- om, isOM := obj.(meta.ObjectMetaAccessor)
- switch {
- case isLM && isOM:
- t.Errorf("%v (%v) implements ListMetaAccessor and ObjectMetaAccessor", gv.WithKind(kind), knownType)
- continue
- case isLM:
- m := lm.GetListMeta()
- if m == nil {
- t.Errorf("%v (%v) returns nil ListMeta", gv.WithKind(kind), knownType)
- continue
- }
- m.SetResourceVersion("102030")
- if m.GetResourceVersion() != "102030" {
- t.Errorf("%v (%v) did not preserve resource version", gv.WithKind(kind), knownType)
- continue
- }
- m.SetSelfLink("102030")
- if m.GetSelfLink() != "102030" {
- t.Errorf("%v (%v) did not preserve self link", gv.WithKind(kind), knownType)
- continue
- }
- case isOM:
- m := om.GetObjectMeta()
- if m == nil {
- t.Errorf("%v (%v) returns nil ObjectMeta", gv.WithKind(kind), knownType)
- continue
- }
- m.SetResourceVersion("102030")
- if m.GetResourceVersion() != "102030" {
- t.Errorf("%v (%v) did not preserve resource version", gv.WithKind(kind), knownType)
- continue
- }
- m.SetSelfLink("102030")
- if m.GetSelfLink() != "102030" {
- t.Errorf("%v (%v) did not preserve self link", gv.WithKind(kind), knownType)
- continue
- }
- labels := map[string]string{"a": "b"}
- m.SetLabels(labels)
- if !reflect.DeepEqual(m.GetLabels(), labels) {
- t.Errorf("%v (%v) did not preserve labels", gv.WithKind(kind), knownType)
- continue
- }
- default:
- if _, ok := obj.(unversioned.ListMetaAccessor); ok {
- continue
- }
- if _, ok := value.Elem().Type().FieldByName("ObjectMeta"); ok {
- t.Errorf("%v (%v) has ObjectMeta but does not implement ObjectMetaAccessor", gv.WithKind(kind), knownType)
- continue
- }
- if _, ok := value.Elem().Type().FieldByName("ListMeta"); ok {
- t.Errorf("%v (%v) has ListMeta but does not implement ListMetaAccessor", gv.WithKind(kind), knownType)
- continue
- }
- t.Logf("%v (%v) does not implement ListMetaAccessor or ObjectMetaAccessor", gv.WithKind(kind), knownType)
- }
- }
- }
- }
- }
|