mongo 2.12.4 → 2.13.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 (854) hide show
  1. checksums.yaml +4 -4
  2. checksums.yaml.gz.sig +0 -0
  3. data.tar.gz.sig +0 -0
  4. data/CONTRIBUTING.md +8 -36
  5. data/LICENSE +1 -1
  6. data/README.md +54 -54
  7. data/Rakefile +16 -10
  8. data/lib/mongo.rb +8 -3
  9. data/lib/mongo/active_support.rb +1 -1
  10. data/lib/mongo/address.rb +40 -13
  11. data/lib/mongo/address/ipv4.rb +32 -5
  12. data/lib/mongo/address/ipv6.rb +32 -5
  13. data/lib/mongo/address/unix.rb +3 -3
  14. data/lib/mongo/address/validator.rb +1 -1
  15. data/lib/mongo/auth.rb +36 -13
  16. data/lib/mongo/auth/aws.rb +37 -0
  17. data/lib/mongo/auth/aws/conversation.rb +128 -0
  18. data/lib/mongo/auth/aws/credentials_retriever.rb +219 -0
  19. data/lib/mongo/auth/aws/request.rb +283 -0
  20. data/lib/mongo/auth/base.rb +129 -0
  21. data/lib/mongo/auth/conversation_base.rb +52 -0
  22. data/lib/mongo/auth/cr.rb +9 -36
  23. data/lib/mongo/auth/cr/conversation.rb +24 -69
  24. data/lib/mongo/auth/credential_cache.rb +1 -1
  25. data/lib/mongo/auth/gssapi.rb +38 -0
  26. data/lib/mongo/auth/gssapi/conversation.rb +108 -0
  27. data/lib/mongo/auth/ldap.rb +9 -34
  28. data/lib/mongo/auth/ldap/conversation.rb +3 -43
  29. data/lib/mongo/auth/roles.rb +1 -1
  30. data/lib/mongo/auth/sasl_conversation_base.rb +111 -0
  31. data/lib/mongo/auth/scram.rb +39 -51
  32. data/lib/mongo/auth/scram/conversation.rb +12 -506
  33. data/lib/mongo/auth/scram256.rb +31 -0
  34. data/lib/mongo/auth/scram256/conversation.rb +63 -0
  35. data/lib/mongo/auth/scram_conversation_base.rb +402 -0
  36. data/lib/mongo/auth/stringprep.rb +5 -4
  37. data/lib/mongo/auth/stringprep/profiles/sasl.rb +2 -1
  38. data/lib/mongo/auth/stringprep/tables.rb +2 -1
  39. data/lib/mongo/auth/stringprep/unicode_normalize/normalize.rb +1 -0
  40. data/lib/mongo/auth/stringprep/unicode_normalize/tables.rb +1 -0
  41. data/lib/mongo/auth/user.rb +2 -2
  42. data/lib/mongo/auth/user/view.rb +1 -1
  43. data/lib/mongo/auth/x509.rb +14 -32
  44. data/lib/mongo/auth/x509/conversation.rb +15 -42
  45. data/lib/mongo/background_thread.rb +11 -2
  46. data/lib/mongo/bson.rb +1 -1
  47. data/lib/mongo/bulk_write.rb +62 -26
  48. data/lib/mongo/bulk_write/combineable.rb +20 -8
  49. data/lib/mongo/bulk_write/ordered_combiner.rb +1 -1
  50. data/lib/mongo/bulk_write/result.rb +1 -1
  51. data/lib/mongo/bulk_write/result_combiner.rb +1 -1
  52. data/lib/mongo/bulk_write/transformable.rb +9 -10
  53. data/lib/mongo/bulk_write/unordered_combiner.rb +1 -1
  54. data/lib/mongo/bulk_write/validatable.rb +5 -1
  55. data/lib/mongo/client.rb +216 -44
  56. data/lib/mongo/client_encryption.rb +1 -1
  57. data/lib/mongo/cluster.rb +177 -69
  58. data/lib/mongo/cluster/periodic_executor.rb +1 -1
  59. data/lib/mongo/cluster/reapers/cursor_reaper.rb +1 -1
  60. data/lib/mongo/cluster/reapers/socket_reaper.rb +1 -1
  61. data/lib/mongo/cluster/sdam_flow.rb +36 -17
  62. data/lib/mongo/cluster/topology.rb +19 -2
  63. data/lib/mongo/cluster/topology/base.rb +1 -1
  64. data/lib/mongo/cluster/topology/no_replica_set_options.rb +1 -1
  65. data/lib/mongo/cluster/topology/replica_set_no_primary.rb +4 -3
  66. data/lib/mongo/cluster/topology/replica_set_with_primary.rb +1 -1
  67. data/lib/mongo/cluster/topology/sharded.rb +2 -2
  68. data/lib/mongo/cluster/topology/single.rb +2 -2
  69. data/lib/mongo/cluster/topology/unknown.rb +1 -1
  70. data/lib/mongo/cluster_time.rb +1 -1
  71. data/lib/mongo/collection.rb +41 -21
  72. data/lib/mongo/collection/view.rb +6 -2
  73. data/lib/mongo/collection/view/aggregation.rb +6 -3
  74. data/lib/mongo/collection/view/builder.rb +1 -1
  75. data/lib/mongo/collection/view/builder/aggregation.rb +1 -1
  76. data/lib/mongo/collection/view/builder/find_command.rb +9 -1
  77. data/lib/mongo/collection/view/builder/flags.rb +1 -1
  78. data/lib/mongo/collection/view/builder/map_reduce.rb +1 -1
  79. data/lib/mongo/collection/view/builder/modifiers.rb +1 -1
  80. data/lib/mongo/collection/view/builder/op_query.rb +1 -1
  81. data/lib/mongo/collection/view/change_stream.rb +3 -6
  82. data/lib/mongo/collection/view/change_stream/retryable.rb +1 -1
  83. data/lib/mongo/collection/view/explainable.rb +1 -1
  84. data/lib/mongo/collection/view/immutable.rb +1 -1
  85. data/lib/mongo/collection/view/iterable.rb +8 -2
  86. data/lib/mongo/collection/view/map_reduce.rb +7 -4
  87. data/lib/mongo/collection/view/readable.rb +10 -2
  88. data/lib/mongo/collection/view/writable.rb +93 -13
  89. data/lib/mongo/crypt.rb +1 -1
  90. data/lib/mongo/crypt/auto_decryption_context.rb +1 -1
  91. data/lib/mongo/crypt/auto_encrypter.rb +1 -1
  92. data/lib/mongo/crypt/auto_encryption_context.rb +1 -1
  93. data/lib/mongo/crypt/binary.rb +1 -1
  94. data/lib/mongo/crypt/binding.rb +1 -1
  95. data/lib/mongo/crypt/context.rb +1 -1
  96. data/lib/mongo/crypt/data_key_context.rb +1 -1
  97. data/lib/mongo/crypt/encryption_io.rb +41 -24
  98. data/lib/mongo/crypt/explicit_decryption_context.rb +1 -1
  99. data/lib/mongo/crypt/explicit_encrypter.rb +1 -1
  100. data/lib/mongo/crypt/explicit_encryption_context.rb +1 -1
  101. data/lib/mongo/crypt/handle.rb +1 -1
  102. data/lib/mongo/crypt/hooks.rb +1 -1
  103. data/lib/mongo/crypt/kms_context.rb +1 -1
  104. data/lib/mongo/crypt/status.rb +1 -1
  105. data/lib/mongo/cursor.rb +3 -3
  106. data/lib/mongo/cursor/builder.rb +1 -1
  107. data/lib/mongo/cursor/builder/get_more_command.rb +1 -1
  108. data/lib/mongo/cursor/builder/kill_cursors_command.rb +1 -1
  109. data/lib/mongo/cursor/builder/op_get_more.rb +1 -1
  110. data/lib/mongo/cursor/builder/op_kill_cursors.rb +1 -1
  111. data/lib/mongo/database.rb +35 -5
  112. data/lib/mongo/database/view.rb +21 -6
  113. data/lib/mongo/dbref.rb +1 -1
  114. data/lib/mongo/distinguishing_semaphore.rb +55 -0
  115. data/lib/mongo/error.rb +28 -2
  116. data/lib/mongo/error/auth_error.rb +1 -1
  117. data/lib/mongo/error/bulk_write_error.rb +1 -1
  118. data/lib/mongo/error/change_stream_resumable.rb +1 -1
  119. data/lib/mongo/error/closed_stream.rb +1 -1
  120. data/lib/mongo/error/connection_check_out_timeout.rb +1 -1
  121. data/lib/mongo/error/connection_perished.rb +23 -0
  122. data/lib/mongo/error/credential_check_error.rb +26 -0
  123. data/lib/mongo/error/extra_file_chunk.rb +1 -1
  124. data/lib/mongo/error/file_not_found.rb +1 -1
  125. data/lib/mongo/error/handshake_error.rb +1 -1
  126. data/lib/mongo/error/insufficient_iteration_count.rb +1 -1
  127. data/lib/mongo/error/invalid_address.rb +1 -1
  128. data/lib/mongo/error/invalid_application_name.rb +1 -1
  129. data/lib/mongo/error/invalid_bulk_operation.rb +1 -1
  130. data/lib/mongo/error/invalid_bulk_operation_type.rb +1 -1
  131. data/lib/mongo/error/invalid_collection_name.rb +1 -1
  132. data/lib/mongo/error/invalid_cursor_operation.rb +1 -1
  133. data/lib/mongo/error/invalid_database_name.rb +1 -1
  134. data/lib/mongo/error/invalid_document.rb +1 -1
  135. data/lib/mongo/error/invalid_file.rb +1 -1
  136. data/lib/mongo/error/invalid_file_revision.rb +1 -1
  137. data/lib/mongo/error/invalid_min_pool_size.rb +1 -1
  138. data/lib/mongo/error/invalid_nonce.rb +2 -2
  139. data/lib/mongo/error/invalid_read_option.rb +1 -1
  140. data/lib/mongo/error/invalid_replacement_document.rb +1 -1
  141. data/lib/mongo/error/invalid_server_auth_host.rb +22 -0
  142. data/lib/mongo/error/invalid_server_auth_response.rb +23 -0
  143. data/lib/mongo/error/invalid_server_preference.rb +6 -1
  144. data/lib/mongo/error/invalid_session.rb +3 -2
  145. data/lib/mongo/error/invalid_signature.rb +1 -1
  146. data/lib/mongo/error/invalid_transaction_operation.rb +1 -1
  147. data/lib/mongo/error/invalid_txt_record.rb +1 -1
  148. data/lib/mongo/error/invalid_update_document.rb +1 -1
  149. data/lib/mongo/error/invalid_uri.rb +1 -1
  150. data/lib/mongo/error/invalid_write_concern.rb +1 -1
  151. data/lib/mongo/error/lint_error.rb +1 -1
  152. data/lib/mongo/error/max_bson_size.rb +1 -1
  153. data/lib/mongo/error/max_message_size.rb +1 -1
  154. data/lib/mongo/error/mismatched_domain.rb +1 -1
  155. data/lib/mongo/error/missing_file_chunk.rb +1 -1
  156. data/lib/mongo/error/missing_password.rb +1 -1
  157. data/lib/mongo/error/missing_resume_token.rb +1 -1
  158. data/lib/mongo/error/missing_scram_server_signature.rb +27 -0
  159. data/lib/mongo/error/multi_index_drop.rb +1 -1
  160. data/lib/mongo/error/need_primary_server.rb +1 -1
  161. data/lib/mongo/error/no_server_available.rb +1 -1
  162. data/lib/mongo/error/no_srv_records.rb +1 -1
  163. data/lib/mongo/error/notable.rb +18 -3
  164. data/lib/mongo/error/operation_failure.rb +68 -49
  165. data/lib/mongo/error/parser.rb +16 -5
  166. data/lib/mongo/error/pool_closed_error.rb +1 -1
  167. data/lib/mongo/error/raise_original_error.rb +29 -0
  168. data/lib/mongo/error/session_ended.rb +1 -1
  169. data/lib/mongo/error/sessions_not_supported.rb +35 -0
  170. data/lib/mongo/error/socket_error.rb +1 -1
  171. data/lib/mongo/error/socket_timeout_error.rb +1 -1
  172. data/lib/mongo/error/unchangeable_collection_option.rb +1 -1
  173. data/lib/mongo/error/unexpected_chunk_length.rb +1 -1
  174. data/lib/mongo/error/unexpected_response.rb +1 -1
  175. data/lib/mongo/error/unknown_payload_type.rb +1 -1
  176. data/lib/mongo/error/unsupported_array_filters.rb +7 -2
  177. data/lib/mongo/error/unsupported_collation.rb +7 -2
  178. data/lib/mongo/error/unsupported_features.rb +1 -1
  179. data/lib/mongo/error/unsupported_message_type.rb +1 -1
  180. data/lib/mongo/error/unsupported_option.rb +99 -0
  181. data/lib/mongo/error/write_retryable.rb +1 -1
  182. data/lib/mongo/event.rb +1 -1
  183. data/lib/mongo/event/base.rb +7 -1
  184. data/lib/mongo/event/listeners.rb +1 -1
  185. data/lib/mongo/event/publisher.rb +1 -1
  186. data/lib/mongo/event/subscriber.rb +1 -1
  187. data/lib/mongo/grid.rb +1 -1
  188. data/lib/mongo/grid/file.rb +1 -1
  189. data/lib/mongo/grid/file/chunk.rb +1 -1
  190. data/lib/mongo/grid/file/info.rb +1 -1
  191. data/lib/mongo/grid/fs_bucket.rb +9 -4
  192. data/lib/mongo/grid/stream.rb +1 -1
  193. data/lib/mongo/grid/stream/read.rb +1 -1
  194. data/lib/mongo/grid/stream/write.rb +1 -1
  195. data/lib/mongo/id.rb +1 -1
  196. data/lib/mongo/index.rb +2 -1
  197. data/lib/mongo/index/view.rb +61 -11
  198. data/lib/mongo/lint.rb +10 -0
  199. data/lib/mongo/loggable.rb +1 -1
  200. data/lib/mongo/logger.rb +1 -1
  201. data/lib/mongo/monitoring.rb +39 -1
  202. data/lib/mongo/monitoring/cmap_log_subscriber.rb +1 -1
  203. data/lib/mongo/monitoring/command_log_subscriber.rb +20 -5
  204. data/lib/mongo/monitoring/event.rb +1 -1
  205. data/lib/mongo/monitoring/event/cmap.rb +1 -1
  206. data/lib/mongo/monitoring/event/cmap/base.rb +1 -1
  207. data/lib/mongo/monitoring/event/cmap/connection_check_out_failed.rb +1 -1
  208. data/lib/mongo/monitoring/event/cmap/connection_check_out_started.rb +1 -1
  209. data/lib/mongo/monitoring/event/cmap/connection_checked_in.rb +1 -1
  210. data/lib/mongo/monitoring/event/cmap/connection_checked_out.rb +1 -1
  211. data/lib/mongo/monitoring/event/cmap/connection_closed.rb +1 -1
  212. data/lib/mongo/monitoring/event/cmap/connection_created.rb +1 -1
  213. data/lib/mongo/monitoring/event/cmap/connection_ready.rb +1 -1
  214. data/lib/mongo/monitoring/event/cmap/pool_cleared.rb +1 -1
  215. data/lib/mongo/monitoring/event/cmap/pool_closed.rb +1 -1
  216. data/lib/mongo/monitoring/event/cmap/pool_created.rb +1 -1
  217. data/lib/mongo/monitoring/event/command_failed.rb +12 -1
  218. data/lib/mongo/monitoring/event/command_started.rb +44 -3
  219. data/lib/mongo/monitoring/event/command_succeeded.rb +12 -1
  220. data/lib/mongo/monitoring/event/secure.rb +8 -2
  221. data/lib/mongo/monitoring/event/server_closed.rb +2 -2
  222. data/lib/mongo/monitoring/event/server_description_changed.rb +28 -5
  223. data/lib/mongo/monitoring/event/server_heartbeat_failed.rb +10 -3
  224. data/lib/mongo/monitoring/event/server_heartbeat_started.rb +10 -3
  225. data/lib/mongo/monitoring/event/server_heartbeat_succeeded.rb +10 -3
  226. data/lib/mongo/monitoring/event/server_opening.rb +2 -2
  227. data/lib/mongo/monitoring/event/topology_changed.rb +2 -2
  228. data/lib/mongo/monitoring/event/topology_closed.rb +2 -2
  229. data/lib/mongo/monitoring/event/topology_opening.rb +2 -2
  230. data/lib/mongo/monitoring/publishable.rb +9 -9
  231. data/lib/mongo/monitoring/sdam_log_subscriber.rb +1 -1
  232. data/lib/mongo/monitoring/server_closed_log_subscriber.rb +1 -1
  233. data/lib/mongo/monitoring/server_description_changed_log_subscriber.rb +10 -2
  234. data/lib/mongo/monitoring/server_opening_log_subscriber.rb +1 -1
  235. data/lib/mongo/monitoring/topology_changed_log_subscriber.rb +2 -2
  236. data/lib/mongo/monitoring/topology_closed_log_subscriber.rb +1 -1
  237. data/lib/mongo/monitoring/topology_opening_log_subscriber.rb +1 -1
  238. data/lib/mongo/monitoring/unified_sdam_log_subscriber.rb +1 -1
  239. data/lib/mongo/operation.rb +1 -0
  240. data/lib/mongo/operation/aggregate.rb +1 -1
  241. data/lib/mongo/operation/aggregate/command.rb +5 -5
  242. data/lib/mongo/operation/aggregate/op_msg.rb +1 -1
  243. data/lib/mongo/operation/aggregate/result.rb +1 -1
  244. data/lib/mongo/operation/collections_info.rb +3 -36
  245. data/lib/mongo/operation/collections_info/command.rb +40 -0
  246. data/lib/mongo/operation/collections_info/result.rb +1 -1
  247. data/lib/mongo/operation/command.rb +1 -1
  248. data/lib/mongo/operation/command/command.rb +3 -3
  249. data/lib/mongo/operation/command/op_msg.rb +1 -1
  250. data/lib/mongo/operation/count.rb +1 -1
  251. data/lib/mongo/operation/count/command.rb +3 -3
  252. data/lib/mongo/operation/count/op_msg.rb +1 -1
  253. data/lib/mongo/operation/create.rb +1 -1
  254. data/lib/mongo/operation/create/command.rb +3 -3
  255. data/lib/mongo/operation/create/op_msg.rb +1 -1
  256. data/lib/mongo/operation/create_index.rb +1 -1
  257. data/lib/mongo/operation/create_index/command.rb +4 -4
  258. data/lib/mongo/operation/create_index/op_msg.rb +6 -3
  259. data/lib/mongo/operation/create_user.rb +1 -1
  260. data/lib/mongo/operation/create_user/command.rb +4 -4
  261. data/lib/mongo/operation/create_user/op_msg.rb +2 -2
  262. data/lib/mongo/operation/delete.rb +1 -1
  263. data/lib/mongo/operation/delete/bulk_result.rb +1 -1
  264. data/lib/mongo/operation/delete/command.rb +4 -4
  265. data/lib/mongo/operation/delete/legacy.rb +2 -2
  266. data/lib/mongo/operation/delete/op_msg.rb +4 -4
  267. data/lib/mongo/operation/delete/result.rb +2 -2
  268. data/lib/mongo/operation/distinct.rb +1 -1
  269. data/lib/mongo/operation/distinct/command.rb +3 -3
  270. data/lib/mongo/operation/distinct/op_msg.rb +1 -1
  271. data/lib/mongo/operation/drop.rb +1 -1
  272. data/lib/mongo/operation/drop/command.rb +3 -3
  273. data/lib/mongo/operation/drop/op_msg.rb +1 -1
  274. data/lib/mongo/operation/drop_database.rb +1 -1
  275. data/lib/mongo/operation/drop_database/command.rb +3 -3
  276. data/lib/mongo/operation/drop_database/op_msg.rb +1 -1
  277. data/lib/mongo/operation/drop_index.rb +1 -1
  278. data/lib/mongo/operation/drop_index/command.rb +4 -4
  279. data/lib/mongo/operation/drop_index/op_msg.rb +2 -2
  280. data/lib/mongo/operation/explain.rb +1 -1
  281. data/lib/mongo/operation/explain/command.rb +3 -3
  282. data/lib/mongo/operation/explain/legacy.rb +3 -3
  283. data/lib/mongo/operation/explain/op_msg.rb +1 -1
  284. data/lib/mongo/operation/explain/result.rb +1 -1
  285. data/lib/mongo/operation/find.rb +1 -1
  286. data/lib/mongo/operation/find/command.rb +3 -3
  287. data/lib/mongo/operation/find/legacy.rb +3 -3
  288. data/lib/mongo/operation/find/legacy/result.rb +1 -1
  289. data/lib/mongo/operation/find/op_msg.rb +2 -12
  290. data/lib/mongo/operation/find/result.rb +1 -1
  291. data/lib/mongo/operation/get_more.rb +1 -1
  292. data/lib/mongo/operation/get_more/command.rb +3 -3
  293. data/lib/mongo/operation/get_more/legacy.rb +2 -2
  294. data/lib/mongo/operation/get_more/op_msg.rb +2 -12
  295. data/lib/mongo/operation/get_more/result.rb +1 -1
  296. data/lib/mongo/operation/indexes.rb +1 -1
  297. data/lib/mongo/operation/indexes/command.rb +3 -3
  298. data/lib/mongo/operation/indexes/legacy.rb +4 -4
  299. data/lib/mongo/operation/indexes/op_msg.rb +1 -1
  300. data/lib/mongo/operation/indexes/result.rb +1 -1
  301. data/lib/mongo/operation/insert.rb +3 -2
  302. data/lib/mongo/operation/insert/bulk_result.rb +6 -2
  303. data/lib/mongo/operation/insert/command.rb +7 -7
  304. data/lib/mongo/operation/insert/legacy.rb +9 -5
  305. data/lib/mongo/operation/insert/op_msg.rb +6 -6
  306. data/lib/mongo/operation/insert/result.rb +7 -4
  307. data/lib/mongo/operation/kill_cursors.rb +1 -1
  308. data/lib/mongo/operation/kill_cursors/command.rb +3 -3
  309. data/lib/mongo/operation/kill_cursors/legacy.rb +2 -2
  310. data/lib/mongo/operation/kill_cursors/op_msg.rb +1 -1
  311. data/lib/mongo/operation/list_collections.rb +1 -1
  312. data/lib/mongo/operation/list_collections/command.rb +4 -4
  313. data/lib/mongo/operation/list_collections/op_msg.rb +2 -2
  314. data/lib/mongo/operation/list_collections/result.rb +1 -1
  315. data/lib/mongo/operation/map_reduce.rb +1 -1
  316. data/lib/mongo/operation/map_reduce/command.rb +3 -3
  317. data/lib/mongo/operation/map_reduce/op_msg.rb +1 -1
  318. data/lib/mongo/operation/map_reduce/result.rb +1 -1
  319. data/lib/mongo/operation/op_msg_base.rb +3 -3
  320. data/lib/mongo/operation/parallel_scan.rb +1 -1
  321. data/lib/mongo/operation/parallel_scan/command.rb +5 -5
  322. data/lib/mongo/operation/parallel_scan/op_msg.rb +2 -2
  323. data/lib/mongo/operation/parallel_scan/result.rb +1 -1
  324. data/lib/mongo/operation/remove_user.rb +1 -1
  325. data/lib/mongo/operation/remove_user/command.rb +4 -4
  326. data/lib/mongo/operation/remove_user/op_msg.rb +2 -2
  327. data/lib/mongo/operation/result.rb +28 -4
  328. data/lib/mongo/operation/shared/bypass_document_validation.rb +10 -4
  329. data/lib/mongo/operation/shared/causal_consistency_supported.rb +3 -3
  330. data/lib/mongo/operation/shared/collections_info_or_list_collections.rb +56 -0
  331. data/lib/mongo/operation/shared/executable.rb +46 -28
  332. data/lib/mongo/operation/shared/executable_no_validate.rb +3 -3
  333. data/lib/mongo/operation/shared/executable_transaction_label.rb +1 -1
  334. data/lib/mongo/operation/shared/idable.rb +1 -1
  335. data/lib/mongo/operation/shared/limited.rb +10 -2
  336. data/lib/mongo/operation/shared/object_id_generator.rb +1 -1
  337. data/lib/mongo/operation/shared/op_msg_or_command.rb +7 -5
  338. data/lib/mongo/operation/shared/op_msg_or_find_command.rb +8 -6
  339. data/lib/mongo/operation/shared/op_msg_or_list_indexes_command.rb +8 -6
  340. data/lib/mongo/operation/shared/polymorphic_lookup.rb +1 -1
  341. data/lib/mongo/operation/shared/polymorphic_result.rb +1 -1
  342. data/lib/mongo/operation/shared/read_preference_supported.rb +19 -16
  343. data/lib/mongo/operation/shared/response_handling.rb +83 -8
  344. data/lib/mongo/operation/shared/result/aggregatable.rb +1 -1
  345. data/lib/mongo/operation/shared/result/use_legacy_error_parser.rb +1 -1
  346. data/lib/mongo/operation/shared/sessions_supported.rb +50 -27
  347. data/lib/mongo/operation/shared/specifiable.rb +32 -20
  348. data/lib/mongo/operation/shared/write.rb +25 -19
  349. data/lib/mongo/operation/shared/write_concern_supported.rb +6 -6
  350. data/lib/mongo/operation/update.rb +1 -1
  351. data/lib/mongo/operation/update/bulk_result.rb +1 -1
  352. data/lib/mongo/operation/update/command.rb +4 -4
  353. data/lib/mongo/operation/update/legacy.rb +2 -2
  354. data/lib/mongo/operation/update/legacy/result.rb +1 -1
  355. data/lib/mongo/operation/update/op_msg.rb +4 -4
  356. data/lib/mongo/operation/update/result.rb +2 -2
  357. data/lib/mongo/operation/update_user.rb +1 -1
  358. data/lib/mongo/operation/update_user/command.rb +4 -4
  359. data/lib/mongo/operation/update_user/op_msg.rb +2 -2
  360. data/lib/mongo/operation/users_info.rb +1 -1
  361. data/lib/mongo/operation/users_info/command.rb +4 -4
  362. data/lib/mongo/operation/users_info/op_msg.rb +2 -2
  363. data/lib/mongo/operation/users_info/result.rb +1 -1
  364. data/lib/mongo/options.rb +1 -1
  365. data/lib/mongo/options/mapper.rb +1 -1
  366. data/lib/mongo/options/redacted.rb +1 -1
  367. data/lib/mongo/protocol/bit_vector.rb +1 -1
  368. data/lib/mongo/protocol/compressed.rb +1 -1
  369. data/lib/mongo/protocol/delete.rb +1 -1
  370. data/lib/mongo/protocol/get_more.rb +1 -1
  371. data/lib/mongo/protocol/insert.rb +1 -1
  372. data/lib/mongo/protocol/kill_cursors.rb +1 -1
  373. data/lib/mongo/protocol/message.rb +37 -18
  374. data/lib/mongo/protocol/msg.rb +19 -5
  375. data/lib/mongo/protocol/query.rb +1 -37
  376. data/lib/mongo/protocol/registry.rb +1 -1
  377. data/lib/mongo/protocol/reply.rb +1 -1
  378. data/lib/mongo/protocol/serializers.rb +1 -1
  379. data/lib/mongo/protocol/update.rb +1 -1
  380. data/lib/mongo/retryable.rb +23 -10
  381. data/lib/mongo/semaphore.rb +1 -1
  382. data/lib/mongo/server.rb +40 -8
  383. data/lib/mongo/server/app_metadata.rb +44 -7
  384. data/lib/mongo/server/connection.rb +37 -133
  385. data/lib/mongo/server/connection_base.rb +27 -10
  386. data/lib/mongo/server/connection_common.rb +75 -1
  387. data/lib/mongo/server/connection_pool.rb +20 -1
  388. data/lib/mongo/server/connection_pool/populator.rb +1 -1
  389. data/lib/mongo/server/context.rb +1 -1
  390. data/lib/mongo/server/description.rb +49 -2
  391. data/lib/mongo/server/description/features.rb +12 -3
  392. data/lib/mongo/server/monitor.rb +145 -69
  393. data/lib/mongo/server/monitor/app_metadata.rb +1 -1
  394. data/lib/mongo/server/monitor/connection.rb +110 -80
  395. data/lib/mongo/server/pending_connection.rb +215 -3
  396. data/lib/mongo/server/push_monitor.rb +173 -0
  397. data/{spec/runners/transactions/context.rb → lib/mongo/server/push_monitor/connection.rb} +9 -14
  398. data/lib/mongo/server/round_trip_time_averager.rb +12 -3
  399. data/lib/mongo/server_selector.rb +2 -2
  400. data/lib/mongo/server_selector/{selectable.rb → base.rb} +159 -86
  401. data/lib/mongo/server_selector/nearest.rb +26 -21
  402. data/lib/mongo/server_selector/primary.rb +24 -28
  403. data/lib/mongo/server_selector/primary_preferred.rb +32 -25
  404. data/lib/mongo/server_selector/secondary.rb +26 -21
  405. data/lib/mongo/server_selector/secondary_preferred.rb +29 -34
  406. data/lib/mongo/session.rb +14 -1
  407. data/lib/mongo/session/server_session.rb +1 -1
  408. data/lib/mongo/session/session_pool.rb +1 -1
  409. data/lib/mongo/socket.rb +121 -41
  410. data/lib/mongo/socket/ssl.rb +98 -35
  411. data/lib/mongo/socket/tcp.rb +39 -31
  412. data/lib/mongo/socket/unix.rb +14 -6
  413. data/lib/mongo/srv.rb +1 -1
  414. data/lib/mongo/srv/monitor.rb +1 -1
  415. data/lib/mongo/srv/resolver.rb +1 -1
  416. data/lib/mongo/srv/result.rb +1 -1
  417. data/lib/mongo/timeout.rb +9 -9
  418. data/lib/mongo/topology_version.rb +89 -0
  419. data/lib/mongo/uri.rb +61 -47
  420. data/lib/mongo/uri/srv_protocol.rb +9 -1
  421. data/lib/mongo/utils.rb +62 -0
  422. data/lib/mongo/version.rb +2 -2
  423. data/lib/mongo/write_concern.rb +1 -1
  424. data/lib/mongo/write_concern/acknowledged.rb +1 -1
  425. data/lib/mongo/write_concern/base.rb +1 -1
  426. data/lib/mongo/write_concern/unacknowledged.rb +1 -1
  427. data/mongo.gemspec +1 -1
  428. data/spec/NOTES.aws-auth.md +291 -0
  429. data/spec/README.aws-auth.md +318 -0
  430. data/spec/README.md +64 -17
  431. data/spec/integration/auth_spec.rb +29 -9
  432. data/spec/integration/awaited_ismaster_spec.rb +28 -0
  433. data/spec/integration/aws_auth_request_spec.rb +74 -0
  434. data/spec/integration/aws_credentials_retriever_spec.rb +103 -0
  435. data/spec/integration/change_stream_examples_spec.rb +6 -2
  436. data/spec/integration/change_stream_spec.rb +123 -51
  437. data/spec/integration/check_clean_slate_spec.rb +16 -0
  438. data/spec/integration/client_authentication_options_spec.rb +0 -37
  439. data/spec/integration/client_construction_aws_auth_spec.rb +191 -0
  440. data/spec/integration/client_construction_spec.rb +2 -1
  441. data/spec/integration/client_side_encryption/auto_encryption_bulk_writes_spec.rb +2 -6
  442. data/spec/integration/collection_indexes_prose_spec.rb +55 -0
  443. data/spec/integration/command_monitoring_spec.rb +30 -6
  444. data/spec/integration/command_spec.rb +11 -9
  445. data/spec/integration/connect_single_rs_name_spec.rb +10 -5
  446. data/spec/integration/connection_spec.rb +7 -3
  447. data/spec/integration/crud_spec.rb +32 -4
  448. data/spec/integration/cursor_reaping_spec.rb +14 -10
  449. data/spec/integration/docs_examples_spec.rb +6 -0
  450. data/spec/integration/fork_reconnect_spec.rb +143 -0
  451. data/spec/integration/get_more_spec.rb +10 -3
  452. data/spec/integration/heartbeat_events_spec.rb +5 -24
  453. data/spec/integration/read_concern_spec.rb +1 -1
  454. data/spec/integration/read_preference_spec.rb +41 -11
  455. data/spec/integration/reconnect_spec.rb +2 -3
  456. data/spec/integration/retryable_errors_spec.rb +33 -14
  457. data/spec/integration/{retryable_writes_spec.rb → retryable_writes/retryable_writes_36_and_older_spec.rb} +55 -51
  458. data/spec/integration/retryable_writes/retryable_writes_40_and_newer_spec.rb +401 -0
  459. data/spec/integration/retryable_writes/shared/adds_diagnostics.rb +15 -0
  460. data/spec/integration/retryable_writes/shared/does_not_support_retries.rb +24 -0
  461. data/spec/integration/retryable_writes/shared/only_supports_legacy_retries.rb +25 -0
  462. data/spec/integration/retryable_writes/shared/performs_legacy_retries.rb +215 -0
  463. data/spec/integration/retryable_writes/shared/performs_modern_retries.rb +232 -0
  464. data/spec/integration/retryable_writes/shared/performs_no_retries.rb +110 -0
  465. data/spec/integration/retryable_writes/shared/supports_legacy_retries.rb +19 -0
  466. data/spec/integration/retryable_writes/shared/supports_modern_retries.rb +25 -0
  467. data/spec/integration/retryable_writes/shared/supports_retries.rb +16 -0
  468. data/spec/integration/sdam_error_handling_spec.rb +142 -22
  469. data/spec/integration/sdam_events_spec.rb +77 -5
  470. data/spec/integration/sdam_prose_spec.rb +64 -0
  471. data/spec/integration/server_monitor_spec.rb +25 -1
  472. data/spec/integration/server_spec.rb +42 -26
  473. data/spec/integration/size_limit_spec.rb +22 -23
  474. data/spec/integration/ssl_uri_options_spec.rb +2 -2
  475. data/spec/integration/step_down_spec.rb +15 -15
  476. data/spec/integration/transactions_api_examples_spec.rb +59 -0
  477. data/spec/integration/transactions_examples_spec.rb +5 -2
  478. data/spec/integration/x509_auth_spec.rb +109 -0
  479. data/spec/kerberos/kerberos_spec.rb +10 -6
  480. data/spec/lite_spec_helper.rb +31 -22
  481. data/spec/mongo/address/ipv4_spec.rb +1 -1
  482. data/spec/mongo/address_spec.rb +2 -2
  483. data/spec/mongo/auth/aws/request_region_spec.rb +42 -0
  484. data/spec/mongo/auth/aws/request_spec.rb +76 -0
  485. data/spec/mongo/auth/cr_spec.rb +7 -7
  486. data/spec/mongo/auth/gssapi/conversation_spec.rb +121 -0
  487. data/spec/mongo/auth/invalid_mechanism_spec.rb +1 -1
  488. data/spec/mongo/auth/ldap/conversation_spec.rb +1 -1
  489. data/spec/mongo/auth/ldap_spec.rb +3 -3
  490. data/spec/mongo/auth/scram/conversation_spec.rb +119 -334
  491. data/spec/mongo/auth/scram256/conversation_spec.rb +171 -0
  492. data/spec/mongo/auth/{scram/negotiation_spec.rb → scram_negotiation_spec.rb} +13 -8
  493. data/spec/mongo/auth/scram_spec.rb +29 -69
  494. data/spec/mongo/auth/user_spec.rb +1 -1
  495. data/spec/mongo/auth/x509/conversation_spec.rb +1 -1
  496. data/spec/mongo/auth/x509_spec.rb +8 -8
  497. data/spec/mongo/auth_spec.rb +4 -4
  498. data/spec/mongo/bulk_write_spec.rb +206 -2
  499. data/spec/mongo/client_construction_spec.rb +609 -86
  500. data/spec/mongo/client_spec.rb +59 -5
  501. data/spec/mongo/cluster/topology/replica_set_spec.rb +52 -9
  502. data/spec/mongo/cluster/topology/single_spec.rb +4 -2
  503. data/spec/mongo/cluster_spec.rb +37 -36
  504. data/spec/mongo/collection/view/aggregation_spec.rb +6 -2
  505. data/spec/mongo/collection/view/builder/find_command_spec.rb +17 -6
  506. data/spec/mongo/collection/view/change_stream_resume_spec.rb +392 -0
  507. data/spec/mongo/collection/view/change_stream_spec.rb +0 -318
  508. data/spec/mongo/collection/view/iterable_spec.rb +38 -0
  509. data/spec/mongo/collection/view/map_reduce_spec.rb +6 -2
  510. data/spec/mongo/collection/view/readable_spec.rb +15 -1
  511. data/spec/mongo/collection/view/writable_spec.rb +208 -1
  512. data/spec/mongo/collection_spec.rb +507 -43
  513. data/spec/mongo/cursor/builder/get_more_command_spec.rb +6 -1
  514. data/spec/mongo/cursor/builder/op_get_more_spec.rb +6 -1
  515. data/spec/mongo/cursor/builder/op_kill_cursors_spec.rb +6 -1
  516. data/spec/mongo/cursor_spec.rb +9 -1
  517. data/spec/mongo/database_spec.rb +251 -10
  518. data/spec/mongo/distinguishing_semaphore_spec.rb +63 -0
  519. data/spec/mongo/error/operation_failure_heavy_spec.rb +58 -0
  520. data/spec/mongo/error/operation_failure_spec.rb +167 -69
  521. data/spec/mongo/error/unsupported_option_spec.rb +54 -0
  522. data/spec/mongo/grid/fs_bucket_spec.rb +18 -0
  523. data/spec/mongo/grid/stream/write_spec.rb +32 -0
  524. data/spec/mongo/index/view_spec.rb +312 -0
  525. data/spec/mongo/monitoring/event/server_description_changed_spec.rb +1 -4
  526. data/spec/mongo/operation/aggregate/result_spec.rb +6 -1
  527. data/spec/mongo/operation/delete/bulk_spec.rb +18 -6
  528. data/spec/mongo/operation/delete/op_msg_spec.rb +22 -14
  529. data/spec/mongo/operation/find/legacy_spec.rb +27 -7
  530. data/spec/mongo/operation/get_more_spec.rb +6 -1
  531. data/spec/mongo/operation/insert/bulk_spec.rb +21 -7
  532. data/spec/mongo/operation/insert/command_spec.rb +4 -0
  533. data/spec/mongo/operation/insert/op_msg_spec.rb +22 -14
  534. data/spec/mongo/operation/limited_spec.rb +5 -3
  535. data/spec/mongo/operation/read_preference_legacy_spec.rb +16 -4
  536. data/spec/mongo/operation/read_preference_op_msg_spec.rb +115 -5
  537. data/spec/mongo/operation/result_spec.rb +6 -1
  538. data/spec/mongo/operation/update/bulk_spec.rb +18 -6
  539. data/spec/mongo/operation/update/command_spec.rb +4 -0
  540. data/spec/mongo/operation/update/op_msg_spec.rb +22 -14
  541. data/spec/mongo/protocol/msg_spec.rb +10 -0
  542. data/spec/mongo/retryable_spec.rb +71 -70
  543. data/spec/mongo/semaphore_spec.rb +51 -0
  544. data/spec/mongo/server/app_metadata_shared.rb +136 -0
  545. data/spec/mongo/server/app_metadata_spec.rb +8 -1
  546. data/spec/mongo/server/connection_auth_spec.rb +33 -14
  547. data/spec/mongo/server/connection_pool_spec.rb +0 -31
  548. data/spec/mongo/server/connection_spec.rb +118 -71
  549. data/spec/mongo/server/monitor/app_metadata_spec.rb +8 -1
  550. data/spec/mongo/server/monitor/connection_spec.rb +1 -82
  551. data/spec/mongo/server/monitor_spec.rb +76 -17
  552. data/spec/mongo/server/round_trip_time_averager_spec.rb +5 -3
  553. data/spec/mongo/server_selector/nearest_spec.rb +24 -23
  554. data/spec/mongo/server_selector/primary_preferred_spec.rb +27 -26
  555. data/spec/mongo/server_selector/primary_spec.rb +27 -9
  556. data/spec/mongo/server_selector/secondary_preferred_spec.rb +40 -23
  557. data/spec/mongo/server_selector/secondary_spec.rb +19 -18
  558. data/spec/mongo/server_selector_spec.rb +4 -5
  559. data/spec/mongo/session/session_pool_spec.rb +7 -3
  560. data/spec/mongo/session_spec.rb +35 -0
  561. data/spec/mongo/socket/ssl_spec.rb +2 -2
  562. data/spec/mongo/socket/tcp_spec.rb +2 -2
  563. data/spec/mongo/socket/unix_spec.rb +2 -2
  564. data/spec/mongo/socket_spec.rb +9 -9
  565. data/spec/mongo/timeout_spec.rb +22 -68
  566. data/spec/mongo/uri_spec.rb +21 -6
  567. data/spec/runners/auth.rb +5 -6
  568. data/spec/runners/change_streams/outcome.rb +42 -0
  569. data/spec/runners/change_streams/spec.rb +57 -0
  570. data/spec/runners/change_streams/test.rb +229 -0
  571. data/spec/runners/cmap.rb +1 -1
  572. data/spec/runners/cmap/verifier.rb +1 -1
  573. data/spec/runners/command_monitoring.rb +4 -35
  574. data/spec/runners/connection_string.rb +3 -2
  575. data/spec/runners/crud.rb +2 -2
  576. data/spec/runners/crud/context.rb +10 -6
  577. data/spec/runners/crud/operation.rb +177 -55
  578. data/spec/runners/crud/outcome.rb +1 -1
  579. data/spec/runners/crud/spec.rb +0 -7
  580. data/spec/runners/crud/test.rb +8 -26
  581. data/spec/runners/crud/test_base.rb +47 -0
  582. data/spec/runners/crud/verifier.rb +21 -3
  583. data/spec/runners/gridfs.rb +1 -1
  584. data/spec/runners/{server_discovery_and_monitoring.rb → sdam.rb} +41 -22
  585. data/spec/runners/sdam/verifier.rb +26 -8
  586. data/spec/runners/server_selection.rb +242 -28
  587. data/spec/runners/transactions.rb +13 -14
  588. data/spec/runners/transactions/operation.rb +155 -25
  589. data/spec/runners/transactions/spec.rb +1 -1
  590. data/spec/runners/transactions/test.rb +103 -65
  591. data/spec/spec_tests/auth_spec.rb +2 -0
  592. data/spec/spec_tests/change_streams_spec.rb +39 -4
  593. data/spec/spec_tests/client_side_encryption_spec.rb +3 -0
  594. data/spec/spec_tests/cmap_spec.rb +5 -0
  595. data/spec/spec_tests/command_monitoring_spec.rb +25 -12
  596. data/spec/spec_tests/connection_string_spec.rb +2 -0
  597. data/spec/spec_tests/crud_spec.rb +3 -1
  598. data/spec/spec_tests/data/auth/connection-string.yml +57 -1
  599. data/spec/spec_tests/data/change_streams/change-streams-errors.yml +27 -1
  600. data/spec/spec_tests/data/change_streams/change-streams-resume-errorLabels.yml +1105 -0
  601. data/spec/spec_tests/data/change_streams/change-streams-resume-whitelist.yml +1173 -0
  602. data/spec/spec_tests/data/change_streams/change-streams.yml +5 -4
  603. data/spec/spec_tests/data/crud_v2/aggregate-merge.yml +1 -1
  604. data/spec/spec_tests/data/crud_v2/bulkWrite-arrayFilters.yml +33 -11
  605. data/spec/spec_tests/data/crud_v2/bulkWrite-delete-hint-clientError.yml +63 -0
  606. data/spec/spec_tests/data/crud_v2/bulkWrite-delete-hint-serverError.yml +92 -0
  607. data/spec/spec_tests/data/crud_v2/bulkWrite-delete-hint.yml +103 -0
  608. data/spec/spec_tests/data/crud_v2/bulkWrite-update-hint-clientError.yml +90 -0
  609. data/spec/spec_tests/data/crud_v2/bulkWrite-update-hint-serverError.yml +147 -0
  610. data/spec/spec_tests/data/crud_v2/bulkWrite-update-hint.yml +164 -0
  611. data/spec/spec_tests/data/crud_v2/deleteMany-hint-clientError.yml +43 -0
  612. data/spec/spec_tests/data/crud_v2/deleteMany-hint-serverError.yml +62 -0
  613. data/spec/spec_tests/data/crud_v2/deleteMany-hint.yml +58 -0
  614. data/spec/spec_tests/data/crud_v2/deleteOne-hint-clientError.yml +41 -0
  615. data/spec/spec_tests/data/crud_v2/deleteOne-hint-serverError.yml +60 -0
  616. data/spec/spec_tests/data/crud_v2/deleteOne-hint.yml +57 -0
  617. data/spec/spec_tests/data/crud_v2/find-allowdiskuse-clientError.yml +28 -0
  618. data/spec/spec_tests/data/crud_v2/find-allowdiskuse-serverError.yml +44 -0
  619. data/spec/spec_tests/data/crud_v2/find-allowdiskuse.yml +50 -0
  620. data/spec/spec_tests/data/crud_v2/findOneAndDelete-hint-clientError.yml +45 -0
  621. data/spec/spec_tests/data/crud_v2/findOneAndDelete-hint-serverError.yml +60 -0
  622. data/spec/spec_tests/data/crud_v2/findOneAndDelete-hint.yml +56 -0
  623. data/spec/spec_tests/data/crud_v2/findOneAndReplace-hint-clientError.yml +40 -0
  624. data/spec/spec_tests/data/crud_v2/findOneAndReplace-hint-serverError.yml +59 -0
  625. data/spec/spec_tests/data/crud_v2/findOneAndReplace-hint.yml +55 -0
  626. data/spec/spec_tests/data/crud_v2/findOneAndUpdate-hint-clientError.yml +40 -0
  627. data/spec/spec_tests/data/crud_v2/findOneAndUpdate-hint-serverError.yml +58 -0
  628. data/spec/spec_tests/data/crud_v2/findOneAndUpdate-hint.yml +55 -0
  629. data/spec/spec_tests/data/crud_v2/replaceOne-hint.yml +61 -0
  630. data/spec/spec_tests/data/crud_v2/unacknowledged-bulkWrite-delete-hint-clientError.yml +60 -0
  631. data/spec/spec_tests/data/crud_v2/unacknowledged-bulkWrite-update-hint-clientError.yml +88 -0
  632. data/spec/spec_tests/data/crud_v2/unacknowledged-deleteMany-hint-clientError.yml +40 -0
  633. data/spec/spec_tests/data/crud_v2/unacknowledged-deleteOne-hint-clientError.yml +38 -0
  634. data/spec/spec_tests/data/crud_v2/unacknowledged-findOneAndDelete-hint-clientError.yml +42 -0
  635. data/spec/spec_tests/data/crud_v2/unacknowledged-findOneAndReplace-hint-clientError.yml +40 -0
  636. data/spec/spec_tests/data/crud_v2/unacknowledged-findOneAndUpdate-hint-clientError.yml +40 -0
  637. data/spec/spec_tests/data/crud_v2/unacknowledged-replaceOne-hint-clientError.yml +40 -0
  638. data/spec/spec_tests/data/crud_v2/unacknowledged-updateMany-hint-clientError.yml +43 -0
  639. data/spec/spec_tests/data/crud_v2/unacknowledged-updateOne-hint-clientError.yml +40 -0
  640. data/spec/spec_tests/data/crud_v2/updateMany-hint-clientError.yml +45 -0
  641. data/spec/spec_tests/data/crud_v2/updateMany-hint-serverError.yml +66 -0
  642. data/spec/spec_tests/data/crud_v2/updateMany-hint.yml +65 -0
  643. data/spec/spec_tests/data/crud_v2/updateOne-hint-clientError.yml +43 -0
  644. data/spec/spec_tests/data/crud_v2/updateOne-hint-serverError.yml +62 -0
  645. data/spec/spec_tests/data/crud_v2/updateOne-hint.yml +61 -0
  646. data/spec/spec_tests/data/crud_v2/updateWithPipelines.yml +65 -0
  647. data/spec/spec_tests/data/dns_seedlist_discovery/direct-connection-false.yml +10 -0
  648. data/spec/spec_tests/data/dns_seedlist_discovery/direct-connection-true.yml +5 -0
  649. data/spec/spec_tests/data/max_staleness/ReplicaSetNoPrimary/MaxStalenessTooSmall.yml +15 -0
  650. data/spec/spec_tests/data/max_staleness/ReplicaSetNoPrimary/NoKnownServers.yml +4 -3
  651. data/spec/spec_tests/data/max_staleness/Unknown/SmallMaxStaleness.yml +1 -0
  652. data/spec/spec_tests/data/read_write_concern/operation/default-write-concern-2.6.yml +215 -0
  653. data/spec/spec_tests/data/read_write_concern/operation/default-write-concern-3.2.yml +58 -0
  654. data/spec/spec_tests/data/read_write_concern/operation/default-write-concern-3.4.yml +95 -0
  655. data/spec/spec_tests/data/read_write_concern/operation/default-write-concern-4.2.yml +36 -0
  656. data/spec/spec_tests/data/retryable_writes/bulkWrite-errorLabels.yml +77 -0
  657. data/spec/spec_tests/data/retryable_writes/bulkWrite-serverErrors.yml +37 -0
  658. data/spec/spec_tests/data/retryable_writes/deleteOne-errorLabels.yml +48 -0
  659. data/spec/spec_tests/data/retryable_writes/deleteOne-serverErrors.yml +22 -0
  660. data/spec/spec_tests/data/retryable_writes/findOneAndDelete-errorLabels.yml +49 -0
  661. data/spec/spec_tests/data/retryable_writes/findOneAndDelete-serverErrors.yml +23 -0
  662. data/spec/spec_tests/data/retryable_writes/findOneAndReplace-errorLabels.yml +52 -0
  663. data/spec/spec_tests/data/retryable_writes/findOneAndReplace-serverErrors.yml +25 -0
  664. data/spec/spec_tests/data/retryable_writes/findOneAndUpdate-errorLabels.yml +52 -0
  665. data/spec/spec_tests/data/retryable_writes/findOneAndUpdate-serverErrors.yml +24 -0
  666. data/spec/spec_tests/data/retryable_writes/insertMany-errorLabels.yml +54 -0
  667. data/spec/spec_tests/data/retryable_writes/insertMany-serverErrors.yml +24 -0
  668. data/spec/spec_tests/data/retryable_writes/insertOne-errorLabels.yml +44 -0
  669. data/spec/spec_tests/data/retryable_writes/insertOne-serverErrors.yml +69 -0
  670. data/spec/spec_tests/data/retryable_writes/replaceOne-errorLabels.yml +53 -0
  671. data/spec/spec_tests/data/retryable_writes/replaceOne-serverErrors.yml +23 -0
  672. data/spec/spec_tests/data/retryable_writes/updateOne-errorLabels.yml +53 -0
  673. data/spec/spec_tests/data/retryable_writes/updateOne-serverErrors.yml +23 -0
  674. data/spec/spec_tests/data/sdam/errors/error_handling_handshake.yml +54 -0
  675. data/spec/spec_tests/data/sdam/errors/non-stale-network-error.yml +46 -0
  676. data/spec/spec_tests/data/sdam/errors/non-stale-network-timeout-error.yml +37 -0
  677. data/spec/spec_tests/data/sdam/errors/non-stale-topologyVersion-greater-InterruptedAtShutdown.yml +60 -0
  678. data/spec/spec_tests/data/sdam/errors/non-stale-topologyVersion-greater-InterruptedDueToReplStateChange.yml +60 -0
  679. data/spec/spec_tests/data/sdam/errors/non-stale-topologyVersion-greater-NotMaster.yml +60 -0
  680. data/spec/spec_tests/data/sdam/errors/non-stale-topologyVersion-greater-NotMasterNoSlaveOk.yml +60 -0
  681. data/spec/spec_tests/data/sdam/errors/non-stale-topologyVersion-greater-NotMasterOrSecondary.yml +60 -0
  682. data/spec/spec_tests/data/sdam/errors/non-stale-topologyVersion-greater-PrimarySteppedDown.yml +60 -0
  683. data/spec/spec_tests/data/sdam/errors/non-stale-topologyVersion-greater-ShutdownInProgress.yml +60 -0
  684. data/spec/spec_tests/data/sdam/errors/non-stale-topologyVersion-missing-InterruptedAtShutdown.yml +51 -0
  685. data/spec/spec_tests/data/sdam/errors/non-stale-topologyVersion-missing-InterruptedDueToReplStateChange.yml +51 -0
  686. data/spec/spec_tests/data/sdam/errors/non-stale-topologyVersion-missing-NotMaster.yml +51 -0
  687. data/spec/spec_tests/data/sdam/errors/non-stale-topologyVersion-missing-NotMasterNoSlaveOk.yml +51 -0
  688. data/spec/spec_tests/data/sdam/errors/non-stale-topologyVersion-missing-NotMasterOrSecondary.yml +51 -0
  689. data/spec/spec_tests/data/sdam/errors/non-stale-topologyVersion-missing-PrimarySteppedDown.yml +51 -0
  690. data/spec/spec_tests/data/sdam/errors/non-stale-topologyVersion-missing-ShutdownInProgress.yml +51 -0
  691. data/spec/spec_tests/data/sdam/errors/non-stale-topologyVersion-proccessId-changed-InterruptedAtShutdown.yml +60 -0
  692. data/spec/spec_tests/data/sdam/errors/non-stale-topologyVersion-proccessId-changed-InterruptedDueToReplStateChange.yml +60 -0
  693. data/spec/spec_tests/data/sdam/errors/non-stale-topologyVersion-proccessId-changed-NotMaster.yml +60 -0
  694. data/spec/spec_tests/data/sdam/errors/non-stale-topologyVersion-proccessId-changed-NotMasterNoSlaveOk.yml +60 -0
  695. data/spec/spec_tests/data/sdam/errors/non-stale-topologyVersion-proccessId-changed-NotMasterOrSecondary.yml +60 -0
  696. data/spec/spec_tests/data/sdam/errors/non-stale-topologyVersion-proccessId-changed-PrimarySteppedDown.yml +60 -0
  697. data/spec/spec_tests/data/sdam/errors/non-stale-topologyVersion-proccessId-changed-ShutdownInProgress.yml +60 -0
  698. data/spec/spec_tests/data/sdam/errors/post-42-InterruptedAtShutdown.yml +46 -0
  699. data/spec/spec_tests/data/sdam/errors/post-42-InterruptedDueToReplStateChange.yml +46 -0
  700. data/spec/spec_tests/data/sdam/errors/post-42-NotMaster.yml +46 -0
  701. data/spec/spec_tests/data/sdam/errors/post-42-NotMasterNoSlaveOk.yml +46 -0
  702. data/spec/spec_tests/data/sdam/errors/post-42-NotMasterOrSecondary.yml +46 -0
  703. data/spec/spec_tests/data/sdam/errors/post-42-PrimarySteppedDown.yml +46 -0
  704. data/spec/spec_tests/data/sdam/errors/post-42-ShutdownInProgress.yml +46 -0
  705. data/spec/spec_tests/data/sdam/errors/pre-42-InterruptedAtShutdown.yml +46 -0
  706. data/spec/spec_tests/data/sdam/errors/pre-42-InterruptedDueToReplStateChange.yml +46 -0
  707. data/spec/spec_tests/data/sdam/errors/pre-42-NotMaster.yml +46 -0
  708. data/spec/spec_tests/data/sdam/errors/pre-42-NotMasterNoSlaveOk.yml +46 -0
  709. data/spec/spec_tests/data/sdam/errors/pre-42-NotMasterOrSecondary.yml +46 -0
  710. data/spec/spec_tests/data/sdam/errors/pre-42-PrimarySteppedDown.yml +46 -0
  711. data/spec/spec_tests/data/sdam/errors/pre-42-ShutdownInProgress.yml +46 -0
  712. data/spec/spec_tests/data/sdam/errors/stale-generation-InterruptedAtShutdown.yml +89 -0
  713. data/spec/spec_tests/data/sdam/errors/stale-generation-InterruptedDueToReplStateChange.yml +89 -0
  714. data/spec/spec_tests/data/sdam/errors/stale-generation-NotMaster.yml +89 -0
  715. data/spec/spec_tests/data/sdam/errors/stale-generation-NotMasterNoSlaveOk.yml +89 -0
  716. data/spec/spec_tests/data/sdam/errors/stale-generation-NotMasterOrSecondary.yml +89 -0
  717. data/spec/spec_tests/data/sdam/errors/stale-generation-PrimarySteppedDown.yml +89 -0
  718. data/spec/spec_tests/data/sdam/errors/stale-generation-ShutdownInProgress.yml +89 -0
  719. data/spec/spec_tests/data/sdam/errors/stale-generation-afterHandshakeCompletes-InterruptedAtShutdown.yml +89 -0
  720. data/spec/spec_tests/data/sdam/errors/stale-generation-afterHandshakeCompletes-InterruptedDueToReplStateChange.yml +89 -0
  721. data/spec/spec_tests/data/sdam/errors/stale-generation-afterHandshakeCompletes-NotMaster.yml +89 -0
  722. data/spec/spec_tests/data/sdam/errors/stale-generation-afterHandshakeCompletes-NotMasterNoSlaveOk.yml +89 -0
  723. data/spec/spec_tests/data/sdam/errors/stale-generation-afterHandshakeCompletes-NotMasterOrSecondary.yml +89 -0
  724. data/spec/spec_tests/data/sdam/errors/stale-generation-afterHandshakeCompletes-PrimarySteppedDown.yml +89 -0
  725. data/spec/spec_tests/data/sdam/errors/stale-generation-afterHandshakeCompletes-ShutdownInProgress.yml +89 -0
  726. data/spec/spec_tests/data/sdam/errors/stale-generation-afterHandshakeCompletes-network.yml +80 -0
  727. data/spec/spec_tests/data/sdam/errors/stale-generation-afterHandshakeCompletes-timeout.yml +80 -0
  728. data/spec/spec_tests/data/sdam/errors/stale-generation-beforeHandshakeCompletes-InterruptedAtShutdown.yml +89 -0
  729. data/spec/spec_tests/data/sdam/errors/stale-generation-beforeHandshakeCompletes-InterruptedDueToReplStateChange.yml +89 -0
  730. data/spec/spec_tests/data/sdam/errors/stale-generation-beforeHandshakeCompletes-NotMaster.yml +89 -0
  731. data/spec/spec_tests/data/sdam/errors/stale-generation-beforeHandshakeCompletes-NotMasterNoSlaveOk.yml +89 -0
  732. data/spec/spec_tests/data/sdam/errors/stale-generation-beforeHandshakeCompletes-NotMasterOrSecondary.yml +89 -0
  733. data/spec/spec_tests/data/sdam/errors/stale-generation-beforeHandshakeCompletes-PrimarySteppedDown.yml +89 -0
  734. data/spec/spec_tests/data/sdam/errors/stale-generation-beforeHandshakeCompletes-ShutdownInProgress.yml +89 -0
  735. data/spec/spec_tests/data/sdam/errors/stale-generation-beforeHandshakeCompletes-network.yml +80 -0
  736. data/spec/spec_tests/data/sdam/errors/stale-generation-beforeHandshakeCompletes-timeout.yml +80 -0
  737. data/spec/spec_tests/data/sdam/errors/stale-topologyVersion-InterruptedAtShutdown.yml +64 -0
  738. data/spec/spec_tests/data/sdam/errors/stale-topologyVersion-InterruptedDueToReplStateChange.yml +64 -0
  739. data/spec/spec_tests/data/sdam/errors/stale-topologyVersion-NotMaster.yml +64 -0
  740. data/spec/spec_tests/data/sdam/errors/stale-topologyVersion-NotMasterNoSlaveOk.yml +64 -0
  741. data/spec/spec_tests/data/sdam/errors/stale-topologyVersion-NotMasterOrSecondary.yml +64 -0
  742. data/spec/spec_tests/data/sdam/errors/stale-topologyVersion-PrimarySteppedDown.yml +64 -0
  743. data/spec/spec_tests/data/sdam/errors/stale-topologyVersion-ShutdownInProgress.yml +64 -0
  744. data/spec/spec_tests/data/sdam/rs/compatible.yml +2 -0
  745. data/spec/spec_tests/data/sdam/rs/compatible_unknown.yml +2 -0
  746. data/spec/spec_tests/data/sdam/rs/discover_arbiters.yml +2 -2
  747. data/spec/spec_tests/data/sdam/rs/discover_arbiters_replicaset.yml +43 -0
  748. data/spec/spec_tests/data/sdam/rs/discover_ghost.yml +35 -0
  749. data/spec/spec_tests/data/sdam/rs/{ghost_discovered.yml → discover_ghost_replicaset.yml} +1 -1
  750. data/spec/spec_tests/data/sdam/rs/discover_hidden.yml +50 -0
  751. data/spec/spec_tests/data/sdam/rs/discover_hidden_replicaset.yml +50 -0
  752. data/spec/spec_tests/data/sdam/rs/discover_passives.yml +2 -2
  753. data/spec/spec_tests/data/sdam/rs/discover_passives_replicaset.yml +81 -0
  754. data/spec/spec_tests/data/sdam/rs/discover_primary.yml +2 -2
  755. data/spec/spec_tests/data/sdam/rs/discover_primary_replicaset.yml +42 -0
  756. data/spec/spec_tests/data/sdam/rs/discover_rsother.yml +49 -0
  757. data/spec/spec_tests/data/sdam/rs/{rsother_discovered.yml → discover_rsother_replicaset.yml} +1 -1
  758. data/spec/spec_tests/data/sdam/rs/discover_secondary.yml +2 -2
  759. data/spec/spec_tests/data/sdam/rs/discover_secondary_replicaset.yml +43 -0
  760. data/spec/spec_tests/data/sdam/rs/incompatible_arbiter.yml +2 -0
  761. data/spec/spec_tests/data/sdam/rs/incompatible_ghost.yml +2 -0
  762. data/spec/spec_tests/data/sdam/rs/incompatible_other.yml +2 -0
  763. data/spec/spec_tests/data/sdam/rs/primary_mismatched_me.yml +23 -27
  764. data/spec/spec_tests/data/sdam/rs/primary_to_no_primary_mismatched_me.yml +79 -55
  765. data/spec/spec_tests/data/sdam/rs/replicaset_rsnp.yml +20 -0
  766. data/spec/spec_tests/data/sdam/rs/secondary_mismatched_me.yml +3 -2
  767. data/spec/spec_tests/data/sdam/rs/too_new.yml +2 -0
  768. data/spec/spec_tests/data/sdam/rs/topology_version_equal.yml +66 -0
  769. data/spec/spec_tests/data/sdam/rs/topology_version_greater.yml +189 -0
  770. data/spec/spec_tests/data/sdam/rs/topology_version_less.yml +62 -0
  771. data/spec/spec_tests/data/sdam/sharded/discover_single_mongos.yml +23 -0
  772. data/spec/spec_tests/data/sdam/single/direct_connection_external_ip.yml +1 -1
  773. data/spec/spec_tests/data/sdam/single/direct_connection_mongos.yml +2 -2
  774. data/spec/spec_tests/data/sdam/single/direct_connection_replicaset.yml +22 -0
  775. data/spec/spec_tests/data/sdam/single/direct_connection_rsarbiter.yml +2 -2
  776. data/spec/spec_tests/data/sdam/single/direct_connection_rsprimary.yml +2 -2
  777. data/spec/spec_tests/data/sdam/single/direct_connection_rssecondary.yml +2 -2
  778. data/spec/spec_tests/data/sdam/single/direct_connection_slave.yml +1 -1
  779. data/spec/spec_tests/data/sdam/single/direct_connection_standalone.yml +2 -2
  780. data/spec/spec_tests/data/sdam/single/{unavailable_seed.yml → direct_connection_unavailable_seed.yml} +2 -2
  781. data/spec/spec_tests/data/sdam/single/direct_connection_wrong_set_name.yml +38 -0
  782. data/spec/spec_tests/data/sdam/single/discover_standalone.yml +34 -0
  783. data/spec/spec_tests/data/sdam/single/discover_unavailable_seed.yml +28 -0
  784. data/spec/spec_tests/data/sdam/single/too_old_then_upgraded.yml +46 -0
  785. data/spec/spec_tests/data/sdam_integration/cancel-server-check.yml +96 -0
  786. data/spec/spec_tests/data/sdam_integration/connectTimeoutMS.yml +88 -0
  787. data/spec/spec_tests/data/sdam_integration/find-network-error.yml +83 -0
  788. data/spec/spec_tests/data/sdam_integration/find-shutdown-error.yml +116 -0
  789. data/spec/spec_tests/data/sdam_integration/insert-network-error.yml +86 -0
  790. data/spec/spec_tests/data/sdam_integration/insert-shutdown-error.yml +115 -0
  791. data/spec/spec_tests/data/sdam_integration/isMaster-command-error.yml +168 -0
  792. data/spec/spec_tests/data/sdam_integration/isMaster-network-error.yml +162 -0
  793. data/spec/spec_tests/data/sdam_integration/isMaster-timeout.yml +229 -0
  794. data/spec/spec_tests/data/sdam_integration/rediscover-quickly-after-step-down.yml +87 -0
  795. data/spec/spec_tests/data/transactions/create-collection.yml +131 -0
  796. data/spec/spec_tests/data/transactions/create-index.yml +152 -0
  797. data/spec/spec_tests/data/transactions/error-labels.yml +87 -21
  798. data/spec/spec_tests/data/transactions/mongos-recovery-token.yml +1 -0
  799. data/spec/spec_tests/data/transactions/retryable-abort-errorLabels.yml +124 -0
  800. data/spec/spec_tests/data/transactions/retryable-abort.yml +17 -2
  801. data/spec/spec_tests/data/transactions/retryable-commit-errorLabels.yml +132 -0
  802. data/spec/spec_tests/data/transactions/retryable-commit.yml +24 -9
  803. data/spec/spec_tests/data/uri_options/connection-options.yml +43 -0
  804. data/spec/spec_tests/data/uri_options/ruby-auth-options.yml +12 -0
  805. data/spec/spec_tests/data/uri_options/ruby-connection-options.yml +57 -0
  806. data/spec/spec_tests/dns_seedlist_discovery_spec.rb +3 -1
  807. data/spec/spec_tests/gridfs_spec.rb +2 -0
  808. data/spec/spec_tests/max_staleness_spec.rb +5 -141
  809. data/spec/spec_tests/read_write_concern_connection_string_spec.rb +2 -0
  810. data/spec/spec_tests/read_write_concern_operaton_spec.rb +10 -0
  811. data/spec/spec_tests/retryable_reads_spec.rb +4 -2
  812. data/spec/spec_tests/retryable_writes_spec.rb +8 -1
  813. data/spec/spec_tests/sdam_integration_spec.rb +13 -0
  814. data/spec/spec_tests/sdam_monitoring_spec.rb +3 -2
  815. data/spec/spec_tests/sdam_spec.rb +70 -1
  816. data/spec/spec_tests/server_selection_rtt_spec.rb +2 -0
  817. data/spec/spec_tests/server_selection_spec.rb +5 -115
  818. data/spec/spec_tests/transactions_api_spec.rb +5 -0
  819. data/spec/spec_tests/transactions_spec.rb +5 -0
  820. data/spec/spec_tests/uri_options_spec.rb +2 -0
  821. data/spec/stress/cleanup_spec.rb +58 -0
  822. data/spec/stress/connection_pool_stress_spec.rb +11 -13
  823. data/spec/stress/connection_pool_timing_spec.rb +3 -6
  824. data/spec/stress/fork_reconnect_stress_spec.rb +109 -0
  825. data/spec/support/authorization.rb +1 -11
  826. data/spec/support/aws_utils.rb +62 -0
  827. data/spec/support/aws_utils/base.rb +134 -0
  828. data/spec/support/aws_utils/inspector.rb +224 -0
  829. data/spec/support/aws_utils/orchestrator.rb +370 -0
  830. data/spec/support/aws_utils/provisioner.rb +360 -0
  831. data/spec/support/background_thread_registry.rb +6 -2
  832. data/spec/support/child_process_helper.rb +78 -0
  833. data/spec/support/client_registry.rb +6 -24
  834. data/spec/support/cluster_config.rb +5 -0
  835. data/spec/support/common_shortcuts.rb +43 -0
  836. data/spec/support/constraints.rb +27 -7
  837. data/spec/support/crypt.rb +1 -1
  838. data/spec/support/event_subscriber.rb +184 -84
  839. data/spec/support/keyword_struct.rb +26 -0
  840. data/spec/support/lite_constraints.rb +47 -0
  841. data/spec/support/shared/scram_conversation.rb +100 -0
  842. data/spec/support/shared/server_selector.rb +93 -1
  843. data/spec/support/shared/session.rb +29 -21
  844. data/spec/support/spec_config.rb +76 -21
  845. data/spec/support/spec_organizer.rb +129 -0
  846. data/spec/support/spec_setup.rb +9 -5
  847. data/spec/support/utils.rb +161 -24
  848. metadata +1185 -744
  849. metadata.gz.sig +0 -0
  850. data/lib/mongo/server/connectable.rb +0 -107
  851. data/spec/runners/change_streams.rb +0 -262
  852. data/spec/runners/change_streams/operation.rb +0 -89
  853. data/spec/runners/sdam_monitoring.rb +0 -89
  854. data/spec/spec_tests/data/sdam/sharded/ruby_discovered_single_mongos.yml +0 -27
