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
|
description: "findOneAndUpdate-errorResponse"
schemaVersion: "1.12"
createEntities:
- client:
id: &client0 client0
- database:
id: &database0 database0
client: *client0
databaseName: &database0Name crud-tests
- collection:
id: &collection0 collection0
database: *database0
collectionName: &collection0Name test
initialData: &initialData
- collectionName: *collection0Name
databaseName: *database0Name
documents:
- { _id: 1, x: "foo" }
tests:
- description: "findOneAndUpdate DuplicateKey error is accessible"
runOnRequirements:
- minServerVersion: "4.2" # SERVER-37124
operations:
- name: createIndex
object: *collection0
arguments:
keys: { x: 1 }
unique: true
- name: findOneAndUpdate
object: *collection0
arguments:
filter: { _id: 2 }
update: { $set: { x: "foo" } }
upsert: true
expectError:
errorCode: 11000 # DuplicateKey
errorResponse:
keyPattern: { x: 1 }
keyValue: { x: "foo" }
- description: "findOneAndUpdate document validation errInfo is accessible"
runOnRequirements:
- minServerVersion: "5.0"
operations:
- name: modifyCollection
object: *database0
arguments:
collection: *collection0Name
validator:
x: { $type: "string" }
- name: findOneAndUpdate
object: *collection0
arguments:
filter: { _id: 1 }
update: { $set: { x: 1 } }
expectError:
errorCode: 121 # DocumentValidationFailure
errorResponse:
# Avoid asserting the exact contents of errInfo as it may vary by
# server version. Likewise, this is why drivers do not model the
# document. The following is sufficient to test that validation
# details are accessible. See SERVER-20547 for more context.
errInfo:
failingDocumentId: 1
details: { $$type: "object" }
|