mongo 2.15.0 → 2.18.1

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 (920) hide show
  1. checksums.yaml +4 -4
  2. checksums.yaml.gz.sig +0 -0
  3. data/README.md +22 -38
  4. data/lib/mongo/auth/aws/request.rb +0 -1
  5. data/lib/mongo/auth/base.rb +8 -1
  6. data/lib/mongo/auth.rb +12 -1
  7. data/lib/mongo/bulk_write/result.rb +10 -1
  8. data/lib/mongo/bulk_write/result_combiner.rb +2 -4
  9. data/lib/mongo/bulk_write.rb +115 -29
  10. data/lib/mongo/client.rb +182 -22
  11. data/lib/mongo/client_encryption.rb +113 -10
  12. data/lib/mongo/cluster/periodic_executor.rb +4 -3
  13. data/lib/mongo/cluster/reapers/cursor_reaper.rb +98 -43
  14. data/lib/mongo/cluster/sdam_flow.rb +9 -3
  15. data/lib/mongo/cluster/topology/base.rb +13 -9
  16. data/lib/mongo/cluster/topology/load_balanced.rb +102 -0
  17. data/lib/mongo/cluster/topology.rb +28 -8
  18. data/lib/mongo/cluster.rb +162 -79
  19. data/lib/mongo/collection/helpers.rb +43 -0
  20. data/lib/mongo/collection/queryable_encryption.rb +122 -0
  21. data/lib/mongo/collection/view/aggregation.rb +68 -22
  22. data/lib/mongo/collection/view/builder/aggregation.rb +16 -17
  23. data/lib/mongo/collection/view/builder/map_reduce.rb +15 -49
  24. data/lib/mongo/collection/view/builder.rb +0 -4
  25. data/lib/mongo/collection/view/change_stream.rb +66 -20
  26. data/lib/mongo/collection/view/explainable.rb +1 -1
  27. data/lib/mongo/collection/view/iterable.rb +64 -30
  28. data/lib/mongo/collection/view/map_reduce.rb +72 -24
  29. data/lib/mongo/collection/view/readable.rb +106 -70
  30. data/lib/mongo/collection/view/writable.rb +296 -177
  31. data/lib/mongo/collection/view.rb +15 -21
  32. data/lib/mongo/collection.rb +141 -53
  33. data/lib/mongo/config/options.rb +62 -0
  34. data/lib/mongo/config/validators/option.rb +26 -0
  35. data/lib/mongo/config.rb +42 -0
  36. data/lib/mongo/crypt/auto_encrypter.rb +136 -14
  37. data/lib/mongo/crypt/binding.rb +513 -144
  38. data/lib/mongo/crypt/context.rb +5 -2
  39. data/lib/mongo/crypt/data_key_context.rb +12 -104
  40. data/lib/mongo/crypt/encryption_io.rb +94 -60
  41. data/lib/mongo/crypt/explicit_encrypter.rb +143 -26
  42. data/lib/mongo/crypt/explicit_encryption_context.rb +25 -2
  43. data/lib/mongo/crypt/handle.rb +160 -86
  44. data/lib/mongo/crypt/hooks.rb +25 -2
  45. data/lib/mongo/crypt/kms/aws.rb +136 -0
  46. data/lib/mongo/crypt/kms/azure.rb +144 -0
  47. data/lib/mongo/crypt/kms/credentials.rb +81 -0
  48. data/lib/mongo/crypt/kms/gcp.rb +189 -0
  49. data/lib/mongo/crypt/kms/kmip.rb +116 -0
  50. data/lib/mongo/crypt/kms/local.rb +82 -0
  51. data/lib/mongo/crypt/kms/master_key_document.rb +65 -0
  52. data/lib/mongo/crypt/kms.rb +117 -0
  53. data/lib/mongo/crypt/rewrap_many_data_key_context.rb +46 -0
  54. data/lib/mongo/crypt/rewrap_many_data_key_result.rb +37 -0
  55. data/lib/mongo/crypt/status.rb +8 -2
  56. data/lib/mongo/crypt.rb +3 -0
  57. data/lib/mongo/cursor/kill_spec.rb +76 -0
  58. data/lib/mongo/cursor.rb +92 -36
  59. data/lib/mongo/database/view.rb +11 -6
  60. data/lib/mongo/database.rb +63 -19
  61. data/lib/mongo/dbref.rb +1 -105
  62. data/lib/mongo/error/bad_load_balancer_target.rb +26 -0
  63. data/lib/mongo/error/bulk_write_error.rb +31 -4
  64. data/lib/mongo/error/invalid_config_option.rb +20 -0
  65. data/lib/mongo/error/invalid_replacement_document.rb +27 -9
  66. data/lib/mongo/error/invalid_update_document.rb +27 -7
  67. data/lib/mongo/error/labelable.rb +72 -0
  68. data/lib/mongo/error/missing_connection.rb +25 -0
  69. data/lib/mongo/error/missing_file_chunk.rb +8 -2
  70. data/lib/mongo/error/missing_service_id.rb +26 -0
  71. data/lib/mongo/error/no_service_connection_available.rb +49 -0
  72. data/lib/mongo/error/notable.rb +14 -0
  73. data/lib/mongo/error/operation_failure.rb +34 -86
  74. data/lib/mongo/error/read_write_retryable.rb +108 -0
  75. data/lib/mongo/error/session_not_materialized.rb +29 -0
  76. data/lib/mongo/error/snapshot_session_invalid_server_version.rb +31 -0
  77. data/lib/mongo/error/snapshot_session_transaction_prohibited.rb +30 -0
  78. data/lib/mongo/error.rb +10 -37
  79. data/lib/mongo/grid/fs_bucket.rb +21 -2
  80. data/lib/mongo/grid/stream/read.rb +6 -0
  81. data/lib/mongo/id.rb +7 -5
  82. data/lib/mongo/index/view.rb +45 -48
  83. data/lib/mongo/monitoring/event/cmap/pool_cleared.rb +7 -4
  84. data/lib/mongo/monitoring/event/command_failed.rb +9 -3
  85. data/lib/mongo/monitoring/event/command_started.rb +3 -1
  86. data/lib/mongo/monitoring/event/command_succeeded.rb +9 -2
  87. data/lib/mongo/monitoring/publishable.rb +11 -7
  88. data/lib/mongo/operation/aggregate/command.rb +8 -0
  89. data/lib/mongo/operation/collections_info/result.rb +5 -2
  90. data/lib/mongo/operation/command/op_msg.rb +6 -0
  91. data/lib/mongo/operation/context.rb +37 -1
  92. data/lib/mongo/operation/count/command.rb +6 -0
  93. data/lib/mongo/operation/count/op_msg.rb +9 -0
  94. data/lib/mongo/operation/create/command.rb +7 -1
  95. data/lib/mongo/operation/create/op_msg.rb +10 -0
  96. data/lib/mongo/operation/create_index/command.rb +17 -1
  97. data/lib/mongo/operation/create_index/op_msg.rb +18 -4
  98. data/lib/mongo/operation/delete/command.rb +6 -3
  99. data/lib/mongo/operation/delete/op_msg.rb +10 -1
  100. data/lib/mongo/operation/delete.rb +0 -1
  101. data/lib/mongo/operation/distinct/command.rb +6 -0
  102. data/lib/mongo/operation/distinct/op_msg.rb +10 -0
  103. data/lib/mongo/operation/drop_index/op_msg.rb +5 -1
  104. data/lib/mongo/operation/explain/command.rb +13 -1
  105. data/lib/mongo/operation/explain/legacy.rb +12 -5
  106. data/lib/mongo/operation/explain/op_msg.rb +9 -1
  107. data/lib/mongo/operation/find/builder/command.rb +111 -0
  108. data/lib/mongo/{collection/view → operation/find}/builder/flags.rb +10 -14
  109. data/lib/mongo/operation/find/builder/legacy.rb +123 -0
  110. data/lib/mongo/{collection/view → operation/find}/builder/modifiers.rb +31 -25
  111. data/lib/mongo/{cursor → operation/find}/builder.rb +4 -4
  112. data/lib/mongo/operation/find/command.rb +9 -0
  113. data/lib/mongo/operation/find/legacy.rb +10 -1
  114. data/lib/mongo/operation/find/op_msg.rb +12 -0
  115. data/lib/mongo/operation/find.rb +1 -0
  116. data/lib/mongo/operation/get_more/command.rb +1 -0
  117. data/lib/mongo/operation/get_more/command_builder.rb +42 -0
  118. data/lib/mongo/operation/get_more/op_msg.rb +1 -0
  119. data/lib/mongo/operation/get_more.rb +1 -0
  120. data/lib/mongo/operation/insert/bulk_result.rb +5 -1
  121. data/lib/mongo/operation/insert/command.rb +0 -4
  122. data/lib/mongo/operation/insert/op_msg.rb +6 -3
  123. data/lib/mongo/operation/insert/result.rb +6 -3
  124. data/lib/mongo/operation/insert.rb +0 -1
  125. data/lib/mongo/operation/kill_cursors/command.rb +8 -0
  126. data/lib/mongo/operation/kill_cursors/{legacy.rb → command_builder.rb} +6 -11
  127. data/lib/mongo/operation/kill_cursors/op_msg.rb +10 -0
  128. data/lib/mongo/operation/kill_cursors.rb +1 -1
  129. data/lib/mongo/operation/list_collections/op_msg.rb +4 -1
  130. data/lib/mongo/operation/map_reduce/command.rb +8 -0
  131. data/lib/mongo/operation/map_reduce/op_msg.rb +1 -1
  132. data/lib/mongo/operation/map_reduce/result.rb +16 -0
  133. data/lib/mongo/operation/result.rb +27 -5
  134. data/lib/mongo/operation/shared/executable.rb +36 -3
  135. data/lib/mongo/operation/shared/polymorphic_operation.rb +15 -3
  136. data/lib/mongo/operation/shared/read_preference_supported.rb +3 -1
  137. data/lib/mongo/operation/shared/response_handling.rb +7 -5
  138. data/lib/mongo/operation/shared/sessions_supported.rb +35 -15
  139. data/lib/mongo/operation/shared/specifiable.rb +11 -29
  140. data/lib/mongo/operation/shared/validatable.rb +87 -0
  141. data/lib/mongo/operation/shared/write.rb +18 -12
  142. data/lib/mongo/operation/update/command.rb +6 -3
  143. data/lib/mongo/operation/update/op_msg.rb +9 -4
  144. data/lib/mongo/operation/update.rb +0 -1
  145. data/lib/mongo/operation/{delete/legacy.rb → write_command/command.rb} +17 -23
  146. data/lib/mongo/operation/write_command/op_msg.rb +43 -0
  147. data/lib/mongo/operation/write_command.rb +32 -0
  148. data/lib/mongo/operation.rb +10 -0
  149. data/lib/mongo/protocol/caching_hash.rb +69 -0
  150. data/lib/mongo/protocol/msg.rb +21 -1
  151. data/lib/mongo/protocol/query.rb +35 -18
  152. data/lib/mongo/protocol.rb +1 -0
  153. data/lib/mongo/query_cache.rb +27 -2
  154. data/lib/mongo/retryable.rb +78 -30
  155. data/lib/mongo/server/connection.rb +58 -3
  156. data/lib/mongo/server/connection_base.rb +14 -1
  157. data/lib/mongo/server/connection_common.rb +41 -1
  158. data/lib/mongo/server/connection_pool/generation_manager.rb +71 -0
  159. data/lib/mongo/server/connection_pool.rb +144 -43
  160. data/lib/mongo/server/description/features.rb +22 -17
  161. data/lib/mongo/server/description/load_balancer.rb +33 -0
  162. data/lib/mongo/server/description.rb +90 -6
  163. data/lib/mongo/server/monitor/connection.rb +16 -10
  164. data/lib/mongo/server/monitor.rb +27 -14
  165. data/lib/mongo/server/pending_connection.rb +47 -31
  166. data/lib/mongo/server/push_monitor.rb +21 -2
  167. data/lib/mongo/server.rb +78 -27
  168. data/lib/mongo/server_selector/base.rb +31 -5
  169. data/lib/mongo/session/session_pool.rb +19 -0
  170. data/lib/mongo/session.rb +142 -27
  171. data/lib/mongo/socket/ocsp_cache.rb +2 -3
  172. data/lib/mongo/socket/ocsp_verifier.rb +7 -39
  173. data/lib/mongo/socket/tcp.rb +3 -0
  174. data/lib/mongo/socket.rb +1 -5
  175. data/lib/mongo/srv/resolver.rb +24 -3
  176. data/lib/mongo/uri/options_mapper.rb +3 -0
  177. data/lib/mongo/uri/srv_protocol.rb +7 -9
  178. data/lib/mongo/uri.rb +38 -0
  179. data/lib/mongo/utils.rb +0 -13
  180. data/lib/mongo/version.rb +1 -1
  181. data/lib/mongo.rb +22 -0
  182. data/mongo.gemspec +11 -5
  183. data/spec/README.md +23 -5
  184. data/spec/integration/auth_spec.rb +31 -1
  185. data/spec/integration/awaited_ismaster_spec.rb +1 -1
  186. data/spec/integration/aws_lambda_examples_spec.rb +68 -0
  187. data/spec/integration/bulk_write_error_message_spec.rb +32 -0
  188. data/spec/integration/bulk_write_spec.rb +17 -1
  189. data/spec/integration/change_stream_spec.rb +9 -8
  190. data/spec/integration/client_construction_spec.rb +128 -8
  191. data/spec/integration/client_side_encryption/auto_encryption_bulk_writes_spec.rb +10 -10
  192. data/spec/integration/client_side_encryption/auto_encryption_command_monitoring_spec.rb +169 -169
  193. data/spec/integration/client_side_encryption/auto_encryption_mongocryptd_spawn_spec.rb +0 -1
  194. data/spec/integration/client_side_encryption/auto_encryption_reconnect_spec.rb +31 -0
  195. data/spec/integration/client_side_encryption/auto_encryption_spec.rb +108 -1
  196. data/spec/integration/client_side_encryption/bson_size_limit_spec.rb +3 -3
  197. data/spec/integration/client_side_encryption/bypass_mongocryptd_spawn_spec.rb +2 -2
  198. data/spec/integration/client_side_encryption/client_close_spec.rb +1 -1
  199. data/spec/integration/client_side_encryption/corpus_spec.rb +64 -35
  200. data/spec/integration/client_side_encryption/custom_endpoint_spec.rb +39 -42
  201. data/spec/integration/client_side_encryption/data_key_spec.rb +98 -8
  202. data/spec/integration/client_side_encryption/decryption_events_prose_spec.rb +158 -0
  203. data/spec/integration/client_side_encryption/explicit_encryption_spec.rb +59 -0
  204. data/spec/integration/client_side_encryption/explicit_queryable_encryption_spec.rb +147 -0
  205. data/spec/integration/client_side_encryption/external_key_vault_spec.rb +6 -6
  206. data/spec/integration/client_side_encryption/kms_tls_options_spec.rb +436 -0
  207. data/spec/integration/client_side_encryption/kms_tls_spec.rb +92 -0
  208. data/spec/integration/client_side_encryption/queryable_encryption_examples_spec.rb +111 -0
  209. data/spec/integration/client_side_encryption/unique_index_on_key_alt_names_prose_spec.rb +85 -0
  210. data/spec/integration/client_side_encryption/views_spec.rb +1 -1
  211. data/spec/integration/client_spec.rb +2 -0
  212. data/spec/integration/client_update_spec.rb +2 -2
  213. data/spec/integration/command_monitoring_spec.rb +1 -1
  214. data/spec/integration/command_spec.rb +1 -1
  215. data/spec/integration/connection_spec.rb +52 -35
  216. data/spec/integration/crud_spec.rb +186 -1
  217. data/spec/integration/cursor_pinning_spec.rb +121 -0
  218. data/spec/integration/cursor_reaping_spec.rb +8 -4
  219. data/spec/integration/fork_reconnect_spec.rb +16 -13
  220. data/spec/integration/get_more_spec.rb +1 -1
  221. data/spec/integration/grid_fs_bucket_spec.rb +3 -3
  222. data/spec/integration/heartbeat_events_spec.rb +1 -1
  223. data/spec/integration/map_reduce_spec.rb +77 -0
  224. data/spec/integration/ocsp_verifier_spec.rb +3 -0
  225. data/spec/integration/query_cache_spec.rb +240 -32
  226. data/spec/integration/query_cache_transactions_spec.rb +1 -1
  227. data/spec/integration/read_concern_spec.rb +1 -1
  228. data/spec/integration/read_preference_spec.rb +17 -13
  229. data/spec/integration/reconnect_spec.rb +32 -12
  230. data/spec/integration/retryable_errors_spec.rb +1 -1
  231. data/spec/integration/retryable_writes/retryable_writes_36_and_older_spec.rb +2 -2
  232. data/spec/integration/retryable_writes/retryable_writes_40_and_newer_spec.rb +1 -1
  233. data/spec/integration/sdam_error_handling_spec.rb +5 -3
  234. data/spec/integration/sdam_events_spec.rb +75 -19
  235. data/spec/integration/sdam_prose_spec.rb +1 -1
  236. data/spec/integration/server_monitor_spec.rb +3 -1
  237. data/spec/integration/server_selector_spec.rb +22 -5
  238. data/spec/integration/server_spec.rb +2 -0
  239. data/spec/integration/size_limit_spec.rb +4 -1
  240. data/spec/integration/snapshot_query_examples_spec.rb +127 -0
  241. data/spec/integration/srv_monitoring_spec.rb +39 -1
  242. data/spec/integration/srv_spec.rb +1 -0
  243. data/spec/integration/step_down_spec.rb +21 -5
  244. data/spec/integration/transaction_pinning_spec.rb +120 -0
  245. data/spec/integration/versioned_api_examples_spec.rb +52 -1
  246. data/spec/integration/x509_auth_spec.rb +1 -1
  247. data/spec/lite_spec_helper.rb +27 -11
  248. data/spec/mongo/address/ipv6_spec.rb +7 -0
  249. data/spec/mongo/address/unix_spec.rb +1 -0
  250. data/spec/mongo/address_spec.rb +7 -0
  251. data/spec/mongo/auth/cr_spec.rb +2 -3
  252. data/spec/mongo/auth/ldap_spec.rb +2 -3
  253. data/spec/mongo/auth/scram/conversation_spec.rb +23 -23
  254. data/spec/mongo/auth/scram256/conversation_spec.rb +20 -20
  255. data/spec/mongo/auth/scram_negotiation_spec.rb +1 -0
  256. data/spec/mongo/auth/scram_spec.rb +2 -3
  257. data/spec/mongo/auth/user/view_spec.rb +1 -1
  258. data/spec/mongo/auth/x509_spec.rb +2 -3
  259. data/spec/mongo/bulk_write/result_spec.rb +15 -1
  260. data/spec/mongo/bulk_write_spec.rb +144 -23
  261. data/spec/mongo/client_construction_spec.rb +443 -35
  262. data/spec/mongo/client_encryption_spec.rb +10 -22
  263. data/spec/mongo/client_spec.rb +303 -5
  264. data/spec/mongo/cluster/cursor_reaper_spec.rb +63 -23
  265. data/spec/mongo/cluster/periodic_executor_spec.rb +3 -1
  266. data/spec/mongo/cluster_spec.rb +33 -36
  267. data/spec/mongo/collection/view/aggregation_spec.rb +178 -83
  268. data/spec/mongo/collection/view/builder/find_command_spec.rb +4 -0
  269. data/spec/mongo/collection/view/builder/op_query_spec.rb +4 -0
  270. data/spec/mongo/collection/view/change_stream_spec.rb +2 -2
  271. data/spec/mongo/collection/view/map_reduce_spec.rb +31 -2
  272. data/spec/mongo/collection/view/readable_spec.rb +661 -1
  273. data/spec/mongo/collection/view/writable_spec.rb +144 -32
  274. data/spec/mongo/collection_crud_spec.rb +70 -15
  275. data/spec/mongo/collection_ddl_spec.rb +1 -1
  276. data/spec/mongo/collection_spec.rb +33 -1
  277. data/spec/mongo/config/options_spec.rb +75 -0
  278. data/spec/mongo/config_spec.rb +73 -0
  279. data/spec/mongo/crypt/auto_decryption_context_spec.rb +17 -1
  280. data/spec/mongo/crypt/auto_encrypter_spec.rb +256 -5
  281. data/spec/mongo/crypt/auto_encryption_context_spec.rb +17 -1
  282. data/spec/mongo/crypt/binding/context_spec.rb +67 -17
  283. data/spec/mongo/crypt/binding/mongocrypt_spec.rb +17 -46
  284. data/spec/mongo/crypt/binding/version_spec.rb +33 -0
  285. data/spec/mongo/crypt/binding_unloaded_spec.rb +14 -0
  286. data/spec/mongo/crypt/data_key_context_spec.rb +42 -114
  287. data/spec/mongo/crypt/encryption_io_spec.rb +2 -0
  288. data/spec/mongo/crypt/explicit_decryption_context_spec.rb +32 -1
  289. data/spec/mongo/crypt/explicit_encryption_context_spec.rb +94 -1
  290. data/spec/mongo/crypt/handle_spec.rb +172 -156
  291. data/spec/mongo/crypt/hooks_spec.rb +30 -0
  292. data/spec/mongo/crypt/kms/credentials_spec.rb +357 -0
  293. data/spec/mongo/crypt/kms_spec.rb +59 -0
  294. data/spec/mongo/cursor/builder/get_more_command_spec.rb +4 -0
  295. data/spec/mongo/cursor/builder/op_get_more_spec.rb +4 -0
  296. data/spec/mongo/cursor_spec.rb +104 -7
  297. data/spec/mongo/database_spec.rb +81 -16
  298. data/spec/mongo/error/operation_failure_heavy_spec.rb +50 -1
  299. data/spec/mongo/grid/fs_bucket_spec.rb +18 -12
  300. data/spec/mongo/grid/stream/write_spec.rb +3 -9
  301. data/spec/mongo/grid/stream_spec.rb +1 -1
  302. data/spec/mongo/index/view_spec.rb +127 -2
  303. data/spec/mongo/operation/create/op_msg_spec.rb +244 -0
  304. data/spec/mongo/operation/delete/op_msg_spec.rb +14 -5
  305. data/spec/mongo/operation/delete_spec.rb +0 -30
  306. data/spec/mongo/{collection/view → operation/find}/builder/flags_spec.rb +2 -2
  307. data/spec/mongo/{collection/view → operation/find}/builder/modifiers_spec.rb +2 -2
  308. data/spec/mongo/operation/find/legacy_spec.rb +1 -0
  309. data/spec/mongo/operation/insert/bulk_spec.rb +1 -1
  310. data/spec/mongo/operation/insert/op_msg_spec.rb +19 -11
  311. data/spec/mongo/operation/insert_spec.rb +0 -32
  312. data/spec/mongo/operation/read_preference_legacy_spec.rb +4 -0
  313. data/spec/mongo/operation/read_preference_op_msg_spec.rb +26 -1
  314. data/spec/mongo/operation/result_spec.rb +20 -0
  315. data/spec/mongo/operation/update/bulk_spec.rb +1 -1
  316. data/spec/mongo/operation/update/op_msg_spec.rb +14 -5
  317. data/spec/mongo/operation/update_spec.rb +0 -29
  318. data/spec/mongo/protocol/caching_hash_spec.rb +82 -0
  319. data/spec/mongo/protocol/msg_spec.rb +41 -0
  320. data/spec/mongo/query_cache_spec.rb +172 -2
  321. data/spec/mongo/retryable_spec.rb +32 -3
  322. data/spec/mongo/server/connection_auth_spec.rb +3 -1
  323. data/spec/mongo/server/connection_common_spec.rb +76 -13
  324. data/spec/mongo/server/connection_pool_spec.rb +178 -45
  325. data/spec/mongo/server/connection_spec.rb +186 -200
  326. data/spec/mongo/server/description/features_spec.rb +24 -0
  327. data/spec/mongo/server/description_spec.rb +1 -1
  328. data/spec/mongo/server/monitor/connection_spec.rb +22 -0
  329. data/spec/mongo/server/monitor_spec.rb +4 -3
  330. data/spec/mongo/server/push_monitor_spec.rb +95 -0
  331. data/spec/mongo/server_selector_spec.rb +136 -15
  332. data/spec/mongo/session/session_pool_spec.rb +42 -10
  333. data/spec/mongo/session_spec.rb +26 -6
  334. data/spec/mongo/session_transaction_spec.rb +15 -29
  335. data/spec/mongo/socket/ssl_spec.rb +42 -63
  336. data/spec/mongo/socket/unix_spec.rb +1 -0
  337. data/spec/mongo/uri/srv_protocol_spec.rb +101 -2
  338. data/spec/mongo/uri_option_parsing_spec.rb +38 -5
  339. data/spec/mongo/uri_spec.rb +25 -0
  340. data/spec/mongo/utils_spec.rb +0 -14
  341. data/spec/runners/auth.rb +1 -1
  342. data/spec/runners/change_streams/spec.rb +1 -1
  343. data/spec/runners/change_streams/test.rb +1 -1
  344. data/spec/runners/cmap.rb +2 -2
  345. data/spec/runners/command_monitoring.rb +1 -1
  346. data/spec/runners/connection_string.rb +16 -4
  347. data/spec/runners/crud/operation.rb +17 -6
  348. data/spec/runners/crud/requirement.rb +10 -4
  349. data/spec/runners/crud/spec.rb +6 -3
  350. data/spec/runners/crud/test.rb +1 -1
  351. data/spec/runners/crud/verifier.rb +7 -2
  352. data/spec/runners/crud.rb +1 -1
  353. data/spec/runners/gridfs.rb +1 -1
  354. data/spec/runners/read_write_concern_document.rb +1 -1
  355. data/spec/runners/sdam.rb +3 -2
  356. data/spec/runners/server_selection.rb +1 -1
  357. data/spec/runners/server_selection_rtt.rb +1 -1
  358. data/spec/runners/transactions/spec.rb +2 -2
  359. data/spec/runners/transactions/test.rb +21 -18
  360. data/spec/runners/transactions.rb +11 -8
  361. data/spec/runners/unified/assertions.rb +95 -15
  362. data/spec/runners/unified/change_stream_operations.rb +12 -0
  363. data/spec/runners/unified/client_side_encryption_operations.rb +83 -0
  364. data/spec/runners/unified/crud_operations.rb +143 -26
  365. data/spec/runners/unified/ddl_operations.rb +74 -1
  366. data/spec/runners/unified/entity_map.rb +3 -3
  367. data/spec/runners/unified/error.rb +2 -1
  368. data/spec/runners/unified/event_subscriber.rb +2 -2
  369. data/spec/runners/unified/grid_fs_operations.rb +21 -0
  370. data/spec/runners/unified/support_operations.rb +21 -5
  371. data/spec/runners/unified/test.rb +96 -8
  372. data/spec/runners/unified/test_group.rb +1 -1
  373. data/spec/runners/unified.rb +10 -3
  374. data/spec/shared/lib/mrss/cluster_config.rb +6 -1
  375. data/spec/shared/lib/mrss/constraints.rb +21 -22
  376. data/spec/shared/lib/mrss/docker_runner.rb +23 -3
  377. data/spec/shared/lib/mrss/eg_config_utils.rb +51 -0
  378. data/spec/shared/lib/mrss/event_subscriber.rb +210 -0
  379. data/spec/shared/lib/mrss/lite_constraints.rb +40 -1
  380. data/spec/shared/lib/mrss/server_version_registry.rb +17 -12
  381. data/spec/shared/lib/mrss/session_registry.rb +69 -0
  382. data/spec/shared/lib/mrss/session_registry_legacy.rb +60 -0
  383. data/spec/shared/share/Dockerfile.erb +61 -58
  384. data/spec/shared/shlib/config.sh +27 -0
  385. data/spec/shared/shlib/distro.sh +2 -1
  386. data/spec/shared/shlib/server.sh +114 -39
  387. data/spec/shared/shlib/set_env.sh +43 -5
  388. data/spec/solo/clean_exit_spec.rb +5 -0
  389. data/spec/spec_helper.rb +0 -1
  390. data/spec/spec_tests/client_side_encryption_spec.rb +1 -1
  391. data/spec/spec_tests/client_side_encryption_unified_spec.rb +16 -0
  392. data/spec/spec_tests/cmap_spec.rb +4 -1
  393. data/spec/spec_tests/crud_spec.rb +0 -10
  394. data/spec/spec_tests/data/change_streams_unified/change-streams-errors.yml +124 -0
  395. data/spec/spec_tests/data/change_streams_unified/change-streams-pre_and_post_images.yml +351 -0
  396. data/spec/spec_tests/data/change_streams_unified/change-streams-resume-allowlist.yml +1171 -0
  397. data/spec/spec_tests/data/change_streams_unified/change-streams-resume-errorLabels.yml +1071 -0
  398. data/spec/spec_tests/data/change_streams_unified/change-streams-showExpandedEvents.yml +298 -0
  399. data/spec/spec_tests/data/change_streams_unified/change-streams.yml +859 -4
  400. data/spec/spec_tests/data/client_side_encryption/aggregate.yml +3 -17
  401. data/spec/spec_tests/data/client_side_encryption/azureKMS.yml +46 -0
  402. data/spec/spec_tests/data/client_side_encryption/badQueries.yml +12 -2
  403. data/spec/spec_tests/data/client_side_encryption/basic.yml +3 -17
  404. data/spec/spec_tests/data/client_side_encryption/bulk.yml +1 -8
  405. data/spec/spec_tests/data/client_side_encryption/bypassAutoEncryption.yml +2 -2
  406. data/spec/spec_tests/data/client_side_encryption/count.yml +1 -8
  407. data/spec/spec_tests/data/client_side_encryption/countDocuments.yml +1 -8
  408. data/spec/spec_tests/data/client_side_encryption/create-and-createIndexes.yml +58 -0
  409. data/spec/spec_tests/data/client_side_encryption/delete.yml +2 -16
  410. data/spec/spec_tests/data/client_side_encryption/distinct.yml +1 -8
  411. data/spec/spec_tests/data/client_side_encryption/explain.yml +1 -8
  412. data/spec/spec_tests/data/client_side_encryption/find.yml +2 -16
  413. data/spec/spec_tests/data/client_side_encryption/findOneAndDelete.yml +1 -8
  414. data/spec/spec_tests/data/client_side_encryption/findOneAndReplace.yml +1 -8
  415. data/spec/spec_tests/data/client_side_encryption/findOneAndUpdate.yml +1 -8
  416. data/spec/spec_tests/data/client_side_encryption/fle2-BypassQueryAnalysis.yml +101 -0
  417. data/spec/spec_tests/data/client_side_encryption/fle2-Compact.yml +80 -0
  418. data/spec/spec_tests/data/client_side_encryption/fle2-CreateCollection.yml +1263 -0
  419. data/spec/spec_tests/data/client_side_encryption/fle2-DecryptExistingData.yml +64 -0
  420. data/spec/spec_tests/data/client_side_encryption/fle2-Delete.yml +107 -0
  421. data/spec/spec_tests/data/client_side_encryption/fle2-EncryptedFields-vs-EncryptedFieldsMap.yml +80 -0
  422. data/spec/spec_tests/data/client_side_encryption/fle2-EncryptedFields-vs-jsonSchema.yml +90 -0
  423. data/spec/spec_tests/data/client_side_encryption/fle2-EncryptedFieldsMap-defaults.yml +57 -0
  424. data/spec/spec_tests/data/client_side_encryption/fle2-FindOneAndUpdate.yml +213 -0
  425. data/spec/spec_tests/data/client_side_encryption/fle2-InsertFind-Indexed.yml +86 -0
  426. data/spec/spec_tests/data/client_side_encryption/fle2-InsertFind-Unindexed.yml +83 -0
  427. data/spec/spec_tests/data/client_side_encryption/fle2-MissingKey.yml +41 -0
  428. data/spec/spec_tests/data/client_side_encryption/fle2-NoEncryption.yml +42 -0
  429. data/spec/spec_tests/data/client_side_encryption/fle2-Update.yml +221 -0
  430. data/spec/spec_tests/data/client_side_encryption/fle2-validatorAndPartialFieldExpression.yml +168 -0
  431. data/spec/spec_tests/data/client_side_encryption/gcpKMS.yml +46 -0
  432. data/spec/spec_tests/data/client_side_encryption/getMore.yml +1 -8
  433. data/spec/spec_tests/data/client_side_encryption/insert.yml +2 -16
  434. data/spec/spec_tests/data/client_side_encryption/keyAltName.yml +1 -8
  435. data/spec/spec_tests/data/client_side_encryption/localKMS.yml +1 -8
  436. data/spec/spec_tests/data/client_side_encryption/localSchema.yml +1 -8
  437. data/spec/spec_tests/data/client_side_encryption/maxWireVersion.yml +2 -0
  438. data/spec/spec_tests/data/client_side_encryption/missingKey.yml +2 -9
  439. data/spec/spec_tests/data/client_side_encryption/noSchema.yml +39 -0
  440. data/spec/spec_tests/data/client_side_encryption/replaceOne.yml +1 -8
  441. data/spec/spec_tests/data/client_side_encryption/types.yml +44 -70
  442. data/spec/spec_tests/data/client_side_encryption/unified/addKeyAltName.yml +194 -0
  443. data/spec/spec_tests/data/client_side_encryption/unified/createDataKey-kms_providers-invalid.yml +67 -0
  444. data/spec/spec_tests/data/client_side_encryption/unified/createDataKey.yml +309 -0
  445. data/spec/spec_tests/data/client_side_encryption/unified/deleteKey.yml +159 -0
  446. data/spec/spec_tests/data/client_side_encryption/unified/getKey.yml +105 -0
  447. data/spec/spec_tests/data/client_side_encryption/unified/getKeyByAltName.yml +104 -0
  448. data/spec/spec_tests/data/client_side_encryption/unified/getKeys.yml +122 -0
  449. data/spec/spec_tests/data/client_side_encryption/unified/removeKeyAltName.yml +157 -0
  450. data/spec/spec_tests/data/client_side_encryption/unified/rewrapManyDataKey-decrypt_failure.yml +69 -0
  451. data/spec/spec_tests/data/client_side_encryption/unified/rewrapManyDataKey-encrypt_failure.yml +122 -0
  452. data/spec/spec_tests/data/client_side_encryption/unified/rewrapManyDataKey.yml +432 -0
  453. data/spec/spec_tests/data/client_side_encryption/updateMany.yml +1 -8
  454. data/spec/spec_tests/data/client_side_encryption/updateOne.yml +1 -8
  455. data/spec/spec_tests/data/client_side_encryption/validatorAndPartialFieldExpression.yml +166 -0
  456. data/spec/spec_tests/data/collection_management/clustered-indexes.yml +135 -0
  457. data/spec/spec_tests/data/collection_management/createCollection-pre_and_post_images.yml +50 -0
  458. data/spec/spec_tests/data/collection_management/modifyCollection-pre_and_post_images.yml +58 -0
  459. data/spec/spec_tests/data/command_monitoring_unified/bulkWrite.yml +68 -0
  460. data/spec/spec_tests/data/command_monitoring_unified/command.yml +50 -0
  461. data/spec/spec_tests/data/command_monitoring_unified/deleteMany.yml +79 -0
  462. data/spec/spec_tests/data/command_monitoring_unified/deleteOne.yml +79 -0
  463. data/spec/spec_tests/data/command_monitoring_unified/find.yml +254 -0
  464. data/spec/spec_tests/data/command_monitoring_unified/insertMany.yml +79 -0
  465. data/spec/spec_tests/data/command_monitoring_unified/insertOne.yml +77 -0
  466. data/spec/spec_tests/data/command_monitoring_unified/pre-42-server-connection-id.yml +56 -0
  467. data/spec/spec_tests/data/command_monitoring_unified/server-connection-id.yml +56 -0
  468. data/spec/spec_tests/data/command_monitoring_unified/unacknowledgedBulkWrite.yml +55 -0
  469. data/spec/spec_tests/data/command_monitoring_unified/updateMany.yml +87 -0
  470. data/spec/spec_tests/data/command_monitoring_unified/updateOne.yml +118 -0
  471. data/spec/spec_tests/data/crud/read/aggregate-collation.yml +2 -1
  472. data/spec/spec_tests/data/crud/read/aggregate-out.yml +1 -0
  473. data/spec/spec_tests/data/crud/read/count-collation.yml +2 -1
  474. data/spec/spec_tests/data/crud/read/distinct-collation.yml +2 -1
  475. data/spec/spec_tests/data/crud/read/find-collation.yml +2 -1
  476. data/spec/spec_tests/data/crud/write/bulkWrite-collation.yml +2 -1
  477. data/spec/spec_tests/data/crud/write/deleteMany-collation.yml +2 -1
  478. data/spec/spec_tests/data/crud/write/deleteOne-collation.yml +2 -1
  479. data/spec/spec_tests/data/crud/write/findOneAndDelete-collation.yml +3 -2
  480. data/spec/spec_tests/data/crud/write/findOneAndReplace-collation.yml +2 -1
  481. data/spec/spec_tests/data/crud/write/findOneAndUpdate-collation.yml +3 -2
  482. data/spec/spec_tests/data/crud/write/replaceOne-collation.yml +3 -2
  483. data/spec/spec_tests/data/crud/write/updateMany-collation.yml +2 -1
  484. data/spec/spec_tests/data/crud/write/updateOne-collation.yml +2 -1
  485. data/spec/spec_tests/data/crud_unified/aggregate-allowdiskuse.yml +75 -0
  486. data/spec/spec_tests/data/crud_unified/aggregate-let.yml +138 -0
  487. data/spec/spec_tests/data/crud_unified/aggregate-merge.yml +185 -0
  488. data/spec/spec_tests/data/crud_unified/aggregate-out-readConcern.yml +171 -0
  489. data/spec/spec_tests/data/crud_unified/aggregate-write-readPreference.yml +155 -0
  490. data/spec/spec_tests/data/crud_unified/aggregate.yml +215 -0
  491. data/spec/spec_tests/data/crud_unified/bulkWrite-arrayFilters-clientError.yml +98 -0
  492. data/spec/spec_tests/data/crud_unified/bulkWrite-arrayFilters.yml +174 -0
  493. data/spec/spec_tests/data/crud_unified/bulkWrite-comment.yml +189 -0
  494. data/spec/spec_tests/data/crud_unified/bulkWrite-delete-hint-clientError.yml +113 -0
  495. data/spec/spec_tests/data/crud_unified/bulkWrite-delete-hint-serverError.yml +142 -0
  496. data/spec/spec_tests/data/crud_unified/bulkWrite-delete-hint.yml +154 -0
  497. data/spec/spec_tests/data/crud_unified/bulkWrite-deleteMany-hint-unacknowledged.yml +98 -0
  498. data/spec/spec_tests/data/crud_unified/bulkWrite-deleteMany-let.yml +86 -0
  499. data/spec/spec_tests/data/crud_unified/bulkWrite-deleteOne-hint-unacknowledged.yml +97 -0
  500. data/spec/spec_tests/data/crud_unified/bulkWrite-deleteOne-let.yml +86 -0
  501. data/spec/spec_tests/data/crud_unified/bulkWrite-insertOne-dots_and_dollars.yml +138 -0
  502. data/spec/spec_tests/data/crud_unified/bulkWrite-replaceOne-dots_and_dollars.yml +165 -0
  503. data/spec/spec_tests/data/crud_unified/bulkWrite-replaceOne-hint-unacknowledged.yml +103 -0
  504. data/spec/spec_tests/data/crud_unified/bulkWrite-replaceOne-let.yml +93 -0
  505. data/spec/spec_tests/data/crud_unified/bulkWrite-update-hint-clientError.yml +148 -0
  506. data/spec/spec_tests/data/crud_unified/bulkWrite-update-hint-serverError.yml +239 -0
  507. data/spec/spec_tests/data/crud_unified/bulkWrite-update-hint.yml +256 -0
  508. data/spec/spec_tests/data/crud_unified/bulkWrite-update-validation.yml +73 -0
  509. data/spec/spec_tests/data/crud_unified/bulkWrite-updateMany-dots_and_dollars.yml +150 -0
  510. data/spec/spec_tests/data/crud_unified/bulkWrite-updateMany-hint-unacknowledged.yml +104 -0
  511. data/spec/spec_tests/data/crud_unified/bulkWrite-updateMany-let.yml +96 -0
  512. data/spec/spec_tests/data/crud_unified/bulkWrite-updateOne-dots_and_dollars.yml +150 -0
  513. data/spec/spec_tests/data/crud_unified/bulkWrite-updateOne-hint-unacknowledged.yml +103 -0
  514. data/spec/spec_tests/data/crud_unified/bulkWrite-updateOne-let.yml +95 -0
  515. data/spec/spec_tests/data/crud_unified/countDocuments-comment.yml +92 -0
  516. data/spec/spec_tests/data/crud_unified/db-aggregate-write-readPreference.yml +151 -0
  517. data/spec/spec_tests/data/crud_unified/db-aggregate.yml +73 -0
  518. data/spec/spec_tests/data/crud_unified/deleteMany-comment.yml +97 -0
  519. data/spec/spec_tests/data/crud_unified/deleteMany-hint-clientError.yml +87 -0
  520. data/spec/spec_tests/data/crud_unified/deleteMany-hint-serverError.yml +107 -0
  521. data/spec/spec_tests/data/crud_unified/deleteMany-hint-unacknowledged.yml +90 -0
  522. data/spec/spec_tests/data/crud_unified/deleteMany-hint.yml +99 -0
  523. data/spec/spec_tests/data/crud_unified/deleteMany-let.yml +93 -0
  524. data/spec/spec_tests/data/crud_unified/deleteOne-comment.yml +98 -0
  525. data/spec/spec_tests/data/crud_unified/deleteOne-hint-clientError.yml +80 -0
  526. data/spec/spec_tests/data/crud_unified/deleteOne-hint-serverError.yml +100 -0
  527. data/spec/spec_tests/data/crud_unified/deleteOne-hint-unacknowledged.yml +89 -0
  528. data/spec/spec_tests/data/crud_unified/deleteOne-hint.yml +95 -0
  529. data/spec/spec_tests/data/crud_unified/deleteOne-let.yml +91 -0
  530. data/spec/spec_tests/data/crud_unified/distinct-comment.yml +98 -0
  531. data/spec/spec_tests/data/crud_unified/estimatedDocumentCount-comment.yml +95 -0
  532. data/spec/spec_tests/data/crud_unified/estimatedDocumentCount.yml +5 -135
  533. data/spec/spec_tests/data/crud_unified/find-allowdiskuse-clientError.yml +55 -0
  534. data/spec/spec_tests/data/crud_unified/find-allowdiskuse-serverError.yml +68 -0
  535. data/spec/spec_tests/data/crud_unified/find-allowdiskuse.yml +79 -0
  536. data/spec/spec_tests/data/crud_unified/find-comment.yml +166 -0
  537. data/spec/spec_tests/data/crud_unified/find-let.yml +71 -0
  538. data/spec/spec_tests/data/crud_unified/find.yml +68 -0
  539. data/spec/spec_tests/data/crud_unified/findOneAndDelete-comment.yml +96 -0
  540. data/spec/spec_tests/data/crud_unified/findOneAndDelete-hint-clientError.yml +91 -0
  541. data/spec/spec_tests/data/crud_unified/findOneAndDelete-hint-serverError.yml +107 -0
  542. data/spec/spec_tests/data/crud_unified/findOneAndDelete-hint-unacknowledged.yml +88 -0
  543. data/spec/spec_tests/data/crud_unified/findOneAndDelete-hint.yml +102 -0
  544. data/spec/spec_tests/data/crud_unified/findOneAndDelete-let.yml +86 -0
  545. data/spec/spec_tests/data/crud_unified/findOneAndReplace-comment.yml +101 -0
  546. data/spec/spec_tests/data/crud_unified/findOneAndReplace-dots_and_dollars.yml +140 -0
  547. data/spec/spec_tests/data/crud_unified/findOneAndReplace-hint-clientError.yml +83 -0
  548. data/spec/spec_tests/data/crud_unified/findOneAndReplace-hint-serverError.yml +99 -0
  549. data/spec/spec_tests/data/crud_unified/findOneAndReplace-hint-unacknowledged.yml +96 -0
  550. data/spec/spec_tests/data/crud_unified/findOneAndReplace-hint.yml +98 -0
  551. data/spec/spec_tests/data/crud_unified/findOneAndReplace-let.yml +94 -0
  552. data/spec/spec_tests/data/crud_unified/findOneAndUpdate-comment.yml +95 -0
  553. data/spec/spec_tests/data/crud_unified/findOneAndUpdate-dots_and_dollars.yml +127 -0
  554. data/spec/spec_tests/data/crud_unified/findOneAndUpdate-hint-clientError.yml +84 -0
  555. data/spec/spec_tests/data/crud_unified/findOneAndUpdate-hint-serverError.yml +100 -0
  556. data/spec/spec_tests/data/crud_unified/findOneAndUpdate-hint-unacknowledged.yml +92 -0
  557. data/spec/spec_tests/data/crud_unified/findOneAndUpdate-hint.yml +99 -0
  558. data/spec/spec_tests/data/crud_unified/findOneAndUpdate-let.yml +96 -0
  559. data/spec/spec_tests/data/crud_unified/insertMany-comment.yml +93 -0
  560. data/spec/spec_tests/data/crud_unified/insertMany-dots_and_dollars.yml +128 -0
  561. data/spec/spec_tests/data/crud_unified/insertOne-comment.yml +91 -0
  562. data/spec/spec_tests/data/crud_unified/insertOne-dots_and_dollars.yml +238 -0
  563. data/spec/spec_tests/data/crud_unified/replaceOne-comment.yml +105 -0
  564. data/spec/spec_tests/data/crud_unified/replaceOne-dots_and_dollars.yml +180 -0
  565. data/spec/spec_tests/data/crud_unified/replaceOne-hint-unacknowledged.yml +95 -0
  566. data/spec/spec_tests/data/crud_unified/replaceOne-hint.yml +108 -0
  567. data/spec/spec_tests/data/crud_unified/replaceOne-let.yml +98 -0
  568. data/spec/spec_tests/data/crud_unified/replaceOne-validation.yml +37 -0
  569. data/spec/spec_tests/data/crud_unified/updateMany-comment.yml +104 -0
  570. data/spec/spec_tests/data/crud_unified/updateMany-dots_and_dollars.yml +138 -0
  571. data/spec/spec_tests/data/crud_unified/updateMany-hint-clientError.yml +91 -0
  572. data/spec/spec_tests/data/crud_unified/updateMany-hint-serverError.yml +115 -0
  573. data/spec/spec_tests/data/crud_unified/updateMany-hint-unacknowledged.yml +96 -0
  574. data/spec/spec_tests/data/crud_unified/updateMany-hint.yml +115 -0
  575. data/spec/spec_tests/data/crud_unified/updateMany-let.yml +107 -0
  576. data/spec/spec_tests/data/crud_unified/updateMany-validation.yml +39 -0
  577. data/spec/spec_tests/data/crud_unified/updateOne-comment.yml +104 -0
  578. data/spec/spec_tests/data/crud_unified/updateOne-dots_and_dollars.yml +138 -0
  579. data/spec/spec_tests/data/crud_unified/updateOne-hint-clientError.yml +85 -0
  580. data/spec/spec_tests/data/crud_unified/updateOne-hint-serverError.yml +109 -0
  581. data/spec/spec_tests/data/crud_unified/updateOne-hint-unacknowledged.yml +95 -0
  582. data/spec/spec_tests/data/crud_unified/updateOne-hint.yml +109 -0
  583. data/spec/spec_tests/data/crud_unified/updateOne-let.yml +102 -0
  584. data/spec/spec_tests/data/crud_unified/updateOne-validation.yml +37 -0
  585. data/spec/spec_tests/data/crud_unified/updateWithPipelines.yml +8 -14
  586. data/spec/spec_tests/data/gridfs_unified/delete.yml +198 -0
  587. data/spec/spec_tests/data/gridfs_unified/download.yml +241 -0
  588. data/spec/spec_tests/data/gridfs_unified/downloadByName.yml +159 -0
  589. data/spec/spec_tests/data/gridfs_unified/upload-disableMD5.yml +92 -0
  590. data/spec/spec_tests/data/gridfs_unified/upload.yml +288 -0
  591. data/spec/spec_tests/data/load_balancers/event-monitoring.yml +99 -0
  592. data/spec/spec_tests/data/load_balancers/lb-connection-establishment.yml +36 -0
  593. data/spec/spec_tests/data/load_balancers/non-lb-connection-establishment.yml +56 -0
  594. data/spec/spec_tests/data/load_balancers/server-selection.yml +50 -0
  595. data/spec/spec_tests/data/max_staleness/ReplicaSetNoPrimary/DefaultNoMaxStaleness.yml +2 -2
  596. data/spec/spec_tests/data/max_staleness/ReplicaSetNoPrimary/LastUpdateTime.yml +3 -3
  597. data/spec/spec_tests/data/max_staleness/ReplicaSetNoPrimary/Nearest.yml +3 -3
  598. data/spec/spec_tests/data/max_staleness/ReplicaSetNoPrimary/Nearest2.yml +3 -3
  599. data/spec/spec_tests/data/max_staleness/ReplicaSetNoPrimary/PrimaryPreferred.yml +2 -2
  600. data/spec/spec_tests/data/max_staleness/ReplicaSetNoPrimary/PrimaryPreferred_tags.yml +2 -2
  601. data/spec/spec_tests/data/max_staleness/ReplicaSetNoPrimary/Secondary.yml +4 -4
  602. data/spec/spec_tests/data/max_staleness/ReplicaSetNoPrimary/SecondaryPreferred.yml +2 -2
  603. data/spec/spec_tests/data/max_staleness/ReplicaSetNoPrimary/SecondaryPreferred_tags.yml +4 -4
  604. data/spec/spec_tests/data/max_staleness/ReplicaSetNoPrimary/ZeroMaxStaleness.yml +2 -2
  605. data/spec/spec_tests/data/max_staleness/ReplicaSetWithPrimary/DefaultNoMaxStaleness.yml +2 -2
  606. data/spec/spec_tests/data/max_staleness/ReplicaSetWithPrimary/LastUpdateTime.yml +3 -3
  607. data/spec/spec_tests/data/max_staleness/ReplicaSetWithPrimary/LongHeartbeat.yml +2 -2
  608. data/spec/spec_tests/data/max_staleness/ReplicaSetWithPrimary/LongHeartbeat2.yml +2 -2
  609. data/spec/spec_tests/data/max_staleness/ReplicaSetWithPrimary/MaxStalenessTooSmall.yml +2 -2
  610. data/spec/spec_tests/data/max_staleness/ReplicaSetWithPrimary/MaxStalenessWithModePrimary.yml +2 -2
  611. data/spec/spec_tests/data/max_staleness/ReplicaSetWithPrimary/Nearest.yml +3 -3
  612. data/spec/spec_tests/data/max_staleness/ReplicaSetWithPrimary/Nearest2.yml +3 -3
  613. data/spec/spec_tests/data/max_staleness/ReplicaSetWithPrimary/Nearest_tags.yml +2 -2
  614. data/spec/spec_tests/data/max_staleness/ReplicaSetWithPrimary/PrimaryPreferred.yml +2 -2
  615. data/spec/spec_tests/data/max_staleness/ReplicaSetWithPrimary/SecondaryPreferred.yml +2 -2
  616. data/spec/spec_tests/data/max_staleness/ReplicaSetWithPrimary/SecondaryPreferred_tags.yml +5 -5
  617. data/spec/spec_tests/data/max_staleness/ReplicaSetWithPrimary/SecondaryPreferred_tags2.yml +3 -3
  618. data/spec/spec_tests/data/max_staleness/ReplicaSetWithPrimary/Secondary_tags.yml +5 -5
  619. data/spec/spec_tests/data/max_staleness/ReplicaSetWithPrimary/Secondary_tags2.yml +3 -3
  620. data/spec/spec_tests/data/max_staleness/ReplicaSetWithPrimary/ZeroMaxStaleness.yml +2 -2
  621. data/spec/spec_tests/data/max_staleness/Sharded/SmallMaxStaleness.yml +2 -2
  622. data/spec/spec_tests/data/max_staleness/Single/SmallMaxStaleness.yml +1 -1
  623. data/spec/spec_tests/data/max_staleness/Unknown/SmallMaxStaleness.yml +1 -1
  624. data/spec/spec_tests/data/retryable_reads/{changeStreams-client.watch-serverErrors.yml → legacy/changeStreams-client.watch-serverErrors.yml} +1 -1
  625. data/spec/spec_tests/data/retryable_reads/{changeStreams-client.watch.yml → legacy/changeStreams-client.watch.yml} +1 -1
  626. data/spec/spec_tests/data/retryable_reads/{changeStreams-db.coll.watch-serverErrors.yml → legacy/changeStreams-db.coll.watch-serverErrors.yml} +1 -1
  627. data/spec/spec_tests/data/retryable_reads/{changeStreams-db.coll.watch.yml → legacy/changeStreams-db.coll.watch.yml} +1 -1
  628. data/spec/spec_tests/data/retryable_reads/{changeStreams-db.watch-serverErrors.yml → legacy/changeStreams-db.watch-serverErrors.yml} +1 -1
  629. data/spec/spec_tests/data/retryable_reads/{changeStreams-db.watch.yml → legacy/changeStreams-db.watch.yml} +1 -1
  630. data/spec/spec_tests/data/retryable_reads/{estimatedDocumentCount-serverErrors-pre4.9.yml → legacy/estimatedDocumentCount-serverErrors.yml} +0 -2
  631. data/spec/spec_tests/data/retryable_reads/{estimatedDocumentCount-pre4.9.yml → legacy/estimatedDocumentCount.yml} +0 -2
  632. data/spec/spec_tests/data/retryable_reads/{mapReduce.yml → legacy/mapReduce.yml} +3 -1
  633. data/spec/spec_tests/data/retryable_reads/unified/handshakeError.yml +129 -0
  634. data/spec/spec_tests/data/retryable_writes/{bulkWrite-serverErrors.yml → legacy/bulkWrite-serverErrors.yml} +1 -1
  635. data/spec/spec_tests/data/retryable_writes/{deleteOne-serverErrors.yml → legacy/deleteOne-serverErrors.yml} +1 -1
  636. data/spec/spec_tests/data/retryable_writes/{findOneAndDelete-serverErrors.yml → legacy/findOneAndDelete-serverErrors.yml} +1 -1
  637. data/spec/spec_tests/data/retryable_writes/{findOneAndReplace-serverErrors.yml → legacy/findOneAndReplace-serverErrors.yml} +1 -1
  638. data/spec/spec_tests/data/retryable_writes/{findOneAndUpdate-serverErrors.yml → legacy/findOneAndUpdate-serverErrors.yml} +1 -1
  639. data/spec/spec_tests/data/retryable_writes/{insertMany-serverErrors.yml → legacy/insertMany-serverErrors.yml} +1 -1
  640. data/spec/spec_tests/data/retryable_writes/{insertOne-serverErrors.yml → legacy/insertOne-serverErrors.yml} +5 -5
  641. data/spec/spec_tests/data/retryable_writes/{replaceOne-serverErrors.yml → legacy/replaceOne-serverErrors.yml} +1 -1
  642. data/spec/spec_tests/data/retryable_writes/{updateOne-serverErrors.yml → legacy/updateOne-serverErrors.yml} +1 -1
  643. data/spec/spec_tests/data/retryable_writes/unified/bulkWrite-serverErrors.yml +96 -0
  644. data/spec/spec_tests/data/retryable_writes/unified/handshakeError.yml +137 -0
  645. data/spec/spec_tests/data/retryable_writes/unified/insertOne-serverErrors.yml +78 -0
  646. data/spec/spec_tests/data/sdam/errors/prefer-error-code.yml +2 -2
  647. data/spec/spec_tests/data/sdam/load-balanced/discover_load_balancer.yml +25 -0
  648. data/spec/spec_tests/data/sdam_integration/find-network-error.yml +2 -0
  649. data/spec/spec_tests/data/sdam_integration/find-shutdown-error.yml +2 -0
  650. data/spec/spec_tests/data/sdam_integration/hello-command-error.yml +9 -15
  651. data/spec/spec_tests/data/sdam_integration/hello-network-error.yml +7 -15
  652. data/spec/spec_tests/data/sdam_integration/hello-timeout.yml +10 -14
  653. data/spec/spec_tests/data/sdam_integration/insert-network-error.yml +2 -0
  654. data/spec/spec_tests/data/sdam_integration/insert-shutdown-error.yml +2 -0
  655. data/spec/spec_tests/data/sdam_monitoring/load_balancer.yml +65 -0
  656. data/spec/spec_tests/data/seed_list_discovery/load-balanced/loadBalanced-directConnection.yml +13 -0
  657. data/spec/spec_tests/data/seed_list_discovery/load-balanced/loadBalanced-no-results.yml +5 -0
  658. data/spec/spec_tests/data/seed_list_discovery/load-balanced/loadBalanced-replicaSet-errors.yml +6 -0
  659. data/spec/spec_tests/data/seed_list_discovery/load-balanced/loadBalanced-true-multiple-hosts.yml +5 -0
  660. data/spec/spec_tests/data/seed_list_discovery/load-balanced/loadBalanced-true-txt.yml +10 -0
  661. data/spec/spec_tests/data/seed_list_discovery/load-balanced/srvMaxHosts-conflicts_with_loadBalanced-true-txt.yml +5 -0
  662. data/spec/spec_tests/data/seed_list_discovery/load-balanced/srvMaxHosts-conflicts_with_loadBalanced-true.yml +5 -0
  663. data/spec/spec_tests/data/seed_list_discovery/load-balanced/srvMaxHosts-zero-txt.yml +10 -0
  664. data/spec/spec_tests/data/seed_list_discovery/load-balanced/srvMaxHosts-zero.yml +10 -0
  665. data/spec/spec_tests/data/seed_list_discovery/replica-set/encoded-userinfo-and-db.yml +15 -0
  666. data/spec/spec_tests/data/seed_list_discovery/replica-set/loadBalanced-false-txt.yml +10 -0
  667. data/spec/spec_tests/data/seed_list_discovery/replica-set/srv-service-name.yml +11 -0
  668. data/spec/spec_tests/data/seed_list_discovery/replica-set/srvMaxHosts-conflicts_with_replicaSet-txt.yml +5 -0
  669. data/spec/spec_tests/data/seed_list_discovery/replica-set/srvMaxHosts-conflicts_with_replicaSet.yml +5 -0
  670. data/spec/spec_tests/data/seed_list_discovery/replica-set/srvMaxHosts-equal_to_srv_records.yml +16 -0
  671. data/spec/spec_tests/data/seed_list_discovery/replica-set/srvMaxHosts-greater_than_srv_records.yml +15 -0
  672. data/spec/spec_tests/data/seed_list_discovery/replica-set/srvMaxHosts-less_than_srv_records.yml +15 -0
  673. data/spec/spec_tests/data/seed_list_discovery/replica-set/srvMaxHosts-zero-txt.yml +15 -0
  674. data/spec/spec_tests/data/seed_list_discovery/replica-set/srvMaxHosts-zero.yml +15 -0
  675. data/spec/spec_tests/data/seed_list_discovery/replica-set/uri-with-admin-database.yml +13 -0
  676. data/spec/spec_tests/data/seed_list_discovery/replica-set/uri-with-auth.yml +12 -0
  677. data/spec/spec_tests/data/seed_list_discovery/sharded/srvMaxHosts-equal_to_srv_records.yml +13 -0
  678. data/spec/spec_tests/data/seed_list_discovery/sharded/srvMaxHosts-greater_than_srv_records.yml +12 -0
  679. data/spec/spec_tests/data/seed_list_discovery/sharded/srvMaxHosts-less_than_srv_records.yml +10 -0
  680. data/spec/spec_tests/data/seed_list_discovery/sharded/srvMaxHosts-zero.yml +11 -0
  681. data/spec/spec_tests/data/server_selection/Unknown/read/ghost.yml +11 -0
  682. data/spec/spec_tests/data/server_selection/Unknown/write/ghost.yml +11 -0
  683. data/spec/spec_tests/data/sessions_unified/driver-sessions-server-support.yml +123 -0
  684. data/spec/spec_tests/data/sessions_unified/snapshot-sessions-not-supported-client-error.yml +75 -0
  685. data/spec/spec_tests/data/sessions_unified/snapshot-sessions-not-supported-server-error.yml +102 -0
  686. data/spec/spec_tests/data/sessions_unified/snapshot-sessions-unsupported-ops.yml +258 -0
  687. data/spec/spec_tests/data/sessions_unified/snapshot-sessions.yml +482 -0
  688. data/spec/spec_tests/data/transactions/error-labels.yml +1 -1
  689. data/spec/spec_tests/data/transactions/errors-client.yml +8 -9
  690. data/spec/spec_tests/data/transactions/mongos-recovery-token.yml +1 -1
  691. data/spec/spec_tests/data/transactions/retryable-abort.yml +7 -7
  692. data/spec/spec_tests/data/transactions/retryable-commit.yml +7 -7
  693. data/spec/spec_tests/data/transactions_unified/do-not-retry-read-in-transaction.yml +64 -0
  694. data/spec/spec_tests/data/transactions_unified/retryable-abort-handshake.yml +118 -0
  695. data/spec/spec_tests/data/transactions_unified/retryable-commit-handshake.yml +118 -0
  696. data/spec/spec_tests/data/unified/invalid/expectedEventsForClient-ignoreExtraEvents-type.yml +15 -0
  697. data/spec/spec_tests/data/unified/valid-fail/operation-unsupported.yml +13 -0
  698. data/spec/spec_tests/data/unified/valid-pass/expectedEventsForClient-ignoreExtraEvents.yml +78 -0
  699. data/spec/spec_tests/data/unified/valid-pass/poc-change-streams.yml +4 -1
  700. data/spec/spec_tests/data/unified/valid-pass/poc-command-monitoring.yml +3 -3
  701. data/spec/spec_tests/data/unified/valid-pass/poc-transactions.yml +3 -2
  702. data/spec/spec_tests/data/uri_options/connection-options.yml +60 -0
  703. data/spec/spec_tests/data/uri_options/srv-options.yml +96 -0
  704. data/spec/spec_tests/data/versioned_api/crud-api-version-1-strict.yml +6 -4
  705. data/spec/spec_tests/data/versioned_api/crud-api-version-1.yml +7 -5
  706. data/spec/spec_tests/gridfs_unified_spec.rb +13 -0
  707. data/spec/spec_tests/load_balancers_spec.rb +15 -0
  708. data/spec/spec_tests/retryable_reads_spec.rb +6 -3
  709. data/spec/spec_tests/retryable_reads_unified_spec.rb +22 -0
  710. data/spec/spec_tests/retryable_writes_spec.rb +5 -2
  711. data/spec/spec_tests/retryable_writes_unified_spec.rb +21 -0
  712. data/spec/spec_tests/sdam_integration_spec.rb +1 -1
  713. data/spec/spec_tests/sdam_monitoring_spec.rb +10 -5
  714. data/spec/spec_tests/sdam_spec.rb +1 -1
  715. data/spec/spec_tests/seed_list_discovery_spec.rb +127 -0
  716. data/spec/spec_tests/sessions_unified_spec.rb +13 -0
  717. data/spec/spec_tests/unified_spec.rb +6 -1
  718. data/spec/spec_tests/uri_options_spec.rb +4 -4
  719. data/spec/stress/connection_pool_timing_spec.rb +3 -2
  720. data/spec/stress/fork_reconnect_stress_spec.rb +4 -7
  721. data/spec/stress/push_monitor_close_spec.rb +44 -0
  722. data/spec/support/authorization.rb +1 -1
  723. data/spec/support/background_thread_registry.rb +3 -13
  724. data/spec/support/certificates/atlas-ocsp-ca.crt +81 -96
  725. data/spec/support/certificates/atlas-ocsp.crt +125 -125
  726. data/spec/support/certificates/retrieve-atlas-cert +38 -0
  727. data/spec/support/cluster_tools.rb +1 -1
  728. data/spec/support/common_shortcuts.rb +24 -3
  729. data/spec/support/crypt/corpus/corpus-encrypted.json +9515 -0
  730. data/spec/support/crypt/corpus/corpus-key-aws.json +32 -32
  731. data/spec/support/crypt/corpus/corpus-key-azure.json +33 -0
  732. data/spec/support/crypt/corpus/corpus-key-gcp.json +35 -0
  733. data/spec/support/crypt/corpus/corpus-key-kmip.json +32 -0
  734. data/spec/support/crypt/corpus/corpus-key-local.json +30 -30
  735. data/spec/support/crypt/corpus/corpus-schema.json +4399 -121
  736. data/spec/support/crypt/corpus/corpus.json +4999 -37
  737. data/spec/support/crypt/data_keys/key_document_azure.json +33 -0
  738. data/spec/support/crypt/data_keys/key_document_gcp.json +37 -0
  739. data/spec/support/crypt/data_keys/key_document_kmip.json +32 -0
  740. data/spec/support/crypt/encryptedFields.json +33 -0
  741. data/spec/support/crypt/keys/key1-document.json +30 -0
  742. data/spec/support/crypt/schema_maps/schema_map_azure.json +17 -0
  743. data/spec/support/crypt/schema_maps/schema_map_azure_key_alt_names.json +12 -0
  744. data/spec/support/crypt/schema_maps/schema_map_gcp.json +17 -0
  745. data/spec/support/crypt/schema_maps/schema_map_gcp_key_alt_names.json +12 -0
  746. data/spec/support/crypt/schema_maps/schema_map_kmip.json +17 -0
  747. data/spec/support/crypt/schema_maps/schema_map_kmip_key_alt_names.json +12 -0
  748. data/spec/support/crypt.rb +258 -13
  749. data/spec/support/macros.rb +28 -0
  750. data/spec/support/matchers.rb +13 -0
  751. data/spec/support/mongos_macros.rb +17 -0
  752. data/spec/support/shared/auth_context.rb +16 -0
  753. data/spec/support/shared/scram_conversation.rb +2 -1
  754. data/spec/support/shared/session.rb +15 -9
  755. data/spec/support/spec_config.rb +100 -12
  756. data/spec/support/using_hash.rb +31 -0
  757. data/spec/support/utils.rb +57 -5
  758. data.tar.gz.sig +0 -0
  759. metadata +778 -381
  760. metadata.gz.sig +0 -0
  761. data/lib/mongo/collection/view/builder/find_command.rb +0 -173
  762. data/lib/mongo/collection/view/builder/op_query.rb +0 -94
  763. data/lib/mongo/cursor/builder/get_more_command.rb +0 -80
  764. data/lib/mongo/cursor/builder/kill_cursors_command.rb +0 -111
  765. data/lib/mongo/cursor/builder/op_get_more.rb +0 -64
  766. data/lib/mongo/cursor/builder/op_kill_cursors.rb +0 -106
  767. data/lib/mongo/operation/insert/legacy.rb +0 -68
  768. data/lib/mongo/operation/update/legacy/result.rb +0 -112
  769. data/lib/mongo/operation/update/legacy.rb +0 -68
  770. data/lib/mongo/server/context.rb +0 -72
  771. data/spec/mongo/cursor/builder/op_kill_cursors_spec.rb +0 -66
  772. data/spec/mongo/dbref_spec.rb +0 -152
  773. data/spec/mongo/operation/kill_cursors_spec.rb +0 -44
  774. data/spec/runners/unified/using_hash.rb +0 -34
  775. data/spec/spec_tests/change_streams_spec.rb +0 -93
  776. data/spec/spec_tests/command_monitoring_spec.rb +0 -71
  777. data/spec/spec_tests/data/change_streams/change-streams-errors.yml +0 -101
  778. data/spec/spec_tests/data/change_streams/change-streams-resume-allowlist.yml +0 -1173
  779. data/spec/spec_tests/data/change_streams/change-streams-resume-errorLabels.yml +0 -1105
  780. data/spec/spec_tests/data/change_streams/change-streams.yml +0 -535
  781. data/spec/spec_tests/data/command_monitoring/bulkWrite.yml +0 -49
  782. data/spec/spec_tests/data/command_monitoring/command.yml +0 -61
  783. data/spec/spec_tests/data/command_monitoring/deleteMany.yml +0 -55
  784. data/spec/spec_tests/data/command_monitoring/deleteOne.yml +0 -55
  785. data/spec/spec_tests/data/command_monitoring/find.yml +0 -266
  786. data/spec/spec_tests/data/command_monitoring/insertMany.yml +0 -75
  787. data/spec/spec_tests/data/command_monitoring/insertOne.yml +0 -51
  788. data/spec/spec_tests/data/command_monitoring/unacknowledgedBulkWrite.yml +0 -34
  789. data/spec/spec_tests/data/command_monitoring/updateMany.yml +0 -65
  790. data/spec/spec_tests/data/command_monitoring/updateOne.yml +0 -90
  791. data/spec/spec_tests/data/crud_v2/aggregate-merge.yml +0 -103
  792. data/spec/spec_tests/data/crud_v2/aggregate-out-readConcern.yml +0 -111
  793. data/spec/spec_tests/data/crud_v2/bulkWrite-arrayFilters.yml +0 -103
  794. data/spec/spec_tests/data/crud_v2/bulkWrite-delete-hint-clientError.yml +0 -63
  795. data/spec/spec_tests/data/crud_v2/bulkWrite-delete-hint-serverError.yml +0 -92
  796. data/spec/spec_tests/data/crud_v2/bulkWrite-delete-hint.yml +0 -103
  797. data/spec/spec_tests/data/crud_v2/bulkWrite-update-hint-clientError.yml +0 -90
  798. data/spec/spec_tests/data/crud_v2/bulkWrite-update-hint-serverError.yml +0 -147
  799. data/spec/spec_tests/data/crud_v2/bulkWrite-update-hint.yml +0 -164
  800. data/spec/spec_tests/data/crud_v2/db-aggregate.yml +0 -39
  801. data/spec/spec_tests/data/crud_v2/deleteMany-hint-clientError.yml +0 -43
  802. data/spec/spec_tests/data/crud_v2/deleteMany-hint-serverError.yml +0 -62
  803. data/spec/spec_tests/data/crud_v2/deleteMany-hint.yml +0 -58
  804. data/spec/spec_tests/data/crud_v2/deleteOne-hint-clientError.yml +0 -41
  805. data/spec/spec_tests/data/crud_v2/deleteOne-hint-serverError.yml +0 -60
  806. data/spec/spec_tests/data/crud_v2/deleteOne-hint.yml +0 -57
  807. data/spec/spec_tests/data/crud_v2/find-allowdiskuse-clientError.yml +0 -28
  808. data/spec/spec_tests/data/crud_v2/find-allowdiskuse-serverError.yml +0 -44
  809. data/spec/spec_tests/data/crud_v2/find-allowdiskuse.yml +0 -50
  810. data/spec/spec_tests/data/crud_v2/findOneAndDelete-hint-clientError.yml +0 -45
  811. data/spec/spec_tests/data/crud_v2/findOneAndDelete-hint-serverError.yml +0 -60
  812. data/spec/spec_tests/data/crud_v2/findOneAndDelete-hint.yml +0 -56
  813. data/spec/spec_tests/data/crud_v2/findOneAndReplace-hint-clientError.yml +0 -40
  814. data/spec/spec_tests/data/crud_v2/findOneAndReplace-hint-serverError.yml +0 -59
  815. data/spec/spec_tests/data/crud_v2/findOneAndReplace-hint.yml +0 -55
  816. data/spec/spec_tests/data/crud_v2/findOneAndUpdate-hint-clientError.yml +0 -40
  817. data/spec/spec_tests/data/crud_v2/findOneAndUpdate-hint-serverError.yml +0 -58
  818. data/spec/spec_tests/data/crud_v2/findOneAndUpdate-hint.yml +0 -55
  819. data/spec/spec_tests/data/crud_v2/replaceOne-hint.yml +0 -61
  820. data/spec/spec_tests/data/crud_v2/unacknowledged-bulkWrite-delete-hint-clientError.yml +0 -60
  821. data/spec/spec_tests/data/crud_v2/unacknowledged-bulkWrite-update-hint-clientError.yml +0 -88
  822. data/spec/spec_tests/data/crud_v2/unacknowledged-deleteMany-hint-clientError.yml +0 -40
  823. data/spec/spec_tests/data/crud_v2/unacknowledged-deleteOne-hint-clientError.yml +0 -38
  824. data/spec/spec_tests/data/crud_v2/unacknowledged-findOneAndDelete-hint-clientError.yml +0 -42
  825. data/spec/spec_tests/data/crud_v2/unacknowledged-findOneAndReplace-hint-clientError.yml +0 -40
  826. data/spec/spec_tests/data/crud_v2/unacknowledged-findOneAndUpdate-hint-clientError.yml +0 -40
  827. data/spec/spec_tests/data/crud_v2/unacknowledged-replaceOne-hint-clientError.yml +0 -40
  828. data/spec/spec_tests/data/crud_v2/unacknowledged-updateMany-hint-clientError.yml +0 -43
  829. data/spec/spec_tests/data/crud_v2/unacknowledged-updateOne-hint-clientError.yml +0 -40
  830. data/spec/spec_tests/data/crud_v2/updateMany-hint-clientError.yml +0 -45
  831. data/spec/spec_tests/data/crud_v2/updateMany-hint-serverError.yml +0 -66
  832. data/spec/spec_tests/data/crud_v2/updateMany-hint.yml +0 -65
  833. data/spec/spec_tests/data/crud_v2/updateOne-hint-clientError.yml +0 -43
  834. data/spec/spec_tests/data/crud_v2/updateOne-hint-serverError.yml +0 -62
  835. data/spec/spec_tests/data/crud_v2/updateOne-hint.yml +0 -61
  836. data/spec/spec_tests/data/crud_v2/updateWithPipelines.yml +0 -157
  837. data/spec/spec_tests/data/retryable_reads/estimatedDocumentCount-4.9.yml +0 -60
  838. data/spec/spec_tests/data/retryable_reads/estimatedDocumentCount-serverErrors-4.9.yml +0 -146
  839. data/spec/spec_tests/dns_seedlist_discovery_spec.rb +0 -79
  840. data/spec/support/crypt/corpus/corpus_encrypted.json +0 -4152
  841. data/spec/support/event_subscriber.rb +0 -221
  842. data/spec/support/session_registry.rb +0 -55
  843. /data/spec/spec_tests/data/retryable_reads/{aggregate-merge.yml → legacy/aggregate-merge.yml} +0 -0
  844. /data/spec/spec_tests/data/retryable_reads/{aggregate-serverErrors.yml → legacy/aggregate-serverErrors.yml} +0 -0
  845. /data/spec/spec_tests/data/retryable_reads/{aggregate.yml → legacy/aggregate.yml} +0 -0
  846. /data/spec/spec_tests/data/retryable_reads/{count-serverErrors.yml → legacy/count-serverErrors.yml} +0 -0
  847. /data/spec/spec_tests/data/retryable_reads/{count.yml → legacy/count.yml} +0 -0
  848. /data/spec/spec_tests/data/retryable_reads/{countDocuments-serverErrors.yml → legacy/countDocuments-serverErrors.yml} +0 -0
  849. /data/spec/spec_tests/data/retryable_reads/{countDocuments.yml → legacy/countDocuments.yml} +0 -0
  850. /data/spec/spec_tests/data/retryable_reads/{distinct-serverErrors.yml → legacy/distinct-serverErrors.yml} +0 -0
  851. /data/spec/spec_tests/data/retryable_reads/{distinct.yml → legacy/distinct.yml} +0 -0
  852. /data/spec/spec_tests/data/retryable_reads/{find-serverErrors.yml → legacy/find-serverErrors.yml} +0 -0
  853. /data/spec/spec_tests/data/retryable_reads/{find.yml → legacy/find.yml} +0 -0
  854. /data/spec/spec_tests/data/retryable_reads/{findOne-serverErrors.yml → legacy/findOne-serverErrors.yml} +0 -0
  855. /data/spec/spec_tests/data/retryable_reads/{findOne.yml → legacy/findOne.yml} +0 -0
  856. /data/spec/spec_tests/data/retryable_reads/{gridfs-download-serverErrors.yml → legacy/gridfs-download-serverErrors.yml} +0 -0
  857. /data/spec/spec_tests/data/retryable_reads/{gridfs-download.yml → legacy/gridfs-download.yml} +0 -0
  858. /data/spec/spec_tests/data/retryable_reads/{gridfs-downloadByName-serverErrors.yml → legacy/gridfs-downloadByName-serverErrors.yml} +0 -0
  859. /data/spec/spec_tests/data/retryable_reads/{gridfs-downloadByName.yml → legacy/gridfs-downloadByName.yml} +0 -0
  860. /data/spec/spec_tests/data/retryable_reads/{listCollectionNames-serverErrors.yml → legacy/listCollectionNames-serverErrors.yml} +0 -0
  861. /data/spec/spec_tests/data/retryable_reads/{listCollectionNames.yml → legacy/listCollectionNames.yml} +0 -0
  862. /data/spec/spec_tests/data/retryable_reads/{listCollectionObjects-serverErrors.yml → legacy/listCollectionObjects-serverErrors.yml} +0 -0
  863. /data/spec/spec_tests/data/retryable_reads/{listCollectionObjects.yml → legacy/listCollectionObjects.yml} +0 -0
  864. /data/spec/spec_tests/data/retryable_reads/{listCollections-serverErrors.yml → legacy/listCollections-serverErrors.yml} +0 -0
  865. /data/spec/spec_tests/data/retryable_reads/{listCollections.yml → legacy/listCollections.yml} +0 -0
  866. /data/spec/spec_tests/data/retryable_reads/{listDatabaseNames-serverErrors.yml → legacy/listDatabaseNames-serverErrors.yml} +0 -0
  867. /data/spec/spec_tests/data/retryable_reads/{listDatabaseNames.yml → legacy/listDatabaseNames.yml} +0 -0
  868. /data/spec/spec_tests/data/retryable_reads/{listDatabaseObjects-serverErrors.yml → legacy/listDatabaseObjects-serverErrors.yml} +0 -0
  869. /data/spec/spec_tests/data/retryable_reads/{listDatabaseObjects.yml → legacy/listDatabaseObjects.yml} +0 -0
  870. /data/spec/spec_tests/data/retryable_reads/{listDatabases-serverErrors.yml → legacy/listDatabases-serverErrors.yml} +0 -0
  871. /data/spec/spec_tests/data/retryable_reads/{listDatabases.yml → legacy/listDatabases.yml} +0 -0
  872. /data/spec/spec_tests/data/retryable_reads/{listIndexNames-serverErrors.yml → legacy/listIndexNames-serverErrors.yml} +0 -0
  873. /data/spec/spec_tests/data/retryable_reads/{listIndexNames.yml → legacy/listIndexNames.yml} +0 -0
  874. /data/spec/spec_tests/data/retryable_reads/{listIndexes-serverErrors.yml → legacy/listIndexes-serverErrors.yml} +0 -0
  875. /data/spec/spec_tests/data/retryable_reads/{listIndexes.yml → legacy/listIndexes.yml} +0 -0
  876. /data/spec/spec_tests/data/retryable_writes/{bulkWrite-errorLabels.yml → legacy/bulkWrite-errorLabels.yml} +0 -0
  877. /data/spec/spec_tests/data/retryable_writes/{bulkWrite.yml → legacy/bulkWrite.yml} +0 -0
  878. /data/spec/spec_tests/data/retryable_writes/{deleteMany.yml → legacy/deleteMany.yml} +0 -0
  879. /data/spec/spec_tests/data/retryable_writes/{deleteOne-errorLabels.yml → legacy/deleteOne-errorLabels.yml} +0 -0
  880. /data/spec/spec_tests/data/retryable_writes/{deleteOne.yml → legacy/deleteOne.yml} +0 -0
  881. /data/spec/spec_tests/data/retryable_writes/{findOneAndDelete-errorLabels.yml → legacy/findOneAndDelete-errorLabels.yml} +0 -0
  882. /data/spec/spec_tests/data/retryable_writes/{findOneAndDelete.yml → legacy/findOneAndDelete.yml} +0 -0
  883. /data/spec/spec_tests/data/retryable_writes/{findOneAndReplace-errorLabels.yml → legacy/findOneAndReplace-errorLabels.yml} +0 -0
  884. /data/spec/spec_tests/data/retryable_writes/{findOneAndReplace.yml → legacy/findOneAndReplace.yml} +0 -0
  885. /data/spec/spec_tests/data/retryable_writes/{findOneAndUpdate-errorLabels.yml → legacy/findOneAndUpdate-errorLabels.yml} +0 -0
  886. /data/spec/spec_tests/data/retryable_writes/{findOneAndUpdate.yml → legacy/findOneAndUpdate.yml} +0 -0
  887. /data/spec/spec_tests/data/retryable_writes/{insertMany-errorLabels.yml → legacy/insertMany-errorLabels.yml} +0 -0
  888. /data/spec/spec_tests/data/retryable_writes/{insertMany.yml → legacy/insertMany.yml} +0 -0
  889. /data/spec/spec_tests/data/retryable_writes/{insertOne-errorLabels.yml → legacy/insertOne-errorLabels.yml} +0 -0
  890. /data/spec/spec_tests/data/retryable_writes/{insertOne.yml → legacy/insertOne.yml} +0 -0
  891. /data/spec/spec_tests/data/retryable_writes/{replaceOne-errorLabels.yml → legacy/replaceOne-errorLabels.yml} +0 -0
  892. /data/spec/spec_tests/data/retryable_writes/{replaceOne.yml → legacy/replaceOne.yml} +0 -0
  893. /data/spec/spec_tests/data/retryable_writes/{updateMany.yml → legacy/updateMany.yml} +0 -0
  894. /data/spec/spec_tests/data/retryable_writes/{updateOne-errorLabels.yml → legacy/updateOne-errorLabels.yml} +0 -0
  895. /data/spec/spec_tests/data/retryable_writes/{updateOne.yml → legacy/updateOne.yml} +0 -0
  896. /data/spec/spec_tests/data/{dns_seedlist_discovery → seed_list_discovery/replica-set}/direct-connection-false.yml +0 -0
  897. /data/spec/spec_tests/data/{dns_seedlist_discovery → seed_list_discovery/replica-set}/direct-connection-true.yml +0 -0
  898. /data/spec/spec_tests/data/{dns_seedlist_discovery → seed_list_discovery/replica-set}/longer-parent-in-return.yml +0 -0
  899. /data/spec/spec_tests/data/{dns_seedlist_discovery → seed_list_discovery/replica-set}/misformatted-option.yml +0 -0
  900. /data/spec/spec_tests/data/{dns_seedlist_discovery → seed_list_discovery/replica-set}/no-results.yml +0 -0
  901. /data/spec/spec_tests/data/{dns_seedlist_discovery → seed_list_discovery/replica-set}/not-enough-parts.yml +0 -0
  902. /data/spec/spec_tests/data/{dns_seedlist_discovery → seed_list_discovery/replica-set}/one-result-default-port.yml +0 -0
  903. /data/spec/spec_tests/data/{dns_seedlist_discovery → seed_list_discovery/replica-set}/one-txt-record-multiple-strings.yml +0 -0
  904. /data/spec/spec_tests/data/{dns_seedlist_discovery → seed_list_discovery/replica-set}/one-txt-record.yml +0 -0
  905. /data/spec/spec_tests/data/{dns_seedlist_discovery → seed_list_discovery/replica-set}/parent-part-mismatch1.yml +0 -0
  906. /data/spec/spec_tests/data/{dns_seedlist_discovery → seed_list_discovery/replica-set}/parent-part-mismatch2.yml +0 -0
  907. /data/spec/spec_tests/data/{dns_seedlist_discovery → seed_list_discovery/replica-set}/parent-part-mismatch3.yml +0 -0
  908. /data/spec/spec_tests/data/{dns_seedlist_discovery → seed_list_discovery/replica-set}/parent-part-mismatch4.yml +0 -0
  909. /data/spec/spec_tests/data/{dns_seedlist_discovery → seed_list_discovery/replica-set}/parent-part-mismatch5.yml +0 -0
  910. /data/spec/spec_tests/data/{dns_seedlist_discovery → seed_list_discovery/replica-set}/returned-parent-too-short.yml +0 -0
  911. /data/spec/spec_tests/data/{dns_seedlist_discovery → seed_list_discovery/replica-set}/returned-parent-wrong.yml +0 -0
  912. /data/spec/spec_tests/data/{dns_seedlist_discovery → seed_list_discovery/replica-set}/two-results-default-port.yml +0 -0
  913. /data/spec/spec_tests/data/{dns_seedlist_discovery → seed_list_discovery/replica-set}/two-results-nonstandard-port.yml +0 -0
  914. /data/spec/spec_tests/data/{dns_seedlist_discovery → seed_list_discovery/replica-set}/two-txt-records.yml +0 -0
  915. /data/spec/spec_tests/data/{dns_seedlist_discovery → seed_list_discovery/replica-set}/txt-record-not-allowed-option.yml +0 -0
  916. /data/spec/spec_tests/data/{dns_seedlist_discovery → seed_list_discovery/replica-set}/txt-record-with-overridden-ssl-option.yml +0 -0
  917. /data/spec/spec_tests/data/{dns_seedlist_discovery → seed_list_discovery/replica-set}/txt-record-with-overridden-uri-option.yml +0 -0
  918. /data/spec/spec_tests/data/{dns_seedlist_discovery → seed_list_discovery/replica-set}/txt-record-with-unallowed-option.yml +0 -0
  919. /data/spec/spec_tests/data/{dns_seedlist_discovery → seed_list_discovery/replica-set}/uri-with-port.yml +0 -0
  920. /data/spec/spec_tests/data/{dns_seedlist_discovery → seed_list_discovery/replica-set}/uri-with-two-hosts.yml +0 -0