@@ -1,4 +1,4 @@
1
- # Copyright (C) 2015-2019 MongoDB, Inc.
1
+ # Copyright (C) 2015-2020 MongoDB Inc.
2
2
  #
3
3
  # Licensed under the Apache License, Version 2.0 (the "License");
4
4
  # you may not use this file except in compliance with the License.
@@ -25,13 +25,6 @@ module Mongo
25
25
  # @return [ Array<Hash, BSON::Document> ] requests The provided requests.
26
26
  attr_reader :requests
27
27
 
28
- # @return [ true, false ] has_collation Whether one or more operations has a collation defined.
29
- attr_reader :has_collation
30
-
31
- # @return [ true, false ] has_array_filters Whether one or more operations specifies an array
32
- # filters option.
33
- attr_reader :has_array_filters
34
-
35
28
  # Create the ordered combiner.
36
29
  #
37
30
  # @api private
@@ -46,6 +39,25 @@ module Mongo
46
39
  @requests = requests
47
40
  @has_collation = false
48
41
  @has_array_filters = false
42
+ @has_hint = false
43
+ end
44
+
45
+ # @return [ Boolean ] Whether one or more operation specifies the collation
46
+ # option.
47
+ def has_collation?
48
+ @has_collation
49
+ end
50
+
51
+ # @return [ Boolean ] Whether one or more operation specifies the
52
+ # array_filters option.
53
+ def has_array_filters?
54
+ @has_array_filters
55
+ end
56
+
57
+ # @return [ Boolean ] Whether one or more operation specifies the
58
+ # hint option.
59
+ def has_hint?
60
+ @has_hint
49
61
  end
