Skip to content

Commit

Permalink
metamorphic: add MVCC{CheckFor,}AcquireLock operations
Browse files Browse the repository at this point in the history
This change adds two new operations to the MVCC metamorphic
testing package that were added in cockroachdb#110323. We check for
determinism in the storage package by adding these operations
to the metamorphic tests as well.

Fixes cockroachdb#109650.

Epic: none

Release note: None
  • Loading branch information
itsbilal committed Nov 2, 2023
1 parent 4dad7f2 commit 0573d37
Show file tree
Hide file tree
Showing 2 changed files with 109 additions and 0 deletions.
1 change: 1 addition & 0 deletions pkg/storage/metamorphic/BUILD.bazel
Original file line number Diff line number Diff line change
Expand Up @@ -16,6 +16,7 @@ go_library(
"//pkg/base",
"//pkg/keys",
"//pkg/kv/kvpb",
"//pkg/kv/kvserver/concurrency/lock",
"//pkg/roachpb",
"//pkg/settings/cluster",
"//pkg/storage",
Expand Down
108 changes: 108 additions & 0 deletions pkg/storage/metamorphic/operations.go
Original file line number Diff line number Diff line change
Expand Up @@ -21,6 +21,7 @@ import (

"github.com/cockroachdb/cockroach/pkg/keys"
"github.com/cockroachdb/cockroach/pkg/kv/kvpb"
"github.com/cockroachdb/cockroach/pkg/kv/kvserver/concurrency/lock"
"github.com/cockroachdb/cockroach/pkg/roachpb"
"github.com/cockroachdb/cockroach/pkg/storage"
"github.com/cockroachdb/cockroach/pkg/storage/enginepb"
Expand Down Expand Up @@ -280,6 +281,56 @@ func (m mvccInitPutOp) run(ctx context.Context) string {
return "ok"
}

type mvccCheckForAcquireLockOp struct {
m *metaTestRunner
writer readWriterID
key roachpb.Key
txn txnID
strength lock.Strength
}

func (m mvccCheckForAcquireLockOp) run(ctx context.Context) string {
txn := m.m.getTxn(m.txn)
txn.Sequence++
writer := m.m.getReadWriter(m.writer)

err := storage.MVCCCheckForAcquireLock(ctx, writer, txn, m.strength, m.key, 64)
if err != nil {
return fmt.Sprintf("error: %s", err)
}

// Update the txn's lock spans to account for this intent being written.
return "ok"
}

type mvccAcquireLockOp struct {
m *metaTestRunner
writer readWriterID
key roachpb.Key
txn txnID
strength lock.Strength
}

func (m mvccAcquireLockOp) run(ctx context.Context) string {
txn := m.m.getTxn(m.txn)
txn.Sequence++
writer := m.m.getReadWriter(m.writer)

err := storage.MVCCAcquireLock(ctx, writer, txn, m.strength, m.key, nil, 64)
if err != nil {
if writeTooOldErr := (*kvpb.WriteTooOldError)(nil); errors.As(err, &writeTooOldErr) {
txn.WriteTimestamp.Forward(writeTooOldErr.ActualTimestamp)
// Update the txn's lock spans to account for this intent being written.
addKeyToLockSpans(txn, m.key)
}
return fmt.Sprintf("error: %s", err)
}

// Update the txn's lock spans to account for this intent being written.
addKeyToLockSpans(txn, m.key)
return "ok"
}

type mvccDeleteRangeOp struct {
m *metaTestRunner
writer readWriterID
Expand Down Expand Up @@ -938,6 +989,63 @@ var opGenerators = []opGenerator{
},
weight: 50,
},
{
name: "mvcc_acquire_lock",
generate: func(ctx context.Context, m *metaTestRunner, args ...string) mvccOp {
writer := readWriterID(args[0])
txn := txnID(args[1])
key := m.txnKeyGenerator.parse(args[2])
strength := lock.Shared
if m.floatGenerator.parse(args[3]) < 0.5 {
strength = lock.Exclusive
}

// Track this write in the txn generator. This ensures the batch will be
// committed before the transaction is committed
m.txnGenerator.trackTransactionalWrite(writer, txn, key.Key, nil)
return &mvccAcquireLockOp{
m: m,
writer: writer,
key: key.Key,
txn: txn,
strength: strength,
}
},
operands: []operandType{
operandReadWriter,
operandTransaction,
operandMVCCKey,
operandFloat,
},
weight: 50,
},
{
name: "mvcc_check_for_acquire_lock",
generate: func(ctx context.Context, m *metaTestRunner, args ...string) mvccOp {
writer := readWriterID(args[0])
txn := txnID(args[1])
key := m.txnKeyGenerator.parse(args[2])
strength := lock.Shared
if m.floatGenerator.parse(args[3]) < 0.5 {
strength = lock.Exclusive
}

return &mvccCheckForAcquireLockOp{
m: m,
writer: writer,
key: key.Key,
txn: txn,
strength: strength,
}
},
operands: []operandType{
operandReadWriter,
operandTransaction,
operandMVCCKey,
operandFloat,
},
weight: 50,
},
{
name: "mvcc_delete_range",
generate: func(ctx context.Context, m *metaTestRunner, args ...string) mvccOp {
Expand Down

0 comments on commit 0573d37

Please sign in to comment.