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 {
|
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)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -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")
|
||||||
|
}
|
||||||
|
}
|
||||||
|
@ -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))
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user