From a057e301298a7545f34d706391a9ba35452bc266 Mon Sep 17 00:00:00 2001 From: Manan Gupta <35839558+GuptaManan100@users.noreply.github.com> Date: Fri, 14 Jul 2023 00:13:50 +0530 Subject: [PATCH] Fix `TestGatewayBufferingWhileReparenting` flakiness (#13469) * feat: fix gateway reparent flakiness Signed-off-by: Manan Gupta * feat: verify the consistant state Signed-off-by: Manan Gupta --------- Signed-off-by: Manan Gupta --- go/vt/vtgate/tabletgateway_flaky_test.go | 9 +++++++-- 1 file changed, 7 insertions(+), 2 deletions(-) diff --git a/go/vt/vtgate/tabletgateway_flaky_test.go b/go/vt/vtgate/tabletgateway_flaky_test.go index b9f4acae64b..c0e87dfc31e 100644 --- a/go/vt/vtgate/tabletgateway_flaky_test.go +++ b/go/vt/vtgate/tabletgateway_flaky_test.go @@ -185,7 +185,14 @@ func TestGatewayBufferingWhileReparenting(t *testing.T) { hc.Broadcast(primaryTablet) // set the serving type for the primary tablet false and broadcast it so that the buffering code registers this change hc.SetServing(primaryTablet, false) + // We call the broadcast twice to ensure that the change has been processed by the keyspace event watcher. + // The second broadcast call is blocking until the first one has been processed. hc.Broadcast(primaryTablet) + hc.Broadcast(primaryTablet) + + require.Len(t, tg.hc.GetHealthyTabletStats(target), 0, "GetHealthyTabletStats has tablets even though it shouldn't") + _, isNotServing := tg.kev.PrimaryIsNotServing(target) + require.True(t, isNotServing) // add a result to the sandbox connection of the new primary sbcReplica.SetResults([]*sqltypes.Result{sqlResult1}) @@ -197,8 +204,6 @@ func TestGatewayBufferingWhileReparenting(t *testing.T) { queryChan <- struct{}{} }() - require.Len(t, tg.hc.GetHealthyTabletStats(target), 0, "GetHealthyTabletStats has tablets even though it shouldn't") - // set the serving type for the new primary tablet true and broadcast it so that the buffering code registers this change // this should stop the buffering and the query executed in the go routine should work. This should be done with some delay so // that we know that the query was buffered