mirror of
https://github.com/k3s-io/kubernetes.git
synced 2025-08-03 09:22:44 +00:00
Merge pull request #31076 from mwielgus/object-meta
Automatic merge from submit-queue Object meta fixes in federation controllers This PR adds helper functions for handling object meta structs and applies them to the existing controllers. cc: @quinton-hoole @jianhuiz @kubernetes/sig-cluster-federation
This commit is contained in:
commit
069929bbfd
@ -263,7 +263,7 @@ func (nc *NamespaceController) reconcileNamespace(namespace string) {
|
|||||||
return
|
return
|
||||||
}
|
}
|
||||||
desiredNamespace := &api_v1.Namespace{
|
desiredNamespace := &api_v1.Namespace{
|
||||||
ObjectMeta: baseNamespace.ObjectMeta,
|
ObjectMeta: util.CopyObjectMeta(baseNamespace.ObjectMeta),
|
||||||
Spec: baseNamespace.Spec,
|
Spec: baseNamespace.Spec,
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -277,7 +277,7 @@ func (nc *NamespaceController) reconcileNamespace(namespace string) {
|
|||||||
clusterNamespace := clusterNamespaceObj.(*api_v1.Namespace)
|
clusterNamespace := clusterNamespaceObj.(*api_v1.Namespace)
|
||||||
|
|
||||||
// Update existing namespace, if needed.
|
// Update existing namespace, if needed.
|
||||||
if !reflect.DeepEqual(desiredNamespace.ObjectMeta, clusterNamespace.ObjectMeta) ||
|
if !util.ObjectMetaEquivalent(desiredNamespace.ObjectMeta, clusterNamespace.ObjectMeta) ||
|
||||||
!reflect.DeepEqual(desiredNamespace.Spec, clusterNamespace.Spec) {
|
!reflect.DeepEqual(desiredNamespace.Spec, clusterNamespace.Spec) {
|
||||||
operations = append(operations, util.FederatedOperation{
|
operations = append(operations, util.FederatedOperation{
|
||||||
Type: util.OperationTypeUpdate,
|
Type: util.OperationTypeUpdate,
|
||||||
|
@ -272,7 +272,7 @@ func (secretcontroller *SecretController) reconcileSecret(namespace string, secr
|
|||||||
}
|
}
|
||||||
|
|
||||||
desiredSecret := &api_v1.Secret{
|
desiredSecret := &api_v1.Secret{
|
||||||
ObjectMeta: baseSecret.ObjectMeta,
|
ObjectMeta: util.CopyObjectMeta(baseSecret.ObjectMeta),
|
||||||
Data: baseSecret.Data,
|
Data: baseSecret.Data,
|
||||||
Type: baseSecret.Type,
|
Type: baseSecret.Type,
|
||||||
}
|
}
|
||||||
@ -287,7 +287,9 @@ func (secretcontroller *SecretController) reconcileSecret(namespace string, secr
|
|||||||
clusterSecret := clusterSecretObj.(*api_v1.Secret)
|
clusterSecret := clusterSecretObj.(*api_v1.Secret)
|
||||||
|
|
||||||
// Update existing secret, if needed.
|
// Update existing secret, if needed.
|
||||||
if !reflect.DeepEqual(desiredSecret.ObjectMeta, clusterSecret.ObjectMeta) {
|
if !util.ObjectMetaEquivalent(desiredSecret.ObjectMeta, clusterSecret.ObjectMeta) ||
|
||||||
|
!reflect.DeepEqual(desiredSecret.Data, clusterSecret.Data) ||
|
||||||
|
!reflect.DeepEqual(desiredSecret.Type, clusterSecret.Type) {
|
||||||
operations = append(operations, util.FederatedOperation{
|
operations = append(operations, util.FederatedOperation{
|
||||||
Type: util.OperationTypeUpdate,
|
Type: util.OperationTypeUpdate,
|
||||||
Obj: desiredSecret,
|
Obj: desiredSecret,
|
||||||
|
54
federation/pkg/federation-controller/util/meta.go
Normal file
54
federation/pkg/federation-controller/util/meta.go
Normal file
@ -0,0 +1,54 @@
|
|||||||
|
/*
|
||||||
|
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 util
|
||||||
|
|
||||||
|
import (
|
||||||
|
"reflect"
|
||||||
|
|
||||||
|
api_v1 "k8s.io/kubernetes/pkg/api/v1"
|
||||||
|
)
|
||||||
|
|
||||||
|
// Copies cluster-independent, user provided data from the given ObjectMeta struct. If in
|
||||||
|
// the future the ObjectMeta structure is expanded then any field that is not populared
|
||||||
|
// by the api server should be included here.
|
||||||
|
func CopyObjectMeta(obj api_v1.ObjectMeta) api_v1.ObjectMeta {
|
||||||
|
return api_v1.ObjectMeta{
|
||||||
|
Name: obj.Name,
|
||||||
|
Namespace: obj.Namespace,
|
||||||
|
Labels: obj.Labels,
|
||||||
|
Annotations: obj.Annotations,
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// Checks if cluster-independed, user provided data in two given ObjectMeta are eqaul. If in
|
||||||
|
// the future the ObjectMeta structure is expanded then any field that is not populared
|
||||||
|
// by the api server should be included here.
|
||||||
|
func ObjectMetaEquivalent(a, b api_v1.ObjectMeta) bool {
|
||||||
|
if a.Name != b.Name {
|
||||||
|
return false
|
||||||
|
}
|
||||||
|
if a.Namespace != b.Namespace {
|
||||||
|
return false
|
||||||
|
}
|
||||||
|
if !reflect.DeepEqual(a.Labels, b.Labels) {
|
||||||
|
return false
|
||||||
|
}
|
||||||
|
if !reflect.DeepEqual(a.Annotations, b.Annotations) {
|
||||||
|
return false
|
||||||
|
}
|
||||||
|
return true
|
||||||
|
}
|
67
federation/pkg/federation-controller/util/meta_test.go
Normal file
67
federation/pkg/federation-controller/util/meta_test.go
Normal file
@ -0,0 +1,67 @@
|
|||||||
|
/*
|
||||||
|
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 util
|
||||||
|
|
||||||
|
import (
|
||||||
|
"testing"
|
||||||
|
|
||||||
|
api_v1 "k8s.io/kubernetes/pkg/api/v1"
|
||||||
|
|
||||||
|
"github.com/stretchr/testify/assert"
|
||||||
|
)
|
||||||
|
|
||||||
|
func TestObjectMeta(t *testing.T) {
|
||||||
|
o1 := api_v1.ObjectMeta{
|
||||||
|
Namespace: "ns1",
|
||||||
|
Name: "s1",
|
||||||
|
UID: "1231231412",
|
||||||
|
ResourceVersion: "999",
|
||||||
|
}
|
||||||
|
o2 := CopyObjectMeta(o1)
|
||||||
|
o3 := api_v1.ObjectMeta{
|
||||||
|
Namespace: "ns1",
|
||||||
|
Name: "s1",
|
||||||
|
UID: "1231231412",
|
||||||
|
Annotations: map[string]string{"A": "B"},
|
||||||
|
}
|
||||||
|
o4 := api_v1.ObjectMeta{
|
||||||
|
Namespace: "ns1",
|
||||||
|
Name: "s1",
|
||||||
|
UID: "1231255531412",
|
||||||
|
Annotations: map[string]string{"A": "B"},
|
||||||
|
}
|
||||||
|
o5 := api_v1.ObjectMeta{
|
||||||
|
Namespace: "ns1",
|
||||||
|
Name: "s1",
|
||||||
|
ResourceVersion: "1231231412",
|
||||||
|
Annotations: map[string]string{"A": "B"},
|
||||||
|
}
|
||||||
|
o6 := api_v1.ObjectMeta{
|
||||||
|
Namespace: "ns1",
|
||||||
|
Name: "s1",
|
||||||
|
ResourceVersion: "1231255531412",
|
||||||
|
Annotations: map[string]string{"A": "B"},
|
||||||
|
}
|
||||||
|
assert.Equal(t, 0, len(o2.UID))
|
||||||
|
assert.Equal(t, 0, len(o2.ResourceVersion))
|
||||||
|
assert.Equal(t, o1.Name, o2.Name)
|
||||||
|
assert.True(t, ObjectMetaEquivalent(o1, o2))
|
||||||
|
assert.False(t, ObjectMetaEquivalent(o1, o3))
|
||||||
|
assert.True(t, ObjectMetaEquivalent(o3, o4))
|
||||||
|
assert.True(t, ObjectMetaEquivalent(o5, o6))
|
||||||
|
assert.True(t, ObjectMetaEquivalent(o3, o5))
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user