Fix validation of event updates

This commit is contained in:
Wojciech Tyczyński 2022-02-10 15:15:07 +01:00
parent 40c2d04946
commit 7314286efd
3 changed files with 48 additions and 8 deletions

View File

@ -78,7 +78,7 @@ func (eventStrategy) AllowCreateOnUpdate() bool {
func (eventStrategy) ValidateUpdate(ctx context.Context, obj, old runtime.Object) field.ErrorList { func (eventStrategy) ValidateUpdate(ctx context.Context, obj, old runtime.Object) field.ErrorList {
groupVersion := requestGroupVersion(ctx) groupVersion := requestGroupVersion(ctx)
event := obj.(*api.Event) event := obj.(*api.Event)
oldEvent := obj.(*api.Event) oldEvent := old.(*api.Event)
return validation.ValidateEventUpdate(event, oldEvent, groupVersion) return validation.ValidateEventUpdate(event, oldEvent, groupVersion)
} }

View File

@ -17,6 +17,7 @@ limitations under the License.
package event package event
import ( import (
"context"
"reflect" "reflect"
"testing" "testing"
@ -117,3 +118,33 @@ func TestSelectableFieldLabelConversions(t *testing.T) {
nil, nil,
) )
} }
func TestValidateUpdate(t *testing.T) {
makeEvent := func(name string) *api.Event {
return &api.Event{
ObjectMeta: metav1.ObjectMeta{
Name: name,
Namespace: "default",
ResourceVersion: "123",
},
InvolvedObject: api.ObjectReference{
Kind: "Pod",
Name: "foo",
Namespace: "default",
UID: "long uid string",
APIVersion: "v1",
ResourceVersion: "0",
FieldPath: "",
},
Reason: "ForTesting",
Source: api.EventSource{Component: "test"},
Type: api.EventTypeNormal,
}
}
eventA := makeEvent("eventA")
eventB := makeEvent("eventB")
errList := Strategy.ValidateUpdate(context.Background(), eventA, eventB)
if len(errList) == 0 {
t.Errorf("ValidateUpdate should fail on name change")
}
}

View File

@ -27,6 +27,7 @@ import (
apiequality "k8s.io/apimachinery/pkg/api/equality" apiequality "k8s.io/apimachinery/pkg/api/equality"
metav1 "k8s.io/apimachinery/pkg/apis/meta/v1" metav1 "k8s.io/apimachinery/pkg/apis/meta/v1"
"k8s.io/apimachinery/pkg/util/diff" "k8s.io/apimachinery/pkg/util/diff"
"k8s.io/apimachinery/pkg/util/strategicpatch"
corev1 "k8s.io/client-go/kubernetes/typed/core/v1" corev1 "k8s.io/client-go/kubernetes/typed/core/v1"
typedeventsv1 "k8s.io/client-go/kubernetes/typed/events/v1" typedeventsv1 "k8s.io/client-go/kubernetes/typed/events/v1"
"k8s.io/kubernetes/test/e2e/framework" "k8s.io/kubernetes/test/e2e/framework"
@ -130,13 +131,20 @@ var _ = common.SIGDescribe("Events API", func() {
framework.ExpectNoError(err, "failed to get test event") framework.ExpectNoError(err, "failed to get test event")
ginkgo.By("patching the test event") ginkgo.By("patching the test event")
eventPatchNote := "This is a test event - patched" oldData, err := json.Marshal(testEvent)
eventPatch, err := json.Marshal(map[string]interface{}{ framework.ExpectNoError(err, "failed to marshal event")
"note": eventPatchNote, newEvent := testEvent.DeepCopy()
}) eventSeries := &eventsv1.EventSeries{
framework.ExpectNoError(err, "failed to marshal the patch JSON payload") Count: 2,
LastObservedTime: metav1.MicroTime{Time: time.Unix(1505828951, 0)},
}
newEvent.Series = eventSeries
newData, err := json.Marshal(newEvent)
framework.ExpectNoError(err, "failed to marshal new event")
patchBytes, err := strategicpatch.CreateTwoWayMergePatch(oldData, newData, eventsv1.Event{})
framework.ExpectNoError(err, "failed to create two-way merge patch")
_, err = client.Patch(context.TODO(), eventName, types.StrategicMergePatchType, []byte(eventPatch), metav1.PatchOptions{}) _, err = client.Patch(context.TODO(), eventName, types.StrategicMergePatchType, patchBytes, metav1.PatchOptions{})
framework.ExpectNoError(err, "failed to patch the test event") framework.ExpectNoError(err, "failed to patch the test event")
ginkgo.By("getting the test event") ginkgo.By("getting the test event")
@ -147,7 +155,8 @@ var _ = common.SIGDescribe("Events API", func() {
testEvent.ObjectMeta.ResourceVersion = "" testEvent.ObjectMeta.ResourceVersion = ""
event.ObjectMeta.ManagedFields = nil event.ObjectMeta.ManagedFields = nil
testEvent.ObjectMeta.ManagedFields = nil testEvent.ObjectMeta.ManagedFields = nil
testEvent.Note = eventPatchNote
testEvent.Series = eventSeries
if !apiequality.Semantic.DeepEqual(testEvent, event) { if !apiequality.Semantic.DeepEqual(testEvent, event) {
framework.Failf("test event wasn't properly patched: %v", diff.ObjectReflectDiff(testEvent, event)) framework.Failf("test event wasn't properly patched: %v", diff.ObjectReflectDiff(testEvent, event))
} }