@@ -16,19 +16,17 @@
16
16
  # limitations under the License.
17
17
 
18
18
  module Mongo
19
- class Collection
20
- class View
19
+ module Operation
20
+ class Find
21
21
  module Builder
22
22
 
23
- # Provides behavior for mapping flags.
23
+ # Provides behavior for converting Ruby options to wire protocol flags
24
+ # when sending find and related commands (e.g. explain).
24
25
  #
25
- # @since 2.2.0
26
+ # @api private
26
27
  module Flags
27
- extend self
28
28
 
29
29
  # Options to cursor flags mapping.
30
- #
31
- # @since 2.2.0
32
30
  MAPPINGS = {
33
31
  :allow_partial_results => [ :partial ],
34
32
  :oplog_replay => [ :oplog_replay ],
@@ -36,20 +34,18 @@ module Mongo
36
34
  :tailable => [ :tailable_cursor ],
37
35
  :tailable_await => [ :await_data, :tailable_cursor],
38
36
  :await_data => [ :await_data ],
39
- :exhaust => [ :exhaust ]
37
+ :exhaust => [ :exhaust ],
40
38
  }.freeze
41
39
 
42
- # Maps an array of flags from the provided options.
40
+ # Converts Ruby find options to an array of flags.
43
41
  #
44
- # @example Map the flags.
45
- # Flags.map_flags(options)
42
+ # Any keys in the input hash that are not options that map to flags
43
+ # are ignored.
46
44
  #
