mongo 2.20.1 → 2.21.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (246) hide show
  1. checksums.yaml +4 -4
  2. data/README.md +3 -0
  3. data/Rakefile +2 -2
  4. data/lib/mongo/address.rb +22 -3
  5. data/lib/mongo/auth/aws/credentials_retriever.rb +70 -17
  6. data/lib/mongo/auth/base.rb +1 -1
  7. data/lib/mongo/bulk_write.rb +35 -2
  8. data/lib/mongo/client.rb +38 -6
  9. data/lib/mongo/client_encryption.rb +6 -3
  10. data/lib/mongo/cluster/reapers/cursor_reaper.rb +6 -1
  11. data/lib/mongo/cluster/sdam_flow.rb +20 -7
  12. data/lib/mongo/cluster.rb +14 -4
  13. data/lib/mongo/collection/helpers.rb +1 -1
  14. data/lib/mongo/collection/view/aggregation/behavior.rb +131 -0
  15. data/lib/mongo/collection/view/aggregation.rb +33 -99
  16. data/lib/mongo/collection/view/builder/aggregation.rb +1 -7
  17. data/lib/mongo/collection/view/change_stream.rb +80 -27
  18. data/lib/mongo/collection/view/iterable.rb +76 -60
  19. data/lib/mongo/collection/view/map_reduce.rb +25 -8
  20. data/lib/mongo/collection/view/readable.rb +79 -30
  21. data/lib/mongo/collection/view/writable.rb +109 -48
  22. data/lib/mongo/collection/view.rb +43 -3
  23. data/lib/mongo/collection.rb +158 -23
  24. data/lib/mongo/crypt/auto_encrypter.rb +4 -6
  25. data/lib/mongo/crypt/binding.rb +4 -4
  26. data/lib/mongo/crypt/context.rb +20 -14
  27. data/lib/mongo/crypt/encryption_io.rb +56 -26
  28. data/lib/mongo/crypt/explicit_encrypter.rb +49 -20
  29. data/lib/mongo/crypt/explicit_encryption_context.rb +17 -11
  30. data/lib/mongo/crypt/kms/azure/credentials_retriever.rb +22 -6
  31. data/lib/mongo/crypt/kms/gcp/credentials_retriever.rb +29 -4
  32. data/lib/mongo/csot_timeout_holder.rb +119 -0
  33. data/lib/mongo/cursor/kill_spec.rb +5 -2
  34. data/lib/mongo/cursor/nontailable.rb +27 -0
  35. data/lib/mongo/cursor.rb +86 -24
  36. data/lib/mongo/cursor_host.rb +82 -0
  37. data/lib/mongo/database/view.rb +81 -14
  38. data/lib/mongo/database.rb +88 -18
  39. data/lib/mongo/error/operation_failure.rb +209 -204
  40. data/lib/mongo/error/server_timeout_error.rb +12 -0
  41. data/lib/mongo/error/socket_timeout_error.rb +3 -1
  42. data/lib/mongo/error/timeout_error.rb +23 -0
  43. data/lib/mongo/error.rb +2 -0
  44. data/lib/mongo/grid/fs_bucket.rb +45 -12
  45. data/lib/mongo/grid/stream/read.rb +15 -1
  46. data/lib/mongo/grid/stream/write.rb +21 -4
  47. data/lib/mongo/index/view.rb +77 -16
  48. data/lib/mongo/operation/context.rb +40 -2
  49. data/lib/mongo/operation/create_search_indexes/op_msg.rb +2 -2
  50. data/lib/mongo/operation/delete/op_msg.rb +2 -1
  51. data/lib/mongo/operation/drop_search_index/op_msg.rb +2 -2
  52. data/lib/mongo/operation/find/op_msg.rb +45 -0
  53. data/lib/mongo/operation/get_more/op_msg.rb +33 -0
  54. data/lib/mongo/operation/insert/op_msg.rb +3 -2
  55. data/lib/mongo/operation/insert/result.rb +4 -2
  56. data/lib/mongo/operation/list_collections/result.rb +1 -1
  57. data/lib/mongo/operation/map_reduce/result.rb +1 -1
  58. data/lib/mongo/operation/op_msg_base.rb +3 -1
  59. data/lib/mongo/operation/result.rb +26 -5
  60. data/lib/mongo/operation/shared/executable.rb +12 -1
  61. data/lib/mongo/operation/shared/op_msg_executable.rb +4 -1
  62. data/lib/mongo/operation/shared/response_handling.rb +3 -3
  63. data/lib/mongo/operation/shared/sessions_supported.rb +1 -1
  64. data/lib/mongo/operation/shared/timed.rb +52 -0
  65. data/lib/mongo/operation/shared/write.rb +4 -1
  66. data/lib/mongo/operation/update/op_msg.rb +2 -1
  67. data/lib/mongo/operation/update_search_index/op_msg.rb +2 -2
  68. data/lib/mongo/operation.rb +1 -0
  69. data/lib/mongo/protocol/message.rb +1 -4
  70. data/lib/mongo/protocol/msg.rb +2 -2
  71. data/lib/mongo/retryable/read_worker.rb +69 -29
  72. data/lib/mongo/retryable/write_worker.rb +49 -18
  73. data/lib/mongo/retryable.rb +8 -2
  74. data/lib/mongo/server/connection.rb +11 -5
  75. data/lib/mongo/server/connection_base.rb +22 -2
  76. data/lib/mongo/server/connection_pool.rb +32 -14
  77. data/lib/mongo/server/description/features.rb +1 -1
  78. data/lib/mongo/server/description.rb +18 -5
  79. data/lib/mongo/server/monitor.rb +7 -4
  80. data/lib/mongo/server/pending_connection.rb +7 -3
  81. data/lib/mongo/server/{round_trip_time_averager.rb → round_trip_time_calculator.rb} +25 -7
  82. data/lib/mongo/server.rb +11 -6
  83. data/lib/mongo/server_selector/base.rb +25 -9
  84. data/lib/mongo/session.rb +78 -9
  85. data/lib/mongo/socket/ssl.rb +109 -17
  86. data/lib/mongo/socket/tcp.rb +40 -6
  87. data/lib/mongo/socket.rb +154 -25
  88. data/lib/mongo/uri/options_mapper.rb +1 -0
  89. data/lib/mongo/version.rb +1 -1
  90. data/lib/mongo.rb +1 -0
  91. data/spec/atlas/atlas_connectivity_spec.rb +4 -0
  92. data/spec/atlas/operations_spec.rb +4 -0
  93. data/spec/integration/client_side_encryption/auto_encryption_mongocryptd_spawn_spec.rb +2 -1
  94. data/spec/integration/client_side_encryption/auto_encryption_spec.rb +494 -487
  95. data/spec/integration/client_side_encryption/on_demand_aws_credentials_spec.rb +1 -1
  96. data/spec/integration/client_side_encryption/range_explicit_encryption_prose_spec.rb +66 -22
  97. data/spec/integration/client_side_operations_timeout/encryption_prose_spec.rb +131 -0
  98. data/spec/integration/connection_pool_populator_spec.rb +2 -0
  99. data/spec/integration/cursor_pinning_spec.rb +15 -60
  100. data/spec/integration/cursor_reaping_spec.rb +1 -1
  101. data/spec/integration/docs_examples_spec.rb +1 -1
  102. data/spec/integration/operation_failure_code_spec.rb +1 -1
  103. data/spec/integration/operation_failure_message_spec.rb +3 -3
  104. data/spec/integration/retryable_errors_spec.rb +2 -2
  105. data/spec/integration/sdam_error_handling_spec.rb +2 -1
  106. data/spec/integration/search_indexes_prose_spec.rb +4 -0
  107. data/spec/integration/server_spec.rb +4 -3
  108. data/spec/integration/transactions_api_examples_spec.rb +2 -0
  109. data/spec/kerberos/kerberos_spec.rb +4 -0
  110. data/spec/lite_spec_helper.rb +3 -1
  111. data/spec/mongo/auth/user/view_spec.rb +1 -1
  112. data/spec/mongo/caching_cursor_spec.rb +1 -1
  113. data/spec/mongo/client_encryption_spec.rb +1 -0
  114. data/spec/mongo/client_spec.rb +158 -4
  115. data/spec/mongo/collection/view/aggregation_spec.rb +14 -39
  116. data/spec/mongo/collection/view/change_stream_spec.rb +3 -3
  117. data/spec/mongo/collection_spec.rb +5 -6
  118. data/spec/mongo/crypt/auto_encrypter_spec.rb +14 -12
  119. data/spec/mongo/crypt/data_key_context_spec.rb +3 -1
  120. data/spec/mongo/crypt/explicit_encryption_context_spec.rb +2 -2
  121. data/spec/mongo/crypt/handle_spec.rb +1 -1
  122. data/spec/mongo/cursor_spec.rb +26 -9
  123. data/spec/mongo/error/operation_failure_heavy_spec.rb +2 -2
  124. data/spec/mongo/operation/context_spec.rb +79 -0
  125. data/spec/mongo/operation/create/op_msg_spec.rb +106 -110
  126. data/spec/mongo/operation/delete/op_msg_spec.rb +6 -5
  127. data/spec/mongo/operation/find/op_msg_spec.rb +66 -0
  128. data/spec/mongo/operation/get_more/op_msg_spec.rb +65 -0
  129. data/spec/mongo/operation/insert/op_msg_spec.rb +128 -131
  130. data/spec/mongo/operation/shared/csot/examples.rb +113 -0
  131. data/spec/mongo/query_cache_spec.rb +243 -225
  132. data/spec/mongo/retryable_spec.rb +1 -0
  133. data/spec/mongo/server/round_trip_time_calculator_spec.rb +120 -0
  134. data/spec/mongo/socket/ssl_spec.rb +0 -10
  135. data/spec/runners/change_streams/test.rb +2 -2
  136. data/spec/runners/crud/operation.rb +1 -1
  137. data/spec/runners/crud/verifier.rb +3 -1
  138. data/spec/runners/transactions/operation.rb +4 -6
  139. data/spec/runners/unified/ambiguous_operations.rb +13 -0
  140. data/spec/runners/unified/assertions.rb +4 -0
  141. data/spec/runners/unified/change_stream_operations.rb +14 -24
  142. data/spec/runners/unified/crud_operations.rb +82 -59
  143. data/spec/runners/unified/ddl_operations.rb +38 -7
  144. data/spec/runners/unified/grid_fs_operations.rb +37 -2
  145. data/spec/runners/unified/support_operations.rb +43 -4
  146. data/spec/runners/unified/test.rb +22 -10
  147. data/spec/runners/unified.rb +1 -1
  148. data/spec/solo/clean_exit_spec.rb +2 -0
  149. data/spec/spec_tests/client_side_operations_timeout_spec.rb +15 -0
  150. data/spec/spec_tests/data/change_streams_unified/change-streams-clusterTime.yml +3 -1
  151. data/spec/spec_tests/data/change_streams_unified/change-streams-disambiguatedPaths.yml +3 -1
  152. data/spec/spec_tests/data/change_streams_unified/change-streams-errors.yml +3 -1
  153. data/spec/spec_tests/data/change_streams_unified/change-streams-pre_and_post_images.yml +1 -1
  154. data/spec/spec_tests/data/change_streams_unified/change-streams-resume-allowlist.yml +1 -1
  155. data/spec/spec_tests/data/change_streams_unified/change-streams-resume-errorLabels.yml +1 -1
  156. data/spec/spec_tests/data/change_streams_unified/change-streams-showExpandedEvents.yml +1 -1
  157. data/spec/spec_tests/data/client_side_encryption/badQueries.yml +2 -1
  158. data/spec/spec_tests/data/client_side_encryption/timeoutMS.yml +67 -0
  159. data/spec/spec_tests/data/client_side_operations_timeout/bulkWrite.yml +87 -0
  160. data/spec/spec_tests/data/client_side_operations_timeout/change-streams.yml +358 -0
  161. data/spec/spec_tests/data/client_side_operations_timeout/close-cursors.yml +129 -0
  162. data/spec/spec_tests/data/client_side_operations_timeout/command-execution.yml +250 -0
  163. data/spec/spec_tests/data/client_side_operations_timeout/convenient-transactions.yml +113 -0
  164. data/spec/spec_tests/data/client_side_operations_timeout/cursors.yml +70 -0
  165. data/spec/spec_tests/data/client_side_operations_timeout/deprecated-options.yml +3982 -0
  166. data/spec/spec_tests/data/client_side_operations_timeout/error-transformations.yml +96 -0
  167. data/spec/spec_tests/data/client_side_operations_timeout/global-timeoutMS.yml +3236 -0
  168. data/spec/spec_tests/data/client_side_operations_timeout/gridfs-advanced.yml +207 -0
  169. data/spec/spec_tests/data/client_side_operations_timeout/gridfs-delete.yml +152 -0
  170. data/spec/spec_tests/data/client_side_operations_timeout/gridfs-download.yml +182 -0
  171. data/spec/spec_tests/data/client_side_operations_timeout/gridfs-find.yml +100 -0
  172. data/spec/spec_tests/data/client_side_operations_timeout/gridfs-upload.yml +249 -0
  173. data/spec/spec_tests/data/client_side_operations_timeout/legacy-timeouts.yml +204 -0
  174. data/spec/spec_tests/data/client_side_operations_timeout/non-tailable-cursors.yml +307 -0
  175. data/spec/spec_tests/data/client_side_operations_timeout/override-collection-timeoutMS.yml +1877 -0
  176. data/spec/spec_tests/data/client_side_operations_timeout/override-operation-timeoutMS.yml +1918 -0
  177. data/spec/spec_tests/data/client_side_operations_timeout/retryability-legacy-timeouts.yml +1676 -0
  178. data/spec/spec_tests/data/client_side_operations_timeout/retryability-timeoutMS.yml +2824 -0
  179. data/spec/spec_tests/data/client_side_operations_timeout/sessions-inherit-timeoutMS.yml +168 -0
  180. data/spec/spec_tests/data/client_side_operations_timeout/sessions-override-operation-timeoutMS.yml +171 -0
  181. data/spec/spec_tests/data/client_side_operations_timeout/sessions-override-timeoutMS.yml +168 -0
  182. data/spec/spec_tests/data/client_side_operations_timeout/tailable-awaitData.yml +247 -0
  183. data/spec/spec_tests/data/client_side_operations_timeout/tailable-non-awaitData.yml +181 -0
  184. data/spec/spec_tests/data/crud_unified/aggregate-write-readPreference.yml +4 -0
  185. data/spec/spec_tests/data/crud_unified/db-aggregate-write-readPreference.yml +4 -0
  186. data/spec/spec_tests/data/crud_unified/find-test-all-options.yml +29 -0
  187. data/spec/spec_tests/server_selection_rtt_spec.rb +6 -6
  188. data/spec/support/certificates/atlas-ocsp-ca.crt +81 -83
  189. data/spec/support/certificates/atlas-ocsp.crt +107 -107
  190. data/spec/support/cluster_tools.rb +3 -3
  191. data/spec/support/common_shortcuts.rb +2 -2
  192. data/spec/support/crypt/encrypted_fields/range-encryptedFields-Date.json +1 -1
  193. data/spec/support/crypt/encrypted_fields/range-encryptedFields-DecimalNoPrecision.json +1 -1
  194. data/spec/support/crypt/encrypted_fields/range-encryptedFields-DecimalPrecision.json +1 -1
  195. data/spec/support/crypt/encrypted_fields/range-encryptedFields-DoubleNoPrecision.json +1 -1
  196. data/spec/support/crypt/encrypted_fields/range-encryptedFields-DoublePrecision.json +1 -1
  197. data/spec/support/crypt/encrypted_fields/range-encryptedFields-Int.json +1 -1
  198. data/spec/support/crypt/encrypted_fields/range-encryptedFields-Long.json +1 -1
  199. data/spec/support/shared/session.rb +2 -2
  200. data/spec/support/spec_setup.rb +2 -2
  201. data/spec/support/utils.rb +3 -1
  202. metadata +78 -91
  203. data/spec/mongo/server/round_trip_time_averager_spec.rb +0 -48
  204. data/spec/spec_tests/data/client_side_encryption/fle2v2-Range-Date-Aggregate.yml +0 -242
  205. data/spec/spec_tests/data/client_side_encryption/fle2v2-Range-Date-Correctness.yml +0 -423
  206. data/spec/spec_tests/data/client_side_encryption/fle2v2-Range-Date-Delete.yml +0 -183
  207. data/spec/spec_tests/data/client_side_encryption/fle2v2-Range-Date-FindOneAndUpdate.yml +0 -240
  208. data/spec/spec_tests/data/client_side_encryption/fle2v2-Range-Date-InsertFind.yml +0 -236
  209. data/spec/spec_tests/data/client_side_encryption/fle2v2-Range-Date-Update.yml +0 -253
  210. data/spec/spec_tests/data/client_side_encryption/fle2v2-Range-Decimal-Aggregate.yml +0 -1688
  211. data/spec/spec_tests/data/client_side_encryption/fle2v2-Range-Decimal-Correctness.yml +0 -294
  212. data/spec/spec_tests/data/client_side_encryption/fle2v2-Range-Decimal-Delete.yml +0 -906
  213. data/spec/spec_tests/data/client_side_encryption/fle2v2-Range-Decimal-FindOneAndUpdate.yml +0 -1685
  214. data/spec/spec_tests/data/client_side_encryption/fle2v2-Range-Decimal-InsertFind.yml +0 -1681
  215. data/spec/spec_tests/data/client_side_encryption/fle2v2-Range-Decimal-Update.yml +0 -1698
  216. data/spec/spec_tests/data/client_side_encryption/fle2v2-Range-DecimalPrecision-Aggregate.yml +0 -330
  217. data/spec/spec_tests/data/client_side_encryption/fle2v2-Range-DecimalPrecision-Correctness.yml +0 -425
  218. data/spec/spec_tests/data/client_side_encryption/fle2v2-Range-DecimalPrecision-Delete.yml +0 -227
  219. data/spec/spec_tests/data/client_side_encryption/fle2v2-Range-DecimalPrecision-FindOneAndUpdate.yml +0 -328
  220. data/spec/spec_tests/data/client_side_encryption/fle2v2-Range-DecimalPrecision-InsertFind.yml +0 -320
  221. data/spec/spec_tests/data/client_side_encryption/fle2v2-Range-DecimalPrecision-Update.yml +0 -337
  222. data/spec/spec_tests/data/client_side_encryption/fle2v2-Range-Double-Aggregate.yml +0 -914
  223. data/spec/spec_tests/data/client_side_encryption/fle2v2-Range-Double-Correctness.yml +0 -293
  224. data/spec/spec_tests/data/client_side_encryption/fle2v2-Range-Double-Delete.yml +0 -519
  225. data/spec/spec_tests/data/client_side_encryption/fle2v2-Range-Double-FindOneAndUpdate.yml +0 -912
  226. data/spec/spec_tests/data/client_side_encryption/fle2v2-Range-Double-InsertFind.yml +0 -908
  227. data/spec/spec_tests/data/client_side_encryption/fle2v2-Range-Double-Update.yml +0 -925
  228. data/spec/spec_tests/data/client_side_encryption/fle2v2-Range-DoublePrecision-Aggregate.yml +0 -326
  229. data/spec/spec_tests/data/client_side_encryption/fle2v2-Range-DoublePrecision-Correctness.yml +0 -425
  230. data/spec/spec_tests/data/client_side_encryption/fle2v2-Range-DoublePrecision-Delete.yml +0 -225
  231. data/spec/spec_tests/data/client_side_encryption/fle2v2-Range-DoublePrecision-FindOneAndUpdate.yml +0 -324
  232. data/spec/spec_tests/data/client_side_encryption/fle2v2-Range-DoublePrecision-InsertFind.yml +0 -320
  233. data/spec/spec_tests/data/client_side_encryption/fle2v2-Range-DoublePrecision-Update.yml +0 -339
  234. data/spec/spec_tests/data/client_side_encryption/fle2v2-Range-Int-Aggregate.yml +0 -242
  235. data/spec/spec_tests/data/client_side_encryption/fle2v2-Range-Int-Correctness.yml +0 -424
  236. data/spec/spec_tests/data/client_side_encryption/fle2v2-Range-Int-Delete.yml +0 -183
  237. data/spec/spec_tests/data/client_side_encryption/fle2v2-Range-Int-FindOneAndUpdate.yml +0 -240
  238. data/spec/spec_tests/data/client_side_encryption/fle2v2-Range-Int-InsertFind.yml +0 -236
  239. data/spec/spec_tests/data/client_side_encryption/fle2v2-Range-Int-Update.yml +0 -255
  240. data/spec/spec_tests/data/client_side_encryption/fle2v2-Range-Long-Aggregate.yml +0 -242
  241. data/spec/spec_tests/data/client_side_encryption/fle2v2-Range-Long-Correctness.yml +0 -423
  242. data/spec/spec_tests/data/client_side_encryption/fle2v2-Range-Long-Delete.yml +0 -183
  243. data/spec/spec_tests/data/client_side_encryption/fle2v2-Range-Long-FindOneAndUpdate.yml +0 -240
  244. data/spec/spec_tests/data/client_side_encryption/fle2v2-Range-Long-InsertFind.yml +0 -236
  245. data/spec/spec_tests/data/client_side_encryption/fle2v2-Range-Long-Update.yml +0 -255
  246. data/spec/spec_tests/data/client_side_encryption/fle2v2-Range-WrongType.yml +0 -44