50
62
 
51
63
  private
@@ -1,4 +1,4 @@
1
- # Copyright (C) 2015-2019 MongoDB, Inc.
1
+ # Copyright (C) 2015-2020 MongoDB Inc.
2
2
  #
3
3
  # Licensed under the Apache License, Version 2.0 (the "License");
4
4
  # you may not use this file except in compliance with the License.
@@ -1,4 +1,4 @@
1
- # Copyright (C) 2015-2019 MongoDB, Inc.
1
+ # Copyright (C) 2015-2020 MongoDB Inc.
2
2
  #
3
3
  # Licensed under the Apache License, Version 2.0 (the "License");
4
4
  # you may not use this file except in compliance with the License.
@@ -1,4 +1,4 @@
1
- # Copyright (C) 2015-2019 MongoDB, Inc.
1
+ # Copyright (C) 2015-2020 MongoDB Inc.
2
2
  #
3
3
  # Licensed under the Apache License, Version 2.0 (the "License");
4
4
  # you may not use this file except in compliance with the License.
@@ -1,4 +1,4 @@
1
- # Copyright (C) 2015-2019 MongoDB, Inc.
1
+ # Copyright (C) 2015-2020 MongoDB Inc.
2
2
  #
3
3
  # Licensed under the Apache License, Version 2.0 (the "License");