47
45
  # @param [ Hash, BSON::Document ] options The options.
48
46
  #
49
47
  # @return [ Array<Symbol> ] The flags.
50
- #
51
- # @since 2.2.0
52
- def map_flags(options)
48
+ module_function def map_flags(options)
53
49
  MAPPINGS.each.reduce(options[:flags] || []) do |flags, (key, value)|
54
50
  cursor_type = options[:cursor_type]
55
51
  if options[key] || (cursor_type && cursor_type == key)
@@ -0,0 +1,123 @@
1
+ # frozen_string_literal: true
2
+ # encoding: utf-8
3
+
4
+ # Copyright (C) 2015-2020 MongoDB Inc.
5
+ #
6
+ # Licensed under the Apache License, Version 2.0 (the "License");
7
+ # you may not use this file except in compliance with the License.
8
+ # You may obtain a copy of the License at
9
+ #
10
+ # http://www.apache.org/licenses/LICENSE-2.0
11
+ #
12
+ # Unless required by applicable law or agreed to in writing, software
13
+ # distributed under the License is distributed on an "AS IS" BASIS,
14
+ # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
15
+ # See the License for the specific language governing permissions and
16
+ # limitations under the License.
17
+
18
+ module Mongo
19
+ module Operation
20
+ class Find
21
+ module Builder
22
+
23
+ # Builds a legacy OP_QUERY specification from options.
24
+ #
25
+ # @api private
26
+ module Legacy
27
+
28
+ # Mappings from driver options to legacy server values.
29
+ #
30
+ # @since 2.2.0
31
+ DRIVER_MAPPINGS = {
32
+ comment: '$comment',
33
+ explain: '$explain',
34
+ hint: '$hint',
35
+ max_scan: '$maxScan',
36
+ max_time_ms: '$maxTimeMS',
37
+ max_value: '$max',
38
+ min_value: '$min',
39
+ show_disk_loc: '$showDiskLoc',
40
+ snapshot: '$snapshot',
41
+ sort: '$orderby',
42
+ return_key: '$returnKey',
43
+ }.freeze
44
+
45
+ module_function def selector(spec, connection)
46
+ if Lint.enabled?
47
+ if spec.keys.any? { |k| String === k }
48
+ raise Error::LintError, "The spec must contain symbol keys only"
49
+ end
50
+ end
51
+
52
+ # Server versions that do not have the find command feature
53
+ # (versions older than 3.2) do not support the allow_disk_use option
54
+ # but perform no validation and will not raise an error if it is
55
+ # specified. If the allow_disk_use option is specified, raise an error
56
+ # to alert the user.
57
+ unless spec[:allow_disk_use].nil?
58
+ raise Error::UnsupportedOption.allow_disk_use_error
59
+ end
60
+
61
+ if spec[:collation] && !connection.features.collation_enabled?
62
+ raise Error::UnsupportedCollation
63
+ end
64
+
65
+ modifiers = {}
66
+ DRIVER_MAPPINGS.each do |k, server_k|
67
+ unless (value = spec[k]).nil?
68
+ modifiers[server_k] = value
69
+ end
70
+ end
71
+
72
+ selector = spec[:filter] || BSON::Document.new
73
+ # Write nil into rp if not talking to mongos, rather than false
74
+ rp = if connection.description.mongos?
75
+ read_pref_formatted(spec)
76
+ end
77
+ if modifiers.any? || rp
78
+ selector = {'$query' => selector}.update(modifiers)
79
+
80
+ if rp
81
+ selector['$readPreference'] = rp
82
+ end
83
+ end
84
+
85
+ selector
86
+ end
87
+
88
+ module_function def query_options(spec, connection)
89
+ query_options = {
90
+ project: spec[:projection],
91
+ skip: spec[:skip],
92
+ limit: spec[:limit],
93
+ # batch_size is converted to batchSize by Mongo::Protocol::Query.
94
+ batch_size: spec[:batch_size],
95
+ }
96
+
97
+ unless (flags = Builder::Flags.map_flags(spec)).empty?
98
+ query_options[:flags] = ((query_options[:flags] || []) + flags).uniq
99
+ end
100
+
101
+ query_options
102
+ end
103
+
104
+ private
105
+
106
+ module_function def read_pref_formatted(spec)
107
+ if spec[:read_preference]
108
+ raise ArgumentError, "Spec cannot include :read_preference here, use :read"
109
+ end
110
+
111
+ if read = spec[:read]
112
+ read_pref = ServerSelector.get(read).to_mongos
113
+ Mongo::Lint.validate_camel_case_read_preference(read_pref)
114
+ read_pref
115
+ else
116
+ nil
117
+ end
118
+ end
119
+ end
120
+ end
121
+ end
122
+ end
123
+ end
@@ -16,64 +16,70 @@
16
16
  # limitations under the License.
