239 lines
		
	
	
		
			7.5 KiB
		
	
	
	
		
			YAML
		
	
	
	
	
	
			
		
		
	
	
			239 lines
		
	
	
		
			7.5 KiB
		
	
	
	
		
			YAML
		
	
	
	
	
	
| description: "insertOne-dots_and_dollars"
 | |
| 
 | |
| schemaVersion: "1.0"
 | |
| 
 | |
| createEntities:
 | |
|   - client:
 | |
|       id: &client0 client0
 | |
|       observeEvents: [ commandStartedEvent ]
 | |
|   - database:
 | |
|       id: &database0 database0
 | |
|       client: *client0
 | |
|       databaseName: &database0Name crud-tests
 | |
|   - collection:
 | |
|       id: &collection0 collection0
 | |
|       database: *database0
 | |
|       collectionName: &collection0Name coll0
 | |
|   - collection:
 | |
|       id: &collection1 collection1
 | |
|       database: *database0
 | |
|       collectionName: &collection1Name coll1
 | |
|       collectionOptions:
 | |
|         writeConcern: { w: 0 }
 | |
| 
 | |
| initialData: &initialData
 | |
|   - collectionName: *collection0Name
 | |
|     databaseName: *database0Name
 | |
|     documents: []
 | |
| 
 | |
| tests:
 | |
|   - description: "Inserting document with top-level dollar-prefixed key on 5.0+ server"
 | |
|     runOnRequirements:
 | |
|       - minServerVersion: "5.0"
 | |
|     operations:
 | |
|       - name: insertOne
 | |
|         object: *collection0
 | |
|         arguments:
 | |
|           document: &dollarPrefixedKey { _id: 1, $a: 1 }
 | |
|         expectResult: &insertResult
 | |
|           # InsertOneResult is optional because all of its fields are optional
 | |
|           $$unsetOrMatches: { insertedId: { $$unsetOrMatches: 1 } }
 | |
|     expectEvents: &expectEventsDollarPrefixedKey
 | |
|       - client: *client0
 | |
|         events:
 | |
|           - commandStartedEvent:
 | |
|               command:
 | |
|                 insert: *collection0Name
 | |
|                 documents:
 | |
|                   - *dollarPrefixedKey
 | |
|     outcome:
 | |
|       - collectionName: *collection0Name
 | |
|         databaseName: *database0Name
 | |
|         documents:
 | |
|           - *dollarPrefixedKey
 | |
| 
 | |
|   - description: "Inserting document with top-level dollar-prefixed key on pre-5.0 server yields server-side error"
 | |
|     runOnRequirements:
 | |
|       - maxServerVersion: "4.99"
 | |
|     operations:
 | |
|       - name: insertOne
 | |
|         object: *collection0
 | |
|         arguments:
 | |
|           document: *dollarPrefixedKey
 | |
|         expectError:
 | |
|           isClientError: false
 | |
|     expectEvents: *expectEventsDollarPrefixedKey
 | |
|     outcome: *initialData
 | |
| 
 | |
|   - description: "Inserting document with top-level dotted key"
 | |
|     operations:
 | |
|       - name: insertOne
 | |
|         object: *collection0
 | |
|         arguments:
 | |
|           document: &dottedKey { _id: 1, a.b: 1 }
 | |
|         expectResult: *insertResult
 | |
|     expectEvents:
 | |
|       - client: *client0
 | |
|         events:
 | |
|           - commandStartedEvent:
 | |
|               command:
 | |
|                 insert: *collection0Name
 | |
|                 documents:
 | |
|                   - *dottedKey
 | |
|     outcome:
 | |
|       - collectionName: *collection0Name
 | |
|         databaseName: *database0Name
 | |
|         documents:
 | |
|           - *dottedKey
 | |
| 
 | |
|   - description: "Inserting document with dollar-prefixed key in embedded doc"
 | |
|     operations:
 | |
|       - name: insertOne
 | |
|         object: *collection0
 | |
|         arguments:
 | |
|           document: &dollarPrefixedKeyInEmbedded { _id: 1, a: { $b: 1 } }
 | |
|         expectResult: *insertResult
 | |
|     expectEvents:
 | |
|       - client: *client0
 | |
|         events:
 | |
|           - commandStartedEvent:
 | |
|               command:
 | |
|                 insert: *collection0Name
 | |
|                 documents:
 | |
|                   - *dollarPrefixedKeyInEmbedded
 | |
|     outcome:
 | |
|       - collectionName: *collection0Name
 | |
|         databaseName: *database0Name
 | |
|         documents:
 | |
|           - *dollarPrefixedKeyInEmbedded
 | |
| 
 | |
|   - description: "Inserting document with dotted key in embedded doc"
 | |
|     operations:
 | |
|       - name: insertOne
 | |
|         object: *collection0
 | |
|         arguments:
 | |
|           document: &dottedKeyInEmbedded { _id: 1, a: { b.c: 1 } }
 | |
|         expectResult: *insertResult
 | |
|     expectEvents:
 | |
|       - client: *client0
 | |
|         events:
 | |
|           - commandStartedEvent:
 | |
|               command:
 | |