4
4
  # you may not use this file except in compliance with the License.
@@ -61,6 +61,7 @@ module Mongo
61
61
  Operation::LIMIT => 0,
62
62
  }.tap do |d|
63
63
  d[Operation::COLLATION] = doc[:collation] if doc[:collation]
64
+ d['hint'] = doc[:hint] if doc[:hint]
64
65
  end
65
66
  }
66
67
 
@@ -73,6 +74,7 @@ module Mongo
73
74
  Operation::LIMIT => 1,
74
75
  }.tap do |d|
75
76
  d[Operation::COLLATION] = doc[:collation] if doc[:collation]
77
+ d['hint'] = doc[:hint] if doc[:hint]
76
78
  end
77
79
  }
78
80
 
@@ -91,10 +93,9 @@ module Mongo
91
93
  Operation::Q => doc[:filter],
92
94
  Operation::U => doc[:replacement],
93
95
  }.tap do |d|
94
- if doc[:upsert]
95
- d['upsert'] = true
96
- end
96
+ d['upsert'] = true if doc[:upsert]
97
97
  d[Operation::COLLATION] = doc[:collation] if doc[:collation]
98
+ d['hint'] = doc[:hint] if doc[:hint]
98
99
  end
99
100
  }
100
101
 
@@ -107,11 +108,10 @@ module Mongo
107
108
  Operation::U => doc[:update],