17
17
 
18
18
  module Mongo
19
- class Collection
20
- class View
19
+ module Operation
20
+ class Find
21
21
  module Builder
22
22
 
23
- # Provides behavior for mapping modifiers.
23
+ # Provides behavior for mapping Ruby options to legacy OP_QUERY
24
+ # find modifiers.
24
25
  #
25
- # @since 2.2.0
26
+ # This module is used in two ways:
27
+ # 1. When Collection#find is invoked with the legacy OP_QUERY
28
+ # syntax (:$query argument etc.), this module is used to map
29
+ # the legacy parameters into the Ruby options that normally
30
+ # are used by applications.
31
+ # 2. When sending a find operation using the OP_QUERY protocol,
32
+ # this module is used to map the Ruby find options to the
33
+ # modifiers in the wire protocol message.
34
+ #
35
+ # @api private
26
36
  module Modifiers
27
- extend self
28
37
 
29
- # Mappings from driver options to legacy server values.
30
- #
31
- # @since 2.2.0
38
+ # Mappings from Ruby options to OP_QUERY modifiers.
32
39
  DRIVER_MAPPINGS = BSON::Document.new(
33
- sort: '$orderby',
34
- hint: '$hint',
35
40
  comment: '$comment',
36
- snapshot: '$snapshot',
41
+ explain: '$explain',
42
+ hint: '$hint',
37
43
  max_scan: '$maxScan',
44
+ max_time_ms: '$maxTimeMS',
38
45
  max_value: '$max',
39
46
  min_value: '$min',
40
- max_time_ms: '$maxTimeMS',
41
47
  return_key: '$returnKey',
42
48
  show_disk_loc: '$showDiskLoc',
43
- explain: '$explain'
49
+ snapshot: '$snapshot',
50
+ sort: '$orderby',
44
51
  ).freeze