|                 insert: *collection0Name
 | |
|                 documents:
 | |
|                   - *dottedKeyInEmbedded
 | |
|     outcome:
 | |
|       - collectionName: *collection0Name
 | |
|         databaseName: *database0Name
 | |
|         documents:
 | |
|           - *dottedKeyInEmbedded
 | |
| 
 | |
|   - description: "Inserting document with dollar-prefixed key in _id yields server-side error"
 | |
|     # Note: 5.0+ did not remove restrictions on dollar-prefixed keys in _id documents
 | |
|     operations:
 | |
|       - name: insertOne
 | |
|         object: *collection0
 | |
|         arguments:
 | |
|           document: &dollarPrefixedKeyInId { _id: { $a: 1 } }
 | |
|         expectError:
 | |
|           isClientError: false
 | |
|     expectEvents:
 | |
|       - client: *client0
 | |
|         events:
 | |
|           - commandStartedEvent:
 | |
|               command:
 | |
|                 insert: *collection0Name
 | |
|                 documents:
 | |
|                   - *dollarPrefixedKeyInId
 | |
|     outcome: *initialData
 | |
| 
 | |
|   - description: "Inserting document with dotted key in _id on 3.6+ server"
 | |
|     runOnRequirements:
 | |
|       - minServerVersion: "3.6"
 | |
|     operations:
 | |
|       - name: insertOne
 | |
|         object: *collection0
 | |
|         arguments:
 | |
|           document: &dottedKeyInId { _id: { a.b: 1 } }
 | |
|         expectResult:
 | |
|           # InsertOneResult is optional because all of its fields are optional
 | |
|           $$unsetOrMatches: { insertedId: { $$unsetOrMatches: { a.b: 1 } } }
 | |
|     expectEvents: &expectEventsDottedKeyInId
 | |
|       - client: *client0
 | |
|         events:
 | |
|           - commandStartedEvent:
 | |
|               command:
 | |
|                 insert: *collection0Name
 | |
|                 documents:
 | |
|                   - *dottedKeyInId
 | |
|     outcome:
 | |
|       - collectionName: *collection0Name
 | |
|         databaseName: *database0Name
 | |
|         documents:
 | |
|           - *dottedKeyInId
 | |
| 
 | |
|   - description: "Inserting document with dotted key in _id on pre-3.6 server yields server-side error"
 | |
|     runOnRequirements:
 | |
|       - maxServerVersion: "3.4.99"
 | |
|     operations:
 | |
|       - name: insertOne
 | |
|         object: *collection0
 | |
|         arguments:
 | |
|           document: *dottedKeyInId
 | |
|         expectError:
 | |
|           isClientError: false
 | |
|     expectEvents: *expectEventsDottedKeyInId
 | |
|     outcome: *initialData
 | |
| 
 | |
|   - description: "Inserting document with DBRef-like keys"
 | |
|     operations:
 | |
|       - name: insertOne
 | |
|         object: *collection0
 | |
|         arguments:
 | |
|           # Note: an incomplete DBRef document may cause issues loading the test
 | |
|           # file with an Extended JSON parser, since the presence of one DBRef
 | |
|           # key may cause the parser to require others and/or enforce expected
 | |
|           # types (e.g. $ref and $db must be strings).
 | |
|           #
 | |
|           # Using "$db" here works for libmongoc so long as it's a string type;
 | |
|           # however, neither $ref nor $id would be accepted on their own.
 | |
|           #
 | |
|           # See https://github.com/mongodb/specifications/blob/master/source/extended-json.rst#parsers
 | |
|           document: &dbrefLikeKey { _id: 1, a: { $db: "foo" } }
 | |
|         expectResult: *insertResult
 | |
|     expectEvents:
 | |
|       - client: *client0
 | |
|         events:
 | |
|           - commandStartedEvent:
 | |
|               command:
 | |
|                 insert: *collection0Name
 | |
|                 documents:
 | |
|                   - *dbrefLikeKey
 | |
|     outcome:
 | |
|       - collectionName: *collection0Name
 | |
|         databaseName: *database0Name
 | |
|         documents:
 | |
|           - *dbrefLikeKey
 | |
| 
 | |
|   - description: "Unacknowledged write using dollar-prefixed or dotted keys may be silently rejected on pre-5.0 server"
 | |
|     runOnRequirements:
 | |
|       - maxServerVersion: "4.99"
 | |
|     operations:
 | |
|       - name: insertOne
 | |
|         object: *collection1
 | |
|         arguments:
 | |
|           document: *dollarPrefixedKeyInId
 | |
|         expectResult:
 | |
|           # InsertOneResult is optional because all of its fields are optional
 | |
|           $$unsetOrMatches: { acknowledged: { $$unsetOrMatches: false } }
 | |
|     expectEvents:
 | |
|       - client: *client0
 | |
|         events:
 | |
|           - commandStartedEvent:
 | |
|               command:
 | |
|                 insert: *collection1Name
 | |
|                 documents:
 | |
|                   - *dollarPrefixedKeyInId
 | |
|                 writeConcern: { w: 0 }
 | |
|     outcome: *initialData
 |