mongo 2.15.0 → 2.17.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 (393) hide show
  1. checksums.yaml +4 -4
  2. checksums.yaml.gz.sig +0 -0
  3. data/README.md +1 -1
  4. data/lib/mongo/auth/aws/request.rb +0 -1
  5. data/lib/mongo/bulk_write.rb +2 -2
  6. data/lib/mongo/client.rb +49 -5
  7. data/lib/mongo/cluster/periodic_executor.rb +4 -3
  8. data/lib/mongo/cluster/reapers/cursor_reaper.rb +76 -43
  9. data/lib/mongo/cluster/sdam_flow.rb +9 -3
  10. data/lib/mongo/cluster/topology/base.rb +13 -9
  11. data/lib/mongo/cluster/topology/load_balanced.rb +102 -0
  12. data/lib/mongo/cluster/topology.rb +28 -8
  13. data/lib/mongo/cluster.rb +136 -51
  14. data/lib/mongo/collection/view/aggregation.rb +63 -23
  15. data/lib/mongo/collection/view/builder/aggregation.rb +16 -17
  16. data/lib/mongo/collection/view/builder/map_reduce.rb +12 -49
  17. data/lib/mongo/collection/view/builder.rb +0 -4
  18. data/lib/mongo/collection/view/change_stream.rb +7 -3
  19. data/lib/mongo/collection/view/iterable.rb +60 -27
  20. data/lib/mongo/collection/view/map_reduce.rb +41 -15
  21. data/lib/mongo/collection/view/readable.rb +84 -52
  22. data/lib/mongo/collection/view/writable.rb +201 -175
  23. data/lib/mongo/collection/view.rb +15 -21
  24. data/lib/mongo/collection.rb +34 -14
  25. data/lib/mongo/cursor/kill_spec.rb +38 -0
  26. data/lib/mongo/cursor.rb +72 -31
  27. data/lib/mongo/database/view.rb +5 -3
  28. data/lib/mongo/database.rb +6 -6
  29. data/lib/mongo/error/bad_load_balancer_target.rb +26 -0
  30. data/lib/mongo/error/missing_service_id.rb +26 -0
  31. data/lib/mongo/error/no_service_connection_available.rb +49 -0
  32. data/lib/mongo/error/notable.rb +7 -0
  33. data/lib/mongo/error/snapshot_session_invalid_server_version.rb +31 -0
  34. data/lib/mongo/error/snapshot_session_transaction_prohibited.rb +30 -0
  35. data/lib/mongo/error.rb +5 -0
  36. data/lib/mongo/grid/fs_bucket.rb +21 -2
  37. data/lib/mongo/id.rb +7 -5
  38. data/lib/mongo/index/view.rb +22 -41
  39. data/lib/mongo/monitoring/event/cmap/pool_cleared.rb +7 -4
  40. data/lib/mongo/monitoring/event/command_failed.rb +1 -1
  41. data/lib/mongo/monitoring/event/command_started.rb +2 -0
  42. data/lib/mongo/monitoring/publishable.rb +2 -2
  43. data/lib/mongo/operation/aggregate/command.rb +8 -0
  44. data/lib/mongo/operation/context.rb +19 -1
  45. data/lib/mongo/operation/count/command.rb +6 -0
  46. data/lib/mongo/operation/count/op_msg.rb +6 -0
  47. data/lib/mongo/operation/create/command.rb +7 -1
  48. data/lib/mongo/operation/create/op_msg.rb +7 -0
  49. data/lib/mongo/operation/create_index/command.rb +17 -1
  50. data/lib/mongo/operation/create_index/op_msg.rb +17 -4
  51. data/lib/mongo/operation/delete/command.rb +6 -3
  52. data/lib/mongo/operation/delete/legacy.rb +9 -2
  53. data/lib/mongo/operation/delete/op_msg.rb +9 -1
  54. data/lib/mongo/operation/distinct/command.rb +6 -0
  55. data/lib/mongo/operation/distinct/op_msg.rb +7 -0
  56. data/lib/mongo/operation/explain/command.rb +13 -1
  57. data/lib/mongo/operation/explain/legacy.rb +12 -5
  58. data/lib/mongo/operation/explain/op_msg.rb +9 -1
  59. data/lib/mongo/operation/find/builder/command.rb +111 -0
  60. data/lib/mongo/{collection/view → operation/find}/builder/flags.rb +10 -14
  61. data/lib/mongo/operation/find/builder/legacy.rb +123 -0
  62. data/lib/mongo/{collection/view → operation/find}/builder/modifiers.rb +31 -25
  63. data/lib/mongo/{cursor → operation/find}/builder.rb +4 -4
  64. data/lib/mongo/operation/find/command.rb +9 -0
  65. data/lib/mongo/operation/find/legacy.rb +10 -1
  66. data/lib/mongo/operation/find/op_msg.rb +12 -0
  67. data/lib/mongo/operation/find.rb +1 -0
  68. data/lib/mongo/operation/get_more/command.rb +1 -0
  69. data/lib/mongo/operation/get_more/command_builder.rb +38 -0
  70. data/lib/mongo/operation/get_more/op_msg.rb +1 -0
  71. data/lib/mongo/operation/get_more.rb +1 -0
  72. data/lib/mongo/operation/kill_cursors/command.rb +8 -0
  73. data/lib/mongo/operation/kill_cursors/command_builder.rb +35 -0
  74. data/lib/mongo/operation/kill_cursors/legacy.rb +2 -1
  75. data/lib/mongo/operation/kill_cursors/op_msg.rb +10 -0
  76. data/lib/mongo/operation/kill_cursors.rb +1 -0
  77. data/lib/mongo/operation/map_reduce/command.rb +8 -0
  78. data/lib/mongo/operation/map_reduce/op_msg.rb +1 -1
  79. data/lib/mongo/operation/result.rb +6 -0
  80. data/lib/mongo/operation/shared/executable.rb +19 -1
  81. data/lib/mongo/operation/shared/polymorphic_operation.rb +1 -1
  82. data/lib/mongo/operation/shared/read_preference_supported.rb +3 -1
  83. data/lib/mongo/operation/shared/response_handling.rb +1 -0
  84. data/lib/mongo/operation/shared/sessions_supported.rb +28 -12
  85. data/lib/mongo/operation/shared/specifiable.rb +11 -29
  86. data/lib/mongo/operation/shared/validatable.rb +87 -0
  87. data/lib/mongo/operation/shared/write.rb +1 -1
  88. data/lib/mongo/operation/update/command.rb +6 -3
  89. data/lib/mongo/operation/update/legacy.rb +19 -11
  90. data/lib/mongo/operation/update/op_msg.rb +8 -4
  91. data/lib/mongo/operation/write_command/command.rb +51 -0
  92. data/lib/mongo/operation/write_command/op_msg.rb +43 -0
  93. data/lib/mongo/operation/write_command.rb +32 -0
  94. data/lib/mongo/operation.rb +10 -0
  95. data/lib/mongo/protocol/query.rb +35 -18
  96. data/lib/mongo/server/connection.rb +25 -3
  97. data/lib/mongo/server/connection_base.rb +12 -1
  98. data/lib/mongo/server/connection_common.rb +38 -1
  99. data/lib/mongo/server/connection_pool/generation_manager.rb +71 -0
  100. data/lib/mongo/server/connection_pool.rb +100 -27
  101. data/lib/mongo/server/description/features.rb +20 -17
  102. data/lib/mongo/server/description/load_balancer.rb +33 -0
  103. data/lib/mongo/server/description.rb +85 -6
  104. data/lib/mongo/server/monitor/connection.rb +5 -6
  105. data/lib/mongo/server/monitor.rb +2 -1
  106. data/lib/mongo/server/pending_connection.rb +47 -31
  107. data/lib/mongo/server/push_monitor.rb +10 -1
  108. data/lib/mongo/server.rb +73 -26
  109. data/lib/mongo/server_selector/base.rb +31 -5
  110. data/lib/mongo/session/session_pool.rb +11 -0
  111. data/lib/mongo/session.rb +40 -1
  112. data/lib/mongo/socket/ocsp_cache.rb +2 -3
  113. data/lib/mongo/socket/ocsp_verifier.rb +6 -37
  114. data/lib/mongo/socket.rb +1 -5
  115. data/lib/mongo/uri/options_mapper.rb +1 -0
  116. data/lib/mongo/uri/srv_protocol.rb +6 -8
  117. data/lib/mongo/uri.rb +18 -0
  118. data/lib/mongo/utils.rb +0 -13
  119. data/lib/mongo/version.rb +1 -1
  120. data/mongo.gemspec +1 -1
  121. data/spec/integration/auth_spec.rb +31 -1
  122. data/spec/integration/awaited_ismaster_spec.rb +1 -1
  123. data/spec/integration/bulk_write_spec.rb +1 -1
  124. data/spec/integration/change_stream_spec.rb +3 -3
  125. data/spec/integration/client_construction_spec.rb +54 -0
  126. data/spec/integration/client_side_encryption/auto_encryption_bulk_writes_spec.rb +1 -1
  127. data/spec/integration/client_side_encryption/auto_encryption_command_monitoring_spec.rb +1 -1
  128. data/spec/integration/client_side_encryption/bson_size_limit_spec.rb +1 -1
  129. data/spec/integration/client_side_encryption/data_key_spec.rb +1 -1
  130. data/spec/integration/client_spec.rb +2 -0
  131. data/spec/integration/command_monitoring_spec.rb +1 -1
  132. data/spec/integration/command_spec.rb +1 -1
  133. data/spec/integration/connection_spec.rb +52 -35
  134. data/spec/integration/crud_spec.rb +174 -1
  135. data/spec/integration/cursor_pinning_spec.rb +121 -0
  136. data/spec/integration/cursor_reaping_spec.rb +8 -4
  137. data/spec/integration/fork_reconnect_spec.rb +1 -5
  138. data/spec/integration/get_more_spec.rb +1 -1
  139. data/spec/integration/heartbeat_events_spec.rb +1 -1
  140. data/spec/integration/map_reduce_spec.rb +77 -0
  141. data/spec/integration/query_cache_spec.rb +47 -2
  142. data/spec/integration/query_cache_transactions_spec.rb +1 -1
  143. data/spec/integration/read_concern_spec.rb +1 -1
  144. data/spec/integration/read_preference_spec.rb +17 -13
  145. data/spec/integration/reconnect_spec.rb +30 -12
  146. data/spec/integration/retryable_errors_spec.rb +1 -1
  147. data/spec/integration/retryable_writes/retryable_writes_36_and_older_spec.rb +1 -1
  148. data/spec/integration/retryable_writes/retryable_writes_40_and_newer_spec.rb +1 -1
  149. data/spec/integration/sdam_error_handling_spec.rb +5 -3
  150. data/spec/integration/sdam_events_spec.rb +35 -19
  151. data/spec/integration/sdam_prose_spec.rb +1 -1
  152. data/spec/integration/server_monitor_spec.rb +1 -0
  153. data/spec/integration/server_selector_spec.rb +22 -5
  154. data/spec/integration/server_spec.rb +2 -0
  155. data/spec/integration/srv_monitoring_spec.rb +1 -1
  156. data/spec/integration/step_down_spec.rb +1 -1
  157. data/spec/integration/transaction_pinning_spec.rb +120 -0
  158. data/spec/integration/versioned_api_examples_spec.rb +45 -0
  159. data/spec/integration/x509_auth_spec.rb +1 -1
  160. data/spec/lite_spec_helper.rb +1 -2
  161. data/spec/mongo/address/unix_spec.rb +1 -0
  162. data/spec/mongo/auth/cr_spec.rb +2 -3
  163. data/spec/mongo/auth/ldap_spec.rb +2 -3
  164. data/spec/mongo/auth/scram_spec.rb +2 -3
  165. data/spec/mongo/auth/user/view_spec.rb +1 -1
  166. data/spec/mongo/auth/x509_spec.rb +2 -3
  167. data/spec/mongo/bulk_write_spec.rb +3 -3
  168. data/spec/mongo/client_construction_spec.rb +259 -28
  169. data/spec/mongo/client_spec.rb +6 -4
  170. data/spec/mongo/cluster/cursor_reaper_spec.rb +36 -21
  171. data/spec/mongo/cluster/periodic_executor_spec.rb +3 -1
  172. data/spec/mongo/cluster_spec.rb +44 -3
  173. data/spec/mongo/collection/view/aggregation_spec.rb +72 -96
  174. data/spec/mongo/collection/view/builder/find_command_spec.rb +4 -0
  175. data/spec/mongo/collection/view/builder/op_query_spec.rb +4 -0
  176. data/spec/mongo/collection/view/change_stream_spec.rb +1 -1
  177. data/spec/mongo/collection/view/map_reduce_spec.rb +15 -2
  178. data/spec/mongo/collection_crud_spec.rb +7 -2
  179. data/spec/mongo/collection_ddl_spec.rb +1 -1
  180. data/spec/mongo/collection_spec.rb +1 -1
  181. data/spec/mongo/cursor/builder/get_more_command_spec.rb +4 -0
  182. data/spec/mongo/cursor/builder/op_get_more_spec.rb +4 -0
  183. data/spec/mongo/cursor_spec.rb +15 -5
  184. data/spec/mongo/database_spec.rb +15 -15
  185. data/spec/mongo/error/operation_failure_heavy_spec.rb +1 -1
  186. data/spec/mongo/grid/fs_bucket_spec.rb +18 -12
  187. data/spec/mongo/grid/stream/write_spec.rb +3 -9
  188. data/spec/mongo/grid/stream_spec.rb +1 -1
  189. data/spec/mongo/index/view_spec.rb +2 -2
  190. data/spec/mongo/operation/delete/op_msg_spec.rb +1 -1
  191. data/spec/mongo/{collection/view → operation/find}/builder/flags_spec.rb +2 -2
  192. data/spec/mongo/{collection/view → operation/find}/builder/modifiers_spec.rb +2 -2
  193. data/spec/mongo/operation/find/legacy_spec.rb +1 -0
  194. data/spec/mongo/operation/insert/bulk_spec.rb +1 -1
  195. data/spec/mongo/operation/insert/op_msg_spec.rb +1 -1
  196. data/spec/mongo/operation/kill_cursors_spec.rb +4 -1
  197. data/spec/mongo/operation/read_preference_legacy_spec.rb +4 -0
  198. data/spec/mongo/operation/read_preference_op_msg_spec.rb +26 -1
  199. data/spec/mongo/operation/update/bulk_spec.rb +1 -1
  200. data/spec/mongo/operation/update/op_msg_spec.rb +1 -1
  201. data/spec/mongo/query_cache_spec.rb +6 -2
  202. data/spec/mongo/server/connection_common_spec.rb +62 -11
  203. data/spec/mongo/server/connection_pool_spec.rb +73 -7
  204. data/spec/mongo/server/connection_spec.rb +138 -43
  205. data/spec/mongo/server/description_spec.rb +1 -1
  206. data/spec/mongo/server/monitor/connection_spec.rb +22 -0
  207. data/spec/mongo/server/monitor_spec.rb +4 -3
  208. data/spec/mongo/server/push_monitor_spec.rb +101 -0
  209. data/spec/mongo/server_selector_spec.rb +136 -15
  210. data/spec/mongo/session/session_pool_spec.rb +42 -10
  211. data/spec/mongo/session_transaction_spec.rb +15 -30
  212. data/spec/mongo/socket/ssl_spec.rb +26 -58
  213. data/spec/mongo/socket/unix_spec.rb +1 -0
  214. data/spec/mongo/uri_option_parsing_spec.rb +38 -5
  215. data/spec/mongo/utils_spec.rb +0 -14
  216. data/spec/runners/change_streams/test.rb +1 -1
  217. data/spec/runners/cmap.rb +1 -1
  218. data/spec/runners/connection_string.rb +7 -3
  219. data/spec/runners/crud/operation.rb +5 -3
  220. data/spec/runners/crud/requirement.rb +1 -0
  221. data/spec/runners/crud/verifier.rb +1 -2
  222. data/spec/runners/crud.rb +1 -1
  223. data/spec/runners/sdam.rb +2 -1
  224. data/spec/runners/transactions/test.rb +2 -2
  225. data/spec/runners/unified/assertions.rb +5 -4
  226. data/spec/runners/unified/crud_operations.rb +77 -23
  227. data/spec/runners/unified/ddl_operations.rb +29 -1
  228. data/spec/runners/unified/entity_map.rb +3 -3
  229. data/spec/runners/unified/event_subscriber.rb +2 -2
  230. data/spec/runners/unified/support_operations.rb +16 -3
  231. data/spec/runners/unified/test.rb +18 -3
  232. data/spec/runners/unified.rb +1 -1
  233. data/spec/shared/lib/mrss/cluster_config.rb +6 -1
  234. data/spec/shared/lib/mrss/constraints.rb +11 -5
  235. data/spec/shared/lib/mrss/event_subscriber.rb +200 -0
  236. data/spec/shared/lib/mrss/server_version_registry.rb +17 -12
  237. data/spec/shared/share/Dockerfile.erb +5 -4
  238. data/spec/shared/shlib/server.sh +70 -20
  239. data/spec/spec_tests/change_streams_spec.rb +1 -1
  240. data/spec/spec_tests/cmap_spec.rb +4 -1
  241. data/spec/spec_tests/command_monitoring_spec.rb +2 -2
  242. data/spec/spec_tests/data/command_monitoring/find.yml +9 -9
  243. data/spec/spec_tests/data/crud/read/aggregate-collation.yml +2 -1
  244. data/spec/spec_tests/data/crud/read/aggregate-out.yml +1 -0
  245. data/spec/spec_tests/data/crud/read/count-collation.yml +2 -1
  246. data/spec/spec_tests/data/crud/read/distinct-collation.yml +2 -1
  247. data/spec/spec_tests/data/crud/read/find-collation.yml +2 -1
  248. data/spec/spec_tests/data/crud/write/bulkWrite-collation.yml +2 -1
  249. data/spec/spec_tests/data/crud/write/deleteMany-collation.yml +2 -1
  250. data/spec/spec_tests/data/crud/write/deleteOne-collation.yml +2 -1
  251. data/spec/spec_tests/data/crud/write/findOneAndDelete-collation.yml +3 -2
  252. data/spec/spec_tests/data/crud/write/findOneAndReplace-collation.yml +2 -1
  253. data/spec/spec_tests/data/crud/write/findOneAndUpdate-collation.yml +3 -2
  254. data/spec/spec_tests/data/crud/write/replaceOne-collation.yml +3 -2
  255. data/spec/spec_tests/data/crud/write/updateMany-collation.yml +2 -1
  256. data/spec/spec_tests/data/crud/write/updateOne-collation.yml +2 -1
  257. data/spec/spec_tests/data/crud_unified/aggregate-let.yml +138 -0
  258. data/spec/spec_tests/data/crud_unified/aggregate-write-readPreference.yml +155 -0
  259. data/spec/spec_tests/data/crud_unified/db-aggregate-write-readPreference.yml +151 -0
  260. data/spec/spec_tests/data/crud_unified/deleteMany-let.yml +91 -0
  261. data/spec/spec_tests/data/crud_unified/deleteOne-let.yml +89 -0
  262. data/spec/spec_tests/data/crud_unified/find-let.yml +71 -0
  263. data/spec/spec_tests/data/crud_unified/findOneAndDelete-let.yml +88 -0
  264. data/spec/spec_tests/data/crud_unified/findOneAndReplace-let.yml +94 -0
  265. data/spec/spec_tests/data/crud_unified/findOneAndUpdate-let.yml +96 -0
  266. data/spec/spec_tests/data/crud_unified/updateMany-let.yml +103 -0
  267. data/spec/spec_tests/data/crud_unified/updateOne-let.yml +98 -0
  268. data/spec/spec_tests/data/load_balancers/event-monitoring.yml +99 -0
  269. data/spec/spec_tests/data/load_balancers/lb-connection-establishment.yml +36 -0
  270. data/spec/spec_tests/data/load_balancers/non-lb-connection-establishment.yml +56 -0
  271. data/spec/spec_tests/data/load_balancers/server-selection.yml +50 -0
  272. data/spec/spec_tests/data/max_staleness/ReplicaSetNoPrimary/DefaultNoMaxStaleness.yml +2 -2
  273. data/spec/spec_tests/data/max_staleness/ReplicaSetNoPrimary/LastUpdateTime.yml +3 -3
  274. data/spec/spec_tests/data/max_staleness/ReplicaSetNoPrimary/Nearest.yml +3 -3
  275. data/spec/spec_tests/data/max_staleness/ReplicaSetNoPrimary/Nearest2.yml +3 -3
  276. data/spec/spec_tests/data/max_staleness/ReplicaSetNoPrimary/PrimaryPreferred.yml +2 -2
  277. data/spec/spec_tests/data/max_staleness/ReplicaSetNoPrimary/PrimaryPreferred_tags.yml +2 -2
  278. data/spec/spec_tests/data/max_staleness/ReplicaSetNoPrimary/Secondary.yml +4 -4
  279. data/spec/spec_tests/data/max_staleness/ReplicaSetNoPrimary/SecondaryPreferred.yml +2 -2
  280. data/spec/spec_tests/data/max_staleness/ReplicaSetNoPrimary/SecondaryPreferred_tags.yml +4 -4
  281. data/spec/spec_tests/data/max_staleness/ReplicaSetNoPrimary/ZeroMaxStaleness.yml +2 -2
  282. data/spec/spec_tests/data/max_staleness/ReplicaSetWithPrimary/DefaultNoMaxStaleness.yml +2 -2
  283. data/spec/spec_tests/data/max_staleness/ReplicaSetWithPrimary/LastUpdateTime.yml +3 -3
  284. data/spec/spec_tests/data/max_staleness/ReplicaSetWithPrimary/LongHeartbeat.yml +2 -2
  285. data/spec/spec_tests/data/max_staleness/ReplicaSetWithPrimary/LongHeartbeat2.yml +2 -2
  286. data/spec/spec_tests/data/max_staleness/ReplicaSetWithPrimary/MaxStalenessTooSmall.yml +2 -2
  287. data/spec/spec_tests/data/max_staleness/ReplicaSetWithPrimary/MaxStalenessWithModePrimary.yml +2 -2
  288. data/spec/spec_tests/data/max_staleness/ReplicaSetWithPrimary/Nearest.yml +3 -3
  289. data/spec/spec_tests/data/max_staleness/ReplicaSetWithPrimary/Nearest2.yml +3 -3
  290. data/spec/spec_tests/data/max_staleness/ReplicaSetWithPrimary/Nearest_tags.yml +2 -2
  291. data/spec/spec_tests/data/max_staleness/ReplicaSetWithPrimary/PrimaryPreferred.yml +2 -2
  292. data/spec/spec_tests/data/max_staleness/ReplicaSetWithPrimary/SecondaryPreferred.yml +2 -2
  293. data/spec/spec_tests/data/max_staleness/ReplicaSetWithPrimary/SecondaryPreferred_tags.yml +5 -5
  294. data/spec/spec_tests/data/max_staleness/ReplicaSetWithPrimary/SecondaryPreferred_tags2.yml +3 -3
  295. data/spec/spec_tests/data/max_staleness/ReplicaSetWithPrimary/Secondary_tags.yml +5 -5
  296. data/spec/spec_tests/data/max_staleness/ReplicaSetWithPrimary/Secondary_tags2.yml +3 -3
  297. data/spec/spec_tests/data/max_staleness/ReplicaSetWithPrimary/ZeroMaxStaleness.yml +2 -2
  298. data/spec/spec_tests/data/max_staleness/Sharded/SmallMaxStaleness.yml +2 -2
  299. data/spec/spec_tests/data/max_staleness/Single/SmallMaxStaleness.yml +1 -1
  300. data/spec/spec_tests/data/max_staleness/Unknown/SmallMaxStaleness.yml +1 -1
  301. data/spec/spec_tests/data/retryable_reads/changeStreams-client.watch-serverErrors.yml +1 -1
  302. data/spec/spec_tests/data/retryable_reads/changeStreams-client.watch.yml +1 -1
  303. data/spec/spec_tests/data/retryable_reads/changeStreams-db.coll.watch-serverErrors.yml +1 -1
  304. data/spec/spec_tests/data/retryable_reads/changeStreams-db.coll.watch.yml +1 -1
  305. data/spec/spec_tests/data/retryable_reads/changeStreams-db.watch-serverErrors.yml +1 -1
  306. data/spec/spec_tests/data/retryable_reads/changeStreams-db.watch.yml +1 -1
  307. data/spec/spec_tests/data/retryable_reads/mapReduce.yml +3 -1
  308. data/spec/spec_tests/data/sdam/load-balanced/discover_load_balancer.yml +25 -0
  309. data/spec/spec_tests/data/sdam_integration/find-network-error.yml +2 -0
  310. data/spec/spec_tests/data/sdam_integration/find-shutdown-error.yml +2 -0
  311. data/spec/spec_tests/data/sdam_integration/hello-command-error.yml +3 -1
  312. data/spec/spec_tests/data/sdam_integration/hello-network-error.yml +3 -1
  313. data/spec/spec_tests/data/sdam_integration/hello-timeout.yml +2 -0
  314. data/spec/spec_tests/data/sdam_integration/insert-network-error.yml +2 -0
  315. data/spec/spec_tests/data/sdam_integration/insert-shutdown-error.yml +2 -0
  316. data/spec/spec_tests/data/sdam_monitoring/load_balancer.yml +65 -0
  317. data/spec/spec_tests/data/seed_list_discovery/load-balanced/loadBalanced-directConnection.yml +13 -0
  318. data/spec/spec_tests/data/seed_list_discovery/load-balanced/loadBalanced-replicaSet-errors.yml +6 -0
  319. data/spec/spec_tests/data/seed_list_discovery/load-balanced/loadBalanced-true-multiple-hosts.yml +5 -0
  320. data/spec/spec_tests/data/seed_list_discovery/load-balanced/loadBalanced-true-txt.yml +10 -0
  321. data/spec/spec_tests/data/{dns_seedlist_discovery → seed_list_discovery/replica-set}/direct-connection-false.yml +0 -0
  322. data/spec/spec_tests/data/{dns_seedlist_discovery → seed_list_discovery/replica-set}/direct-connection-true.yml +0 -0
  323. data/spec/spec_tests/data/seed_list_discovery/replica-set/encoded-userinfo-and-db.yml +15 -0
  324. data/spec/spec_tests/data/seed_list_discovery/replica-set/loadBalanced-false-txt.yml +10 -0
  325. data/spec/spec_tests/data/{dns_seedlist_discovery → seed_list_discovery/replica-set}/longer-parent-in-return.yml +0 -0
  326. data/spec/spec_tests/data/{dns_seedlist_discovery → seed_list_discovery/replica-set}/misformatted-option.yml +0 -0
  327. data/spec/spec_tests/data/{dns_seedlist_discovery → seed_list_discovery/replica-set}/no-results.yml +0 -0
  328. data/spec/spec_tests/data/{dns_seedlist_discovery → seed_list_discovery/replica-set}/not-enough-parts.yml +0 -0
  329. data/spec/spec_tests/data/{dns_seedlist_discovery → seed_list_discovery/replica-set}/one-result-default-port.yml +0 -0
  330. data/spec/spec_tests/data/{dns_seedlist_discovery → seed_list_discovery/replica-set}/one-txt-record-multiple-strings.yml +0 -0
  331. data/spec/spec_tests/data/{dns_seedlist_discovery → seed_list_discovery/replica-set}/one-txt-record.yml +0 -0
  332. data/spec/spec_tests/data/{dns_seedlist_discovery → seed_list_discovery/replica-set}/parent-part-mismatch1.yml +0 -0
  333. data/spec/spec_tests/data/{dns_seedlist_discovery → seed_list_discovery/replica-set}/parent-part-mismatch2.yml +0 -0
  334. data/spec/spec_tests/data/{dns_seedlist_discovery → seed_list_discovery/replica-set}/parent-part-mismatch3.yml +0 -0
  335. data/spec/spec_tests/data/{dns_seedlist_discovery → seed_list_discovery/replica-set}/parent-part-mismatch4.yml +0 -0
  336. data/spec/spec_tests/data/{dns_seedlist_discovery → seed_list_discovery/replica-set}/parent-part-mismatch5.yml +0 -0
  337. data/spec/spec_tests/data/{dns_seedlist_discovery → seed_list_discovery/replica-set}/returned-parent-too-short.yml +0 -0
  338. data/spec/spec_tests/data/{dns_seedlist_discovery → seed_list_discovery/replica-set}/returned-parent-wrong.yml +0 -0
  339. data/spec/spec_tests/data/{dns_seedlist_discovery → seed_list_discovery/replica-set}/two-results-default-port.yml +0 -0
  340. data/spec/spec_tests/data/{dns_seedlist_discovery → seed_list_discovery/replica-set}/two-results-nonstandard-port.yml +0 -0
  341. data/spec/spec_tests/data/{dns_seedlist_discovery → seed_list_discovery/replica-set}/two-txt-records.yml +0 -0
  342. data/spec/spec_tests/data/{dns_seedlist_discovery → seed_list_discovery/replica-set}/txt-record-not-allowed-option.yml +0 -0
  343. data/spec/spec_tests/data/{dns_seedlist_discovery → seed_list_discovery/replica-set}/txt-record-with-overridden-ssl-option.yml +0 -0
  344. data/spec/spec_tests/data/{dns_seedlist_discovery → seed_list_discovery/replica-set}/txt-record-with-overridden-uri-option.yml +0 -0
  345. data/spec/spec_tests/data/{dns_seedlist_discovery → seed_list_discovery/replica-set}/txt-record-with-unallowed-option.yml +0 -0
  346. data/spec/spec_tests/data/seed_list_discovery/replica-set/uri-with-admin-database.yml +13 -0
  347. data/spec/spec_tests/data/seed_list_discovery/replica-set/uri-with-auth.yml +12 -0
  348. data/spec/spec_tests/data/{dns_seedlist_discovery → seed_list_discovery/replica-set}/uri-with-port.yml +0 -0
  349. data/spec/spec_tests/data/{dns_seedlist_discovery → seed_list_discovery/replica-set}/uri-with-two-hosts.yml +0 -0
  350. data/spec/spec_tests/data/sessions_unified/snapshot-sessions-not-supported-client-error.yml +69 -0
  351. data/spec/spec_tests/data/sessions_unified/snapshot-sessions-not-supported-server-error.yml +102 -0
  352. data/spec/spec_tests/data/sessions_unified/snapshot-sessions-unsupported-ops.yml +258 -0
  353. data/spec/spec_tests/data/sessions_unified/snapshot-sessions.yml +482 -0
  354. data/spec/spec_tests/data/transactions/retryable-abort-errorLabels.yml +2 -0
  355. data/spec/spec_tests/data/transactions/retryable-abort.yml +2 -0
  356. data/spec/spec_tests/data/transactions/retryable-commit-errorLabels.yml +2 -0
  357. data/spec/spec_tests/data/transactions/retryable-commit.yml +2 -0
  358. data/spec/spec_tests/data/transactions/retryable-writes.yml +2 -0
  359. data/spec/spec_tests/data/uri_options/connection-options.yml +60 -0
  360. data/spec/spec_tests/load_balancers_spec.rb +15 -0
  361. data/spec/spec_tests/retryable_reads_spec.rb +2 -2
  362. data/spec/spec_tests/retryable_writes_spec.rb +1 -1
  363. data/spec/spec_tests/sdam_integration_spec.rb +1 -1
  364. data/spec/spec_tests/sdam_monitoring_spec.rb +10 -5
  365. data/spec/spec_tests/sdam_spec.rb +1 -1
  366. data/spec/spec_tests/seed_list_discovery_spec.rb +118 -0
  367. data/spec/spec_tests/sessions_unified_spec.rb +13 -0
  368. data/spec/spec_tests/uri_options_spec.rb +4 -4
  369. data/spec/stress/fork_reconnect_stress_spec.rb +1 -5
  370. data/spec/stress/push_monitor_close_spec.rb +44 -0
  371. data/spec/support/certificates/atlas-ocsp-ca.crt +82 -90
  372. data/spec/support/certificates/atlas-ocsp.crt +127 -122
  373. data/spec/support/common_shortcuts.rb +2 -3
  374. data/spec/support/matchers.rb +13 -0
  375. data/spec/support/shared/auth_context.rb +16 -0
  376. data/spec/support/shared/session.rb +2 -2
  377. data/spec/support/spec_config.rb +10 -11
  378. data/spec/support/using_hash.rb +31 -0
  379. data/spec/support/utils.rb +1 -1
  380. data.tar.gz.sig +3 -4
  381. metadata +1111 -1029
  382. metadata.gz.sig +2 -3
  383. data/lib/mongo/collection/view/builder/find_command.rb +0 -173
  384. data/lib/mongo/collection/view/builder/op_query.rb +0 -94
  385. data/lib/mongo/cursor/builder/get_more_command.rb +0 -80
  386. data/lib/mongo/cursor/builder/kill_cursors_command.rb +0 -111
  387. data/lib/mongo/cursor/builder/op_get_more.rb +0 -64
  388. data/lib/mongo/cursor/builder/op_kill_cursors.rb +0 -106
  389. data/lib/mongo/server/context.rb +0 -72
  390. data/spec/mongo/cursor/builder/op_kill_cursors_spec.rb +0 -66
  391. data/spec/runners/unified/using_hash.rb +0 -34
  392. data/spec/spec_tests/dns_seedlist_discovery_spec.rb +0 -79
  393. data/spec/support/event_subscriber.rb +0 -221