45
52
 
46
- # Mappings from server values to driver options.
47
- #
48
- # @since 2.2.0
53
+ # Mappings from OP_QUERY modifiers to Ruby options.
49
54
  SERVER_MAPPINGS = BSON::Document.new(DRIVER_MAPPINGS.invert).freeze
50
55
 
51
- # Transform the provided server modifiers to driver options.
56
+ # Transform the provided OP_QUERY modifiers to Ruby options.
52
57
  #
53
58
  # @example Transform to driver options.
54
59
  # Modifiers.map_driver_options(modifiers)
55
60
  #
56
61
  # @param [ Hash ] modifiers The modifiers.
57
62
  #
58
- # @return [ BSON::Document ] The driver options.
59
- #
60
- # @since 2.2.0
61
- def self.map_driver_options(modifiers)
63
+ # @return [ BSON::Document ] The Ruby options.
64
+ module_function def map_driver_options(modifiers)
62
65
  Options::Mapper.transform_documents(modifiers, SERVER_MAPPINGS)
63
66
  end
64
67
 
65
- # Transform the provided options into a document of only server
68
+ # Transform the provided Ruby options into a document of OP_QUERY
66
69
  # modifiers.
67
70
  #
71
+ # Accepts both string and symbol keys.
72
+ #
73
+ # The input mapping may contain additional keys that do not map to
74
+ # OP_QUERY modifiers, in which case the extra keys are ignored.
75
+ #
68
76
  # @example Map the server modifiers.