108
109
  Operation::MULTI => true,
109
110
  }.tap do |d|
110
- if doc[:upsert]
111
- d['upsert'] = true
112
- end
111
+ d['upsert'] = true if doc[:upsert]
113
112
  d[Operation::COLLATION] = doc[:collation] if doc[:collation]
114
113
  d[Operation::ARRAY_FILTERS] = doc[:array_filters] if doc[:array_filters]
114
+ d['hint'] = doc[:hint] if doc[:hint]
115
115
  end
116
116
  }
117
117
 
@@ -123,11 +123,10 @@ module Mongo
123
123
  Operation::Q => doc[:filter],
124
124
  Operation::U => doc[:update],
125
125
  }.tap do |d|
126
- if doc[:upsert]
127
- d['upsert'] = true
128
- end
126
+ d['upsert'] = true if doc[:upsert]
129
127
  d[Operation::COLLATION] = doc[:collation] if doc[:collation]
130
128
  d[Operation::ARRAY_FILTERS] = doc[:array_filters] if doc[:array_filters]
129
+ d['hint'] = doc[:hint] if doc[:hint]
131
130
  end
132
131
  }
133
132
 
@@ -1,4 +1,4 @@
1
- # Copyright (C) 2015-2019 MongoDB, Inc.
1
+ # Copyright (C) 2015-2020 MongoDB Inc.
2
2
  #
