Skip to content

Commit

Permalink
sql: fix flaky TestLeaseRenewedPeriodically
Browse files Browse the repository at this point in the history
I changed GossipUpdateEvent as well which is strictly not needed
but there is a chance without it there will continue to be
some flakiness.

This fix essentially moves the check for release counts
further up before lease acquisition. This fixes a race
where after lease acquisition the periodic timer would
fire, acquire/release some leases.

fixes #28771

Release note: None
  • Loading branch information
vivekmenezes committed Aug 31, 2018
1 parent 5375efa commit e91f931
Show file tree
Hide file tree
Showing 3 changed files with 20 additions and 12 deletions.
9 changes: 6 additions & 3 deletions pkg/sql/lease.go
Original file line number Diff line number Diff line change
Expand Up @@ -1168,8 +1168,9 @@ var _ base.ModuleTestingKnobs = &LeaseStoreTestingKnobs{}
type LeaseManagerTestingKnobs struct {
// A callback called when a gossip update is received, before the leases are
// refreshed. Careful when using this to block for too long - you can block
// all the gossip users in the system.
GossipUpdateEvent func(config.SystemConfig)
// all the gossip users in the system. If it returns an error the gossip
// update is ignored.
GossipUpdateEvent func(config.SystemConfig) error
// A callback called after the leases are refreshed as a result of a gossip update.
TestingLeasesRefreshedEvent func(config.SystemConfig)

Expand Down Expand Up @@ -1627,7 +1628,9 @@ func (m *LeaseManager) RefreshLeases(s *stop.Stopper, db *client.DB, g *gossip.G
case <-gossipUpdateC:
cfg, _ := g.GetSystemConfig()
if m.testingKnobs.GossipUpdateEvent != nil {
m.testingKnobs.GossipUpdateEvent(cfg)
if err := m.testingKnobs.GossipUpdateEvent(cfg); err != nil {
break
}
}
// Read all tables and their versions
if log.V(2) {
Expand Down
3 changes: 2 additions & 1 deletion pkg/sql/lease_internal_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -127,9 +127,10 @@ func TestPurgeOldVersions(t *testing.T) {
serverParams := base.TestServerArgs{
Knobs: base.TestingKnobs{
SQLLeaseManager: &LeaseManagerTestingKnobs{
GossipUpdateEvent: func(cfg config.SystemConfig) {
GossipUpdateEvent: func(cfg config.SystemConfig) error {
gossipSem <- struct{}{}
<-gossipSem
return nil
},
},
},
Expand Down
20 changes: 12 additions & 8 deletions pkg/sql/lease_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -1591,6 +1591,9 @@ func TestLeaseRenewedPeriodically(testingT *testing.T) {
atomic.AddInt32(&testAcquisitionBlockCount, 1)
},
},
GossipUpdateEvent: func(cfg config.SystemConfig) error {
return errors.Errorf("ignore gossip update")
},
},
}
params.LeaseManagerConfig = base.NewLeaseManagerConfig()
Expand Down Expand Up @@ -1620,6 +1623,15 @@ CREATE TABLE t.test2 ();

atomic.StoreInt32(&testAcquisitionBlockCount, 0)

numReleasedLeases := func() int {
mu.Lock()
defer mu.Unlock()
return len(releasedIDs)
}
if count := numReleasedLeases(); count != 0 {
t.Fatalf("expected no leases to be releases, released %d", count)
}

// Acquire a lease on test1 by name.
ts1, _, err := t.node(1).AcquireByName(ctx, t.server.Clock().Now(), dbID, "test1")
if err != nil {
Expand All @@ -1644,14 +1656,6 @@ CREATE TABLE t.test2 ();

// From now on henceforth do not acquire a lease, so any renewals can only
// happen through the periodic lease renewal mechanism.
numReleasedLeases := func() int {
mu.Lock()
defer mu.Unlock()
return len(releasedIDs)
}
if count := numReleasedLeases(); count != 0 {
t.Fatalf("expected no leases to be releases, released %d", count)
}

// Reset testAcquisitionBlockCount as the first acqusitions will always block.
atomic.StoreInt32(&testAcquisitionBlockCount, 0)
Expand Down

0 comments on commit e91f931

Please sign in to comment.