69
77
  # Modifiers.map_server_modifiers(options)
70
78
  #
71
79
  # @param [ Hash, BSON::Document ] options The options.
72
80
  #
73
81
  # @return [ BSON::Document ] The modifiers.
74
- #
75
- # @since 2.2.0
76
- def self.map_server_modifiers(options)
82
+ module_function def map_server_modifiers(options)
77
83
  Options::Mapper.transform_documents(options, DRIVER_MAPPINGS)
78
84
  end
79
85
  end
@@ -15,7 +15,7 @@
15
15
  # See the License for the specific language governing permissions and
16
16
  # limitations under the License.
17
17
 
18
- require 'mongo/cursor/builder/op_get_more'
19
- require 'mongo/cursor/builder/op_kill_cursors'
20
- require 'mongo/cursor/builder/get_more_command'
21
- require 'mongo/cursor/builder/kill_cursors_command'
18
+ require 'mongo/operation/find/builder/command'
19
+ require 'mongo/operation/find/builder/flags'
20
+ require 'mongo/operation/find/builder/legacy'
21
+ require 'mongo/operation/find/builder/modifiers'
@@ -33,6 +33,15 @@ module Mongo
33
33
 
34
34
  private
35
35
 
36
+ def selector(connection)
37
+ # The mappings are BSON::Documents and as such store keys as
38
+ # strings, the spec here has symbol keys
39
+ spec = BSON::Document.new(self.spec)
40
+ {
41
+ find: coll_name,
42
+ }.update(Find::Builder::Command.selector(spec, connection))
43
+ end
44
+
36
45
  def message(connection)