@@ -0,0 +1,138 @@
1
+ description: "aggregate-let"
2
+
3
+ schemaVersion: "1.4"
4
+
5
+ createEntities:
6
+ - client:
7
+ id: &client0 client0
8
+ observeEvents: [ commandStartedEvent ]
9
+ - database:
10
+ id: &database0 database0
11
+ client: *client0
12
+ databaseName: &database0Name crud-tests
13
+ - collection:
14
+ id: &collection0 collection0
15
+ database: *database0
16
+ collectionName: &collection0Name coll0
17
+ - collection:
18
+ id: &collection1 collection1
19
+ database: *database0
20
+ collectionName: &collection1Name coll1
21
+
22
+ initialData: &initialData
23
+ - collectionName: *collection0Name
24
+ databaseName: *database0Name
25
+ documents:
26
+ - { _id: 1 }
27
+ - collectionName: *collection1Name
28
+ databaseName: *database0Name
29
+ documents: [ ]
30
+
31
+ tests:
32
+ - description: "Aggregate with let option"
33
+ runOnRequirements:
34
+ - minServerVersion: "5.0"
35
+ operations:
36
+ - name: aggregate
37
+ object: *collection0
38
+ arguments:
39
+ pipeline: &pipeline0
40
+ # $match takes a query expression, so $expr is necessary to utilize
41
+ # an aggregate expression context and access "let" variables.
42
+ - $match: { $expr: { $eq: ["$_id", "$$id"] } }
43
+ - $project: { _id: 0, x: "$$x", y: "$$y", rand: "$$rand" }
44
+ # Values in "let" must be constant or closed expressions that do not
45
+ # depend on document values. This test demonstrates a basic constant
46
+ # value, a value wrapped with $literal (to avoid expression parsing),
47
+ # and a closed expression (e.g. $rand).
48
+ let: &let0
49
+ id: 1
50
+ x: foo
51
+ y: { $literal: "$bar" }
52
+ rand: { $rand: {} }
53
+ expectResult:
54
+ - { x: "foo", y: "$bar", rand: { $$type: "double" } }
55
+ expectEvents:
56
+ - client: *client0
57
+ events:
58
+ - commandStartedEvent:
59
+ command:
60
+ aggregate: *collection0Name
61
+ pipeline: *pipeline0
62
+ let: *let0
63
+
64
+ - description: "Aggregate with let option unsupported (server-side error)"
65
+ runOnRequirements:
66
+ - minServerVersion: "2.6.0"
67
+ maxServerVersion: "4.4.99"
68
+ operations:
69
+ - name: aggregate
70
+ object: *collection0
71
+ arguments:
72
+ pipeline: &pipeline1
73
+ - $match: { _id: 1 }
74
+ let: &let1
75
+ x: foo
76
+ expectError:
77
+ # Older server versions may not report an error code, but the error
78
+ # message is consistent between 2.6.x and 4.4.x server versions.
79
+ errorContains: "unrecognized field 'let'"
80
+ isClientError: false
81
+ expectEvents:
82
+ - client: *client0
83
+ events:
84
+ - commandStartedEvent:
85
+ command:
86
+ aggregate: *collection0Name
87
+ pipeline: *pipeline1
88
+ let: *let1
89
+
90
+ - description: "Aggregate to collection with let option"
91
+ runOnRequirements:
92
+ - minServerVersion: "5.0"
93
+ serverless: "forbid"
94
+ operations:
95
+ - name: aggregate
96
+ object: *collection0
97
+ arguments:
98
+ pipeline: &pipeline2
99
+ - $match: { $expr: { $eq: ["$_id", "$$id"] } }
100
+ - $project: { _id: 1 }
101
+ - $out: *collection1Name
102
+ let: &let2
103
+ id: 1
104
+ expectEvents:
105
+ - client: *client0
106
+ events:
107
+ - commandStartedEvent:
108
+ command:
109
+ aggregate: *collection0Name
110
+ pipeline: *pipeline2
111
+ let: *let2
112
+ outcome:
113
+ - collectionName: *collection1Name
114
+ databaseName: *database0Name
115
+ documents:
116
+ - { _id: 1 }
117
+
118
+ - description: "Aggregate to collection with let option unsupported (server-side error)"
119
+ runOnRequirements:
120
+ - minServerVersion: "2.6.0"
121
+ maxServerVersion: "4.4.99"
122
+ operations:
123
+ - name: aggregate
124
+ object: *collection0
125
+ arguments:
126
+ pipeline: *pipeline2
127
+ let: *let2
128
+ expectError:
129
+ errorContains: "unrecognized field 'let'"
130
+ isClientError: false
131
+ expectEvents:
132
+ - client: *client0
133
+ events:
134
+ - commandStartedEvent:
135
+ command:
136
+ aggregate: *collection0Name
137
+ pipeline: *pipeline2
138
+ let: *let2
@@ -0,0 +1,155 @@
1
+ description: aggregate-write-readPreference
2
+
3
+ schemaVersion: '1.4'
4
+
5
+ runOnRequirements:
6
+ # 3.6+ non-standalone is needed to utilize $readPreference in OP_MSG
7
+ - minServerVersion: "3.6"
8
+ topologies: [ replicaset, sharded, load-balanced ]
9
+
10
+ _yamlAnchors:
11
+ readConcern: &readConcern
12
+ level: &readConcernLevel "local"
13
+ writeConcern: &writeConcern
14
+ w: &writeConcernW 1
15
+
16
+ createEntities:
17
+ - client:
18
+ id: &client0 client0
19
+ observeEvents:
20
+ - commandStartedEvent
21
+ # Used to test that read and write concerns are still inherited
22
+ uriOptions:
23
+ readConcernLevel: *readConcernLevel
24
+ w: *writeConcernW
25
+ - database:
26
+ id: &database0 database0
27
+ client: *client0
28
+ databaseName: &database0Name db0
29
+ - collection:
30
+ id: &collection0 collection0
31
+ database: *database0
32
+ collectionName: &collection0Name coll0
33
+ collectionOptions:
34
+ readPreference: &readPreference
35
+ # secondaryPreferred is specified for compatibility with clusters that
36
+ # may not have a secondary (e.g. each shard is only a primary).
37
+ mode: secondaryPreferred
38
+ # maxStalenessSeconds is specified to ensure that drivers forward the
39
+ # read preference to mongos or a load balancer. That would not be the
40
+ # case with only secondaryPreferred.
41
+ maxStalenessSeconds: 600
42
+ - collection:
43
+ id: &collection1 collection1
44
+ database: *database0
45
+ collectionName: &collection1Name coll1
46
+
47
+ initialData:
48
+ - collectionName: *collection0Name
49
+ databaseName: *database0Name
50
+ documents:
51
+ - { _id: 1, x: 11 }
52
+ - { _id: 2, x: 22 }
53
+ - { _id: 3, x: 33 }
54
+ - collectionName: *collection1Name
55
+ databaseName: *database0Name
56
+ documents: []
57
+
58
+ tests:
59
+ - description: "Aggregate with $out includes read preference for 5.0+ server"
60
+ runOnRequirements:
61
+ - minServerVersion: "5.0"
62
+ serverless: "forbid"
63
+ operations:
64
+ - object: *collection0
65
+ name: aggregate
66
+ arguments:
67
+ pipeline: &outPipeline
68
+ - { $match: { _id: { $gt: 1 } } }
69
+ - { $sort: { x: 1 } }
70
+ - { $out: *collection1Name }
71
+ expectEvents:
72
+ - client: *client0
73
+ events:
74
+ - commandStartedEvent:
75
+ command:
76
+ aggregate: *collection0Name
77
+ pipeline: *outPipeline
78
+ $readPreference: *readPreference
79
+ readConcern: *readConcern
80
+ writeConcern: *writeConcern
81
+ outcome: &outcome
82
+ - collectionName: *collection1Name
83
+ databaseName: *database0Name
84
+ documents:
85
+ - { _id: 2, x: 22 }
86
+ - { _id: 3, x: 33 }
87
+
88
+ - description: "Aggregate with $out omits read preference for pre-5.0 server"
89
+ runOnRequirements:
90
+ # MongoDB 4.2 introduced support for read concerns and write stages.
91
+ # Pre-4.2 servers may allow a "local" read concern anyway, but some
92
+ # drivers may avoid inheriting a client-level read concern for pre-4.2.
93
+ - minServerVersion: "4.2"
94
+ maxServerVersion: "4.4.99"
95
+ serverless: "forbid"
96
+ operations:
97
+ - object: *collection0
98
+ name: aggregate
99
+ arguments:
100
+ pipeline: *outPipeline
101
+ expectEvents:
102
+ - client: *client0
103
+ events:
104
+ - commandStartedEvent:
105
+ command:
106
+ aggregate: *collection0Name
107
+ pipeline: *outPipeline
108
+ $readPreference: { $$exists: false }
109
+ readConcern: *readConcern
110
+ writeConcern: *writeConcern
111
+ outcome: *outcome
112
+
113
+ - description: "Aggregate with $merge includes read preference for 5.0+ server"
114
+ runOnRequirements:
115
+ - minServerVersion: "5.0"
116
+ operations:
117
+ - object: *collection0
118
+ name: aggregate
119
+ arguments:
120
+ pipeline: &mergePipeline
121
+ - { $match: { _id: { $gt: 1 } } }
122
+ - { $sort: { x: 1 } }
123
+ - { $merge: { into: *collection1Name } }
124
+ expectEvents:
125
+ - client: *client0
126
+ events:
127
+ - commandStartedEvent:
128
+ command:
129
+ aggregate: *collection0Name
130
+ pipeline: *mergePipeline
131
+ $readPreference: *readPreference
132
+ readConcern: *readConcern
133
+ writeConcern: *writeConcern
134
+ outcome: *outcome
135
+
136
+ - description: "Aggregate with $merge omits read preference for pre-5.0 server"
137
+ runOnRequirements:
138
+ - minServerVersion: "4.2"
139
+ maxServerVersion: "4.4.99"
140
+ operations:
141
+ - object: *collection0
142
+ name: aggregate
143
+ arguments:
144
+ pipeline: *mergePipeline
145
+ expectEvents:
146
+ - client: *client0
147
+ events:
148
+ - commandStartedEvent:
149
+ command:
150
+ aggregate: *collection0Name
151
+ pipeline: *mergePipeline
152
+ $readPreference: { $$exists: false }
153
+ readConcern: *readConcern
154
+ writeConcern: *writeConcern
155
+ outcome: *outcome
@@ -0,0 +1,151 @@
1
+ description: db-aggregate-write-readPreference
2
+
3
+ schemaVersion: '1.4'
4
+
5
+ runOnRequirements:
6
+ # 3.6+ non-standalone is needed to utilize $readPreference in OP_MSG.
7
+ # Serverless does not support $listLocalSessions and $currentOp stages, and
8
+ # mongos does not allow combining them with $out or $merge.
9
+ - minServerVersion: "3.6"
10
+ topologies: [ replicaset ]
11
+ serverless: forbid
12
+
13
+ _yamlAnchors:
14
+ readConcern: &readConcern
15
+ level: &readConcernLevel "local"
16
+ writeConcern: &writeConcern
17
+ w: &writeConcernW 1
18
+
19
+ createEntities:
20
+ - client:
21
+ id: &client0 client0
22
+ observeEvents:
23
+ - commandStartedEvent
24
+ # Used to test that read and write concerns are still inherited
25
+ uriOptions:
26
+ readConcernLevel: *readConcernLevel
27
+ w: *writeConcernW
28
+ - database:
29
+ id: &database0 database0
30
+ client: *client0
31
+ databaseName: &database0Name db0
32
+ databaseOptions:
33
+ readPreference: &readPreference
34
+ # secondaryPreferred is specified for compatibility with clusters that
35
+ # may not have a secondary (e.g. each shard is only a primary).
36
+ mode: secondaryPreferred
37
+ # maxStalenessSeconds is specified to ensure that drivers forward the
38
+ # read preference to mongos or a load balancer. That would not be the
39
+ # case with only secondaryPreferred.
40
+ maxStalenessSeconds: 600
41
+ - collection:
42
+ id: &collection0 collection0
43
+ database: *database0
44
+ collectionName: &collection0Name coll0
45
+
46
+ initialData:
47
+ - collectionName: *collection0Name
48
+ databaseName: *database0Name
49
+ documents: []
50
+
51
+ tests:
52
+ - description: "Database-level aggregate with $out includes read preference for 5.0+ server"
53
+ runOnRequirements:
54
+ - minServerVersion: "5.0"
55
+ serverless: "forbid"
56
+ operations:
57
+ - object: *database0
58
+ name: aggregate
59
+ arguments:
60
+ pipeline: &outPipeline
61
+ - { $listLocalSessions: {} }
62
+ - { $limit: 1 }
63
+ - { $addFields: { _id: 1 } }
64
+ - { $project: { _id: 1 } }
65
+ - { $out: *collection0Name }
66
+ expectEvents:
67
+ - client: *client0
68
+ events:
69
+ - commandStartedEvent:
70
+ command:
71
+ aggregate: 1
72
+ pipeline: *outPipeline
73
+ $readPreference: *readPreference
74
+ readConcern: *readConcern
75
+ writeConcern: *writeConcern
76
+ outcome: &outcome
77
+ - collectionName: *collection0Name
78
+ databaseName: *database0Name
79
+ documents:
80
+ - { _id: 1 }
81
+
82
+ - description: "Database-level aggregate with $out omits read preference for pre-5.0 server"
83
+ runOnRequirements:
84
+ # MongoDB 4.2 introduced support for read concerns and write stages.
85
+ # Pre-4.2 servers may allow a "local" read concern anyway, but some
86
+ # drivers may avoid inheriting a client-level read concern for pre-4.2.
87
+ - minServerVersion: "4.2"
88
+ maxServerVersion: "4.4.99"
89
+ serverless: "forbid"
90
+ operations:
91
+ - object: *database0
92
+ name: aggregate
93
+ arguments:
94
+ pipeline: *outPipeline
95
+ expectEvents:
96
+ - client: *client0
97
+ events:
98
+ - commandStartedEvent:
99
+ command:
100
+ aggregate: 1
101
+ pipeline: *outPipeline
102
+ $readPreference: { $$exists: false }
103
+ readConcern: *readConcern
104
+ writeConcern: *writeConcern
105
+ outcome: *outcome
106
+
107
+ - description: "Database-level aggregate with $merge includes read preference for 5.0+ server"
108
+ runOnRequirements:
109
+ - minServerVersion: "5.0"
110
+ operations:
111
+ - object: *database0
112
+ name: aggregate
113
+ arguments:
114
+ pipeline: &mergePipeline
115
+ - { $listLocalSessions: {} }
116
+ - { $limit: 1 }
117
+ - { $addFields: { _id: 1 } }
118
+ - { $project: { _id: 1 } }
119
+ - { $merge: { into: *collection0Name } }
120
+ expectEvents:
121
+ - client: *client0
122
+ events:
123
+ - commandStartedEvent:
124
+ command:
125
+ aggregate: 1
126
+ pipeline: *mergePipeline
127
+ $readPreference: *readPreference
128
+ readConcern: *readConcern
129
+ writeConcern: *writeConcern
130
+ outcome: *outcome
131
+
132
+ - description: "Database-level aggregate with $merge omits read preference for pre-5.0 server"
133
+ runOnRequirements:
134
+ - minServerVersion: "4.2"
135
+ maxServerVersion: "4.4.99"
136
+ operations:
137
+ - object: *database0
138
+ name: aggregate
139
+ arguments:
140
+ pipeline: *mergePipeline
141
+ expectEvents:
142
+ - client: *client0
143
+ events:
144
+ - commandStartedEvent:
145
+ command:
146
+ aggregate: 1
147
+ pipeline: *mergePipeline
148
+ $readPreference: { $$exists: false }
149
+ readConcern: *readConcern
150
+ writeConcern: *writeConcern
151
+ outcome: *outcome
@@ -0,0 +1,91 @@
1
+ description: "deleteMany-let"
2
+
3
+ schemaVersion: "1.0"
4
+
5
+ createEntities:
6
+ - client:
7
+ id: &client0 client0
8
+ observeEvents: [ commandStartedEvent ]
9
+ - database:
10
+ id: &database0 database0
11
+ client: *client0
12
+ databaseName: &database0Name crud-tests
13
+ - collection:
14
+ id: &collection0 collection0
15
+ database: *database0
16
+ collectionName: &collection0Name coll0
17
+
18
+ initialData: &initialData
19
+ - collectionName: *collection0Name
20
+ databaseName: *database0Name
21
+ documents:
22
+ - { _id: 1 }
23
+ - { _id: 2, name: "name" }
24
+ - { _id: 3, name: "name" }
25
+
26
+ tests:
27
+ - description: "deleteMany with let option"
28
+ runOnRequirements:
29
+ - minServerVersion: "5.0"
30
+ operations:
31
+ - name: deleteMany
32
+ object: *collection0
33
+ arguments:
34
+ filter: &filter
35
+ $expr:
36
+ $eq: [ "$name", "$$name" ]
37
+ let: &let0
38
+ name: "name"
39
+ expectResult:
40
+ deletedCount: 2
41
+ expectEvents:
42
+ - client: *client0
43
+ events:
44
+ - commandStartedEvent:
45
+ command:
46
+ delete: *collection0Name
47
+ deletes:
48
+ -
49
+ q: *filter
50
+ let: *let0
51
+ outcome:
52
+ -
53
+ collectionName: *collection0Name
54
+ databaseName: *database0Name
55
+ documents:
56
+ - { _id: 1 }
57
+
58
+ - description: "deleteMany with let option unsupported (server-side error)"
59
+ runOnRequirements:
60
+ - minServerVersion: "3.6.0"
61
+ maxServerVersion: "4.4.99"
62
+ operations:
63
+ - name: deleteMany
64
+ object: *collection0
65
+ arguments:
66
+ filter: &filter1
67
+ $expr:
68
+ $eq: [ "$name", "$$name" ]
69
+ let: &let1
70
+ name: "name"
71
+ expectError:
72
+ errorContains: "'delete.let' is an unknown field"
73
+ isClientError: false
74
+ expectEvents:
75
+ - client: *client0
76
+ events:
77
+ - commandStartedEvent:
78
+ command:
79
+ delete: *collection0Name
80
+ deletes:
81
+ -
82
+ q: *filter1
83
+ let: *let1
84
+ outcome:
85
+ -
86
+ collectionName: *collection0Name
87
+ databaseName: *database0Name
88
+ documents:
89
+ - { _id: 1 }
90
+ - { _id: 2, name: "name" }
91
+ - { _id: 3, name: "name" }
@@ -0,0 +1,89 @@
1
+ description: "deleteOne-let"
2
+
3
+ schemaVersion: "1.0"
4
+
5
+ createEntities:
6
+ - client:
7
+ id: &client0 client0
8
+ observeEvents: [ commandStartedEvent ]
9
+ - database:
10
+ id: &database0 database0
11
+ client: *client0
12
+ databaseName: &database0Name crud-tests
13
+ - collection:
14
+ id: &collection0 collection0
15
+ database: *database0
16
+ collectionName: &collection0Name coll0
17
+
18
+ initialData: &initialData
19
+ - collectionName: *collection0Name
20
+ databaseName: *database0Name
21
+ documents:
22
+ - { _id: 1 }
23
+ - { _id: 2 }
24
+
25
+ tests:
26
+ - description: "deleteOne with let option"
27
+ runOnRequirements:
28
+ - minServerVersion: "5.0"
29
+ operations:
30
+ - name: deleteOne
31
+ object: *collection0
32
+ arguments:
33
+ filter: &filter
34
+ $expr:
35
+ $eq: [ "$_id", "$$id" ]
36
+ let: &let0
37
+ id: 1
38
+ expectResult:
39
+ deletedCount: 1
40
+ expectEvents:
41
+ - client: *client0
42
+ events:
43
+ - commandStartedEvent:
44
+ command:
45
+ delete: *collection0Name
46
+ deletes:
47
+ -
48
+ q: *filter
49
+ let: *let0
50
+ outcome:
51
+ -
52
+ collectionName: *collection0Name
53
+ databaseName: *database0Name
54
+ documents:
55
+ - { _id: 2 }
56
+
57
+ - description: "deleteOne with let option unsupported (server-side error)"
58
+ runOnRequirements:
59
+ - minServerVersion: "3.6.0"
60
+ maxServerVersion: "4.4.99"
61
+ operations:
62
+ - name: deleteOne
63
+ object: *collection0
64
+ arguments:
65
+ filter: &filter1
66
+ $expr:
67
+ $eq: [ "$_id", "$$id" ]
68
+ let: &let1
69
+ id: 1
70
+ expectError:
71
+ errorContains: "'delete.let' is an unknown field"
72
+ isClientError: false
73
+ expectEvents:
74
+ - client: *client0
75
+ events:
76
+ - commandStartedEvent:
77
+ command:
78
+ delete: *collection0Name
79
+ deletes:
80
+ -
81
+ q: *filter1
82
+ let: *let1
83
+ outcome:
84
+ -
85
+ collectionName: *collection0Name
86
+ databaseName: *database0Name
87
+ documents:
88
+ - { _id: 1 }
89
+ - { _id: 2 }
@@ -0,0 +1,71 @@
1
+ description: "find-let"
2
+
3
+ schemaVersion: "1.0"
4
+
5
+ createEntities:
6
+ - client:
7
+ id: &client0 client0
8
+ observeEvents: [ commandStartedEvent ]
9
+ - database:
10
+ id: &database0 database0
11
+ client: *client0
12
+ databaseName: &database0Name crud-tests
13
+ - collection:
14
+ id: &collection0 collection0
15
+ database: *database0
16
+ collectionName: &collection0Name coll0
17
+
18
+ initialData: &initialData
19
+ - collectionName: *collection0Name
20
+ databaseName: *database0Name
21
+ documents:
22
+ - { _id: 1 }
23
+ - { _id: 2 }
24
+
25
+ tests:
26
+ - description: "Find with let option"
27
+ runOnRequirements:
28
+ - minServerVersion: "5.0"
29
+ operations:
30
+ - name: find
31
+ object: *collection0
32
+ arguments:
33
+ filter: &filter
34
+ $expr:
35
+ $eq: [ "$_id", "$$id" ]
36
+ let: &let0
37
+ id: 1
38
+ expectResult:
39
+ - { _id: 1 }
40
+ expectEvents:
41
+ - client: *client0
42
+ events:
43
+ - commandStartedEvent:
44
+ command:
45
+ find: *collection0Name
46
+ filter: *filter
47
+ let: *let0
48
+
49
+ - description: "Find with let option unsupported (server-side error)"
50
+ runOnRequirements:
51
+ - minServerVersion: "3.6.0"
52
+ maxServerVersion: "4.4.99"
53
+ operations:
54
+ - name: find
55
+ object: *collection0
56
+ arguments:
57
+ filter: &filter1
58
+ _id: 1
59
+ let: &let1
60
+ x: 1
61
+ expectError:
62
+ errorContains: "Unrecognized field 'let'"
63
+ isClientError: false
64
+ expectEvents:
65
+ - client: *client0
66
+ events:
67
+ - commandStartedEvent:
68
+ command:
69
+ find: *collection0Name
70
+ filter: *filter1
71
+ let: *let1