From c2655b4112638600f481914edd326d280d880e32 Mon Sep 17 00:00:00 2001 From: Marek Siarkowicz Date: Thu, 5 Oct 2023 14:09:38 +0200 Subject: [PATCH] Fix watch validation assuming that client requesting older watch revision Signed-off-by: Marek Siarkowicz --- tests/robustness/validate/validate_test.go | 168 +++++++++++++++++++++ tests/robustness/validate/watch.go | 9 +- 2 files changed, 172 insertions(+), 5 deletions(-) diff --git a/tests/robustness/validate/validate_test.go b/tests/robustness/validate/validate_test.go index d6d980eb29c..7a50ef8621e 100644 --- a/tests/robustness/validate/validate_test.go +++ b/tests/robustness/validate/validate_test.go @@ -23,6 +23,7 @@ import ( "go.uber.org/zap/zaptest" "go.etcd.io/etcd/tests/v3/framework/testutils" + "go.etcd.io/etcd/tests/v3/robustness/model" "go.etcd.io/etcd/tests/v3/robustness/report" ) @@ -47,3 +48,170 @@ func TestValidate(t *testing.T) { }) } } + +func TestValidateWatch(t *testing.T) { + tcs := []struct { + name string + reports []report.ClientReport + }{ + { + name: "earlier event after bookmark in separate request", + reports: []report.ClientReport{ + { + Watch: []model.WatchOperation{ + { + Request: model.WatchRequest{ + Key: "a", + Revision: 100, + }, + Responses: []model.WatchResponse{ + { + IsProgressNotify: true, + Revision: 100, + }, + }, + }, + { + Request: model.WatchRequest{ + Key: "a", + Revision: 99, + }, + Responses: []model.WatchResponse{ + { + Events: []model.WatchEvent{ + { + Event: model.Event{ + Type: model.PutOperation, + Key: "a", + Value: model.ValueOrHash{ + Value: "99", + }, + }, + Revision: 99, + }, + }, + Revision: 100, + }, + }, + }, + }, + }, + }, + }, + { + name: "earlier event after in separate request", + reports: []report.ClientReport{ + { + Watch: []model.WatchOperation{ + { + Request: model.WatchRequest{ + Key: "a", + Revision: 100, + }, + Responses: []model.WatchResponse{ + { + Events: []model.WatchEvent{ + { + Event: model.Event{ + Type: model.PutOperation, + Key: "a", + Value: model.ValueOrHash{ + Value: "100", + }, + }, + Revision: 100, + }, + }, + Revision: 100, + }, + }, + }, + { + Request: model.WatchRequest{ + Key: "a", + Revision: 99, + }, + Responses: []model.WatchResponse{ + { + Events: []model.WatchEvent{ + { + Event: model.Event{ + Type: model.PutOperation, + Key: "a", + Value: model.ValueOrHash{ + Value: "99", + }, + }, + Revision: 99, + }, + }, + Revision: 100, + }, + }, + }, + }, + }, + }, + }, + { + name: "duplicated event between two separate requests", + reports: []report.ClientReport{ + { + Watch: []model.WatchOperation{ + { + Request: model.WatchRequest{ + Key: "a", + Revision: 100, + }, + Responses: []model.WatchResponse{ + { + Events: []model.WatchEvent{ + { + Event: model.Event{ + Type: model.PutOperation, + Key: "a", + Value: model.ValueOrHash{ + Value: "100", + }, + }, + Revision: 100, + }, + }, + Revision: 100, + }, + }, + }, + { + Request: model.WatchRequest{ + Key: "a", + Revision: 100, + }, + Responses: []model.WatchResponse{ + { + Events: []model.WatchEvent{ + { + Event: model.Event{ + Type: model.PutOperation, + Key: "a", + Value: model.ValueOrHash{ + Value: "100", + }, + }, + Revision: 100, + }, + }, + Revision: 100, + }, + }, + }, + }, + }, + }, + }, + } + for _, tc := range tcs { + t.Run(tc.name, func(t *testing.T) { + validateWatch(t, Config{ExpectRevisionUnique: true}, tc.reports) + }) + } +} diff --git a/tests/robustness/validate/watch.go b/tests/robustness/validate/watch.go index 9ae06172ecd..e71e7bc49a1 100644 --- a/tests/robustness/validate/watch.go +++ b/tests/robustness/validate/watch.go @@ -43,8 +43,8 @@ func validateWatch(t *testing.T, cfg Config, reports []report.ClientReport) []mo } func validateBookmarkable(t *testing.T, report report.ClientReport) { - var lastProgressNotifyRevision int64 for _, op := range report.Watch { + var lastProgressNotifyRevision int64 for _, resp := range op.Responses { for _, event := range resp.Events { if event.Revision <= lastProgressNotifyRevision { @@ -59,8 +59,8 @@ func validateBookmarkable(t *testing.T, report report.ClientReport) { } func validateOrdered(t *testing.T, report report.ClientReport) { - var lastEventRevision int64 = 1 for _, op := range report.Watch { + var lastEventRevision int64 = 1 for _, resp := range op.Responses { for _, event := range resp.Events { if event.Revision < lastEventRevision { @@ -73,9 +73,8 @@ func validateOrdered(t *testing.T, report report.ClientReport) { } func validateUnique(t *testing.T, expectUniqueRevision bool, report report.ClientReport) { - uniqueOperations := map[any]struct{}{} - for _, op := range report.Watch { + uniqueOperations := map[any]struct{}{} for _, resp := range op.Responses { for _, event := range resp.Events { var key any @@ -97,8 +96,8 @@ func validateUnique(t *testing.T, expectUniqueRevision bool, report report.Clien } func validateAtomic(t *testing.T, report report.ClientReport) { - var lastEventRevision int64 = 1 for _, op := range report.Watch { + var lastEventRevision int64 = 1 for _, resp := range op.Responses { if len(resp.Events) > 0 { if resp.Events[0].Revision == lastEventRevision {