37
46
  Protocol::Query.new(db_name, Database::COMMAND, command(connection), options(connection))
38
47
  end
@@ -35,7 +35,16 @@ module Mongo
35
35
  private
36
36
 
37
37
  def message(connection)
38
- Protocol::Query.new(db_name, coll_name, command(connection), options(connection))
38
+ selector = Find::Builder::Legacy.selector(spec, connection)
39
+ options = options(connection).update(
40
+ Find::Builder::Legacy.query_options(spec, connection),
41
+ )
42
+ Protocol::Query.new(
43
+ db_name,
44
+ coll_name,
45
+ selector,
46
+ options,
47
+ )
39
48
  end
40
49
  end
41
50
  end
@@ -28,6 +28,18 @@ module Mongo
28
28
  include CausalConsistencySupported
29
29
  include ExecutableTransactionLabel
30
30
  include PolymorphicResult
31
+
32
+ private
33
+
34
+ def selector(connection)
35
+ # The mappings are BSON::Documents and as such store keys as
36
+ # strings, the spec here has symbol keys.
37
+ spec = BSON::Document.new(self.spec)
38
+ {
39
+ find: coll_name,
40
+ Protocol::Msg::DATABASE_IDENTIFIER => db_name,
41
+ }.update(Find::Builder::Command.selector(spec, connection))
42
+ end
31
43
  end