3
3
  # Licensed under the Apache License, Version 2.0 (the "License");
4
4
  # you may not use this file except in compliance with the License.
@@ -1,4 +1,4 @@
1
- # Copyright (C) 2015-2019 MongoDB, Inc.
1
+ # Copyright (C) 2015-2020 MongoDB Inc.
2
2
  #
3
3
  # Licensed under the Apache License, Version 2.0 (the "License");
4
4
  # you may not use this file except in compliance with the License.
@@ -47,6 +47,10 @@ module Mongo
47
47
  if document.respond_to?(:keys) && document[:array_filters]
48
48
  @has_array_filters = true
49
49
  end
50
+
51
+ if document.respond_to?(:keys) && document[:hint]
52
+ @has_hint = true
53
+ end
50
54
  end
51
55
 
52
56
  private
data/lib/mongo/client.rb CHANGED
@@ -1,4 +1,4 @@
1
- # Copyright (C) 2014-2019 MongoDB, Inc.
1
+ # Copyright (C) 2014-2020 MongoDB Inc.
2
2
  #
3
3
  # Licensed under the Apache License, Version 2.0 (the 'License');
4
4
  # you may not use this file except in compliance with the License.
@@ -55,8 +55,10 @@ module Mongo
55
55
  :auth_mech_properties,