@@ -0,0 +1,307 @@
1
+ description: "timeoutMS behaves correctly for non-tailable cursors"
2
+
3
+ schemaVersion: "1.9"
4
+
5
+ runOnRequirements:
6
+ - minServerVersion: "4.4"
7
+
8
+ createEntities:
9
+ - client:
10
+ id: &failPointClient failPointClient
11
+ useMultipleMongoses: false
12
+ - client:
13
+ id: &client client
14
+ uriOptions:
15
+ timeoutMS: 10
16
+ useMultipleMongoses: false
17
+ observeEvents:
18
+ - commandStartedEvent
19
+ ignoreCommandMonitoringEvents:
20
+ - killCursors
21
+ - database:
22
+ id: &database database
23
+ client: *client
24
+ databaseName: &databaseName test
25
+ - collection:
26
+ id: &collection collection
27
+ database: *database
28
+ collectionName: &collectionName coll
29
+
30
+ initialData:
31
+ - collectionName: *collectionName
32
+ databaseName: *databaseName
33
+ documents:
34
+ - { _id: 0 }
35
+ - { _id: 1 }
36
+ - { _id: 2 }
37
+ - collectionName: &aggregateOutputCollectionName aggregateOutputColl
38
+ databaseName: *databaseName
39
+ documents: []
40
+
41
+ tests:
42
+ # If timeoutMode is explicitly set to CURSOR_LIFETIME, the timeout should apply to the initial command.
43
+ # This should also be the case if timeoutMode is unset, but this is already tested in global-timeoutMS.yml.
44
+ - description: "timeoutMS applied to find if timeoutMode is cursor_lifetime"
45
+ operations:
46
+ - name: failPoint
47
+ object: testRunner
48
+ arguments:
49
+ client: *failPointClient
50
+ failPoint:
51
+ configureFailPoint: failCommand
52
+ mode: { times: 1 }
53
+ data:
54
+ failCommands: ["find"]
55
+ blockConnection: true
56
+ # changed to 30ms to accommodate jruby latencies
57
+ blockTimeMS: 30
58
+ - name: find
59
+ object: *collection
60
+ arguments:
61
+ filter: {}
62
+ # added as a 25ms timeout to accommodate jruby latencies
63
+ timeoutMS: 25
64
+ timeoutMode: cursorLifetime
65
+ expectError:
66
+ isTimeoutError: true
67
+ expectEvents:
68
+ - client: *client
69
+ events:
70
+ - commandStartedEvent:
71
+ commandName: find
72
+ databaseName: *databaseName
73
+ command:
74
+ find: *collectionName
75
+ maxTimeMS: { $$type: ["int", "long"] }
76
+
77
+ # If timeoutMode is unset, it should default to CURSOR_LIFETIME and the time remaining after the find succeeds should
78
+ # be applied to the getMore.
79
+ - description: "remaining timeoutMS applied to getMore if timeoutMode is unset"
80
+ operations:
81
+ # Block find/getMore for 15ms.
82
+ - name: failPoint
83
+ object: testRunner
84
+ arguments:
85
+ client: *failPointClient
86
+ failPoint:
87
+ configureFailPoint: failCommand
88
+ mode: { times: 2 }
89
+ data:
90
+ failCommands: ["find", "getMore"]
91
+ blockConnection: true
92
+ # bumped to 50 to accommodate jruby latencies
93
+ blockTimeMS: 50
94
+ # Run a find with timeoutMS=39 and batchSize=1 to force two batches, which will cause a find and a getMore to be
95
+ # sent. Both will block for 20ms so together they will go over the timeout.
96
+ - name: find
97
+ object: *collection
98
+ arguments:
99
+ filter: {}
100
+ # bumped to 99 to accommodate jruby latencies
101
+ timeoutMS: 99
102
+ batchSize: 2
103
+ expectError:
104
+ isTimeoutError: true
105
+ expectEvents:
106
+ - client: *client
107
+ events:
108
+ - commandStartedEvent:
109
+ commandName: find
110
+ databaseName: *databaseName
111
+ command:
112
+ find: *collectionName
113
+ maxTimeMS: { $$type: ["int", "long"] }
114
+ - commandStartedEvent:
115
+ commandName: getMore
116
+ databaseName: *databaseName
117
+ command:
118
+ getMore: { $$type: ["int", "long"] }
119
+ collection: *collectionName
120
+ maxTimeMS: { $$exists: false }
121
+
122
+ # Same test as above, but with timeoutMode explicitly set to CURSOR_LIFETIME.
123
+ - description: "remaining timeoutMS applied to getMore if timeoutMode is cursor_lifetime"
124
+ operations:
125
+ - name: failPoint
126
+ object: testRunner
127
+ arguments:
128
+ client: *failPointClient
129
+ failPoint:
130
+ configureFailPoint: failCommand
131
+ mode: { times: 2 }
132
+ data:
133
+ failCommands: ["find", "getMore"]
134
+ blockConnection: true
135
+ blockTimeMS: 20
136
+ - name: find
137
+ object: *collection
138
+ arguments:
139
+ filter: {}
140
+ timeoutMode: cursorLifetime
141
+ timeoutMS: 39
142
+ batchSize: 2
143
+ expectError:
144
+ isTimeoutError: true
145
+ expectEvents:
146
+ - client: *client
147
+ events:
148
+ - commandStartedEvent:
149
+ commandName: find
150
+ databaseName: *databaseName
151
+ command:
152
+ find: *collectionName
153
+ maxTimeMS: { $$type: ["int", "long"] }
154
+ - commandStartedEvent:
155
+ commandName: getMore
156
+ databaseName: *databaseName
157
+ command:
158
+ getMore: { $$type: ["int", "long"] }
159
+ collection: *collectionName
160
+ maxTimeMS: { $$exists: false }
161
+
162
+ # If timeoutMode=ITERATION, timeoutMS should apply to the initial find command and the command shouldn't have a
163
+ # maxTimeMS field.
164
+ - description: "timeoutMS applied to find if timeoutMode is iteration"
165
+ operations:
166
+ - name: failPoint
167
+ object: testRunner
168
+ arguments:
169
+ client: *failPointClient
170
+ failPoint:
171
+ configureFailPoint: failCommand
172
+ mode: { times: 1 }
173
+ data:
174
+ failCommands: ["find"]
175
+ blockConnection: true
176
+ blockTimeMS: 15
177
+ - name: find
178
+ object: *collection
179
+ arguments:
180
+ filter: {}
181
+ timeoutMode: iteration
182
+ expectError:
183
+ isTimeoutError: true
184
+ expectEvents:
185
+ - client: *client
186
+ events:
187
+ - commandStartedEvent:
188
+ commandName: find
189
+ databaseName: *databaseName
190
+ command:
191
+ find: *collectionName
192
+ maxTimeMS: { $$exists: false }
193
+
194
+ # If timeoutMode=ITERATION, timeoutMS applies separately to the initial find and the getMore on the cursor. Neither
195
+ # command should have a maxTimeMS field. This is a success test. The "find" is executed with timeoutMS=29 and both
196
+ # "find" and "getMore" commands are blocked for 15ms each. Neither exceeds the timeout, so iteration succeeds.
197
+ - description: "timeoutMS is refreshed for getMore if timeoutMode is iteration - success"
198
+ operations:
199
+ - name: failPoint
200
+ object: testRunner
201
+ arguments:
202
+ client: *failPointClient
203
+ failPoint:
204
+ configureFailPoint: failCommand
205
+ mode: { times: 2 }
206
+ data:
207
+ failCommands: ["find", "getMore"]
208
+ blockConnection: true
209
+ # blockTimeMS: 15
210
+ # Increase timeout
211
+ blockTimeMS: 20
212
+ - name: find
213
+ object: *collection
214
+ arguments:
215
+ filter: {}
216
+ timeoutMode: iteration
217
+ # timeoutMS: 29
218
+ # Increase timeout
219
+ timeoutMS: 39
220
+ batchSize: 2
221
+ expectEvents:
222
+ - client: *client
223
+ events:
224
+ - commandStartedEvent:
225
+ commandName: find
226
+ databaseName: *databaseName
227
+ command:
228
+ find: *collectionName
229
+ maxTimeMS: { $$exists: false }
230
+ - commandStartedEvent:
231
+ commandName: getMore
232
+ databaseName: *databaseName
233
+ command:
234
+ getMore: { $$type: ["int", "long"] }
235
+ collection: *collectionName
236
+ maxTimeMS: { $$exists: false }
237
+
238
+ # If timeoutMode=ITERATION, timeoutMS applies separately to the initial find and the getMore on the cursor. Neither
239
+ # command should have a maxTimeMS field. This is a failure test. The "find" inherits timeoutMS=10 and "getMore"
240
+ # commands are blocked for 15ms, causing iteration to fail with a timeout error.
241
+ - description: "timeoutMS is refreshed for getMore if timeoutMode is iteration - failure"
242
+ operations:
243
+ - name: failPoint
244
+ object: testRunner
245
+ arguments:
246
+ client: *failPointClient
247
+ failPoint:
248
+ configureFailPoint: failCommand
249
+ mode: { times: 1 }
250
+ data:
251
+ failCommands: ["getMore"]
252
+ blockConnection: true
253
+ blockTimeMS: 15
254
+ - name: find
255
+ object: *collection
256
+ arguments:
257
+ filter: {}
258
+ timeoutMode: iteration
259
+ batchSize: 2
260
+ expectError:
261
+ isTimeoutError: true
262
+ expectEvents:
263
+ - client: *client
264
+ events:
265
+ - commandStartedEvent:
266
+ commandName: find
267
+ databaseName: *databaseName
268
+ command:
269
+ find: *collectionName
270
+ maxTimeMS: { $$exists: false }
271
+ - commandStartedEvent:
272
+ commandName: getMore
273
+ databaseName: *databaseName
274
+ command:
275
+ getMore: { $$type: ["int", "long"] }
276
+ collection: *collectionName
277
+ maxTimeMS: { $$exists: false }
278
+
279
+ - description: "aggregate with $out errors if timeoutMode is iteration"
280
+ operations:
281
+ - name: aggregate
282
+ object: *collection
283
+ arguments:
284
+ pipeline:
285
+ - $out: *aggregateOutputCollectionName
286
+ timeoutMS: 100
287
+ timeoutMode: iteration
288
+ expectError:
289
+ isClientError: true
290
+ expectEvents:
291
+ - client: *client
292
+ events: []
293
+
294
+ - description: "aggregate with $merge errors if timeoutMode is iteration"
295
+ operations:
296
+ - name: aggregate
297
+ object: *collection
298
+ arguments:
299
+ pipeline:
300
+ - $merge: *aggregateOutputCollectionName
301
+ timeoutMS: 100
302
+ timeoutMode: iteration
303
+ expectError:
304
+ isClientError: true
305
+ expectEvents:
306
+ - client: *client
307
+ events: []