32
44
  end
33
45
  end
@@ -19,6 +19,7 @@ require 'mongo/operation/find/command'
19
19
  require 'mongo/operation/find/op_msg'
20
20
  require 'mongo/operation/find/legacy'
21
21
  require 'mongo/operation/find/result'
22
+ require 'mongo/operation/find/builder'
22
23
 
23
24
  module Mongo
24
25
  module Operation
@@ -30,6 +30,7 @@ module Mongo
30
30
  include Limited
31
31
  include ReadPreferenceSupported
32
32
  include PolymorphicResult
33
+ include CommandBuilder
33
34
 
34
35
  private
35
36
 
@@ -0,0 +1,42 @@
1
+ # frozen_string_literal: true
2
+ # encoding: utf-8
3
+
4
+ # Copyright (C) 2021 MongoDB Inc.
5
+ #
6
+ # Licensed under the Apache License, Version 2.0 (the "License");
7
+ # you may not use this file except in compliance with the License.
8
+ # You may obtain a copy of the License at
9
+ #
10
+ # http://www.apache.org/licenses/LICENSE-2.0
11
+ #
12
+ # Unless required by applicable law or agreed to in writing, software
13
+ # distributed under the License is distributed on an "AS IS" BASIS,
14
+ # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
15
+ # See the License for the specific language governing permissions and
16
+ # limitations under the License.
17
+
18
+ module Mongo
19
+ module Operation
20
+ class GetMore
21
+
22
+ # @api private
23
+ module CommandBuilder
24
+
25
+ private
26
+
27
+ def selector(connection)
28
+ {
29
+ getMore: BSON::Int64.new(spec.fetch(:cursor_id)),
30
+ collection: spec.fetch(:coll_name),
31
+ batchSize: spec[:batch_size],
32
+ maxTimeMS: spec[:max_time_ms],
33
+ }.compact.tap do |sel|
34
+ if spec[:comment] && connection.features.get_more_comment_enabled?
35
+ sel[:comment] = spec[:comment]
36
+ end
37
+ end
38
+ end
39
+ end
40
+ end
41
+ end
42
+ end
@@ -27,6 +27,7 @@ module Mongo
27
27
  class OpMsg < OpMsgBase
28
28
  include ExecutableTransactionLabel
29
29
  include PolymorphicResult
30
+ include CommandBuilder
30
31
  end
31
32
  end
32
33
  end
@@ -15,6 +15,7 @@
15
15
  # See the License for the specific language governing permissions and
16
16
  # limitations under the License.
17
17
 
18
+ require 'mongo/operation/get_more/command_builder'
18
19
  require 'mongo/operation/get_more/command'
19
20
  require 'mongo/operation/get_more/op_msg'
20
21
  require 'mongo/operation/get_more/legacy'
@@ -41,13 +41,17 @@ module Mongo
41
41
  # @param [ Server::Description ] connection_description
42
42
  # Server description of the server that performed the operation that
43
43
  # this result is for.
44
+ # @param [ Integer ] connection_global_id
45
+ # Global id of the connection on which the operation that
46
+ # this result is for was performed.
44
47
  # @param [ Array<Object> ] ids The ids of the inserted documents.
45
48
  #
46
49
  # @since 2.0.0
47
50
  # @api private
48
- def initialize(replies, connection_description, ids)
51
+ def initialize(replies, connection_description, connection_global_id, ids)
49
52
  @replies = [*replies] if replies
50
53
  @connection_description = connection_description
54
+ @connection_global_id = connection_global_id
51
55
  if replies && replies.first && (doc = replies.first.documents.first)
52
56
  if errors = doc['writeErrors']
53
57
  # some documents were potentially inserted
@@ -46,10 +46,6 @@ module Mongo
46
46
  ordered: ordered? }
47
47
  end
48
48
 
49
- def options(server)
50
- super.merge(validating_keys: true)
51
- end
52
-
53
49
  def message(connection)
54
50
  Protocol::Query.new(db_name, Database::COMMAND, command(connection), options(connection))
55
51
  end
@@ -39,14 +39,17 @@ module Mongo
39
39
  end
40
40
 
41
41
  def selector(connection)
42
- { insert: coll_name,
42
+ {
43
+ insert: coll_name,
43
44
  Protocol::Msg::DATABASE_IDENTIFIER => db_name,
44
- ordered: ordered? }
45
+ ordered: ordered?,
46
+ comment: spec[:comment],
47
+ }.compact
45
48
  end
46
49
 
47
50
  def message(connection)
48
51
  section = Protocol::Msg::Section1.new(IDENTIFIER, send(IDENTIFIER))
49
- Protocol::Msg.new(flags, { validating_keys: true }, command(connection), section)
52
+ Protocol::Msg.new(flags, {}, command(connection), section)
50
53
  end
51
54
  end
52
55
  end
@@ -43,12 +43,15 @@ module Mongo
43
43
  # @param [ Server::Description ] connection_description
44
44
  # Server description of the server that performed the operation that
45
45
  # this result is for.
46
+ # @param [ Integer ] connection_global_id
47
+ # Global id of the connection on which the operation that
48
+ # this result is for was performed.
46
49
  # @param [ Array<Object> ] ids The ids of the inserted documents.
47
50
  #
48
51
  # @since 2.0.0
49
52
  # @api private
50
- def initialize(replies, connection_description, ids)
51
- super(replies, connection_description)
53
+ def initialize(replies, connection_description, connection_global_id, ids)
54
+ super(replies, connection_description, connection_global_id)
52
55
  @inserted_ids = ids
53
56
  end
54
57
 
@@ -67,7 +70,7 @@ module Mongo
67
70
 
68
71
  # @api public
69
72
  def bulk_result
70
- BulkResult.new(@replies, connection_description, @inserted_ids)
73
+ BulkResult.new(@replies, connection_description, connection_global_id, @inserted_ids)
71
74
  end
72
75
  end
73
76
  end
@@ -17,7 +17,6 @@
17
17
 
18
18
  require 'mongo/operation/insert/command'
19
19
  require 'mongo/operation/insert/op_msg'
20
- require 'mongo/operation/insert/legacy'
21
20
  require 'mongo/operation/insert/result'
22
21
  require 'mongo/operation/insert/bulk_result'
23
22
 
@@ -28,9 +28,17 @@ module Mongo
28
28
  include Specifiable
29
29
  include Executable
30
30
  include Limited
31
+ include CommandBuilder
31
32
 
32
33
  private
33
34
 
35
+ def selector(connection)
36
+ {
37
+ killCursors: coll_name,
38
+ cursors: int64_cursor_ids,
39
+ }
40
+ end
41
+
34
42
  def message(connection)
35
43
  Protocol::Query.new(db_name, Database::COMMAND, selector(connection), options(connection))
36
44
  end
@@ -1,7 +1,7 @@
1
1
  # frozen_string_literal: true
2
2
  # encoding: utf-8
3
3
 
4
- # Copyright (C) 2014-2020 MongoDB Inc.
4
+ # Copyright (C) 2021 MongoDB Inc.
5
5
  #
6
6
  # Licensed under the Apache License, Version 2.0 (the "License");
7
7
  # you may not use this file except in compliance with the License.
@@ -19,22 +19,17 @@ module Mongo
19
19
  module Operation
20
20
  class KillCursors
21
21
 
22
- # A MongoDB killcursors operation sent as a legacy wire protocol message.
23
- #
24
22
  # @api private
25
- #
26
- # @since 2.5.2
27
- class Legacy
28
- include Specifiable
29
- include Executable
23
+ module CommandBuilder
30
24
 
31
25
  private
32
26
 
33
- def message(connection)
34
- Protocol::KillCursors.new(coll_name, db_name, cursor_ids)
27
+ def int64_cursor_ids
28
+ spec.fetch(:cursor_ids).map do |id|
29
+ BSON::Int64.new(id)
30
+ end
35
31
  end
36
32
  end
37
33
  end
38
34
  end
39
35
  end
40
-
@@ -26,6 +26,16 @@ module Mongo
26
26
  # @since 2.5.2
27
27
  class OpMsg < OpMsgBase
28
28
  include ExecutableTransactionLabel
29
+ include CommandBuilder
30
+
31
+ private
32
+
33
+ def selector(connection)
34
+ {
35
+ killCursors: coll_name,
36
+ cursors: int64_cursor_ids,
37
+ }
38
+ end
29
39
  end
30
40
  end
31
41
  end
@@ -15,9 +15,9 @@
15
15
  # See the License for the specific language governing permissions and
16
16
  # limitations under the License.
17
17
 
18
+ require 'mongo/operation/kill_cursors/command_builder'
18
19
  require 'mongo/operation/kill_cursors/command'
19
20
  require 'mongo/operation/kill_cursors/op_msg'
20
- require 'mongo/operation/kill_cursors/legacy'
21
21
 
22
22
  module Mongo
23
23
  module Operation
@@ -31,7 +31,10 @@ module Mongo
31
31
  private
32
32
 
33
33
  def selector(connection)
34
- (spec[SELECTOR] || {}).merge(listCollections: 1)
34
+ (spec[SELECTOR] || {}).merge({
35
+ listCollections: 1,
36
+ comment: spec[:comment]
37
+ }).compact
35
38
  end
36
39
  end
37
40
  end
@@ -34,6 +34,14 @@ module Mongo
34
34
 
35
35
  private
36
36
 
37
+ def selector(connection)
38
+ super.tap do |selector|
39
+ if selector[:collation] && !connection.features.collation_enabled?
40
+ raise Error::UnsupportedCollation
41
+ end
42
+ end
43
+ end
44
+
37
45
  def message(connection)
38
46
  Protocol::Query.new(db_name, Database::COMMAND, command(connection), options(connection))
39
47
  end
@@ -19,7 +19,7 @@ module Mongo
19
19
  module Operation
20
20
  class MapReduce
21
21
 
22
- # A MongoDB mapreduce operation sent as an op message.
22
+ # A MongoDB map-reduce operation sent as an op message.
23
23
  #
24
24
  # @api private
25
25
  #
@@ -131,6 +131,22 @@ module Mongo
131
131
  0
132
132
  end
133
133
 
134
+ # Get the number of documents returned by the server in this batch.
135
+ #
136
+ # Map/Reduce operation returns documents inline without using
137
+ # cursors; as such, the standard Mongo::Reply#returned_count does
138
+ # not work correctly for Map/Reduce.
139
+ #
140
+ # Note that the Map/Reduce operation is limited to max BSON document
141
+ # size (16 MB) in its inline result set.
142
+ #
143
+ # @return [ Integer ] The number of documents returned.
144
+ #
145
+ # @api public
146
+ def returned_count
147
+ reply.documents.length
148
+ end
149
+
134
150
  private
135
151
 
136
152
  def first_document