bson/testdata/convenient-transactions/commit-transienttransactionerror.yml
2025-03-17 20:58:26 +01:00

176 lines
5.4 KiB
YAML

runOn:
-
minServerVersion: "4.0"
topology: ["replicaset"]
-
minServerVersion: "4.1.8"
topology: ["sharded"]
database_name: &database_name "withTransaction-tests"
collection_name: &collection_name "test"
data: []
# These tests use error codes where the TransientTransactionError label will be
# applied to the error response for commitTransaction. This will cause the
# entire transaction to be retried instead of commitTransaction.
#
# See: https://github.com/mongodb/mongo/blob/r4.1.6/src/mongo/db/handle_request_response.cpp
tests:
-
description: transaction is retried after commitTransaction TransientTransactionError (LockTimeout)
failPoint:
configureFailPoint: failCommand
mode: { times: 2 }
data:
failCommands: ["commitTransaction"]
errorCode: 24 # LockTimeout
closeConnection: false
operations: &operations
-
name: withTransaction
object: session0
arguments:
callback:
operations:
-
name: insertOne
object: collection
arguments:
session: session0
document: { _id: 1 }
result:
insertedId: 1
expectations: &expectations
-
command_started_event:
command:
insert: *collection_name
documents:
- { _id: 1 }
ordered: true
lsid: session0
txnNumber: { $numberLong: "1" }
startTransaction: true
autocommit: false
# omitted fields
readConcern: ~
writeConcern: ~
command_name: insert
database_name: *database_name
-
command_started_event:
command:
commitTransaction: 1
lsid: session0
txnNumber: { $numberLong: "1" }
autocommit: false
# omitted fields
readConcern: ~
startTransaction: ~
writeConcern: ~
command_name: commitTransaction
database_name: admin
-
command_started_event:
command:
insert: *collection_name
documents:
- { _id: 1 }
ordered: true
lsid: session0
# second transaction will be causally consistent with the first
readConcern: { afterClusterTime: 42 }
# txnNumber is incremented when retrying the transaction
txnNumber: { $numberLong: "2" }
startTransaction: true
autocommit: false
# omitted fields
writeConcern: ~
command_name: insert
database_name: *database_name
-
command_started_event:
command:
commitTransaction: 1
lsid: session0
txnNumber: { $numberLong: "2" }
autocommit: false
# omitted fields
readConcern: ~
startTransaction: ~
writeConcern: ~
command_name: commitTransaction
database_name: admin
-
command_started_event:
command:
insert: *collection_name
documents:
- { _id: 1 }
ordered: true
lsid: session0
# third transaction will be causally consistent with the second
readConcern: { afterClusterTime: 42 }
# txnNumber is incremented when retrying the transaction
txnNumber: { $numberLong: "3" }
startTransaction: true
autocommit: false
# omitted fields
writeConcern: ~
command_name: insert
database_name: *database_name
-
command_started_event:
command:
commitTransaction: 1
lsid: session0
txnNumber: { $numberLong: "3" }
autocommit: false
# omitted fields
readConcern: ~
startTransaction: ~
writeConcern: ~
command_name: commitTransaction
database_name: admin
outcome: &outcome
collection:
data:
- { _id: 1 }
-
description: transaction is retried after commitTransaction TransientTransactionError (WriteConflict)
failPoint:
configureFailPoint: failCommand
mode: { times: 2 }
data:
failCommands: ["commitTransaction"]
errorCode: 112 # WriteConflict
closeConnection: false
operations: *operations
expectations: *expectations
outcome: *outcome
-
description: transaction is retried after commitTransaction TransientTransactionError (SnapshotUnavailable)
failPoint:
configureFailPoint: failCommand
mode: { times: 2 }
data:
failCommands: ["commitTransaction"]
errorCode: 246 # SnapshotUnavailable
closeConnection: false
operations: *operations
expectations: *expectations
outcome: *outcome
-
description: transaction is retried after commitTransaction TransientTransactionError (NoSuchTransaction)
failPoint:
configureFailPoint: failCommand
mode: { times: 2 }
data:
failCommands: ["commitTransaction"]
errorCode: 251 # NoSuchTransaction
closeConnection: false
operations: *operations
expectations: *expectations
outcome: *outcome