From 84cc33ffad04e41a286db212c038c1af7beb3f29 Mon Sep 17 00:00:00 2001 From: Austen McClernon Date: Fri, 6 Dec 2024 18:26:19 -0500 Subject: [PATCH] kvserver: use leader leases in TestFlowControlSendQueueRangeSplitMerge Use leader leases in this test, to avoid the leader changing while the test doesn't expect it. Also, to further test leader leases. Part of: #132614 Release note: None --- pkg/kv/kvserver/flow_control_integration_test.go | 10 ++++++++++ 1 file changed, 10 insertions(+) diff --git a/pkg/kv/kvserver/flow_control_integration_test.go b/pkg/kv/kvserver/flow_control_integration_test.go index a1deeb404a14..18a21ea459d7 100644 --- a/pkg/kv/kvserver/flow_control_integration_test.go +++ b/pkg/kv/kvserver/flow_control_integration_test.go @@ -5691,6 +5691,13 @@ func TestFlowControlSendQueueRangeSplitMerge(t *testing.T) { // lower (8 and 16 MiB default). kvflowcontrol.ElasticTokensPerStream.Override(ctx, &settings.SV, 2<<20) kvflowcontrol.RegularTokensPerStream.Override(ctx, &settings.SV, 4<<20) + // This test doesn't want leadership changing hands, and leader leases (by + // virtue of raft fortification) help ensure this. Override to disable any + // metamorphosis. + kvserver.OverrideDefaultLeaseType(ctx, &settings.SV, roachpb.LeaseLeader) + // Using a manual clock here ensures that StoreLiveness support, once + // established, never expires. By extension, leadership should stay sticky. + manualClock := hlc.NewHybridManualClock() disableWorkQueueGrantingServers := make([]atomic.Bool, numNodes) setTokenReturnEnabled := func(enabled bool, serverIdxs ...int) { @@ -5705,6 +5712,9 @@ func TestFlowControlSendQueueRangeSplitMerge(t *testing.T) { argsPerServer[i] = base.TestServerArgs{ Settings: settings, Knobs: base.TestingKnobs{ + Server: &server.TestingKnobs{ + WallClock: manualClock, + }, Store: &kvserver.StoreTestingKnobs{ FlowControlTestingKnobs: &kvflowcontrol.TestingKnobs{ UseOnlyForScratchRanges: true,