Skip to content

Commit

Permalink
Merge #40607
Browse files Browse the repository at this point in the history
40607: storage: fix flake in TestTxnRecordLifecycleTransitions r=nvanbenschoten a=nvanbenschoten

Fixes #40537.

The test was specifically not restarting transactions at the push timestamp (for the outdated epoch) cases, but the broken subtest `TestTxnRecordLifecycleTransitions/push_transaction_(abort)_after_end_transaction_(stage)_with_outdated_epoch` was expecting its timestamp to be equal to the push timestamp.

The second commit ensures that we're not accidentally relying on the fact that `runTs` was usually one logical tick above `txn.Timestamp` by manually incrementing the clock. With this change, the flake fixed in the previous commit fails reliably.

The `s/clone.Restart(-1, 0, now.Add(0, 1))/clone.Restart(-1, 0, now)/` is just cleanup.

Co-authored-by: Nathan VanBenschoten <[email protected]>
  • Loading branch information
craig[bot] and nvanbenschoten committed Sep 10, 2019
2 parents 9834a49 + fac112b commit 1b75c93
Showing 1 changed file with 15 additions and 13 deletions.
28 changes: 15 additions & 13 deletions pkg/storage/replica_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -10551,14 +10551,14 @@ func TestTxnRecordLifecycleTransitions(t *testing.T) {
},
run: func(txn *roachpb.Transaction, now hlc.Timestamp) error {
clone := txn.Clone()
clone.Timestamp.Forward(now)
clone.Timestamp = clone.Timestamp.Add(0, 1)
pt := pushTxnArgs(pusher, clone, roachpb.PUSH_ABORT)
return sendWrappedWithErr(roachpb.Header{}, &pt)
},
expTxn: func(txn *roachpb.Transaction, pushTs hlc.Timestamp) roachpb.TransactionRecord {
record := txnWithStatus(roachpb.ABORTED)(txn, pushTs)
record.Timestamp.Forward(pushTs)
record.LastHeartbeat.Forward(pushTs)
record.Timestamp = record.Timestamp.Add(0, 1)
record.LastHeartbeat = record.LastHeartbeat.Add(0, 1)
record.Priority = pusher.Priority - 1
return record
},
Expand Down Expand Up @@ -10608,7 +10608,7 @@ func TestTxnRecordLifecycleTransitions(t *testing.T) {
expTxn: func(txn *roachpb.Transaction, pushTs hlc.Timestamp) roachpb.TransactionRecord {
record := txnWithStatus(roachpb.ABORTED)(txn, pushTs)
record.Epoch = txn.Epoch + 1
record.Timestamp.Forward(pushTs)
record.Timestamp = record.Timestamp.Add(0, 1)
record.LastHeartbeat = record.LastHeartbeat.Add(0, 1)
record.Priority = pusher.Priority - 1
return record
Expand Down Expand Up @@ -10642,7 +10642,7 @@ func TestTxnRecordLifecycleTransitions(t *testing.T) {
},
{
name: "heartbeat transaction with epoch bump after end transaction (abort)",
setup: func(txn *roachpb.Transaction, now hlc.Timestamp) error {
setup: func(txn *roachpb.Transaction, _ hlc.Timestamp) error {
et, etH := endTxnArgs(txn, false /* commit */)
return sendWrappedWithErr(etH, &et)
},
Expand All @@ -10652,7 +10652,7 @@ func TestTxnRecordLifecycleTransitions(t *testing.T) {
// threshold against this timestamp instead of its minimum
// timestamp.
clone := txn.Clone()
clone.Restart(-1, 0, now.Add(0, 1))
clone.Restart(-1, 0, now)
hb, hbH := heartbeatArgs(clone, now)
return sendWrappedWithErr(hbH, &hb)
},
Expand Down Expand Up @@ -11115,7 +11115,7 @@ func TestTxnRecordLifecycleTransitions(t *testing.T) {
},
{
name: "begin transaction after push transaction (abort)",
setup: func(txn *roachpb.Transaction, now hlc.Timestamp) error {
setup: func(txn *roachpb.Transaction, _ hlc.Timestamp) error {
pt := pushTxnArgs(pusher, txn, roachpb.PUSH_ABORT)
return sendWrappedWithErr(roachpb.Header{}, &pt)
},
Expand All @@ -11128,7 +11128,7 @@ func TestTxnRecordLifecycleTransitions(t *testing.T) {
},
{
name: "heartbeat transaction after push transaction (abort)",
setup: func(txn *roachpb.Transaction, now hlc.Timestamp) error {
setup: func(txn *roachpb.Transaction, _ hlc.Timestamp) error {
pt := pushTxnArgs(pusher, txn, roachpb.PUSH_ABORT)
return sendWrappedWithErr(roachpb.Header{}, &pt)
},
Expand All @@ -11141,7 +11141,7 @@ func TestTxnRecordLifecycleTransitions(t *testing.T) {
},
{
name: "heartbeat transaction with epoch bump after push transaction (abort)",
setup: func(txn *roachpb.Transaction, now hlc.Timestamp) error {
setup: func(txn *roachpb.Transaction, _ hlc.Timestamp) error {
pt := pushTxnArgs(pusher, txn, roachpb.PUSH_ABORT)
return sendWrappedWithErr(roachpb.Header{}, &pt)
},
Expand All @@ -11151,7 +11151,7 @@ func TestTxnRecordLifecycleTransitions(t *testing.T) {
// threshold against this timestamp instead of its minimum
// timestamp.
clone := txn.Clone()
clone.Restart(-1, 0, now.Add(0, 1))
clone.Restart(-1, 0, now)
hb, hbH := heartbeatArgs(clone, now)
return sendWrappedWithErr(hbH, &hb)
},
Expand All @@ -11160,7 +11160,7 @@ func TestTxnRecordLifecycleTransitions(t *testing.T) {
},
{
name: "end transaction (stage) after push transaction (abort)",
setup: func(txn *roachpb.Transaction, now hlc.Timestamp) error {
setup: func(txn *roachpb.Transaction, _ hlc.Timestamp) error {
pt := pushTxnArgs(pusher, txn, roachpb.PUSH_ABORT)
return sendWrappedWithErr(roachpb.Header{}, &pt)
},
Expand All @@ -11174,7 +11174,7 @@ func TestTxnRecordLifecycleTransitions(t *testing.T) {
},
{
name: "end transaction (abort) after push transaction (abort)",
setup: func(txn *roachpb.Transaction, now hlc.Timestamp) error {
setup: func(txn *roachpb.Transaction, _ hlc.Timestamp) error {
pt := pushTxnArgs(pusher, txn, roachpb.PUSH_ABORT)
return sendWrappedWithErr(roachpb.Header{}, &pt)
},
Expand All @@ -11188,7 +11188,7 @@ func TestTxnRecordLifecycleTransitions(t *testing.T) {
},
{
name: "end transaction (commit) after push transaction (abort)",
setup: func(txn *roachpb.Transaction, now hlc.Timestamp) error {
setup: func(txn *roachpb.Transaction, _ hlc.Timestamp) error {
pt := pushTxnArgs(pusher, txn, roachpb.PUSH_ABORT)
return sendWrappedWithErr(roachpb.Header{}, &pt)
},
Expand Down Expand Up @@ -11512,7 +11512,9 @@ func TestTxnRecordLifecycleTransitions(t *testing.T) {
defer setTxnAutoGC(!c.disableTxnAutoGC)()

txn := newTransaction(c.name, roachpb.Key(c.name), 1, tc.Clock())
manual.Increment(99)
runTs := tc.Clock().Now()

if c.setup != nil {
if err := c.setup(txn, runTs); err != nil {
t.Fatalf("failed during test setup: %+v", err)
Expand Down

0 comments on commit 1b75c93

Please sign in to comment.