mirror of
https://github.com/k3s-io/kubernetes.git
synced 2025-07-21 19:01:49 +00:00
Fix validation of event updates
This commit is contained in:
parent
40c2d04946
commit
7314286efd
@ -78,7 +78,7 @@ func (eventStrategy) AllowCreateOnUpdate() bool {
|
||||
func (eventStrategy) ValidateUpdate(ctx context.Context, obj, old runtime.Object) field.ErrorList {
|
||||
groupVersion := requestGroupVersion(ctx)
|
||||
event := obj.(*api.Event)
|
||||
oldEvent := obj.(*api.Event)
|
||||
oldEvent := old.(*api.Event)
|
||||
return validation.ValidateEventUpdate(event, oldEvent, groupVersion)
|
||||
}
|
||||
|
||||
|
@ -17,6 +17,7 @@ limitations under the License.
|
||||
package event
|
||||
|
||||
import (
|
||||
"context"
|
||||
"reflect"
|
||||
"testing"
|
||||
|
||||
@ -117,3 +118,33 @@ func TestSelectableFieldLabelConversions(t *testing.T) {
|
||||
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")
|
||||
}
|
||||
}
|
||||
|
@ -27,6 +27,7 @@ import (
|
||||
apiequality "k8s.io/apimachinery/pkg/api/equality"
|
||||
metav1 "k8s.io/apimachinery/pkg/apis/meta/v1"
|
||||
"k8s.io/apimachinery/pkg/util/diff"
|
||||
"k8s.io/apimachinery/pkg/util/strategicpatch"
|
||||
corev1 "k8s.io/client-go/kubernetes/typed/core/v1"
|
||||
typedeventsv1 "k8s.io/client-go/kubernetes/typed/events/v1"
|
||||
"k8s.io/kubernetes/test/e2e/framework"
|
||||
@ -130,13 +131,20 @@ var _ = common.SIGDescribe("Events API", func() {
|
||||
framework.ExpectNoError(err, "failed to get test event")
|
||||
|
||||
ginkgo.By("patching the test event")
|
||||
eventPatchNote := "This is a test event - patched"
|
||||
eventPatch, err := json.Marshal(map[string]interface{}{
|
||||
"note": eventPatchNote,
|
||||
})
|
||||
framework.ExpectNoError(err, "failed to marshal the patch JSON payload")
|
||||
oldData, err := json.Marshal(testEvent)
|
||||
framework.ExpectNoError(err, "failed to marshal event")
|
||||
newEvent := testEvent.DeepCopy()
|
||||
eventSeries := &eventsv1.EventSeries{
|
||||
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")
|
||||
|
||||
ginkgo.By("getting the test event")
|
||||
@ -147,7 +155,8 @@ var _ = common.SIGDescribe("Events API", func() {
|
||||
testEvent.ObjectMeta.ResourceVersion = ""
|
||||
event.ObjectMeta.ManagedFields = nil
|
||||
testEvent.ObjectMeta.ManagedFields = nil
|
||||
testEvent.Note = eventPatchNote
|
||||
|
||||
testEvent.Series = eventSeries
|
||||
if !apiequality.Semantic.DeepEqual(testEvent, event) {
|
||||
framework.Failf("test event wasn't properly patched: %v", diff.ObjectReflectDiff(testEvent, event))
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user