// assertTS is a helper function for layeredIntervalTestCase // validators. It queries the timestamp cache for the given keys and // reports a test error if it doesn't match the given timestamp and // transaction ID. func assertTS( t *testing.T, tc *timestampCache, start, end roachpb.Key, expectedTS hlc.Timestamp, expectedTxnID *uuid.UUID, ) { var keys string if len(end) == 0 { keys = fmt.Sprintf("%q", start) } else { keys = fmt.Sprintf("%q-%q", start, end) } ts, txnID, _ := tc.GetMaxRead(start, end) if !ts.Equal(expectedTS) { t.Errorf("expected %s to have timestamp %v, found %v", keys, expectedTS, ts) } if expectedTxnID == nil { if txnID != nil { t.Errorf("expected %s to have no txn id, but found %s", keys, txnID.Short()) } } else { if txnID == nil { t.Errorf("expected %s to have txn id %s, but found nil", keys, expectedTxnID.Short()) } else if *txnID != *expectedTxnID { t.Errorf("expected %s to have txn id %s, but found %s", keys, expectedTxnID.Short(), txnID.Short()) } } }