56
56
  :auth_source,
57
57
  :auto_encryption_options,
58
+ :bg_error_backtrace,
58
59
  :cleanup,
59
60
  :compressors,
61
+ :direct_connection,
60
62
  :connect,
61
63
  :connect_timeout,
62
64
  :database,
@@ -102,6 +104,7 @@ module Mongo
102
104
  :truncate_logs,
103
105
  :user,
104
106
  :wait_queue_timeout,
107
+ :wrapping_libraries,
105
108
  :write,
106
109
  :write_concern,
107
110
  :zlib_compression_level,
@@ -205,7 +208,6 @@ module Mongo
205
208
  # connection string is also provided, these options take precedence over any
206
209
  # analogous options present in the URI string.
207
210
  #
208
- #
209
211
  # @option options [ String, Symbol ] :app_name Application name that is
210
212
  # printed to the mongod logs upon establishing a connection in server
211
213
  # versions >= 3.4.
@@ -213,11 +215,19 @@ module Mongo
213
215
  # use. One of :mongodb_cr, :mongodb_x509, :plain, :scram, :scram256
214
216
  # @option options [ Hash ] :auth_mech_properties
215
217
  # @option options [ String ] :auth_source The source to authenticate from.
218
+ # @option options [ true | false | nil | Integer ] :bg_error_backtrace
219
+ # Experimental. Set to true to log complete backtraces for errors in
220
+ # background threads. Set to false or nil to not log backtraces. Provide
221
+ # a positive integer to log up to that many backtrace lines.
216
222
  # @option options [ Array<String> ] :compressors A list of potential
217
223
  # compressors to use, in order of preference. The driver chooses the
218
224
  # first compressor that is also supported by the server. Currently the
219
225
  # driver only supports 'zlib'.
220
- # @option options [ Symbol ] :connect The connection method to use. This
226
+ # @option options [ true | false ] :direct_connection Whether to connect
227
+ # directly to the specified seed, bypassing topology discovery. Exactly
228
+ # one seed must be provided.
229
+ # @option options [ Symbol ] :connect Deprecated - use :direct_connection
230
+ # option instead of this option. The connection method to use. This
221
231
  # forces the cluster to behave in the specified way instead of
222
232
  # auto-discovering. One of :direct, :replica_set, :sharded
223
233
  # @option options [ Float ] :connect_timeout The timeout, in seconds, to
@@ -294,7 +304,7 @@ module Mongo
294
304
  # will ignore it and will never scan seeds in the constructor.
295
305
  # @option options [ Proc ] :sdam_proc A Proc to invoke with the client
296
306
  # as the argument prior to performing server discovery and monitoring.
297
- # Use this to set up SDAM event listeners to receive events dispatched
307
+ # Use this to set up SDAM event listeners to receive events published
298
308
  # during client construction.
299
309
  #
300
310
  # Note: the client is not fully constructed when sdam_proc is invoked,
@@ -366,6 +376,10 @@ module Mongo
366
376
  # @option options [ String ] :user The user name.
367
377
  # @option options [ Float ] :wait_queue_timeout The time to wait, in
368
378
  # seconds, in the connection pool for a connection to be checked in.
379
+ # @option options [ Array<Hash> ] :wrapping_libraries Information about
380
+ # libraries such as ODMs that are wrapping the driver, to be added to
381
+ # metadata sent to the server. Specify the lower level libraries first.
382
+ # Allowed hash keys: :name, :version, :platform.
369
383
  # @option options [ Hash ] :write Deprecated. Equivalent to :write_concern
370
384
  # option.
371
385
  # @option options [ Hash ] :write_concern The write concern options.
@@ -439,6 +453,12 @@ module Mongo
439
453
  @srv_records = uri.srv_records
440
454
  else
441
455
  addresses = addresses_or_uri
456
+ addresses.each do |addr|
457
+ if addr =~ /\Amongodb(\+srv)?:\/\//i
458
+ raise ArgumentError, "Host '#{addr}' should not contain protocol. Did you mean to not use an array?"
459
+ end
460
+ end
461
+
442
462
  @srv_records = nil
443
463
  end
444
464
 
@@ -446,18 +466,7 @@ module Mongo
446
466
  # construction
447
467
  sdam_proc = options.delete(:sdam_proc)
448
468
 
449
- # For gssapi service_name, the default option is given in a hash
450
- # (one level down from the top level).
451
- merged_options = default_options(options)
452
- options.each do |k, v|
453
- default_v = merged_options[k]
454
- if Hash === default_v
455
- v = default_v.merge(v)
456
- end
457
- merged_options[k] = v
458
- end
459
- options = merged_options
460
-
469
+ options = default_options(options).merge(options)
461
470
  @options = validate_new_options!(options)
462
471
  =begin WriteConcern object support
463
472
  if @options[:write_concern].is_a?(WriteConcern::Base)
@@ -467,7 +476,7 @@ module Mongo
467
476
  end
468
477
  =end
469
478
  @options.freeze
470
- validate_options!
479
+ validate_options!(addresses)
471
480
  validate_authentication_options!
472
481
 
473
482
  @database = Database.new(self, @options[:database], @options)
@@ -496,7 +505,6 @@ module Mongo
496
505
  end
497
506
  end
498
507
 
499
- yield(self) if block_given?
500
508
  rescue
501
509
  begin
502
510
  @cluster.disconnect!
@@ -506,6 +514,14 @@ module Mongo
506
514
  end
507
515
  raise
508
516
  end
517
+
518
+ if block_given?
519
+ begin
520
+ yield(self)
521
+ ensure
522
+ close
523
+ end
524
+ end
509
525
  end
510
526
 
511
527
  # @api private
@@ -616,7 +632,7 @@ module Mongo
616
632
  #
617
633
  # @return [ BSON::Document ] The user-defined read preference.
618
634
  # The document may have the following fields:
619
- # - *:mode* -- read preference specified as a symbol; valid values are
635
+ # - *:read* -- read preference specified as a symbol; valid values are
620
636
  # *:primary*, *:primary_preferred*, *:secondary*, *:secondary_preferred*
621
637
  # and *:nearest*.
622
638
  # - *:tag_sets* -- an array of hashes.
@@ -809,6 +825,13 @@ module Mongo
809
825
  # @param [ Hash ] filter The filter criteria for getting a list of databases.
810
826
  # @param [ Hash ] opts The command options.
811
827
  #
828
+ # @option opts [ true, false ] :authorized_databases A flag that determines
829
+ # which databases are returned based on user privileges when access control
830
+ # is enabled
831
+ #
832
+ # See https://docs.mongodb.com/manual/reference/command/listDatabases/
833
+ # for more information and usage.
834
+ #
812
835
  # @return [ Array<String> ] The names of the databases.
