1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170
|
runOn:
-
minServerVersion: "4.0"
topology: ["replicaset"]
-
minServerVersion: "4.1.8"
topology: ["sharded"]
database_name: &database_name "withTransaction-tests"
collection_name: &collection_name "test"
data: []
tests:
-
# Session state will be ABORTED when callback returns to withTransaction
description: withTransaction succeeds if callback aborts
useMultipleMongoses: true
operations:
-
name: withTransaction
object: session0
arguments:
callback:
operations:
-
name: insertOne
object: collection
arguments:
session: session0
document: { _id: 1 }
result:
insertedId: 1
-
name: abortTransaction
object: session0
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:
abortTransaction: 1
lsid: session0
txnNumber: { $numberLong: "1" }
autocommit: false
# omitted fields
readConcern: ~
startTransaction: ~
writeConcern: ~
command_name: abortTransaction
database_name: admin
outcome:
collection:
data: []
-
# Session state will be ABORTED when callback returns to withTransaction
description: withTransaction succeeds if callback aborts with no ops
useMultipleMongoses: true
operations:
-
name: withTransaction
object: session0
arguments:
callback:
operations:
-
name: abortTransaction
object: session0
expectations: []
outcome:
collection:
data: []
-
# Session state will be NO_TXN when callback returns to withTransaction
description: withTransaction still succeeds if callback aborts and runs extra op
useMultipleMongoses: true
operations:
-
name: withTransaction
object: session0
arguments:
callback:
operations:
-
name: insertOne
object: collection
arguments:
session: session0
document: { _id: 1 }
result:
insertedId: 1
-
name: abortTransaction
object: session0
-
name: insertOne
object: collection
arguments:
session: session0
document: { _id: 2 }
result:
insertedId: 2
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:
abortTransaction: 1
lsid: session0
txnNumber: { $numberLong: "1" }
autocommit: false
# omitted fields
readConcern: ~
startTransaction: ~
writeConcern: ~
command_name: abortTransaction
database_name: admin
-
command_started_event:
command:
# This test is agnostic about retryWrites, so we do not assert the
# txnNumber. If retryWrites=true, the txnNumber will be incremented
# from the value used in the previous transaction; otherwise, the
# field will not be present at all.
insert: *collection_name
documents:
- { _id: 2 }
ordered: true
lsid: session0
# omitted fields
autocommit: ~
readConcern: ~
startTransaction: ~
writeConcern: ~
command_name: insert
database_name: *database_name
outcome:
collection:
data:
- { _id: 2 }
|