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
|
description: "Transaction handling"
schemaVersion: "1.1"
runOnRequirements:
- minServerVersion: "4.9"
topologies: [ replicaset, sharded-replicaset, load-balanced ]
createEntities:
- client:
id: &client client
observeEvents:
- commandStartedEvent
serverApi:
version: "1"
- database:
id: &database database
client: *client
databaseName: &databaseName versioned-api-tests
- collection:
id: &collection collection
database: *database
collectionName: &collectionName test
- session:
id: &session session
client: *client
_yamlAnchors:
versions:
- &expectedApiVersion
apiVersion: "1"
apiStrict: { $$unsetOrMatches: false }
apiDeprecationErrors: { $$unsetOrMatches: false }
initialData:
- collectionName: *collectionName
databaseName: *databaseName
documents:
- { _id: 1, x: 11 }
- { _id: 2, x: 22 }
- { _id: 3, x: 33 }
- { _id: 4, x: 44 }
- { _id: 5, x: 55 }
tests:
- description: "All commands in a transaction declare an API version"
runOnRequirements:
- topologies: [ replicaset, sharded-replicaset, load-balanced ]
operations:
- name: startTransaction
object: *session
- name: insertOne
object: *collection
arguments:
session: *session
document: { _id: 6, x: 66 }
expectResult: { $$unsetOrMatches: { insertedId: { $$unsetOrMatches: 6 } } }
- name: insertOne
object: *collection
arguments:
session: *session
document: { _id: 7, x: 77 }
expectResult: { $$unsetOrMatches: { insertedId: { $$unsetOrMatches: 7 } } }
- name: commitTransaction
object: *session
expectEvents:
- client: *client
events:
- commandStartedEvent:
command:
insert: *collectionName
documents: [ { _id: 6, x: 66 } ]
lsid: { $$sessionLsid: *session }
startTransaction: true
<<: *expectedApiVersion
- commandStartedEvent:
command:
insert: *collectionName
documents: [ { _id: 7, x: 77 } ]
lsid: { $$sessionLsid: *session }
<<: *expectedApiVersion
- commandStartedEvent:
command:
commitTransaction: 1
lsid: { $$sessionLsid: *session }
<<: *expectedApiVersion
- description: "abortTransaction includes an API version"
runOnRequirements:
- topologies: [ replicaset, sharded-replicaset, load-balanced ]
operations:
- name: startTransaction
object: *session
- name: insertOne
object: *collection
arguments:
session: *session
document: { _id: 6, x: 66 }
expectResult: { $$unsetOrMatches: { insertedId: { $$unsetOrMatches: 6 } } }
- name: insertOne
object: *collection
arguments:
session: *session
document: { _id: 7, x: 77 }
expectResult: { $$unsetOrMatches: { insertedId: { $$unsetOrMatches: 7 } } }
- name: abortTransaction
object: *session
expectEvents:
- client: *client
events:
- commandStartedEvent:
command:
insert: *collectionName
documents: [ { _id: 6, x: 66 } ]
lsid: { $$sessionLsid: *session }
startTransaction: true
<<: *expectedApiVersion
- commandStartedEvent:
command:
insert: *collectionName
documents: [ { _id: 7, x: 77 } ]
lsid: { $$sessionLsid: *session }
<<: *expectedApiVersion
- commandStartedEvent:
command:
abortTransaction: 1
lsid: { $$sessionLsid: *session }
<<: *expectedApiVersion
|