813
836
  #
814
837
  # @since 2.0.5
@@ -825,6 +848,13 @@ module Mongo
825
848
  # @param [ true, false ] name_only Whether to only return each database name without full metadata.
826
849
  # @param [ Hash ] opts The command options.
827
850
  #
851
+ # @option opts [ true, false ] :authorized_databases A flag that determines
852
+ # which databases are returned based on user privileges when access control
853
+ # is enabled
854
+ #
855
+ # See https://docs.mongodb.com/manual/reference/command/listDatabases/
856
+ # for more information and usage.
857
+ #
828
858
  # @return [ Array<Hash> ] The info for each database.
829
859
  #
830
860
  # @since 2.0.5
@@ -832,6 +862,7 @@ module Mongo
832
862
  cmd = { listDatabases: 1 }
833
863
  cmd[:nameOnly] = !!name_only
834
864
  cmd[:filter] = filter unless filter.empty?
865
+ cmd[:authorizedDatabases] = true if opts[:authorized_databases]
835
866
  use(Database::ADMIN).database.read_command(cmd, opts).first[Database::DATABASES]
836
867
  end
837
868
 
@@ -872,8 +903,16 @@ module Mongo
872
903
  #
873
904
  # @since 2.5.0
874
905
  def start_session(options = {})
875
- get_session(options.merge(implicit: false)) or
876
- raise Error::InvalidSession.new(Session::SESSIONS_NOT_SUPPORTED)
906
+ session = get_session!(options.merge(implicit: false))
907
+ if block_given?
908
+ begin
909
+ yield session
910
+ ensure
911
+ session.end_session
912
+ end
913
+ else
914
+ session
915
+ end
877
916
  end
878
917
 
879
918
  # As of version 3.6 of the MongoDB server, a ``$changeStream`` pipeline stage is supported
@@ -919,6 +958,59 @@ module Mongo
919
958
  options)
920
959
  end
921
960
 
961
+ # Returns a session to use for operations if possible.
962
+ #
963
+ # If :session option is set, validates that session and returns it.
964
+ # Otherwise, if deployment supports sessions, creates a new session and
965
+ # returns it. When a new session is created, the session will be implicit
966
+ # (lifecycle is managed by the driver) if the :implicit option is given,
967
+ # otherwise the session will be explicit (lifecycle managed by the
968
+ # application). If deployment does not support session, returns nil.
969
+ #
970
+ # @option options [ true | false ] :implicit When no session is passed in,
971
+ # whether to create an implicit session.
972
+ # @option options [ Session ] :session The session to validate and return.
973
+ #
974
+ # @return [ Session | nil ] Session object or nil if sessions are not
975
+ # supported by the deployment.
976
+ #
977
+ # @api private
978
+ def get_session(options = {})
979
+ get_session!(options)
980
+ rescue Error::SessionsNotSupported
981
+ nil
982
+ end
983
+
984
+ # Creates a session to use for operations if possible and yields it to
985
+ # the provided block.
986
+ #
987
+ # If :session option is set, validates that session and uses it.
988
+ # Otherwise, if deployment supports sessions, creates a new session and
989
+ # uses it. When a new session is created, the session will be implicit
990
+ # (lifecycle is managed by the driver) if the :implicit option is given,
991
+ # otherwise the session will be explicit (lifecycle managed by the
992
+ # application). If deployment does not support session, yields nil to
993
+ # the block.
994
+ #
995
+ # When the block finishes, if the session was created and was implicit,
996
+ # or if an implicit session was passed in, the session is ended which
997
+ # returns it to the pool of available sessions.
998
+ #
999
+ # @option options [ true | false ] :implicit When no session is passed in,
1000
+ # whether to create an implicit session.
1001
+ # @option options [ Session ] :session The session to validate and return.
1002
+ #
1003
+ # @api private
1004
+ def with_session(options = {}, &block)
1005
+ session = get_session(options)
1006
+
1007
+ yield session
1008
+ ensure
1009
+ if session && session.implicit?
1010
+ session.end_session
1011
+ end
1012
+ end
1013
+
922
1014
  private
923
1015
 
924
1016
  # Create a new encrypter object using the client's auto encryption options
@@ -951,30 +1043,34 @@ module Mongo
951
1043
  close_encrypter
952
1044
  end
953
1045
 
954
- # If options[:session] is set, validates that session and returns it.
955
- # If deployment supports sessions, creates a new session and returns it.
956
- # The session is implicit unless options[:implicit] is given.
957
- # If deployment does not support session, returns nil.
1046
+ # Returns a session to use for operations.
958
1047
  #
959
- # @return [ Session | nil ] Session object or nil if sessions are not
960
- # supported by the deployment.
961
- def get_session(options = {})
1048
+ # If :session option is set, validates that session and returns it.
1049
+ # Otherwise, if deployment supports sessions, creates a new session and
1050
+ # returns it. When a new session is created, the session will be implicit
1051
+ # (lifecycle is managed by the driver) if the :implicit option is given,
1052
+ # otherwise the session will be explicit (lifecycle managed by the
1053
+ # application). If deployment does not support session, raises
1054
+ # Error::InvalidSession.
1055
+ #
1056
+ # @option options [ true | false ] :implicit When no session is passed in,
1057
+ # whether to create an implicit session.
1058
+ # @option options [ Session ] :session The session to validate and return.
1059
+ #
1060
+ # @return [ Session ] A session object.
1061
+ #
1062
+ # @raise Error::SessionsNotSupported if sessions are not supported by
1063
+ # the deployment.
1064
+ #
1065
+ # @api private
1066
+ def get_session!(options = {})
962
1067
  if options[:session]
963
1068
  return options[:session].validate!(self)
964
1069
  end
965
1070
 
966
- if cluster.sessions_supported?
967
- Session.new(cluster.session_pool.checkout, self, { implicit: true }.merge(options))
968
- end
969
- end
1071
+ cluster.validate_session_support!
970
1072
 
971
- def with_session(options = {}, &block)
972
- session = get_session(options)
973
- yield(session)
974
- ensure
975
- if session && session.implicit?
976
- session.end_session
977
- end
1073
+ Session.new(cluster.session_pool.checkout, self, { implicit: true }.merge(options))
978
1074
  end
979
1075
 
980
1076
  def initialize_copy(original)
@@ -1023,10 +1119,82 @@ module Mongo
1023
1119
  # Validates all options after they are set on the client.
1024
1120
  # This method is intended to catch combinations of options which are
1025
1121
  # not allowed.
1026
- def validate_options!
1122
+ def validate_options!(addresses = nil)
1027
1123
  if options[:write] && options[:write_concern] && options[:write] != options[:write_concern]
1028
1124
  raise ArgumentError, "If :write and :write_concern are both given, they must be identical: #{options.inspect}"
1029
1125
  end
1126
+
1127
+ if options[:direct_connection]
1128
+ if options[:connect] && options[:connect].to_sym != :direct
1129
+ raise ArgumentError, "Conflicting client options: direct_connection=true and connect=#{options[:connect]}"
1130
+ end
1131
+ # When a new client is created, we get the list of seed addresses
1132
+ if addresses && addresses.length > 1
1133
+ raise ArgumentError, "direct_connection=true cannot be used with multiple seeds"
1134
+ end
1135
+ # When a client is copied using #with, we have a cluster
1136
+ if cluster && !cluster.topology.is_a?(Mongo::Cluster::Topology::Single)
1137
+ raise ArgumentError, "direct_connection=true cannot be used with topologies other than Single (this client is #{cluster.topology.class.name.sub(/.*::/, '')})"
1138
+ end
1139
+ end
1140
+
1141
+ if options[:direct_connection] == false && options[:connect] && options[:connect].to_sym == :direct
1142
+ raise ArgumentError, "Conflicting client options: direct_connection=false and connect=#{options[:connect]}"
1143
+ end
1144
+
1145
+ %i(connect_timeout socket_timeout).each do |key|
1146
+ if value = options[key]
1147
+ unless Numeric === value
1148
+ raise ArgumentError, "#{key} must be a non-negative number: #{value}"
1149
+ end
1150
+ if value < 0
1151
+ raise ArgumentError, "#{key} must be a non-negative number: #{value}"
1152
+ end
1153
+ end
1154
+ end
1155
+
1156
+ if value = options[:bg_error_backtrace]
1157
+ case value
1158
+ when Integer
1159
+ if value <= 0
1160
+ raise ArgumentError, ":bg_error_backtrace option value must be true, false, nil or a positive integer: #{value}"
1161
+ end
1162
+ when true
1163
+ # OK
1164
+ else
1165
+ raise ArgumentError, ":bg_error_backtrace option value must be true, false, nil or a positive integer: #{value}"
1166
+ end
1167
+ end
1168
+
1169
+ if libraries = options[:wrapping_libraries]
1170
+ unless Array === libraries
1171
+ raise ArgumentError, ":wrapping_libraries must be an array of hashes: #{libraries}"
1172
+ end
1173
+
1174
+ libraries = libraries.map do |library|
1175
+ Utils.shallow_symbolize_keys(library)
1176
+ end
1177
+
1178
+ libraries.each do |library|
1179
+ unless Hash === library
1180
+ raise ArgumentError, ":wrapping_libraries element is not a hash: #{library}"
1181
+ end
1182
+
1183
+ if library.empty?
1184
+ raise ArgumentError, ":wrapping_libraries element is empty"
1185
+ end
1186
+
1187
+ unless (library.keys - %i(name platform version)).empty?
1188
+ raise ArgumentError, ":wrapping_libraries element has invalid keys (allowed keys: :name, :platform, :version): #{library}"
1189
+ end
1190
+
1191
+ library.each do |key, value|
1192
+ if value.include?('|')
1193
+ raise ArgumentError, ":wrapping_libraries element value cannot include '|': #{value}"
1194
+ end
1195
+ end
1196
+ end
1197
+ end
1030
1198
  end
1031
1199
 
1032
1200
  # Validates all authentication-related options after they are set on the client
@@ -1054,11 +1222,11 @@ module Mongo
1054
1222
  raise Mongo::Auth::InvalidMechanism.new(auth_mech)
1055
1223
  end
1056
1224
 
1057
- if user.nil? && auth_mech != :mongodb_x509
1225
+ if user.nil? && !%i(aws mongodb_x509).include?(auth_mech)
1058
1226
  raise Mongo::Auth::InvalidConfiguration, "Username is required for auth mechanism #{auth_mech}"
1059
1227
  end
1060
1228
 
1061
- if password.nil? && ![:gssapi, :mongodb_x509].include?(auth_mech)
1229
+ if password.nil? && !%i(aws gssapi mongodb_x509).include?(auth_mech)
1062
1230
  raise Mongo::Auth::InvalidConfiguration, "Password is required for auth mechanism #{auth_mech}"
1063
1231
  end
1064
1232
 
@@ -1066,7 +1234,11 @@ module Mongo
1066
1234
  raise Mongo::Auth::InvalidConfiguration, 'Password is not supported for :mongodb_x509 auth mechanism'
1067
1235
  end
1068
1236
 
1069
- if [:gssapi, :mongodb_x509].include?(auth_mech)
1237
+ if auth_mech == :aws && user && !password
1238
+ raise Mongo::Auth::InvalidConfiguration, 'Username is provided but password is not provided for :aws auth mechanism'
1239
+ end
1240
+
1241
+ if %i(aws gssapi mongodb_x509).include?(auth_mech)
1070
1242
  if !['$external', nil].include?(auth_source)
1071
1243
  raise Mongo::Auth::InvalidConfiguration, "#{auth_source} is an invalid auth source for #{auth_mech}; valid options are $external and nil"
1072
1244
  end
@@ -1077,7 +1249,7 @@ module Mongo
1077
1249
  end
1078
1250
  end
1079
1251
 
1080
- if mech_properties && auth_mech != :gssapi
1252
+ if mech_properties && !%i(aws gssapi).include?(auth_mech)
1081
1253
  raise Mongo::Auth::InvalidConfiguration, ":mechanism_properties are not supported for auth mechanism #{auth_mech}"
1082
1254
  end
1083
1255
  end