mongo 2.14.0 → 2.16.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 (1225) hide show
  1. checksums.yaml +4 -4
  2. checksums.yaml.gz.sig +0 -0
  3. data/README.md +5 -2
  4. data/Rakefile +8 -15
  5. data/lib/mongo/active_support.rb +3 -0
  6. data/lib/mongo/address/ipv4.rb +3 -0
  7. data/lib/mongo/address/ipv6.rb +3 -0
  8. data/lib/mongo/address/unix.rb +3 -0
  9. data/lib/mongo/address/validator.rb +3 -0
  10. data/lib/mongo/address.rb +3 -0
  11. data/lib/mongo/auth/aws/conversation.rb +4 -4
  12. data/lib/mongo/auth/aws/credentials_retriever.rb +3 -0
  13. data/lib/mongo/auth/aws/request.rb +3 -0
  14. data/lib/mongo/auth/aws.rb +3 -0
  15. data/lib/mongo/auth/base.rb +17 -8
  16. data/lib/mongo/auth/conversation_base.rb +35 -0
  17. data/lib/mongo/auth/cr/conversation.rb +9 -29
  18. data/lib/mongo/auth/cr.rb +3 -0
  19. data/lib/mongo/auth/credential_cache.rb +3 -0
  20. data/lib/mongo/auth/gssapi/conversation.rb +7 -15
  21. data/lib/mongo/auth/gssapi.rb +3 -0
  22. data/lib/mongo/auth/ldap/conversation.rb +6 -14
  23. data/lib/mongo/auth/ldap.rb +3 -0
  24. data/lib/mongo/auth/roles.rb +3 -0
  25. data/lib/mongo/auth/sasl_conversation_base.rb +4 -13
  26. data/lib/mongo/auth/scram/conversation.rb +3 -0
  27. data/lib/mongo/auth/scram.rb +5 -2
  28. data/lib/mongo/auth/scram256/conversation.rb +3 -0
  29. data/lib/mongo/auth/scram256.rb +3 -0
  30. data/lib/mongo/auth/scram_conversation_base.rb +10 -34
  31. data/lib/mongo/auth/stringprep/profiles/sasl.rb +3 -0
  32. data/lib/mongo/auth/stringprep/tables.rb +3 -0
  33. data/lib/mongo/auth/stringprep/unicode_normalize/normalize.rb +2 -2
  34. data/lib/mongo/auth/stringprep/unicode_normalize/tables.rb +1 -1
  35. data/lib/mongo/auth/stringprep.rb +4 -1
  36. data/lib/mongo/auth/user/view.rb +19 -9
  37. data/lib/mongo/auth/user.rb +3 -0
  38. data/lib/mongo/auth/x509/conversation.rb +7 -25
  39. data/lib/mongo/auth/x509.rb +3 -0
  40. data/lib/mongo/auth.rb +4 -1
  41. data/lib/mongo/background_thread.rb +16 -2
  42. data/lib/mongo/bson.rb +3 -0
  43. data/lib/mongo/bulk_write/combineable.rb +3 -0
  44. data/lib/mongo/bulk_write/ordered_combiner.rb +3 -0
  45. data/lib/mongo/bulk_write/result.rb +3 -0
  46. data/lib/mongo/bulk_write/result_combiner.rb +3 -0
  47. data/lib/mongo/bulk_write/transformable.rb +3 -0
  48. data/lib/mongo/bulk_write/unordered_combiner.rb +3 -0
  49. data/lib/mongo/bulk_write/validatable.rb +3 -0
  50. data/lib/mongo/bulk_write.rb +26 -20
  51. data/lib/mongo/caching_cursor.rb +3 -0
  52. data/lib/mongo/client.rb +131 -12
  53. data/lib/mongo/client_encryption.rb +3 -0
  54. data/lib/mongo/cluster/periodic_executor.rb +7 -3
  55. data/lib/mongo/cluster/reapers/cursor_reaper.rb +80 -40
  56. data/lib/mongo/cluster/reapers/socket_reaper.rb +3 -0
  57. data/lib/mongo/cluster/sdam_flow.rb +26 -3
  58. data/lib/mongo/cluster/topology/base.rb +16 -9
  59. data/lib/mongo/cluster/topology/load_balanced.rb +102 -0
  60. data/lib/mongo/cluster/topology/no_replica_set_options.rb +3 -0
  61. data/lib/mongo/cluster/topology/replica_set_no_primary.rb +3 -0
  62. data/lib/mongo/cluster/topology/replica_set_with_primary.rb +3 -0
  63. data/lib/mongo/cluster/topology/sharded.rb +3 -0
  64. data/lib/mongo/cluster/topology/single.rb +3 -0
  65. data/lib/mongo/cluster/topology/unknown.rb +3 -0
  66. data/lib/mongo/cluster/topology.rb +31 -8
  67. data/lib/mongo/cluster.rb +156 -77
  68. data/lib/mongo/cluster_time.rb +3 -0
  69. data/lib/mongo/collection/view/aggregation.rb +9 -11
  70. data/lib/mongo/collection/view/builder/aggregation.rb +9 -5
  71. data/lib/mongo/collection/view/builder/map_reduce.rb +15 -49
  72. data/lib/mongo/collection/view/builder.rb +3 -4
  73. data/lib/mongo/collection/view/change_stream/retryable.rb +3 -0
  74. data/lib/mongo/collection/view/change_stream.rb +5 -2
  75. data/lib/mongo/collection/view/explainable.rb +3 -0
  76. data/lib/mongo/collection/view/immutable.rb +3 -0
  77. data/lib/mongo/collection/view/iterable.rb +62 -25
  78. data/lib/mongo/collection/view/map_reduce.rb +44 -17
  79. data/lib/mongo/collection/view/readable.rb +105 -65
  80. data/lib/mongo/collection/view/writable.rb +187 -181
  81. data/lib/mongo/collection/view.rb +18 -21
  82. data/lib/mongo/collection.rb +54 -28
  83. data/lib/mongo/crypt/auto_decryption_context.rb +3 -0
  84. data/lib/mongo/crypt/auto_encrypter.rb +4 -1
  85. data/lib/mongo/crypt/auto_encryption_context.rb +3 -0
  86. data/lib/mongo/crypt/binary.rb +3 -0
  87. data/lib/mongo/crypt/binding.rb +4 -1
  88. data/lib/mongo/crypt/context.rb +3 -0
  89. data/lib/mongo/crypt/data_key_context.rb +3 -0
  90. data/lib/mongo/crypt/encryption_io.rb +3 -0
  91. data/lib/mongo/crypt/explicit_decryption_context.rb +3 -0
  92. data/lib/mongo/crypt/explicit_encrypter.rb +3 -0
  93. data/lib/mongo/crypt/explicit_encryption_context.rb +3 -0
  94. data/lib/mongo/crypt/handle.rb +3 -0
  95. data/lib/mongo/crypt/hooks.rb +3 -0
  96. data/lib/mongo/crypt/kms_context.rb +3 -0
  97. data/lib/mongo/crypt/status.rb +3 -0
  98. data/lib/mongo/crypt.rb +3 -0
  99. data/lib/mongo/cursor/kill_spec.rb +38 -0
  100. data/lib/mongo/cursor.rb +76 -31
  101. data/lib/mongo/database/view.rb +5 -2
  102. data/lib/mongo/database.rb +26 -6
  103. data/lib/mongo/dbref.rb +3 -0
  104. data/lib/mongo/distinguishing_semaphore.rb +3 -0
  105. data/lib/mongo/error/auth_error.rb +3 -0
  106. data/lib/mongo/error/bad_load_balancer_target.rb +26 -0
  107. data/lib/mongo/error/bulk_write_error.rb +20 -3
  108. data/lib/mongo/error/change_stream_resumable.rb +3 -0
  109. data/lib/mongo/error/closed_stream.rb +3 -0
  110. data/lib/mongo/error/connection_check_out_timeout.rb +3 -0
  111. data/lib/mongo/error/connection_perished.rb +3 -0
  112. data/lib/mongo/error/credential_check_error.rb +3 -0
  113. data/lib/mongo/error/crypt_error.rb +3 -0
  114. data/lib/mongo/error/extra_file_chunk.rb +3 -0
  115. data/lib/mongo/error/failed_string_prep_validation.rb +3 -0
  116. data/lib/mongo/error/file_not_found.rb +3 -0
  117. data/lib/mongo/error/handshake_error.rb +3 -0
  118. data/lib/mongo/error/insufficient_iteration_count.rb +3 -0
  119. data/lib/mongo/error/internal_driver_error.rb +25 -0
  120. data/lib/mongo/error/invalid_address.rb +3 -0
  121. data/lib/mongo/error/invalid_application_name.rb +3 -0
  122. data/lib/mongo/error/invalid_bulk_operation.rb +3 -0
  123. data/lib/mongo/error/invalid_bulk_operation_type.rb +3 -0
  124. data/lib/mongo/error/invalid_collection_name.rb +3 -0
  125. data/lib/mongo/error/invalid_cursor_operation.rb +3 -0
  126. data/lib/mongo/error/invalid_database_name.rb +3 -0
  127. data/lib/mongo/error/invalid_document.rb +3 -0
  128. data/lib/mongo/error/invalid_file.rb +3 -0
  129. data/lib/mongo/error/invalid_file_revision.rb +3 -0
  130. data/lib/mongo/error/invalid_min_pool_size.rb +3 -0
  131. data/lib/mongo/error/invalid_nonce.rb +3 -0
  132. data/lib/mongo/error/invalid_read_concern.rb +3 -0
  133. data/lib/mongo/error/invalid_read_option.rb +3 -0
  134. data/lib/mongo/error/invalid_replacement_document.rb +3 -0
  135. data/lib/mongo/error/invalid_server_auth_host.rb +3 -0
  136. data/lib/mongo/error/invalid_server_auth_response.rb +3 -0
  137. data/lib/mongo/error/invalid_server_preference.rb +3 -0
  138. data/lib/mongo/error/invalid_session.rb +3 -0
  139. data/lib/mongo/error/invalid_signature.rb +3 -0
  140. data/lib/mongo/error/invalid_transaction_operation.rb +3 -0
  141. data/lib/mongo/error/invalid_txt_record.rb +3 -0
  142. data/lib/mongo/error/invalid_update_document.rb +3 -0
  143. data/lib/mongo/error/invalid_uri.rb +3 -0
  144. data/lib/mongo/error/invalid_write_concern.rb +3 -0
  145. data/lib/mongo/error/kms_error.rb +3 -0
  146. data/lib/mongo/error/lint_error.rb +3 -0
  147. data/lib/mongo/error/max_bson_size.rb +3 -0
  148. data/lib/mongo/error/max_message_size.rb +3 -0
  149. data/lib/mongo/error/mismatched_domain.rb +3 -0
  150. data/lib/mongo/error/missing_file_chunk.rb +3 -0
  151. data/lib/mongo/error/missing_password.rb +3 -0
  152. data/lib/mongo/error/missing_resume_token.rb +3 -0
  153. data/lib/mongo/error/missing_scram_server_signature.rb +3 -0
  154. data/lib/mongo/error/missing_service_id.rb +26 -0
  155. data/lib/mongo/error/mongocryptd_spawn_error.rb +3 -0
  156. data/lib/mongo/error/multi_index_drop.rb +3 -0
  157. data/lib/mongo/error/need_primary_server.rb +3 -0
  158. data/lib/mongo/error/no_server_available.rb +3 -0
  159. data/lib/mongo/error/no_service_connection_available.rb +49 -0
  160. data/lib/mongo/error/no_srv_records.rb +3 -0
  161. data/lib/mongo/error/notable.rb +10 -0
  162. data/lib/mongo/error/operation_failure.rb +26 -4
  163. data/lib/mongo/error/parser.rb +69 -13
  164. data/lib/mongo/error/pool_closed_error.rb +3 -0
  165. data/lib/mongo/error/raise_original_error.rb +3 -0
  166. data/lib/mongo/error/sdam_error_detection.rb +16 -5
  167. data/lib/mongo/error/server_api_conflict.rb +26 -0
  168. data/lib/mongo/error/server_api_not_supported.rb +27 -0
  169. data/lib/mongo/error/server_certificate_revoked.rb +3 -0
  170. data/lib/mongo/error/session_ended.rb +3 -0
  171. data/lib/mongo/error/sessions_not_supported.rb +3 -0
  172. data/lib/mongo/error/socket_error.rb +3 -0
  173. data/lib/mongo/error/socket_timeout_error.rb +3 -0
  174. data/lib/mongo/error/unchangeable_collection_option.rb +3 -0
  175. data/lib/mongo/error/unexpected_chunk_length.rb +3 -0
  176. data/lib/mongo/error/unexpected_response.rb +3 -0
  177. data/lib/mongo/error/unknown_payload_type.rb +3 -0
  178. data/lib/mongo/error/unmet_dependency.rb +24 -0
  179. data/lib/mongo/error/unsupported_array_filters.rb +3 -0
  180. data/lib/mongo/error/unsupported_collation.rb +3 -0
  181. data/lib/mongo/error/unsupported_features.rb +3 -0
  182. data/lib/mongo/error/unsupported_message_type.rb +3 -0
  183. data/lib/mongo/error/unsupported_option.rb +3 -0
  184. data/lib/mongo/error/write_retryable.rb +3 -0
  185. data/lib/mongo/error.rb +15 -1
  186. data/lib/mongo/event/base.rb +3 -0
  187. data/lib/mongo/event/listeners.rb +3 -0
  188. data/lib/mongo/event/publisher.rb +3 -0
  189. data/lib/mongo/event/subscriber.rb +3 -0
  190. data/lib/mongo/event.rb +3 -0
  191. data/lib/mongo/grid/file/chunk.rb +4 -1
  192. data/lib/mongo/grid/file/info.rb +3 -0
  193. data/lib/mongo/grid/file.rb +3 -0
  194. data/lib/mongo/grid/fs_bucket.rb +86 -46
  195. data/lib/mongo/grid/stream/read.rb +22 -7
  196. data/lib/mongo/grid/stream/write.rb +3 -0
  197. data/lib/mongo/grid/stream.rb +3 -0
  198. data/lib/mongo/grid.rb +3 -0
  199. data/lib/mongo/id.rb +10 -5
  200. data/lib/mongo/index/view.rb +46 -52
  201. data/lib/mongo/index.rb +3 -0
  202. data/lib/mongo/lint.rb +3 -0
  203. data/lib/mongo/loggable.rb +3 -0
  204. data/lib/mongo/logger.rb +3 -0
  205. data/lib/mongo/monitoring/cmap_log_subscriber.rb +3 -0
  206. data/lib/mongo/monitoring/command_log_subscriber.rb +3 -0
  207. data/lib/mongo/monitoring/event/cmap/base.rb +3 -0
  208. data/lib/mongo/monitoring/event/cmap/connection_check_out_failed.rb +3 -0
  209. data/lib/mongo/monitoring/event/cmap/connection_check_out_started.rb +3 -0
  210. data/lib/mongo/monitoring/event/cmap/connection_checked_in.rb +3 -0
  211. data/lib/mongo/monitoring/event/cmap/connection_checked_out.rb +3 -0
  212. data/lib/mongo/monitoring/event/cmap/connection_closed.rb +3 -0
  213. data/lib/mongo/monitoring/event/cmap/connection_created.rb +3 -0
  214. data/lib/mongo/monitoring/event/cmap/connection_ready.rb +3 -0
  215. data/lib/mongo/monitoring/event/cmap/pool_cleared.rb +10 -4
  216. data/lib/mongo/monitoring/event/cmap/pool_closed.rb +3 -0
  217. data/lib/mongo/monitoring/event/cmap/pool_created.rb +3 -0
  218. data/lib/mongo/monitoring/event/cmap.rb +3 -0
  219. data/lib/mongo/monitoring/event/command_failed.rb +32 -5
  220. data/lib/mongo/monitoring/event/command_started.rb +22 -2
  221. data/lib/mongo/monitoring/event/command_succeeded.rb +29 -3
  222. data/lib/mongo/monitoring/event/secure.rb +39 -5
  223. data/lib/mongo/monitoring/event/server_closed.rb +3 -0
  224. data/lib/mongo/monitoring/event/server_description_changed.rb +4 -1
  225. data/lib/mongo/monitoring/event/server_heartbeat_failed.rb +32 -18
  226. data/lib/mongo/monitoring/event/server_heartbeat_started.rb +3 -0
  227. data/lib/mongo/monitoring/event/server_heartbeat_succeeded.rb +30 -16
  228. data/lib/mongo/monitoring/event/server_opening.rb +3 -0
  229. data/lib/mongo/monitoring/event/topology_changed.rb +3 -0
  230. data/lib/mongo/monitoring/event/topology_closed.rb +3 -0
  231. data/lib/mongo/monitoring/event/topology_opening.rb +3 -0
  232. data/lib/mongo/monitoring/event.rb +3 -0
  233. data/lib/mongo/monitoring/publishable.rb +34 -12
  234. data/lib/mongo/monitoring/sdam_log_subscriber.rb +3 -0
  235. data/lib/mongo/monitoring/server_closed_log_subscriber.rb +3 -0
  236. data/lib/mongo/monitoring/server_description_changed_log_subscriber.rb +3 -0
  237. data/lib/mongo/monitoring/server_opening_log_subscriber.rb +3 -0
  238. data/lib/mongo/monitoring/topology_changed_log_subscriber.rb +3 -0
  239. data/lib/mongo/monitoring/topology_closed_log_subscriber.rb +3 -0
  240. data/lib/mongo/monitoring/topology_opening_log_subscriber.rb +3 -0
  241. data/lib/mongo/monitoring/unified_sdam_log_subscriber.rb +3 -0
  242. data/lib/mongo/monitoring.rb +20 -8
  243. data/lib/mongo/operation/aggregate/command.rb +11 -0
  244. data/lib/mongo/operation/aggregate/op_msg.rb +3 -0
  245. data/lib/mongo/operation/aggregate/result.rb +3 -0
  246. data/lib/mongo/operation/aggregate.rb +3 -0
  247. data/lib/mongo/operation/collections_info/command.rb +5 -2
  248. data/lib/mongo/operation/collections_info/result.rb +3 -0
  249. data/lib/mongo/operation/collections_info.rb +21 -1
  250. data/lib/mongo/operation/command/command.rb +3 -0
  251. data/lib/mongo/operation/command/op_msg.rb +3 -0
  252. data/lib/mongo/operation/command.rb +3 -0
  253. data/lib/mongo/operation/context.rb +120 -0
  254. data/lib/mongo/operation/count/command.rb +9 -0
  255. data/lib/mongo/operation/count/op_msg.rb +9 -0
  256. data/lib/mongo/operation/count.rb +3 -0
  257. data/lib/mongo/operation/create/command.rb +10 -1
  258. data/lib/mongo/operation/create/op_msg.rb +10 -0
  259. data/lib/mongo/operation/create.rb +3 -0
  260. data/lib/mongo/operation/create_index/command.rb +20 -1
  261. data/lib/mongo/operation/create_index/op_msg.rb +20 -4
  262. data/lib/mongo/operation/create_index.rb +3 -0
  263. data/lib/mongo/operation/create_user/command.rb +3 -0
  264. data/lib/mongo/operation/create_user/op_msg.rb +3 -0
  265. data/lib/mongo/operation/create_user.rb +3 -0
  266. data/lib/mongo/operation/delete/bulk_result.rb +3 -0
  267. data/lib/mongo/operation/delete/command.rb +9 -3
  268. data/lib/mongo/operation/delete/legacy.rb +12 -2
  269. data/lib/mongo/operation/delete/op_msg.rb +11 -1
  270. data/lib/mongo/operation/delete/result.rb +3 -0
  271. data/lib/mongo/operation/delete.rb +3 -0
  272. data/lib/mongo/operation/distinct/command.rb +9 -0
  273. data/lib/mongo/operation/distinct/op_msg.rb +10 -0
  274. data/lib/mongo/operation/distinct.rb +3 -0
  275. data/lib/mongo/operation/drop/command.rb +3 -0
  276. data/lib/mongo/operation/drop/op_msg.rb +3 -0
  277. data/lib/mongo/operation/drop.rb +3 -0
  278. data/lib/mongo/operation/drop_database/command.rb +3 -0
  279. data/lib/mongo/operation/drop_database/op_msg.rb +3 -0
  280. data/lib/mongo/operation/drop_database.rb +3 -0
  281. data/lib/mongo/operation/drop_index/command.rb +3 -0
  282. data/lib/mongo/operation/drop_index/op_msg.rb +3 -0
  283. data/lib/mongo/operation/drop_index.rb +3 -0
  284. data/lib/mongo/operation/explain/command.rb +16 -1
  285. data/lib/mongo/operation/explain/legacy.rb +15 -5
  286. data/lib/mongo/operation/explain/op_msg.rb +12 -1
  287. data/lib/mongo/operation/explain/result.rb +3 -0
  288. data/lib/mongo/operation/explain.rb +3 -0
  289. data/lib/mongo/operation/find/builder/command.rb +110 -0
  290. data/lib/mongo/{collection/view → operation/find}/builder/flags.rb +13 -14
  291. data/lib/mongo/operation/find/builder/legacy.rb +123 -0
  292. data/lib/mongo/{collection/view → operation/find}/builder/modifiers.rb +34 -25
  293. data/lib/mongo/{cursor → operation/find}/builder.rb +7 -4
  294. data/lib/mongo/operation/find/command.rb +12 -0
  295. data/lib/mongo/operation/find/legacy/result.rb +3 -0
  296. data/lib/mongo/operation/find/legacy.rb +13 -1
  297. data/lib/mongo/operation/find/op_msg.rb +15 -0
  298. data/lib/mongo/operation/find/result.rb +3 -0
  299. data/lib/mongo/operation/find.rb +4 -0
  300. data/lib/mongo/operation/get_more/command.rb +4 -0
  301. data/lib/mongo/operation/get_more/command_builder.rb +38 -0
  302. data/lib/mongo/operation/get_more/legacy.rb +3 -0
  303. data/lib/mongo/operation/get_more/op_msg.rb +4 -0
  304. data/lib/mongo/operation/get_more/result.rb +3 -0
  305. data/lib/mongo/operation/get_more.rb +4 -0
  306. data/lib/mongo/operation/indexes/command.rb +3 -0
  307. data/lib/mongo/operation/indexes/legacy.rb +3 -0
  308. data/lib/mongo/operation/indexes/op_msg.rb +3 -0
  309. data/lib/mongo/operation/indexes/result.rb +3 -0
  310. data/lib/mongo/operation/indexes.rb +18 -1
  311. data/lib/mongo/operation/insert/bulk_result.rb +3 -0
  312. data/lib/mongo/operation/insert/command.rb +5 -2
  313. data/lib/mongo/operation/insert/legacy.rb +5 -2
  314. data/lib/mongo/operation/insert/op_msg.rb +5 -2
  315. data/lib/mongo/operation/insert/result.rb +3 -0
  316. data/lib/mongo/operation/insert.rb +3 -0
  317. data/lib/mongo/operation/kill_cursors/command.rb +11 -0
  318. data/lib/mongo/operation/kill_cursors/command_builder.rb +35 -0
  319. data/lib/mongo/operation/kill_cursors/legacy.rb +5 -1
  320. data/lib/mongo/operation/kill_cursors/op_msg.rb +13 -0
  321. data/lib/mongo/operation/kill_cursors.rb +4 -0
  322. data/lib/mongo/operation/list_collections/command.rb +3 -0
  323. data/lib/mongo/operation/list_collections/op_msg.rb +3 -0
  324. data/lib/mongo/operation/list_collections/result.rb +7 -1
  325. data/lib/mongo/operation/list_collections.rb +3 -0
  326. data/lib/mongo/operation/map_reduce/command.rb +11 -0
  327. data/lib/mongo/operation/map_reduce/op_msg.rb +4 -1
  328. data/lib/mongo/operation/map_reduce/result.rb +3 -0
  329. data/lib/mongo/operation/map_reduce.rb +3 -0
  330. data/lib/mongo/operation/op_msg_base.rb +3 -0
  331. data/lib/mongo/operation/parallel_scan/command.rb +4 -2
  332. data/lib/mongo/operation/parallel_scan/op_msg.rb +3 -0
  333. data/lib/mongo/operation/parallel_scan/result.rb +3 -0
  334. data/lib/mongo/operation/parallel_scan.rb +3 -0
  335. data/lib/mongo/operation/remove_user/command.rb +3 -0
  336. data/lib/mongo/operation/remove_user/op_msg.rb +3 -0
  337. data/lib/mongo/operation/remove_user.rb +3 -0
  338. data/lib/mongo/operation/result.rb +5 -0
  339. data/lib/mongo/operation/shared/bypass_document_validation.rb +3 -0
  340. data/lib/mongo/operation/shared/causal_consistency_supported.rb +3 -0
  341. data/lib/mongo/operation/shared/executable.rb +39 -15
  342. data/lib/mongo/operation/shared/executable_no_validate.rb +5 -2
  343. data/lib/mongo/operation/shared/executable_transaction_label.rb +3 -0
  344. data/lib/mongo/operation/shared/idable.rb +3 -0
  345. data/lib/mongo/operation/shared/limited.rb +3 -0
  346. data/lib/mongo/operation/shared/object_id_generator.rb +3 -0
  347. data/lib/mongo/operation/shared/op_msg_or_command.rb +4 -7
  348. data/lib/mongo/operation/shared/op_msg_or_find_command.rb +4 -7
  349. data/lib/mongo/operation/shared/polymorphic_lookup.rb +3 -0
  350. data/lib/mongo/operation/shared/polymorphic_operation.rb +42 -0
  351. data/lib/mongo/operation/shared/polymorphic_result.rb +3 -0
  352. data/lib/mongo/operation/shared/read_preference_supported.rb +44 -37
  353. data/lib/mongo/operation/shared/response_handling.rb +27 -23
  354. data/lib/mongo/operation/shared/result/aggregatable.rb +3 -0
  355. data/lib/mongo/operation/shared/result/use_legacy_error_parser.rb +3 -0
  356. data/lib/mongo/operation/shared/sessions_supported.rb +31 -16
  357. data/lib/mongo/operation/shared/specifiable.rb +14 -29
  358. data/lib/mongo/operation/shared/validatable.rb +87 -0
  359. data/lib/mongo/operation/shared/write.rb +12 -19
  360. data/lib/mongo/operation/shared/write_concern_supported.rb +3 -0
  361. data/lib/mongo/operation/update/bulk_result.rb +3 -0
  362. data/lib/mongo/operation/update/command.rb +9 -3
  363. data/lib/mongo/operation/update/legacy/result.rb +3 -0
  364. data/lib/mongo/operation/update/legacy.rb +22 -11
  365. data/lib/mongo/operation/update/op_msg.rb +10 -4
  366. data/lib/mongo/operation/update/result.rb +3 -0
  367. data/lib/mongo/operation/update.rb +3 -0
  368. data/lib/mongo/operation/update_user/command.rb +3 -0
  369. data/lib/mongo/operation/update_user/op_msg.rb +3 -0
  370. data/lib/mongo/operation/update_user.rb +3 -0
  371. data/lib/mongo/operation/users_info/command.rb +3 -0
  372. data/lib/mongo/operation/users_info/op_msg.rb +3 -0
  373. data/lib/mongo/operation/users_info/result.rb +3 -0
  374. data/lib/mongo/operation/users_info.rb +3 -0
  375. data/lib/mongo/operation/write_command/command.rb +51 -0
  376. data/lib/mongo/operation/write_command/op_msg.rb +43 -0
  377. data/lib/mongo/operation/write_command.rb +32 -0
  378. data/lib/mongo/operation.rb +15 -2
  379. data/lib/mongo/options/mapper.rb +3 -0
  380. data/lib/mongo/options/redacted.rb +3 -0
  381. data/lib/mongo/options.rb +3 -0
  382. data/lib/mongo/protocol/bit_vector.rb +3 -0
  383. data/lib/mongo/protocol/compressed.rb +54 -5
  384. data/lib/mongo/protocol/delete.rb +3 -0
  385. data/lib/mongo/protocol/get_more.rb +3 -0
  386. data/lib/mongo/protocol/insert.rb +3 -0
  387. data/lib/mongo/protocol/kill_cursors.rb +3 -0
  388. data/lib/mongo/protocol/message.rb +23 -2
  389. data/lib/mongo/protocol/msg.rb +39 -16
  390. data/lib/mongo/protocol/query.rb +53 -32
  391. data/lib/mongo/protocol/registry.rb +3 -0
  392. data/lib/mongo/protocol/reply.rb +3 -0
  393. data/lib/mongo/protocol/serializers.rb +3 -0
  394. data/lib/mongo/protocol/update.rb +3 -0
  395. data/lib/mongo/protocol.rb +3 -0
  396. data/lib/mongo/query_cache.rb +33 -0
  397. data/lib/mongo/retryable.rb +4 -1
  398. data/lib/mongo/semaphore.rb +3 -0
  399. data/lib/mongo/server/app_metadata.rb +89 -33
  400. data/lib/mongo/server/connection.rb +34 -4
  401. data/lib/mongo/server/connection_base.rb +47 -21
  402. data/lib/mongo/server/connection_common.rb +71 -1
  403. data/lib/mongo/server/connection_pool/generation_manager.rb +71 -0
  404. data/lib/mongo/server/connection_pool/populator.rb +3 -0
  405. data/lib/mongo/server/connection_pool.rb +108 -30
  406. data/lib/mongo/server/description/features.rb +30 -25
  407. data/lib/mongo/server/description/load_balancer.rb +33 -0
  408. data/lib/mongo/server/description.rb +112 -16
  409. data/lib/mongo/server/monitor/app_metadata.rb +4 -1
  410. data/lib/mongo/server/monitor/connection.rb +56 -47
  411. data/lib/mongo/server/monitor.rb +28 -14
  412. data/lib/mongo/server/pending_connection.rb +75 -42
  413. data/lib/mongo/server/push_monitor/connection.rb +3 -0
  414. data/lib/mongo/server/push_monitor.rb +38 -17
  415. data/lib/mongo/server/round_trip_time_averager.rb +6 -3
  416. data/lib/mongo/server.rb +97 -41
  417. data/lib/mongo/server_selector/base.rb +11 -4
  418. data/lib/mongo/server_selector/nearest.rb +6 -4
  419. data/lib/mongo/server_selector/primary.rb +6 -4
  420. data/lib/mongo/server_selector/primary_preferred.rb +6 -4
  421. data/lib/mongo/server_selector/secondary.rb +6 -4
  422. data/lib/mongo/server_selector/secondary_preferred.rb +8 -11
  423. data/lib/mongo/server_selector.rb +3 -0
  424. data/lib/mongo/session/server_session.rb +3 -0
  425. data/lib/mongo/session/session_pool.rb +18 -2
  426. data/lib/mongo/session.rb +39 -12
  427. data/lib/mongo/socket/ocsp_cache.rb +3 -0
  428. data/lib/mongo/socket/ocsp_verifier.rb +15 -38
  429. data/lib/mongo/socket/ssl.rb +11 -0
  430. data/lib/mongo/socket/tcp.rb +3 -0
  431. data/lib/mongo/socket/unix.rb +3 -0
  432. data/lib/mongo/socket.rb +36 -6
  433. data/lib/mongo/srv/monitor.rb +3 -11
  434. data/lib/mongo/srv/resolver.rb +3 -0
  435. data/lib/mongo/srv/result.rb +3 -0
  436. data/lib/mongo/srv.rb +3 -0
  437. data/lib/mongo/timeout.rb +3 -0
  438. data/lib/mongo/topology_version.rb +4 -1
  439. data/lib/mongo/uri/options_mapper.rb +42 -0
  440. data/lib/mongo/uri/srv_protocol.rb +9 -8
  441. data/lib/mongo/uri.rb +21 -0
  442. data/lib/mongo/utils.rb +38 -0
  443. data/lib/mongo/version.rb +4 -1
  444. data/lib/mongo/write_concern/acknowledged.rb +3 -0
  445. data/lib/mongo/write_concern/base.rb +3 -0
  446. data/lib/mongo/write_concern/unacknowledged.rb +3 -0
  447. data/lib/mongo/write_concern.rb +3 -0
  448. data/lib/mongo.rb +26 -0
  449. data/mongo.gemspec +1 -1
  450. data/spec/README.md +24 -1
  451. data/spec/atlas/atlas_connectivity_spec.rb +3 -0
  452. data/spec/atlas/operations_spec.rb +3 -0
  453. data/spec/integration/auth_spec.rb +58 -15
  454. data/spec/integration/awaited_ismaster_spec.rb +9 -6
  455. data/spec/integration/aws_auth_request_spec.rb +3 -0
  456. data/spec/integration/aws_credentials_retriever_spec.rb +3 -0
  457. data/spec/integration/bson_symbol_spec.rb +4 -1
  458. data/spec/integration/bulk_insert_spec.rb +3 -0
  459. data/spec/integration/bulk_write_error_message_spec.rb +41 -0
  460. data/spec/integration/bulk_write_spec.rb +4 -1
  461. data/spec/integration/change_stream_examples_spec.rb +3 -0
  462. data/spec/integration/change_stream_spec.rb +10 -7
  463. data/spec/integration/check_clean_slate_spec.rb +3 -0
  464. data/spec/integration/client_authentication_options_spec.rb +21 -8
  465. data/spec/integration/client_connectivity_spec.rb +4 -1
  466. data/spec/integration/client_construction_aws_auth_spec.rb +3 -0
  467. data/spec/integration/client_construction_spec.rb +57 -0
  468. data/spec/integration/client_side_encryption/auto_encryption_bulk_writes_spec.rb +4 -1
  469. data/spec/integration/client_side_encryption/auto_encryption_command_monitoring_spec.rb +4 -1
  470. data/spec/integration/client_side_encryption/auto_encryption_mongocryptd_spawn_spec.rb +3 -0
  471. data/spec/integration/client_side_encryption/auto_encryption_old_wire_version_spec.rb +3 -0
  472. data/spec/integration/client_side_encryption/auto_encryption_reconnect_spec.rb +3 -0
  473. data/spec/integration/client_side_encryption/auto_encryption_spec.rb +3 -0
  474. data/spec/integration/client_side_encryption/bson_size_limit_spec.rb +4 -1
  475. data/spec/integration/client_side_encryption/bypass_mongocryptd_spawn_spec.rb +4 -1
  476. data/spec/integration/client_side_encryption/client_close_spec.rb +3 -0
  477. data/spec/integration/client_side_encryption/corpus_spec.rb +3 -0
  478. data/spec/integration/client_side_encryption/custom_endpoint_spec.rb +3 -0
  479. data/spec/integration/client_side_encryption/data_key_spec.rb +4 -1
  480. data/spec/integration/client_side_encryption/explicit_encryption_spec.rb +3 -0
  481. data/spec/integration/client_side_encryption/external_key_vault_spec.rb +3 -0
  482. data/spec/integration/client_side_encryption/views_spec.rb +3 -0
  483. data/spec/integration/client_spec.rb +7 -2
  484. data/spec/integration/client_update_spec.rb +3 -0
  485. data/spec/integration/collection_indexes_prose_spec.rb +3 -0
  486. data/spec/integration/command_monitoring_spec.rb +64 -26
  487. data/spec/integration/command_spec.rb +4 -1
  488. data/spec/integration/connect_single_rs_name_spec.rb +6 -3
  489. data/spec/integration/connection_pool_populator_spec.rb +3 -0
  490. data/spec/integration/connection_spec.rb +58 -36
  491. data/spec/integration/crud_spec.rb +205 -1
  492. data/spec/integration/cursor_pinning_spec.rb +121 -0
  493. data/spec/integration/cursor_reaping_spec.rb +11 -4
  494. data/spec/integration/docs_examples_spec.rb +11 -1
  495. data/spec/integration/error_detection_spec.rb +3 -0
  496. data/spec/integration/fork_reconnect_spec.rb +9 -7
  497. data/spec/integration/get_more_spec.rb +4 -1
  498. data/spec/integration/grid_fs_bucket_spec.rb +4 -1
  499. data/spec/integration/heartbeat_events_spec.rb +8 -5
  500. data/spec/integration/map_reduce_spec.rb +77 -0
  501. data/spec/integration/mmapv1_spec.rb +3 -0
  502. data/spec/integration/mongos_pinning_spec.rb +3 -0
  503. data/spec/integration/ocsp_connectivity_spec.rb +3 -0
  504. data/spec/integration/ocsp_verifier_cache_spec.rb +3 -0
  505. data/spec/integration/ocsp_verifier_spec.rb +29 -8
  506. data/spec/integration/operation_failure_code_spec.rb +4 -1
  507. data/spec/integration/operation_failure_message_spec.rb +90 -0
  508. data/spec/integration/query_cache_spec.rb +50 -2
  509. data/spec/integration/query_cache_transactions_spec.rb +4 -1
  510. data/spec/integration/read_concern_spec.rb +4 -1
  511. data/spec/integration/read_preference_spec.rb +4 -1
  512. data/spec/integration/reconnect_spec.rb +34 -13
  513. data/spec/integration/retryable_errors_spec.rb +4 -1
  514. data/spec/integration/retryable_writes/retryable_writes_36_and_older_spec.rb +4 -1
  515. data/spec/integration/retryable_writes/retryable_writes_40_and_newer_spec.rb +4 -1
  516. data/spec/integration/retryable_writes/shared/adds_diagnostics.rb +3 -0
  517. data/spec/integration/retryable_writes/shared/does_not_support_retries.rb +3 -0
  518. data/spec/integration/retryable_writes/shared/only_supports_legacy_retries.rb +3 -0
  519. data/spec/integration/retryable_writes/shared/performs_legacy_retries.rb +3 -0
  520. data/spec/integration/retryable_writes/shared/performs_modern_retries.rb +3 -0
  521. data/spec/integration/retryable_writes/shared/performs_no_retries.rb +3 -0
  522. data/spec/integration/retryable_writes/shared/supports_legacy_retries.rb +3 -0
  523. data/spec/integration/retryable_writes/shared/supports_modern_retries.rb +3 -0
  524. data/spec/integration/retryable_writes/shared/supports_retries.rb +3 -0
  525. data/spec/integration/retryable_writes_errors_spec.rb +3 -0
  526. data/spec/integration/sdam_error_handling_spec.rb +11 -6
  527. data/spec/integration/sdam_events_spec.rb +50 -30
  528. data/spec/integration/sdam_prose_spec.rb +5 -2
  529. data/spec/integration/secondary_reads_spec.rb +102 -0
  530. data/spec/integration/server_description_spec.rb +3 -0
  531. data/spec/integration/server_monitor_spec.rb +5 -1
  532. data/spec/integration/server_selection_spec.rb +3 -0
  533. data/spec/integration/server_selector_spec.rb +25 -5
  534. data/spec/integration/server_spec.rb +5 -0
  535. data/spec/integration/shell_examples_spec.rb +3 -0
  536. data/spec/integration/size_limit_spec.rb +3 -0
  537. data/spec/integration/snappy_compression_spec.rb +28 -0
  538. data/spec/integration/srv_monitoring_spec.rb +5 -2
  539. data/spec/integration/srv_spec.rb +3 -0
  540. data/spec/integration/ssl_uri_options_spec.rb +3 -0
  541. data/spec/integration/step_down_spec.rb +4 -1
  542. data/spec/integration/time_zone_querying_spec.rb +3 -0
  543. data/spec/integration/transaction_pinning_spec.rb +120 -0
  544. data/spec/integration/transactions_api_examples_spec.rb +3 -0
  545. data/spec/integration/transactions_examples_spec.rb +9 -0
  546. data/spec/integration/truncated_utf8_spec.rb +26 -0
  547. data/spec/integration/versioned_api_examples_spec.rb +114 -0
  548. data/spec/integration/x509_auth_spec.rb +5 -2
  549. data/spec/integration/zlib_compression_spec.rb +4 -1
  550. data/spec/integration/zstd_compression_spec.rb +29 -0
  551. data/spec/kerberos/kerberos_spec.rb +3 -0
  552. data/spec/lite_spec_helper.rb +12 -3
  553. data/spec/mongo/address/ipv4_spec.rb +3 -0
  554. data/spec/mongo/address/ipv6_spec.rb +3 -0
  555. data/spec/mongo/address/unix_spec.rb +4 -0
  556. data/spec/mongo/address/validator_spec.rb +3 -0
  557. data/spec/mongo/address_spec.rb +18 -11
  558. data/spec/mongo/auth/aws/request_region_spec.rb +3 -0
  559. data/spec/mongo/auth/aws/request_spec.rb +3 -0
  560. data/spec/mongo/auth/cr_spec.rb +5 -3
  561. data/spec/mongo/auth/gssapi/conversation_spec.rb +3 -0
  562. data/spec/mongo/auth/invalid_mechanism_spec.rb +3 -0
  563. data/spec/mongo/auth/ldap/conversation_spec.rb +4 -1
  564. data/spec/mongo/auth/ldap_spec.rb +10 -4
  565. data/spec/mongo/auth/scram/conversation_spec.rb +3 -0
  566. data/spec/mongo/auth/scram256/conversation_spec.rb +3 -0
  567. data/spec/mongo/auth/scram_negotiation_spec.rb +4 -1
  568. data/spec/mongo/auth/scram_spec.rb +5 -3
  569. data/spec/mongo/auth/stringprep/profiles/sasl_spec.rb +3 -0
  570. data/spec/mongo/auth/stringprep_spec.rb +3 -0
  571. data/spec/mongo/auth/user/view_spec.rb +4 -1
  572. data/spec/mongo/auth/user_spec.rb +3 -0
  573. data/spec/mongo/auth/x509/conversation_spec.rb +6 -3
  574. data/spec/mongo/auth/x509_spec.rb +5 -3
  575. data/spec/mongo/auth_spec.rb +3 -0
  576. data/spec/mongo/bson_spec.rb +3 -0
  577. data/spec/mongo/bulk_write/ordered_combiner_spec.rb +3 -0
  578. data/spec/mongo/bulk_write/result_spec.rb +3 -0
  579. data/spec/mongo/bulk_write/unordered_combiner_spec.rb +3 -0
  580. data/spec/mongo/bulk_write_spec.rb +6 -3
  581. data/spec/mongo/caching_cursor_spec.rb +3 -0
  582. data/spec/mongo/client_construction_spec.rb +472 -62
  583. data/spec/mongo/client_encryption_spec.rb +3 -0
  584. data/spec/mongo/client_spec.rb +26 -4
  585. data/spec/mongo/cluster/cursor_reaper_spec.rb +39 -21
  586. data/spec/mongo/cluster/periodic_executor_spec.rb +6 -1
  587. data/spec/mongo/cluster/socket_reaper_spec.rb +3 -0
  588. data/spec/mongo/cluster/topology/replica_set_spec.rb +12 -9
  589. data/spec/mongo/cluster/topology/sharded_spec.rb +5 -2
  590. data/spec/mongo/cluster/topology/single_spec.rb +5 -2
  591. data/spec/mongo/cluster/topology/unknown_spec.rb +3 -0
  592. data/spec/mongo/cluster/topology_spec.rb +3 -0
  593. data/spec/mongo/cluster_spec.rb +51 -21
  594. data/spec/mongo/cluster_time_spec.rb +3 -0
  595. data/spec/mongo/collection/view/aggregation_spec.rb +4 -1
  596. data/spec/mongo/collection/view/builder/find_command_spec.rb +7 -0
  597. data/spec/mongo/collection/view/builder/op_query_spec.rb +7 -0
  598. data/spec/mongo/collection/view/change_stream_resume_spec.rb +7 -2
  599. data/spec/mongo/collection/view/change_stream_spec.rb +16 -0
  600. data/spec/mongo/collection/view/explainable_spec.rb +4 -1
  601. data/spec/mongo/collection/view/immutable_spec.rb +3 -0
  602. data/spec/mongo/collection/view/iterable_spec.rb +3 -0
  603. data/spec/mongo/collection/view/map_reduce_spec.rb +4 -1
  604. data/spec/mongo/collection/view/readable_spec.rb +51 -18
  605. data/spec/mongo/collection/view/writable_spec.rb +3 -0
  606. data/spec/mongo/collection/view_spec.rb +3 -0
  607. data/spec/mongo/collection_crud_spec.rb +4365 -0
  608. data/spec/mongo/collection_ddl_spec.rb +537 -0
  609. data/spec/mongo/collection_spec.rb +9 -4860
  610. data/spec/mongo/crypt/auto_decryption_context_spec.rb +3 -0
  611. data/spec/mongo/crypt/auto_encrypter_spec.rb +3 -0
  612. data/spec/mongo/crypt/auto_encryption_context_spec.rb +3 -0
  613. data/spec/mongo/crypt/binary_spec.rb +3 -0
  614. data/spec/mongo/crypt/binding/binary_spec.rb +3 -0
  615. data/spec/mongo/crypt/binding/context_spec.rb +3 -0
  616. data/spec/mongo/crypt/binding/helpers_spec.rb +3 -0
  617. data/spec/mongo/crypt/binding/mongocrypt_spec.rb +3 -0
  618. data/spec/mongo/crypt/binding/status_spec.rb +3 -0
  619. data/spec/mongo/crypt/binding/version_spec.rb +3 -0
  620. data/spec/mongo/crypt/binding_unloaded_spec.rb +3 -0
  621. data/spec/mongo/crypt/data_key_context_spec.rb +3 -0
  622. data/spec/mongo/crypt/encryption_io_spec.rb +3 -0
  623. data/spec/mongo/crypt/explicit_decryption_context_spec.rb +3 -0
  624. data/spec/mongo/crypt/explicit_encryption_context_spec.rb +3 -0
  625. data/spec/mongo/crypt/handle_spec.rb +3 -0
  626. data/spec/mongo/crypt/helpers/mongo_crypt_spec_helper.rb +3 -0
  627. data/spec/mongo/crypt/status_spec.rb +3 -0
  628. data/spec/mongo/cursor/builder/get_more_command_spec.rb +11 -2
  629. data/spec/mongo/cursor/builder/op_get_more_spec.rb +11 -2
  630. data/spec/mongo/cursor_spec.rb +89 -12
  631. data/spec/mongo/database_spec.rb +90 -25
  632. data/spec/mongo/dbref_spec.rb +3 -0
  633. data/spec/mongo/distinguishing_semaphore_spec.rb +3 -0
  634. data/spec/mongo/error/bulk_write_error_spec.rb +6 -3
  635. data/spec/mongo/error/crypt_error_spec.rb +3 -0
  636. data/spec/mongo/error/max_bson_size_spec.rb +3 -0
  637. data/spec/mongo/error/no_server_available_spec.rb +3 -0
  638. data/spec/mongo/error/notable_spec.rb +3 -0
  639. data/spec/mongo/error/operation_failure_heavy_spec.rb +4 -1
  640. data/spec/mongo/error/operation_failure_spec.rb +94 -31
  641. data/spec/mongo/error/parser_spec.rb +40 -6
  642. data/spec/mongo/error/unsupported_option_spec.rb +3 -0
  643. data/spec/mongo/event/publisher_spec.rb +3 -0
  644. data/spec/mongo/event/subscriber_spec.rb +3 -0
  645. data/spec/mongo/grid/file/chunk_spec.rb +7 -4
  646. data/spec/mongo/grid/file/info_spec.rb +3 -0
  647. data/spec/mongo/grid/file_spec.rb +4 -1
  648. data/spec/mongo/grid/fs_bucket_spec.rb +40 -17
  649. data/spec/mongo/grid/stream/read_spec.rb +33 -10
  650. data/spec/mongo/grid/stream/write_spec.rb +6 -9
  651. data/spec/mongo/grid/stream_spec.rb +4 -1
  652. data/spec/mongo/id_spec.rb +3 -0
  653. data/spec/mongo/index/view_spec.rb +13 -4
  654. data/spec/mongo/lint_spec.rb +3 -0
  655. data/spec/mongo/logger_spec.rb +3 -0
  656. data/spec/mongo/monitoring/command_log_subscriber_spec.rb +3 -0
  657. data/spec/mongo/monitoring/event/cmap/connection_check_out_failed_spec.rb +3 -0
  658. data/spec/mongo/monitoring/event/cmap/connection_check_out_started_spec.rb +3 -0
  659. data/spec/mongo/monitoring/event/cmap/connection_checked_in_spec.rb +3 -0
  660. data/spec/mongo/monitoring/event/cmap/connection_checked_out_spec.rb +3 -0
  661. data/spec/mongo/monitoring/event/cmap/connection_closed_spec.rb +3 -0
  662. data/spec/mongo/monitoring/event/cmap/connection_created_spec.rb +3 -0
  663. data/spec/mongo/monitoring/event/cmap/connection_ready_spec.rb +3 -0
  664. data/spec/mongo/monitoring/event/cmap/pool_cleared_spec.rb +3 -0
  665. data/spec/mongo/monitoring/event/cmap/pool_closed_spec.rb +3 -0
  666. data/spec/mongo/monitoring/event/cmap/pool_created_spec.rb +3 -0
  667. data/spec/mongo/monitoring/event/command_failed_spec.rb +59 -2
  668. data/spec/mongo/monitoring/event/command_started_spec.rb +3 -0
  669. data/spec/mongo/monitoring/event/command_succeeded_spec.rb +46 -6
  670. data/spec/mongo/monitoring/event/secure_spec.rb +28 -4
  671. data/spec/mongo/monitoring/event/server_closed_spec.rb +3 -0
  672. data/spec/mongo/monitoring/event/server_description_changed_spec.rb +3 -0
  673. data/spec/mongo/monitoring/event/server_heartbeat_failed_spec.rb +4 -1
  674. data/spec/mongo/monitoring/event/server_heartbeat_started_spec.rb +3 -0
  675. data/spec/mongo/monitoring/event/server_heartbeat_succeeded_spec.rb +4 -1
  676. data/spec/mongo/monitoring/event/server_opening_spec.rb +3 -0
  677. data/spec/mongo/monitoring/event/topology_changed_spec.rb +3 -0
  678. data/spec/mongo/monitoring/event/topology_closed_spec.rb +3 -0
  679. data/spec/mongo/monitoring/event/topology_opening_spec.rb +3 -0
  680. data/spec/mongo/monitoring_spec.rb +3 -0
  681. data/spec/mongo/operation/aggregate/result_spec.rb +7 -2
  682. data/spec/mongo/operation/aggregate_spec.rb +5 -1
  683. data/spec/mongo/operation/collections_info_spec.rb +7 -1
  684. data/spec/mongo/operation/command_spec.rb +11 -5
  685. data/spec/mongo/operation/create_index_spec.rb +9 -3
  686. data/spec/mongo/operation/create_user_spec.rb +9 -3
  687. data/spec/mongo/operation/delete/bulk_spec.rb +12 -6
  688. data/spec/mongo/operation/delete/command_spec.rb +3 -0
  689. data/spec/mongo/operation/delete/op_msg_spec.rb +4 -1
  690. data/spec/mongo/operation/delete_spec.rb +14 -7
  691. data/spec/mongo/operation/drop_index_spec.rb +9 -2
  692. data/spec/mongo/{collection/view → operation/find}/builder/flags_spec.rb +5 -2
  693. data/spec/mongo/{collection/view → operation/find}/builder/modifiers_spec.rb +5 -2
  694. data/spec/mongo/operation/find/legacy_spec.rb +8 -2
  695. data/spec/mongo/operation/get_more_spec.rb +6 -1
  696. data/spec/mongo/operation/indexes_spec.rb +8 -1
  697. data/spec/mongo/operation/insert/bulk_spec.rb +14 -8
  698. data/spec/mongo/operation/insert/command_spec.rb +3 -0
  699. data/spec/mongo/operation/insert/op_msg_spec.rb +4 -1
  700. data/spec/mongo/operation/insert_spec.rb +18 -12
  701. data/spec/mongo/operation/kill_cursors_spec.rb +7 -1
  702. data/spec/mongo/operation/limited_spec.rb +3 -0
  703. data/spec/mongo/operation/map_reduce_spec.rb +8 -2
  704. data/spec/mongo/operation/read_preference_legacy_spec.rb +39 -42
  705. data/spec/mongo/operation/read_preference_op_msg_spec.rb +8 -3
  706. data/spec/mongo/operation/remove_user_spec.rb +9 -3
  707. data/spec/mongo/operation/result_spec.rb +10 -5
  708. data/spec/mongo/operation/specifiable_spec.rb +3 -0
  709. data/spec/mongo/operation/update/bulk_spec.rb +13 -7
  710. data/spec/mongo/operation/update/command_spec.rb +3 -0
  711. data/spec/mongo/operation/update/op_msg_spec.rb +4 -1
  712. data/spec/mongo/operation/update_spec.rb +13 -7
  713. data/spec/mongo/operation/update_user_spec.rb +7 -1
  714. data/spec/mongo/options/redacted_spec.rb +3 -0
  715. data/spec/mongo/protocol/compressed_spec.rb +29 -12
  716. data/spec/mongo/protocol/delete_spec.rb +3 -0
  717. data/spec/mongo/protocol/get_more_spec.rb +3 -0
  718. data/spec/mongo/protocol/insert_spec.rb +3 -0
  719. data/spec/mongo/protocol/kill_cursors_spec.rb +3 -0
  720. data/spec/mongo/protocol/msg_spec.rb +4 -1
  721. data/spec/mongo/protocol/query_spec.rb +6 -3
  722. data/spec/mongo/protocol/registry_spec.rb +3 -0
  723. data/spec/mongo/protocol/reply_spec.rb +3 -0
  724. data/spec/mongo/protocol/update_spec.rb +3 -0
  725. data/spec/mongo/query_cache_middleware_spec.rb +55 -0
  726. data/spec/mongo/query_cache_spec.rb +9 -2
  727. data/spec/mongo/retryable_spec.rb +6 -2
  728. data/spec/mongo/semaphore_spec.rb +3 -0
  729. data/spec/mongo/server/app_metadata_spec.rb +46 -21
  730. data/spec/mongo/server/connection_auth_spec.rb +6 -9
  731. data/spec/mongo/server/connection_common_spec.rb +75 -0
  732. data/spec/mongo/server/connection_pool/populator_spec.rb +6 -1
  733. data/spec/mongo/server/connection_pool_spec.rb +77 -8
  734. data/spec/mongo/server/connection_spec.rb +167 -56
  735. data/spec/mongo/server/description/features_spec.rb +3 -0
  736. data/spec/mongo/server/description_query_methods_spec.rb +4 -1
  737. data/spec/mongo/server/description_spec.rb +624 -611
  738. data/spec/mongo/server/monitor/app_metadata_spec.rb +3 -1
  739. data/spec/mongo/server/monitor/connection_spec.rb +57 -7
  740. data/spec/mongo/server/monitor_spec.rb +26 -14
  741. data/spec/mongo/server/round_trip_time_averager_spec.rb +3 -0
  742. data/spec/mongo/server_selector/nearest_spec.rb +8 -2
  743. data/spec/mongo/server_selector/primary_preferred_spec.rb +8 -2
  744. data/spec/mongo/server_selector/primary_spec.rb +8 -2
  745. data/spec/mongo/server_selector/secondary_preferred_spec.rb +14 -8
  746. data/spec/mongo/server_selector/secondary_spec.rb +8 -2
  747. data/spec/mongo/server_selector_spec.rb +5 -1
  748. data/spec/mongo/server_spec.rb +18 -2
  749. data/spec/mongo/session/server_session_spec.rb +3 -0
  750. data/spec/mongo/session/session_pool_spec.rb +45 -10
  751. data/spec/mongo/session_spec.rb +3 -0
  752. data/spec/mongo/session_transaction_spec.rb +17 -37
  753. data/spec/mongo/socket/ssl_spec.rb +43 -0
  754. data/spec/mongo/socket/tcp_spec.rb +3 -0
  755. data/spec/mongo/socket/unix_spec.rb +4 -0
  756. data/spec/mongo/socket_spec.rb +5 -2
  757. data/spec/mongo/srv/monitor_spec.rb +3 -0
  758. data/spec/mongo/srv/result_spec.rb +3 -0
  759. data/spec/mongo/timeout_spec.rb +3 -0
  760. data/spec/mongo/tls_context_hooks_spec.rb +40 -0
  761. data/spec/mongo/uri/srv_protocol_spec.rb +4 -0
  762. data/spec/mongo/uri_option_parsing_spec.rb +41 -5
  763. data/spec/mongo/uri_spec.rb +3 -0
  764. data/spec/mongo/utils_spec.rb +17 -0
  765. data/spec/mongo/write_concern/acknowledged_spec.rb +3 -0
  766. data/spec/mongo/write_concern/unacknowledged_spec.rb +3 -0
  767. data/spec/mongo/write_concern_spec.rb +3 -0
  768. data/spec/runners/auth.rb +22 -1
  769. data/spec/runners/change_streams/outcome.rb +3 -0
  770. data/spec/runners/change_streams/spec.rb +3 -0
  771. data/spec/runners/change_streams/test.rb +4 -1
  772. data/spec/runners/cmap/verifier.rb +3 -0
  773. data/spec/runners/cmap.rb +4 -1
  774. data/spec/runners/command_monitoring.rb +3 -0
  775. data/spec/runners/connection_string.rb +10 -7
  776. data/spec/runners/crud/context.rb +3 -0
  777. data/spec/runners/crud/operation.rb +8 -3
  778. data/spec/runners/crud/outcome.rb +3 -0
  779. data/spec/runners/crud/requirement.rb +68 -3
  780. data/spec/runners/crud/spec.rb +3 -0
  781. data/spec/runners/crud/test.rb +3 -0
  782. data/spec/runners/crud/test_base.rb +3 -0
  783. data/spec/runners/crud/verifier.rb +11 -0
  784. data/spec/runners/crud.rb +23 -1
  785. data/spec/runners/gridfs.rb +3 -0
  786. data/spec/runners/read_write_concern_document.rb +3 -0
  787. data/spec/runners/sdam/verifier.rb +3 -0
  788. data/spec/runners/sdam.rb +8 -4
  789. data/spec/runners/server_selection.rb +3 -0
  790. data/spec/runners/server_selection_rtt.rb +4 -1
  791. data/spec/runners/transactions/operation.rb +16 -2
  792. data/spec/runners/transactions/spec.rb +3 -0
  793. data/spec/runners/transactions/test.rb +6 -2
  794. data/spec/runners/transactions.rb +3 -0
  795. data/spec/runners/unified/assertions.rb +281 -0
  796. data/spec/runners/unified/change_stream_operations.rb +29 -0
  797. data/spec/runners/unified/crud_operations.rb +206 -0
  798. data/spec/runners/unified/ddl_operations.rb +106 -0
  799. data/spec/runners/unified/entity_map.rb +42 -0
  800. data/spec/runners/unified/error.rb +28 -0
  801. data/spec/runners/unified/event_subscriber.rb +104 -0
  802. data/spec/runners/unified/exceptions.rb +24 -0
  803. data/spec/runners/unified/grid_fs_operations.rb +58 -0
  804. data/spec/runners/unified/support_operations.rb +261 -0
  805. data/spec/runners/unified/test.rb +426 -0
  806. data/spec/runners/unified/test_group.rb +31 -0
  807. data/spec/runners/unified.rb +99 -0
  808. data/spec/shared/bin/get-mongodb-download-url +17 -0
  809. data/spec/shared/bin/s3-copy +45 -0
  810. data/spec/shared/bin/s3-upload +69 -0
  811. data/spec/shared/lib/mrss/cluster_config.rb +231 -0
  812. data/spec/shared/lib/mrss/constraints.rb +92 -10
  813. data/spec/shared/lib/mrss/docker_runner.rb +271 -0
  814. data/spec/shared/lib/mrss/event_subscriber.rb +200 -0
  815. data/spec/shared/lib/mrss/lite_constraints.rb +16 -0
  816. data/spec/shared/lib/mrss/server_version_registry.rb +120 -0
  817. data/spec/shared/lib/mrss/spec_organizer.rb +32 -2
  818. data/spec/shared/lib/mrss/utils.rb +15 -0
  819. data/spec/shared/share/Dockerfile.erb +323 -0
  820. data/spec/shared/share/haproxy-1.conf +16 -0
  821. data/spec/shared/share/haproxy-2.conf +17 -0
  822. data/spec/shared/shlib/distro.sh +73 -0
  823. data/spec/shared/shlib/server.sh +367 -0
  824. data/spec/shared/shlib/set_env.sh +131 -0
  825. data/spec/solo/clean_exit_spec.rb +24 -0
  826. data/spec/spec_helper.rb +8 -3
  827. data/spec/spec_tests/auth_spec.rb +30 -13
  828. data/spec/spec_tests/change_streams_spec.rb +4 -1
  829. data/spec/spec_tests/change_streams_unified_spec.rb +13 -0
  830. data/spec/spec_tests/client_side_encryption_spec.rb +3 -0
  831. data/spec/spec_tests/cmap_spec.rb +7 -1
  832. data/spec/spec_tests/collection_management_spec.rb +13 -0
  833. data/spec/spec_tests/command_monitoring_spec.rb +32 -27
  834. data/spec/spec_tests/command_monitoring_unified_spec.rb +13 -0
  835. data/spec/spec_tests/connection_string_spec.rb +3 -0
  836. data/spec/spec_tests/crud_spec.rb +3 -0
  837. data/spec/spec_tests/crud_unified_spec.rb +13 -0
  838. data/spec/spec_tests/data/change_streams/change-streams-errors.yml +5 -5
  839. data/spec/spec_tests/data/change_streams/{change-streams-resume-whitelist.yml → change-streams-resume-allowlist.yml} +58 -58
  840. data/spec/spec_tests/data/change_streams/change-streams-resume-errorLabels.yml +46 -46
  841. data/spec/spec_tests/data/change_streams/change-streams.yml +0 -1
  842. data/spec/spec_tests/data/change_streams_unified/change-streams.yml +72 -0
  843. data/spec/spec_tests/data/collection_management/timeseries-collection.yml +129 -0
  844. data/spec/spec_tests/data/command_monitoring/find.yml +9 -9
  845. data/spec/spec_tests/data/command_monitoring_unified/redacted-commands.yml +340 -0
  846. data/spec/spec_tests/data/crud/read/aggregate-collation.yml +2 -1
  847. data/spec/spec_tests/data/crud/read/aggregate-out.yml +1 -0
  848. data/spec/spec_tests/data/crud/read/count-collation.yml +2 -1
  849. data/spec/spec_tests/data/crud/read/distinct-collation.yml +2 -1
  850. data/spec/spec_tests/data/crud/read/find-collation.yml +2 -1
  851. data/spec/spec_tests/data/crud/write/bulkWrite-collation.yml +2 -1
  852. data/spec/spec_tests/data/crud/write/bulkWrite.yml +26 -22
  853. data/spec/spec_tests/data/crud/write/deleteMany-collation.yml +2 -1
  854. data/spec/spec_tests/data/crud/write/deleteOne-collation.yml +2 -1
  855. data/spec/spec_tests/data/crud/write/findOneAndDelete-collation.yml +3 -2
  856. data/spec/spec_tests/data/crud/write/findOneAndReplace-collation.yml +2 -1
  857. data/spec/spec_tests/data/crud/write/findOneAndUpdate-collation.yml +3 -2
  858. data/spec/spec_tests/data/crud/write/insertMany.yml +26 -22
  859. data/spec/spec_tests/data/crud/write/replaceOne-collation.yml +3 -2
  860. data/spec/spec_tests/data/crud/write/updateMany-collation.yml +2 -1
  861. data/spec/spec_tests/data/crud/write/updateOne-collation.yml +2 -1
  862. data/spec/spec_tests/data/crud_unified/estimatedDocumentCount.yml +267 -0
  863. data/spec/spec_tests/data/crud_unified/updateWithPipelines.yml +305 -0
  864. data/spec/spec_tests/data/crud_v2/aggregate-out-readConcern.yml +1 -0
  865. data/spec/spec_tests/data/crud_v2/db-aggregate.yml +1 -0
  866. data/spec/spec_tests/data/load_balancers/event-monitoring.yml +99 -0
  867. data/spec/spec_tests/data/load_balancers/lb-connection-establishment.yml +36 -0
  868. data/spec/spec_tests/data/load_balancers/non-lb-connection-establishment.yml +56 -0
  869. data/spec/spec_tests/data/load_balancers/server-selection.yml +50 -0
  870. data/spec/spec_tests/data/retryable_reads/aggregate-serverErrors.yml +1 -1
  871. data/spec/spec_tests/data/retryable_reads/changeStreams-client.watch-serverErrors.yml +7 -6
  872. data/spec/spec_tests/data/retryable_reads/changeStreams-client.watch.yml +2 -1
  873. data/spec/spec_tests/data/retryable_reads/changeStreams-db.coll.watch-serverErrors.yml +7 -6
  874. data/spec/spec_tests/data/retryable_reads/changeStreams-db.coll.watch.yml +2 -1
  875. data/spec/spec_tests/data/retryable_reads/changeStreams-db.watch-serverErrors.yml +7 -6
  876. data/spec/spec_tests/data/retryable_reads/changeStreams-db.watch.yml +2 -1
  877. data/spec/spec_tests/data/retryable_reads/count-serverErrors.yml +1 -1
  878. data/spec/spec_tests/data/retryable_reads/countDocuments-serverErrors.yml +1 -1
  879. data/spec/spec_tests/data/retryable_reads/distinct-serverErrors.yml +1 -1
  880. data/spec/spec_tests/data/retryable_reads/estimatedDocumentCount-4.9.yml +60 -0
  881. data/spec/spec_tests/data/retryable_reads/{estimatedDocumentCount.yml → estimatedDocumentCount-pre4.9.yml} +2 -0
  882. data/spec/spec_tests/data/retryable_reads/estimatedDocumentCount-serverErrors-4.9.yml +146 -0
  883. data/spec/spec_tests/data/retryable_reads/{estimatedDocumentCount-serverErrors.yml → estimatedDocumentCount-serverErrors-pre4.9.yml} +3 -1
  884. data/spec/spec_tests/data/retryable_reads/find-serverErrors.yml +1 -1
  885. data/spec/spec_tests/data/retryable_reads/findOne-serverErrors.yml +1 -1
  886. data/spec/spec_tests/data/retryable_reads/gridfs-download-serverErrors.yml +1 -1
  887. data/spec/spec_tests/data/retryable_reads/gridfs-downloadByName-serverErrors.yml +1 -1
  888. data/spec/spec_tests/data/retryable_reads/listCollectionNames-serverErrors.yml +1 -1
  889. data/spec/spec_tests/data/retryable_reads/listCollectionObjects-serverErrors.yml +1 -1
  890. data/spec/spec_tests/data/retryable_reads/listCollections-serverErrors.yml +1 -1
  891. data/spec/spec_tests/data/retryable_reads/listDatabaseNames-serverErrors.yml +1 -1
  892. data/spec/spec_tests/data/retryable_reads/listDatabaseObjects-serverErrors.yml +1 -1
  893. data/spec/spec_tests/data/retryable_reads/listDatabases-serverErrors.yml +1 -1
  894. data/spec/spec_tests/data/retryable_reads/listIndexNames-serverErrors.yml +1 -1
  895. data/spec/spec_tests/data/retryable_reads/listIndexNames.yml +1 -1
  896. data/spec/spec_tests/data/retryable_reads/listIndexes-serverErrors.yml +1 -1
  897. data/spec/spec_tests/data/retryable_reads/mapReduce.yml +3 -1
  898. data/spec/spec_tests/data/retryable_writes/bulkWrite.yml +30 -24
  899. data/spec/spec_tests/data/retryable_writes/insertOne-serverErrors.yml +5 -4
  900. data/spec/spec_tests/data/sdam/errors/error_handling_handshake.yml +2 -1
  901. data/spec/spec_tests/data/sdam/errors/non-stale-network-error.yml +2 -1
  902. data/spec/spec_tests/data/sdam/errors/non-stale-network-timeout-error.yml +2 -1
  903. data/spec/spec_tests/data/sdam/errors/non-stale-topologyVersion-greater-InterruptedAtShutdown.yml +2 -1
  904. data/spec/spec_tests/data/sdam/errors/non-stale-topologyVersion-greater-InterruptedDueToReplStateChange.yml +2 -1
  905. data/spec/spec_tests/data/sdam/errors/non-stale-topologyVersion-greater-LegacyNotPrimary.yml +61 -0
  906. data/spec/spec_tests/data/sdam/errors/{non-stale-topologyVersion-greater-NotMasterNoSlaveOk.yml → non-stale-topologyVersion-greater-NotPrimaryNoSecondaryOk.yml} +5 -4
  907. data/spec/spec_tests/data/sdam/errors/{non-stale-topologyVersion-greater-NotMasterOrSecondary.yml → non-stale-topologyVersion-greater-NotPrimaryOrSecondary.yml} +5 -4
  908. data/spec/spec_tests/data/sdam/errors/{non-stale-topologyVersion-greater-NotMaster.yml → non-stale-topologyVersion-greater-NotWritablePrimary.yml} +5 -4
  909. data/spec/spec_tests/data/sdam/errors/non-stale-topologyVersion-greater-PrimarySteppedDown.yml +2 -1
  910. data/spec/spec_tests/data/sdam/errors/non-stale-topologyVersion-greater-ShutdownInProgress.yml +2 -1
  911. data/spec/spec_tests/data/sdam/errors/non-stale-topologyVersion-missing-InterruptedAtShutdown.yml +2 -1
  912. data/spec/spec_tests/data/sdam/errors/non-stale-topologyVersion-missing-InterruptedDueToReplStateChange.yml +2 -1
  913. data/spec/spec_tests/data/sdam/errors/non-stale-topologyVersion-missing-LegacyNotPrimary.yml +52 -0
  914. data/spec/spec_tests/data/sdam/errors/{non-stale-topologyVersion-missing-NotMasterNoSlaveOk.yml → non-stale-topologyVersion-missing-NotPrimaryNoSecondaryOk.yml} +5 -4
  915. data/spec/spec_tests/data/sdam/errors/{non-stale-topologyVersion-missing-NotMasterOrSecondary.yml → non-stale-topologyVersion-missing-NotPrimaryOrSecondary.yml} +5 -4
  916. data/spec/spec_tests/data/sdam/errors/{non-stale-topologyVersion-missing-NotMaster.yml → non-stale-topologyVersion-missing-NotWritablePrimary.yml} +5 -4
  917. data/spec/spec_tests/data/sdam/errors/non-stale-topologyVersion-missing-PrimarySteppedDown.yml +2 -1
  918. data/spec/spec_tests/data/sdam/errors/non-stale-topologyVersion-missing-ShutdownInProgress.yml +2 -1
  919. data/spec/spec_tests/data/sdam/errors/non-stale-topologyVersion-proccessId-changed-InterruptedAtShutdown.yml +2 -1
  920. data/spec/spec_tests/data/sdam/errors/non-stale-topologyVersion-proccessId-changed-InterruptedDueToReplStateChange.yml +2 -1
  921. data/spec/spec_tests/data/sdam/errors/non-stale-topologyVersion-proccessId-changed-LegacyNotPrimary.yml +61 -0
  922. data/spec/spec_tests/data/sdam/errors/{non-stale-topologyVersion-proccessId-changed-NotMasterNoSlaveOk.yml → non-stale-topologyVersion-proccessId-changed-NotPrimaryNoSecondaryOk.yml} +5 -4
  923. data/spec/spec_tests/data/sdam/errors/{non-stale-topologyVersion-proccessId-changed-NotMasterOrSecondary.yml → non-stale-topologyVersion-proccessId-changed-NotPrimaryOrSecondary.yml} +5 -4
  924. data/spec/spec_tests/data/sdam/errors/{non-stale-topologyVersion-proccessId-changed-NotMaster.yml → non-stale-topologyVersion-proccessId-changed-NotWritablePrimary.yml} +5 -4
  925. data/spec/spec_tests/data/sdam/errors/non-stale-topologyVersion-proccessId-changed-PrimarySteppedDown.yml +2 -1
  926. data/spec/spec_tests/data/sdam/errors/non-stale-topologyVersion-proccessId-changed-ShutdownInProgress.yml +2 -1
  927. data/spec/spec_tests/data/sdam/errors/post-42-InterruptedAtShutdown.yml +2 -1
  928. data/spec/spec_tests/data/sdam/errors/post-42-InterruptedDueToReplStateChange.yml +2 -1
  929. data/spec/spec_tests/data/sdam/errors/post-42-LegacyNotPrimary.yml +47 -0
  930. data/spec/spec_tests/data/sdam/errors/{post-42-NotMasterNoSlaveOk.yml → post-42-NotPrimaryNoSecondaryOk.yml} +5 -4
  931. data/spec/spec_tests/data/sdam/errors/{post-42-NotMasterOrSecondary.yml → post-42-NotPrimaryOrSecondary.yml} +5 -4
  932. data/spec/spec_tests/data/sdam/errors/{post-42-NotMaster.yml → post-42-NotWritablePrimary.yml} +5 -4
  933. data/spec/spec_tests/data/sdam/errors/post-42-PrimarySteppedDown.yml +2 -1
  934. data/spec/spec_tests/data/sdam/errors/post-42-ShutdownInProgress.yml +2 -1
  935. data/spec/spec_tests/data/sdam/errors/pre-42-InterruptedAtShutdown.yml +2 -1
  936. data/spec/spec_tests/data/sdam/errors/pre-42-InterruptedDueToReplStateChange.yml +2 -1
  937. data/spec/spec_tests/data/sdam/errors/{pre-42-NotMaster.yml → pre-42-LegacyNotPrimary.yml} +6 -5
  938. data/spec/spec_tests/data/sdam/errors/pre-42-NotPrimaryNoSecondaryOk.yml +47 -0
  939. data/spec/spec_tests/data/sdam/errors/{pre-42-NotMasterOrSecondary.yml → pre-42-NotPrimaryOrSecondary.yml} +5 -4
  940. data/spec/spec_tests/data/sdam/errors/{pre-42-NotMasterNoSlaveOk.yml → pre-42-NotWritablePrimary.yml} +6 -5
  941. data/spec/spec_tests/data/sdam/errors/pre-42-PrimarySteppedDown.yml +2 -1
  942. data/spec/spec_tests/data/sdam/errors/pre-42-ShutdownInProgress.yml +2 -1
  943. data/spec/spec_tests/data/sdam/errors/prefer-error-code.yml +54 -0
  944. data/spec/spec_tests/data/sdam/errors/stale-generation-InterruptedAtShutdown.yml +4 -2
  945. data/spec/spec_tests/data/sdam/errors/stale-generation-InterruptedDueToReplStateChange.yml +4 -2
  946. data/spec/spec_tests/data/sdam/errors/{stale-generation-NotMasterNoSlaveOk.yml → stale-generation-NotPrimaryNoSecondaryOk.yml} +7 -5
  947. data/spec/spec_tests/data/sdam/errors/{stale-generation-NotMasterOrSecondary.yml → stale-generation-NotPrimaryOrSecondary.yml} +7 -5
  948. data/spec/spec_tests/data/sdam/errors/{stale-generation-NotMaster.yml → stale-generation-NotWritablePrimary.yml} +7 -5
  949. data/spec/spec_tests/data/sdam/errors/stale-generation-PrimarySteppedDown.yml +4 -2
  950. data/spec/spec_tests/data/sdam/errors/stale-generation-ShutdownInProgress.yml +4 -2
  951. data/spec/spec_tests/data/sdam/errors/stale-generation-afterHandshakeCompletes-InterruptedAtShutdown.yml +4 -2
  952. data/spec/spec_tests/data/sdam/errors/stale-generation-afterHandshakeCompletes-InterruptedDueToReplStateChange.yml +4 -2
  953. data/spec/spec_tests/data/sdam/errors/{stale-generation-afterHandshakeCompletes-NotMaster.yml → stale-generation-afterHandshakeCompletes-LegacyNotPrimary.yml} +8 -6
  954. data/spec/spec_tests/data/sdam/errors/stale-generation-afterHandshakeCompletes-NotPrimaryNoSecondaryOk.yml +91 -0
  955. data/spec/spec_tests/data/sdam/errors/{stale-generation-afterHandshakeCompletes-NotMasterOrSecondary.yml → stale-generation-afterHandshakeCompletes-NotPrimaryOrSecondary.yml} +7 -5
  956. data/spec/spec_tests/data/sdam/errors/{stale-generation-afterHandshakeCompletes-NotMasterNoSlaveOk.yml → stale-generation-afterHandshakeCompletes-NotWritablePrimary.yml} +8 -6
  957. data/spec/spec_tests/data/sdam/errors/stale-generation-afterHandshakeCompletes-PrimarySteppedDown.yml +4 -2
  958. data/spec/spec_tests/data/sdam/errors/stale-generation-afterHandshakeCompletes-ShutdownInProgress.yml +4 -2
  959. data/spec/spec_tests/data/sdam/errors/stale-generation-afterHandshakeCompletes-network.yml +6 -4
  960. data/spec/spec_tests/data/sdam/errors/stale-generation-afterHandshakeCompletes-timeout.yml +6 -4
  961. data/spec/spec_tests/data/sdam/errors/stale-generation-beforeHandshakeCompletes-InterruptedAtShutdown.yml +4 -2
  962. data/spec/spec_tests/data/sdam/errors/stale-generation-beforeHandshakeCompletes-InterruptedDueToReplStateChange.yml +4 -2
  963. data/spec/spec_tests/data/sdam/errors/{stale-generation-beforeHandshakeCompletes-NotMaster.yml → stale-generation-beforeHandshakeCompletes-LegacyNotPrimary.yml} +8 -6
  964. data/spec/spec_tests/data/sdam/errors/stale-generation-beforeHandshakeCompletes-NotPrimaryNoSecondaryOk.yml +91 -0
  965. data/spec/spec_tests/data/sdam/errors/{stale-generation-beforeHandshakeCompletes-NotMasterOrSecondary.yml → stale-generation-beforeHandshakeCompletes-NotPrimaryOrSecondary.yml} +7 -5
  966. data/spec/spec_tests/data/sdam/errors/{stale-generation-beforeHandshakeCompletes-NotMasterNoSlaveOk.yml → stale-generation-beforeHandshakeCompletes-NotWritablePrimary.yml} +8 -6
  967. data/spec/spec_tests/data/sdam/errors/stale-generation-beforeHandshakeCompletes-PrimarySteppedDown.yml +4 -2
  968. data/spec/spec_tests/data/sdam/errors/stale-generation-beforeHandshakeCompletes-ShutdownInProgress.yml +4 -2
  969. data/spec/spec_tests/data/sdam/errors/stale-generation-beforeHandshakeCompletes-network.yml +6 -4
  970. data/spec/spec_tests/data/sdam/errors/stale-generation-beforeHandshakeCompletes-timeout.yml +6 -4
  971. data/spec/spec_tests/data/sdam/errors/stale-topologyVersion-InterruptedAtShutdown.yml +2 -1
  972. data/spec/spec_tests/data/sdam/errors/stale-topologyVersion-InterruptedDueToReplStateChange.yml +2 -1
  973. data/spec/spec_tests/data/sdam/errors/stale-topologyVersion-LegacyNotPrimary.yml +65 -0
  974. data/spec/spec_tests/data/sdam/errors/{stale-topologyVersion-NotMasterNoSlaveOk.yml → stale-topologyVersion-NotPrimaryNoSecondaryOk.yml} +7 -6
  975. data/spec/spec_tests/data/sdam/errors/{stale-topologyVersion-NotMasterOrSecondary.yml → stale-topologyVersion-NotPrimaryOrSecondary.yml} +7 -6
  976. data/spec/spec_tests/data/sdam/errors/{stale-topologyVersion-NotMaster.yml → stale-topologyVersion-NotWritablePrimary.yml} +7 -6
  977. data/spec/spec_tests/data/sdam/errors/stale-topologyVersion-PrimarySteppedDown.yml +2 -1
  978. data/spec/spec_tests/data/sdam/errors/stale-topologyVersion-ShutdownInProgress.yml +2 -1
  979. data/spec/spec_tests/data/sdam/errors/write_errors_ignored.yml +42 -0
  980. data/spec/spec_tests/data/sdam/load-balanced/discover_load_balancer.yml +25 -0
  981. data/spec/spec_tests/data/sdam/rs/compatible.yml +4 -2
  982. data/spec/spec_tests/data/sdam/rs/compatible_unknown.yml +2 -1
  983. data/spec/spec_tests/data/sdam/rs/discover_arbiters.yml +2 -1
  984. data/spec/spec_tests/data/sdam/rs/discover_arbiters_replicaset.yml +2 -1
  985. data/spec/spec_tests/data/sdam/rs/discover_ghost.yml +2 -1
  986. data/spec/spec_tests/data/sdam/rs/discover_ghost_replicaset.yml +2 -1
  987. data/spec/spec_tests/data/sdam/rs/discover_hidden.yml +2 -1
  988. data/spec/spec_tests/data/sdam/rs/discover_hidden_replicaset.yml +2 -1
  989. data/spec/spec_tests/data/sdam/rs/discover_passives.yml +4 -2
  990. data/spec/spec_tests/data/sdam/rs/discover_passives_replicaset.yml +4 -2
  991. data/spec/spec_tests/data/sdam/rs/discover_primary.yml +2 -1
  992. data/spec/spec_tests/data/sdam/rs/discover_primary_replicaset.yml +2 -1
  993. data/spec/spec_tests/data/sdam/rs/discover_rsother.yml +2 -1
  994. data/spec/spec_tests/data/sdam/rs/discover_rsother_replicaset.yml +4 -2
  995. data/spec/spec_tests/data/sdam/rs/discover_secondary.yml +2 -1
  996. data/spec/spec_tests/data/sdam/rs/discover_secondary_replicaset.yml +2 -1
  997. data/spec/spec_tests/data/sdam/rs/discovery.yml +8 -4
  998. data/spec/spec_tests/data/sdam/rs/equal_electionids.yml +4 -2
  999. data/spec/spec_tests/data/sdam/rs/hosts_differ_from_seeds.yml +2 -1
  1000. data/spec/spec_tests/data/sdam/rs/incompatible_arbiter.yml +3 -1
  1001. data/spec/spec_tests/data/sdam/rs/incompatible_ghost.yml +3 -1
  1002. data/spec/spec_tests/data/sdam/rs/incompatible_other.yml +3 -1
  1003. data/spec/spec_tests/data/sdam/rs/ls_timeout.yml +12 -6
  1004. data/spec/spec_tests/data/sdam/rs/member_reconfig.yml +4 -2
  1005. data/spec/spec_tests/data/sdam/rs/member_standalone.yml +4 -2
  1006. data/spec/spec_tests/data/sdam/rs/new_primary.yml +4 -2
  1007. data/spec/spec_tests/data/sdam/rs/new_primary_new_electionid.yml +6 -3
  1008. data/spec/spec_tests/data/sdam/rs/new_primary_new_setversion.yml +6 -3
  1009. data/spec/spec_tests/data/sdam/rs/new_primary_wrong_set_name.yml +4 -2
  1010. data/spec/spec_tests/data/sdam/rs/non_rs_member.yml +1 -0
  1011. data/spec/spec_tests/data/sdam/rs/normalize_case.yml +2 -1
  1012. data/spec/spec_tests/data/sdam/rs/normalize_case_me.yml +4 -2
  1013. data/spec/spec_tests/data/sdam/rs/null_election_id.yml +8 -4
  1014. data/spec/spec_tests/data/sdam/rs/primary_becomes_ghost.yml +4 -2
  1015. data/spec/spec_tests/data/sdam/rs/primary_becomes_mongos.yml +4 -2
  1016. data/spec/spec_tests/data/sdam/rs/primary_becomes_standalone.yml +2 -1
  1017. data/spec/spec_tests/data/sdam/rs/primary_changes_set_name.yml +4 -2
  1018. data/spec/spec_tests/data/sdam/rs/primary_disconnect.yml +2 -1
  1019. data/spec/spec_tests/data/sdam/rs/primary_disconnect_electionid.yml +10 -5
  1020. data/spec/spec_tests/data/sdam/rs/primary_disconnect_setversion.yml +10 -5
  1021. data/spec/spec_tests/data/sdam/rs/primary_hint_from_secondary_with_mismatched_me.yml +4 -2
  1022. data/spec/spec_tests/data/sdam/rs/primary_mismatched_me.yml +2 -1
  1023. data/spec/spec_tests/data/sdam/rs/primary_mismatched_me_not_removed.yml +5 -3
  1024. data/spec/spec_tests/data/sdam/rs/primary_reports_new_member.yml +8 -4
  1025. data/spec/spec_tests/data/sdam/rs/primary_to_no_primary_mismatched_me.yml +4 -2
  1026. data/spec/spec_tests/data/sdam/rs/primary_wrong_set_name.yml +2 -1
  1027. data/spec/spec_tests/data/sdam/rs/repeated.yml +9 -5
  1028. data/spec/spec_tests/data/sdam/rs/replicaset_rsnp.yml +2 -1
  1029. data/spec/spec_tests/data/sdam/rs/response_from_removed.yml +4 -2
  1030. data/spec/spec_tests/data/sdam/rs/sec_not_auth.yml +4 -2
  1031. data/spec/spec_tests/data/sdam/rs/secondary_ignore_ok_0.yml +4 -2
  1032. data/spec/spec_tests/data/sdam/rs/secondary_mismatched_me.yml +2 -1
  1033. data/spec/spec_tests/data/sdam/rs/secondary_wrong_set_name.yml +2 -1
  1034. data/spec/spec_tests/data/sdam/rs/secondary_wrong_set_name_with_primary.yml +4 -2
  1035. data/spec/spec_tests/data/sdam/rs/setversion_without_electionid.yml +4 -2
  1036. data/spec/spec_tests/data/sdam/rs/stepdown_change_set_name.yml +4 -2
  1037. data/spec/spec_tests/data/sdam/rs/too_new.yml +4 -2
  1038. data/spec/spec_tests/data/sdam/rs/too_old.yml +4 -2
  1039. data/spec/spec_tests/data/sdam/rs/topology_version_equal.yml +4 -2
  1040. data/spec/spec_tests/data/sdam/rs/topology_version_greater.yml +10 -5
  1041. data/spec/spec_tests/data/sdam/rs/topology_version_less.yml +4 -2
  1042. data/spec/spec_tests/data/sdam/rs/unexpected_mongos.yml +2 -1
  1043. data/spec/spec_tests/data/sdam/rs/use_setversion_without_electionid.yml +6 -3
  1044. data/spec/spec_tests/data/sdam/rs/wrong_set_name.yml +2 -1
  1045. data/spec/spec_tests/data/sdam/sharded/compatible.yml +4 -2
  1046. data/spec/spec_tests/data/sdam/sharded/discover_single_mongos.yml +2 -1
  1047. data/spec/spec_tests/data/sdam/sharded/ls_timeout_mongos.yml +9 -5
  1048. data/spec/spec_tests/data/sdam/sharded/mongos_disconnect.yml +6 -3
  1049. data/spec/spec_tests/data/sdam/sharded/multiple_mongoses.yml +4 -2
  1050. data/spec/spec_tests/data/sdam/sharded/non_mongos_removed.yml +4 -2
  1051. data/spec/spec_tests/data/sdam/sharded/too_new.yml +4 -2
  1052. data/spec/spec_tests/data/sdam/sharded/too_old.yml +4 -2
  1053. data/spec/spec_tests/data/sdam/single/compatible.yml +2 -1
  1054. data/spec/spec_tests/data/sdam/single/direct_connection_external_ip.yml +2 -1
  1055. data/spec/spec_tests/data/sdam/single/direct_connection_mongos.yml +2 -1
  1056. data/spec/spec_tests/data/sdam/single/direct_connection_replicaset.yml +2 -1
  1057. data/spec/spec_tests/data/sdam/single/direct_connection_rsarbiter.yml +2 -1
  1058. data/spec/spec_tests/data/sdam/single/direct_connection_rsprimary.yml +2 -1
  1059. data/spec/spec_tests/data/sdam/single/direct_connection_rssecondary.yml +2 -1
  1060. data/spec/spec_tests/data/sdam/single/direct_connection_standalone.yml +2 -1
  1061. data/spec/spec_tests/data/sdam/single/direct_connection_wrong_set_name.yml +4 -2
  1062. data/spec/spec_tests/data/sdam/single/discover_standalone.yml +2 -1
  1063. data/spec/spec_tests/data/sdam/single/ls_timeout_standalone.yml +2 -1
  1064. data/spec/spec_tests/data/sdam/single/not_ok_response.yml +5 -3
  1065. data/spec/spec_tests/data/sdam/single/standalone_removed.yml +2 -1
  1066. data/spec/spec_tests/data/sdam/single/{direct_connection_slave.yml → standalone_using_legacy_hello.yml} +3 -3
  1067. data/spec/spec_tests/data/sdam/single/too_new.yml +2 -1
  1068. data/spec/spec_tests/data/sdam/single/too_old.yml +2 -1
  1069. data/spec/spec_tests/data/sdam/single/too_old_then_upgraded.yml +4 -2
  1070. data/spec/spec_tests/data/sdam_integration/cancel-server-check.yml +1 -1
  1071. data/spec/spec_tests/data/sdam_integration/connectTimeoutMS.yml +2 -2
  1072. data/spec/spec_tests/data/sdam_integration/find-network-error.yml +2 -0
  1073. data/spec/spec_tests/data/sdam_integration/find-shutdown-error.yml +2 -0
  1074. data/spec/spec_tests/data/sdam_integration/{isMaster-command-error.yml → hello-command-error.yml} +22 -30
  1075. data/spec/spec_tests/data/sdam_integration/{isMaster-network-error.yml → hello-network-error.yml} +12 -16
  1076. data/spec/spec_tests/data/sdam_integration/{isMaster-timeout.yml → hello-timeout.yml} +9 -13
  1077. data/spec/spec_tests/data/sdam_integration/insert-network-error.yml +2 -0
  1078. data/spec/spec_tests/data/sdam_integration/insert-shutdown-error.yml +2 -0
  1079. data/spec/spec_tests/data/sdam_integration/rediscover-quickly-after-step-down.yml +14 -3
  1080. data/spec/spec_tests/data/sdam_monitoring/discovered_standalone.yml +1 -1
  1081. data/spec/spec_tests/data/sdam_monitoring/load_balancer.yml +65 -0
  1082. data/spec/spec_tests/data/sdam_monitoring/replica_set_with_no_primary.yml +2 -1
  1083. data/spec/spec_tests/data/sdam_monitoring/replica_set_with_primary.yml +2 -1
  1084. data/spec/spec_tests/data/sdam_monitoring/replica_set_with_removal.yml +3 -2
  1085. data/spec/spec_tests/data/sdam_monitoring/required_replica_set.yml +2 -1
  1086. data/spec/spec_tests/data/sdam_monitoring/standalone.yml +1 -1
  1087. data/spec/spec_tests/data/sdam_monitoring/standalone_suppress_equal_description_changes.yml +2 -2
  1088. data/spec/spec_tests/data/seed_list_discovery/load-balanced/loadBalanced-directConnection.yml +13 -0
  1089. data/spec/spec_tests/data/seed_list_discovery/load-balanced/loadBalanced-replicaSet-errors.yml +6 -0
  1090. data/spec/spec_tests/data/seed_list_discovery/load-balanced/loadBalanced-true-multiple-hosts.yml +5 -0
  1091. data/spec/spec_tests/data/seed_list_discovery/load-balanced/loadBalanced-true-txt.yml +10 -0
  1092. data/spec/spec_tests/data/{dns_seedlist_discovery → seed_list_discovery/replica-set}/direct-connection-false.yml +0 -0
  1093. data/spec/spec_tests/data/{dns_seedlist_discovery → seed_list_discovery/replica-set}/direct-connection-true.yml +0 -0
  1094. data/spec/spec_tests/data/seed_list_discovery/replica-set/encoded-userinfo-and-db.yml +15 -0
  1095. data/spec/spec_tests/data/seed_list_discovery/replica-set/loadBalanced-false-txt.yml +10 -0
  1096. data/spec/spec_tests/data/{dns_seedlist_discovery → seed_list_discovery/replica-set}/longer-parent-in-return.yml +0 -0
  1097. data/spec/spec_tests/data/{dns_seedlist_discovery → seed_list_discovery/replica-set}/misformatted-option.yml +0 -0
  1098. data/spec/spec_tests/data/{dns_seedlist_discovery → seed_list_discovery/replica-set}/no-results.yml +0 -0
  1099. data/spec/spec_tests/data/{dns_seedlist_discovery → seed_list_discovery/replica-set}/not-enough-parts.yml +0 -0
  1100. data/spec/spec_tests/data/{dns_seedlist_discovery → seed_list_discovery/replica-set}/one-result-default-port.yml +0 -0
  1101. data/spec/spec_tests/data/{dns_seedlist_discovery → seed_list_discovery/replica-set}/one-txt-record-multiple-strings.yml +0 -0
  1102. data/spec/spec_tests/data/{dns_seedlist_discovery → seed_list_discovery/replica-set}/one-txt-record.yml +0 -0
  1103. data/spec/spec_tests/data/{dns_seedlist_discovery → seed_list_discovery/replica-set}/parent-part-mismatch1.yml +0 -0
  1104. data/spec/spec_tests/data/{dns_seedlist_discovery → seed_list_discovery/replica-set}/parent-part-mismatch2.yml +0 -0
  1105. data/spec/spec_tests/data/{dns_seedlist_discovery → seed_list_discovery/replica-set}/parent-part-mismatch3.yml +0 -0
  1106. data/spec/spec_tests/data/{dns_seedlist_discovery → seed_list_discovery/replica-set}/parent-part-mismatch4.yml +0 -0
  1107. data/spec/spec_tests/data/{dns_seedlist_discovery → seed_list_discovery/replica-set}/parent-part-mismatch5.yml +0 -0
  1108. data/spec/spec_tests/data/{dns_seedlist_discovery → seed_list_discovery/replica-set}/returned-parent-too-short.yml +0 -0
  1109. data/spec/spec_tests/data/{dns_seedlist_discovery → seed_list_discovery/replica-set}/returned-parent-wrong.yml +0 -0
  1110. data/spec/spec_tests/data/{dns_seedlist_discovery → seed_list_discovery/replica-set}/two-results-default-port.yml +0 -0
  1111. data/spec/spec_tests/data/{dns_seedlist_discovery → seed_list_discovery/replica-set}/two-results-nonstandard-port.yml +0 -0
  1112. data/spec/spec_tests/data/{dns_seedlist_discovery → seed_list_discovery/replica-set}/two-txt-records.yml +0 -0
  1113. data/spec/spec_tests/data/{dns_seedlist_discovery → seed_list_discovery/replica-set}/txt-record-not-allowed-option.yml +0 -0
  1114. data/spec/spec_tests/data/{dns_seedlist_discovery → seed_list_discovery/replica-set}/txt-record-with-overridden-ssl-option.yml +0 -0
  1115. data/spec/spec_tests/data/{dns_seedlist_discovery → seed_list_discovery/replica-set}/txt-record-with-overridden-uri-option.yml +0 -0
  1116. data/spec/spec_tests/data/{dns_seedlist_discovery → seed_list_discovery/replica-set}/txt-record-with-unallowed-option.yml +0 -0
  1117. data/spec/spec_tests/data/seed_list_discovery/replica-set/uri-with-admin-database.yml +13 -0
  1118. data/spec/spec_tests/data/seed_list_discovery/replica-set/uri-with-auth.yml +12 -0
  1119. data/spec/spec_tests/data/{dns_seedlist_discovery → seed_list_discovery/replica-set}/uri-with-port.yml +0 -0
  1120. data/spec/spec_tests/data/{dns_seedlist_discovery → seed_list_discovery/replica-set}/uri-with-two-hosts.yml +0 -0
  1121. data/spec/spec_tests/data/transactions/error-labels.yml +3 -0
  1122. data/spec/spec_tests/data/transactions/mongos-pin-auto.yml +3 -0
  1123. data/spec/spec_tests/data/transactions/mongos-recovery-token.yml +2 -0
  1124. data/spec/spec_tests/data/transactions/pin-mongos.yml +6 -3
  1125. data/spec/spec_tests/data/transactions/retryable-abort-errorLabels.yml +2 -0
  1126. data/spec/spec_tests/data/transactions/retryable-abort.yml +2 -0
  1127. data/spec/spec_tests/data/transactions/retryable-commit-errorLabels.yml +2 -0
  1128. data/spec/spec_tests/data/transactions/retryable-commit.yml +2 -0
  1129. data/spec/spec_tests/data/transactions/retryable-writes.yml +2 -0
  1130. data/spec/spec_tests/data/transactions_unified/mongos-unpin.yml +172 -0
  1131. data/spec/spec_tests/data/unified/valid-fail/operation-failure.yml +31 -0
  1132. data/spec/spec_tests/data/unified/valid-pass/poc-change-streams.yml +220 -0
  1133. data/spec/spec_tests/data/unified/valid-pass/poc-command-monitoring.yml +102 -0
  1134. data/spec/spec_tests/data/unified/valid-pass/poc-crud.yml +184 -0
  1135. data/spec/spec_tests/data/unified/valid-pass/poc-gridfs.yml +155 -0
  1136. data/spec/spec_tests/data/unified/valid-pass/poc-retryable-reads.yml +193 -0
  1137. data/spec/spec_tests/data/unified/valid-pass/poc-retryable-writes.yml +210 -0
  1138. data/spec/spec_tests/data/unified/valid-pass/poc-sessions.yml +215 -0
  1139. data/spec/spec_tests/data/unified/valid-pass/poc-transactions-convenient-api.yml +235 -0
  1140. data/spec/spec_tests/data/unified/valid-pass/poc-transactions-mongos-pin-auto.yml +169 -0
  1141. data/spec/spec_tests/data/unified/valid-pass/poc-transactions.yml +170 -0
  1142. data/spec/spec_tests/data/uri_options/compression-options.yml +1 -1
  1143. data/spec/spec_tests/data/uri_options/connection-options.yml +60 -0
  1144. data/spec/spec_tests/data/versioned_api/crud-api-version-1-strict.yml +417 -0
  1145. data/spec/spec_tests/data/versioned_api/crud-api-version-1.yml +411 -0
  1146. data/spec/spec_tests/data/versioned_api/runcommand-helper-no-api-version-declared.yml +75 -0
  1147. data/spec/spec_tests/data/versioned_api/test-commands-deprecation-errors.yml +47 -0
  1148. data/spec/spec_tests/data/versioned_api/test-commands-strict-mode.yml +46 -0
  1149. data/spec/spec_tests/data/versioned_api/transaction-handling.yml +128 -0
  1150. data/spec/spec_tests/gridfs_spec.rb +3 -0
  1151. data/spec/spec_tests/load_balancers_spec.rb +15 -0
  1152. data/spec/spec_tests/max_staleness_spec.rb +3 -0
  1153. data/spec/spec_tests/read_write_concern_connection_string_spec.rb +3 -0
  1154. data/spec/spec_tests/read_write_concern_document_spec.rb +3 -0
  1155. data/spec/spec_tests/read_write_concern_operaton_spec.rb +3 -0
  1156. data/spec/spec_tests/retryable_reads_spec.rb +5 -2
  1157. data/spec/spec_tests/retryable_writes_spec.rb +10 -7
  1158. data/spec/spec_tests/sdam_integration_spec.rb +4 -1
  1159. data/spec/spec_tests/sdam_monitoring_spec.rb +14 -6
  1160. data/spec/spec_tests/sdam_spec.rb +5 -2
  1161. data/spec/spec_tests/seed_list_discovery_spec.rb +118 -0
  1162. data/spec/spec_tests/server_selection_rtt_spec.rb +3 -0
  1163. data/spec/spec_tests/server_selection_spec.rb +3 -0
  1164. data/spec/spec_tests/transactions_api_spec.rb +3 -0
  1165. data/spec/spec_tests/transactions_spec.rb +3 -0
  1166. data/spec/spec_tests/transactions_unified_spec.rb +13 -0
  1167. data/spec/spec_tests/unified_spec.rb +18 -0
  1168. data/spec/spec_tests/uri_options_spec.rb +21 -2
  1169. data/spec/spec_tests/versioned_api_spec.rb +13 -0
  1170. data/spec/stress/cleanup_spec.rb +3 -0
  1171. data/spec/stress/connection_pool_stress_spec.rb +3 -0
  1172. data/spec/stress/connection_pool_timing_spec.rb +3 -0
  1173. data/spec/stress/fork_reconnect_stress_spec.rb +7 -8
  1174. data/spec/stress/push_monitor_close_spec.rb +44 -0
  1175. data/spec/support/authorization.rb +3 -0
  1176. data/spec/support/aws_utils/base.rb +3 -0
  1177. data/spec/support/aws_utils/inspector.rb +3 -0
  1178. data/spec/support/aws_utils/orchestrator.rb +3 -0
  1179. data/spec/support/aws_utils/provisioner.rb +3 -0
  1180. data/spec/support/aws_utils.rb +3 -0
  1181. data/spec/support/background_thread_registry.rb +4 -1
  1182. data/spec/support/certificates/README.md +3 -2
  1183. data/spec/support/certificates/atlas-ocsp-ca.crt +107 -25
  1184. data/spec/support/certificates/atlas-ocsp.crt +156 -40
  1185. data/spec/support/client_registry.rb +12 -5
  1186. data/spec/support/client_registry_macros.rb +7 -4
  1187. data/spec/support/cluster_tools.rb +4 -1
  1188. data/spec/support/common_shortcuts.rb +39 -7
  1189. data/spec/support/constraints.rb +3 -0
  1190. data/spec/support/crypt.rb +3 -0
  1191. data/spec/support/dns.rb +3 -0
  1192. data/spec/support/json_ext_formatter.rb +3 -0
  1193. data/spec/support/keyword_struct.rb +3 -0
  1194. data/spec/support/local_resource_registry.rb +3 -0
  1195. data/spec/support/matchers.rb +17 -1
  1196. data/spec/support/monitoring_ext.rb +3 -0
  1197. data/spec/support/primary_socket.rb +3 -0
  1198. data/spec/support/sdam_formatter_integration.rb +3 -0
  1199. data/spec/support/session_registry.rb +3 -0
  1200. data/spec/{mongo/server/app_metadata_shared.rb → support/shared/app_metadata.rb} +38 -7
  1201. data/spec/support/shared/auth_context.rb +16 -0
  1202. data/spec/support/shared/protocol.rb +3 -0
  1203. data/spec/support/shared/scram_conversation.rb +3 -0
  1204. data/spec/support/shared/server_selector.rb +6 -3
  1205. data/spec/support/shared/session.rb +7 -4
  1206. data/spec/support/spec_config.rb +99 -23
  1207. data/spec/support/spec_setup.rb +51 -38
  1208. data/spec/support/using_hash.rb +31 -0
  1209. data/spec/support/utils.rb +69 -5
  1210. data.tar.gz.sig +0 -0
  1211. metadata +1265 -1053
  1212. metadata.gz.sig +0 -0
  1213. data/lib/mongo/collection/view/builder/find_command.rb +0 -170
  1214. data/lib/mongo/collection/view/builder/op_query.rb +0 -91
  1215. data/lib/mongo/cursor/builder/get_more_command.rb +0 -77
  1216. data/lib/mongo/cursor/builder/kill_cursors_command.rb +0 -108
  1217. data/lib/mongo/cursor/builder/op_get_more.rb +0 -61
  1218. data/lib/mongo/cursor/builder/op_kill_cursors.rb +0 -103
  1219. data/lib/mongo/operation/shared/collections_info_or_list_collections.rb +0 -58
  1220. data/lib/mongo/operation/shared/op_msg_or_list_indexes_command.rb +0 -47
  1221. data/lib/mongo/server/context.rb +0 -69
  1222. data/spec/mongo/cursor/builder/op_kill_cursors_spec.rb +0 -61
  1223. data/spec/spec_tests/dns_seedlist_discovery_spec.rb +0 -76
  1224. data/spec/support/cluster_config.rb +0 -207
  1225. data/spec/support/event_subscriber.rb +0 -212
data/lib/mongo/client.rb CHANGED
@@ -1,3 +1,6 @@
1
+ # frozen_string_literal: true
2
+ # encoding: utf-8
3
+
1
4
  # Copyright (C) 2014-2020 MongoDB Inc.
2
5
  #
3
6
  # Licensed under the Apache License, Version 2.0 (the 'License');
@@ -64,6 +67,7 @@ module Mongo
64
67
  :database,
65
68
  :heartbeat_frequency,
66
69
  :id_generator,
70
+ :load_balanced,
67
71
  :local_threshold,
68
72
  :logger,
69
73
  :log_prefix,
@@ -85,6 +89,7 @@ module Mongo
85
89
  :retry_writes,
86
90
  :scan,
87
91
  :sdam_proc,
92
+ :server_api,
88
93
  :server_selection_timeout,
89
94
  :socket_timeout,
90
95
  :ssl,
@@ -114,7 +119,16 @@ module Mongo
114
119
  # The compression algorithms supported by the driver.
115
120
  #
116
121
  # @since 2.5.0
117
- VALID_COMPRESSORS = [ Mongo::Protocol::Compressed::ZLIB ].freeze
122
+ VALID_COMPRESSORS = [
123
+ Mongo::Protocol::Compressed::ZSTD,
124
+ Mongo::Protocol::Compressed::SNAPPY,
125
+ Mongo::Protocol::Compressed::ZLIB
126
+ ].freeze
127
+
128
+ # The known server API versions.
129
+ VALID_SERVER_API_VERSIONS = %w(
130
+ 1
131
+ ).freeze
118
132
 
119
133
  # @return [ Mongo::Cluster ] cluster The cluster of servers for the client.
120
134
  attr_reader :cluster
@@ -223,21 +237,26 @@ module Mongo
223
237
  # @option options [ Array<String> ] :compressors A list of potential
224
238
  # compressors to use, in order of preference. The driver chooses the
225
239
  # first compressor that is also supported by the server. Currently the
226
- # driver only supports 'zlib'.
240
+ # driver only supports 'zstd, 'snappy' and 'zlib'.
227
241
  # @option options [ true | false ] :direct_connection Whether to connect
228
242
  # directly to the specified seed, bypassing topology discovery. Exactly
229
243
  # one seed must be provided.
230
244
  # @option options [ Symbol ] :connect Deprecated - use :direct_connection
231
245
  # option instead of this option. The connection method to use. This
232
246
  # forces the cluster to behave in the specified way instead of
233
- # auto-discovering. One of :direct, :replica_set, :sharded
247
+ # auto-discovering. One of :direct, :replica_set, :sharded,
248
+ # :load_balanced. If :connect is set to :load_balanced, the driver
249
+ # will behave as if the server is a load balancer even if it isn't
250
+ # connected to a load balancer.
234
251
  # @option options [ Float ] :connect_timeout The timeout, in seconds, to
235
252
  # attempt a connection.
236
253
  # @option options [ String ] :database The database to connect to.
237
254
  # @option options [ Float ] :heartbeat_frequency The interval, in seconds,
238
- # for the server monitor to refresh its description via ismaster.
255
+ # for the server monitor to refresh its description via hello.
239
256
  # @option options [ Object ] :id_generator A custom object to generate ids
240
257
  # for documents. Must respond to #generate.
258
+ # @option options [ true | false ] :load_balanced Whether to expect to
259
+ # connect to a load balancer.
241
260
  # @option options [ Integer ] :local_threshold The local threshold boundary
242
261
  # in seconds for selecting a near server for an operation.
243
262
  # @option options [ Logger ] :logger A custom logger to use.
@@ -312,6 +331,11 @@ module Mongo
312
331
  # in particular the cluster is nil at this time. sdam_proc should
313
332
  # limit itself to calling #subscribe and #unsubscribe methods on the
314
333
  # client only.
334
+ # @option options [ Hash ] :server_api The requested server API version.
335
+ # This hash can have the following items:
336
+ # - *:version* -- string
337
+ # - *:strict* -- boolean
338
+ # - *:deprecation_errors* -- boolean
315
339
  # @option options [ Integer ] :server_selection_timeout The timeout in seconds
316
340
  # for selecting a server for an operation.
317
341
  # @option options [ Float ] :socket_timeout The timeout, in seconds, to
@@ -465,6 +489,18 @@ module Mongo
465
489
 
466
490
  options = self.class.canonicalize_ruby_options(options)
467
491
 
492
+ # The server API version is specified to be a string.
493
+ # However, it is very annoying to always provide the number 1 as a string,
494
+ # therefore cast to the string type here.
495
+ if server_api = options[:server_api]
496
+ if server_api.is_a?(Hash)
497
+ server_api = Options::Redacted.new(server_api)
498
+ if (version = server_api[:version]).is_a?(Integer)
499
+ options[:server_api] = server_api.merge(version: version.to_s)
500
+ end
501
+ end
502
+ end
503
+
468
504
  # Special handling for sdam_proc as it is only used during client
469
505
  # construction
470
506
  sdam_proc = options.delete(:sdam_proc)
@@ -499,7 +535,9 @@ module Mongo
499
535
  validate_options!(addresses)
500
536
  validate_authentication_options!
501
537
 
502
- @database = Database.new(self, @options[:database], @options)
538
+ database_options = @options.dup
539
+ database_options.delete(:server_api)
540
+ @database = Database.new(self, @options[:database], database_options)
503
541
 
504
542
  # Temporarily set monitoring so that event subscriptions can be
505
543
  # set up without there being a cluster
@@ -697,9 +735,9 @@ module Mongo
697
735
  # @return [ Mongo::Client ] A new client instance.
698
736
  #
699
737
  # @since 2.0.0
700
- def with(new_options = Options::Redacted.new)
738
+ def with(new_options = nil)
701
739
  clone.tap do |client|
702
- opts = client.update_options(new_options)
740
+ opts = client.update_options(new_options || Options::Redacted.new)
703
741
  Database.create(client)
704
742
  # We can't use the same cluster if some options that would affect it
705
743
  # have changed.
@@ -726,6 +764,8 @@ module Mongo
726
764
  def update_options(new_options)
727
765
  old_options = @options
728
766
 
767
+ new_options = self.class.canonicalize_ruby_options(new_options || {})
768
+
729
769
  validate_new_options!(new_options).tap do |opts|
730
770
  # Our options are frozen
731
771
  options = @options.dup
@@ -1127,7 +1167,7 @@ module Mongo
1127
1167
  # The argument may contain a subset of options that the client will
1128
1168
  # eventually have; this method validates each of the provided options
1129
1169
  # but does not check for interactions between combinations of options.
1130
- def validate_new_options!(opts = Options::Redacted.new)
1170
+ def validate_new_options!(opts)
1131
1171
  return Options::Redacted.new unless opts
1132
1172
  if opts[:read_concern]
1133
1173
  # Raise an error for non user-settable options
@@ -1146,6 +1186,23 @@ module Mongo
1146
1186
  end
1147
1187
  end
1148
1188
 
1189
+ if server_api = opts[:server_api]
1190
+ unless server_api.is_a?(Hash)
1191
+ raise ArgumentError, ":server_api value must be a hash: #{server_api}"
1192
+ end
1193
+
1194
+ extra_keys = server_api.keys - %w(version strict deprecation_errors)
1195
+ unless extra_keys.empty?
1196
+ raise ArgumentError, "Unknown keys under :server_api: #{extra_keys.map(&:inspect).join(', ')}"
1197
+ end
1198
+
1199
+ if version = server_api[:version]
1200
+ unless VALID_SERVER_API_VERSIONS.include?(version)
1201
+ raise ArgumentError, "Unknown server API version: #{version}"
1202
+ end
1203
+ end
1204
+ end
1205
+
1149
1206
  Lint.validate_underscore_read_preference(opts[:read])
1150
1207
  Lint.validate_read_concern_option(opts[:read_concern])
1151
1208
  opts.each.inject(Options::Redacted.new) do |_options, (k, v)|
@@ -1155,6 +1212,15 @@ module Mongo
1155
1212
  validate_read!(key, opts)
1156
1213
  if key == :compressors
1157
1214
  compressors = valid_compressors(v)
1215
+
1216
+ if compressors.include?('snappy')
1217
+ validate_snappy_compression!
1218
+ end
1219
+
1220
+ if compressors.include?('zstd')
1221
+ validate_zstd_compression!
1222
+ end
1223
+
1158
1224
  _options[key] = compressors unless compressors.empty?
1159
1225
  else
1160
1226
  _options[key] = v
@@ -1174,9 +1240,15 @@ module Mongo
1174
1240
  raise ArgumentError, "If :write and :write_concern are both given, they must be identical: #{options.inspect}"
1175
1241
  end
1176
1242
 
1243
+ connect = options[:connect]&.to_sym
1244
+
1245
+ if connect && !%i(direct replica_set sharded load_balanced).include?(connect)
1246
+ raise ArgumentError, "Invalid :connect option value: #{connect}"
1247
+ end
1248
+
1177
1249
  if options[:direct_connection]
1178
- if options[:connect] && options[:connect].to_sym != :direct
1179
- raise ArgumentError, "Conflicting client options: direct_connection=true and connect=#{options[:connect]}"
1250
+ if connect && connect != :direct
1251
+ raise ArgumentError, "Conflicting client options: direct_connection=true and connect=#{connect}"
1180
1252
  end
1181
1253
  # When a new client is created, we get the list of seed addresses
1182
1254
  if addresses && addresses.length > 1
@@ -1188,8 +1260,36 @@ module Mongo
1188
1260
  end
1189
1261
  end
1190
1262
 
1191
- if options[:direct_connection] == false && options[:connect] && options[:connect].to_sym == :direct
1192
- raise ArgumentError, "Conflicting client options: direct_connection=false and connect=#{options[:connect]}"
1263
+ if options[:load_balanced]
1264
+ if addresses && addresses.length > 1
1265
+ raise ArgumentError, "load_balanced=true cannot be used with multiple seeds"
1266
+ end
1267
+
1268
+ if options[:direct_connection]
1269
+ raise ArgumentError, "direct_connection=true cannot be used with load_balanced=true"
1270
+ end
1271
+
1272
+ if connect && connect != :load_balanced
1273
+ raise ArgumentError, "connect=#{connect} cannot be used with load_balanced=true"
1274
+ end
1275
+
1276
+ if options[:replica_set]
1277
+ raise ArgumentError, "load_balanced=true cannot be used with replica_set option"
1278
+ end
1279
+ end
1280
+
1281
+ if connect == :load_balanced
1282
+ if addresses && addresses.length > 1
1283
+ raise ArgumentError, "connect=load_balanced cannot be used with multiple seeds"
1284
+ end
1285
+
1286
+ if options[:replica_set]
1287
+ raise ArgumentError, "connect=load_balanced cannot be used with replica_set option"
1288
+ end
1289
+ end
1290
+
1291
+ if options[:direct_connection] == false && connect && connect == :direct
1292
+ raise ArgumentError, "Conflicting client options: direct_connection=false and connect=#{connect}"
1193
1293
  end
1194
1294
 
1195
1295
  %i(connect_timeout socket_timeout).each do |key|
@@ -1311,11 +1411,30 @@ module Mongo
1311
1411
  "This compressor will not be used.")
1312
1412
  false
1313
1413
  else
1414
+
1314
1415
  true
1315
1416
  end
1316
1417
  end
1317
1418
  end
1318
1419
 
1420
+ def validate_snappy_compression!
1421
+ return if defined?(Snappy)
1422
+ require 'snappy'
1423
+ rescue LoadError => e
1424
+ raise Error::UnmetDependency, "Cannot enable snappy compression because the snappy gem " \
1425
+ "has not been installed. Add \"gem 'snappy'\" to your Gemfile and run " \
1426
+ "\"bundle install\" to install the gem. (#{e.class}: #{e})"
1427
+ end
1428
+
1429
+ def validate_zstd_compression!
1430
+ return if defined?(Zstd)
1431
+ require 'zstd-ruby'
1432
+ rescue LoadError => e
1433
+ raise Error::UnmetDependency, "Cannot enable zstd compression because the zstd-ruby gem " \
1434
+ "has not been installed. Add \"gem 'zstd-ruby'\" to your Gemfile and run " \
1435
+ "\"bundle install\" to install the gem. (#{e.class}: #{e})"
1436
+ end
1437
+
1319
1438
  def validate_max_min_pool_size!(option, opts)
1320
1439
  if option == :min_pool_size && opts[:min_pool_size]
1321
1440
  max = opts[:max_pool_size] || Server::ConnectionPool::DEFAULT_MAX_SIZE
@@ -1,3 +1,6 @@
1
+ # frozen_string_literal: true
2
+ # encoding: utf-8
3
+
1
4
  # Copyright (C) 2019-2020 MongoDB Inc.
2
5
  #
3
6
  # Licensed under the Apache License, Version 2.0 (the "License");
@@ -1,3 +1,6 @@
1
+ # frozen_string_literal: true
2
+ # encoding: utf-8
3
+
1
4
  # Copyright (C) 2014-2020 MongoDB Inc.
2
5
  #
3
6
  # Licensed under the Apache License, Version 2.0 (the "License");
@@ -33,14 +36,15 @@ module Mongo
33
36
  #
34
37
  # @example Create a PeriodicExecutor.
35
38
  # Mongo::Cluster::PeriodicExecutor.new([reaper, reaper2])
39
+ #
40
+ # @param [ Array<Object> ] executors The executors. Each must respond
41
+ # to #execute and #flush.
36
42
  # @param [ Hash ] options The options.
37
43
  #
38
44
  # @option options [ Logger ] :logger A custom logger to use.
39
45
  #
40
46
  # @api private
41
- #
42
- # @since 2.5.0
43
- def initialize(executors = [], options = {})
47
+ def initialize(executors, options = {})
44
48
  @thread = nil
45
49
  @executors = executors
46
50
  @stop_semaphore = Semaphore.new
@@ -1,3 +1,6 @@
1
+ # frozen_string_literal: true
2
+ # encoding: utf-8
3
+
1
4
  # Copyright (C) 2014-2020 MongoDB Inc.
2
5
  #
3
6
  # Licensed under the Apache License, Version 2.0 (the "License");
@@ -25,42 +28,38 @@ module Mongo
25
28
  class CursorReaper
26
29
  include Retryable
27
30
 
28
- # The default time interval for the cursor reaper to send pending kill cursors operations.
31
+ # The default time interval for the cursor reaper to send pending
32
+ # kill cursors operations.
29
33
  #
30
34
  # @since 2.3.0
31
35
  FREQUENCY = 1.freeze
32
36
 
33
37
  # Create a cursor reaper.
34
38
  #
35
- # @example Create a CursorReaper.
36
- # Mongo::Cluster::CursorReaper.new(cluster)
39
+ # @param [ Cluster ] cluster The cluster.
37
40
  #
38
41
  # @api private
39
- #
40
- # @since 2.3.0
41
- def initialize
42
+ def initialize(cluster)
43
+ @cluster = cluster
42
44
  @to_kill = {}
43
- @active_cursors = Set.new
45
+ @active_cursor_ids = Set.new
44
46
  @mutex = Mutex.new
45
47
  end
46
48
 
49
+ attr_reader :cluster
50
+
47
51
  # Schedule a kill cursors operation to be eventually executed.
48
52
  #
49
- # @example Schedule a kill cursors operation.
50
- # cursor_reaper.schedule_kill_cursor(id, op_spec, server)
51
- #
52
- # @param [ Integer ] id The id of the cursor to kill.
53
- # @param [ Hash ] op_spec The spec for the kill cursors op.
54
- # @param [ Mongo::Server ] server The server to send the kill cursors operation to.
53
+ # @param [ Cursor::KillSpec ] kill_spec The kill specification.
54
+ # @param [ Mongo::Server ] server The server to send the kill cursors
55
+ # operation to.
55
56
  #
56
57
  # @api private
57
- #
58
- # @since 2.3.0
59
- def schedule_kill_cursor(id, op_spec, server)
58
+ def schedule_kill_cursor(kill_spec, server)
60
59
  @mutex.synchronize do
61
- if @active_cursors.include?(id)
62
- @to_kill[server] ||= Set.new
63
- @to_kill[server] << op_spec
60
+ if @active_cursor_ids.include?(kill_spec.cursor_id)
61
+ @to_kill[server.address.seed] ||= Set.new
62
+ @to_kill[server.address.seed] << kill_spec
64
63
  end
65
64
  end
66
65
  end
@@ -84,7 +83,7 @@ module Mongo
84
83
  end
85
84
 
86
85
  @mutex.synchronize do
87
- @active_cursors << id
86
+ @active_cursor_ids << id
88
87
  end
89
88
  end
90
89
 
@@ -107,7 +106,7 @@ module Mongo
107
106
  end
108
107
 
109
108
  @mutex.synchronize do
110
- @active_cursors.delete(id)
109
+ @active_cursor_ids.delete(id)
111
110
  end
112
111
  end
113
112
 
@@ -120,29 +119,70 @@ module Mongo
120
119
  #
121
120
  # @since 2.3.0
122
121
  def kill_cursors
123
- to_kill_copy = {}
124
- active_cursors_copy = []
122
+ # TODO optimize this to batch kill cursor operations for the same
123
+ # server/database/collection instead of killing each cursor
124
+ # individually.
125
125
 
126
- @mutex.synchronize do
127
- to_kill_copy = @to_kill.dup
128
- active_cursors_copy = @active_cursors.dup
129
- @to_kill = {}
130
- end
126
+ loop do
127
+ server_address_str = nil
131
128
 
132
- to_kill_copy.each do |server, op_specs|
133
- op_specs.each do |op_spec|
134
- if server.features.find_command_enabled?
135
- Cursor::Builder::KillCursorsCommand.update_cursors(op_spec, active_cursors_copy.to_a)
136
- if Cursor::Builder::KillCursorsCommand.get_cursors_list(op_spec).size > 0
137
- Operation::KillCursors.new(op_spec).execute(server, client: nil)
138
- end
139
- else
140
- Cursor::Builder::OpKillCursors.update_cursors(op_spec, active_cursors_copy.to_a)
141
- if Cursor::Builder::OpKillCursors.get_cursors_list(op_spec).size > 0
142
- Operation::KillCursors.new(op_spec).execute(server, client: nil)
143
- end
129
+ kill_spec = @mutex.synchronize do
130
+ # Find a server that has any cursors scheduled for destruction.
131
+ server_address_str, specs =
132
+ @to_kill.detect { |server_address_str, specs| specs.any? }
133
+
134
+ if specs.nil?
135
+ # All servers have empty specs, nothing to do.
136
+ return
144
137
  end
138
+
139
+ # Note that this mutates the spec in the queue.
140
+ # If the kill cursor operation fails, we don't attempt to
141
+ # kill that cursor again.
142
+ spec = specs.take(1).tap do |arr|
143
+ specs.subtract(arr)
144
+ end.first
145
+
146
+ unless @active_cursor_ids.include?(spec.cursor_id)
147
+ # The cursor was already killed, typically because it has
148
+ # been iterated to completion. Remove the kill spec from
149
+ # our records without doing any more work.
150
+ spec = nil
151
+ end
152
+
153
+ spec
154
+ end
155
+
156
+ # If there was a spec to kill but its cursor was already killed,
157
+ # look for another spec.
158
+ next unless kill_spec
159
+
160
+ # We could also pass kill_spec directly into the KillCursors
161
+ # operation, though this would make that operation have a
162
+ # different API from all of the other ones which accept hashes.
163
+ spec = {
164
+ cursor_ids: [kill_spec.cursor_id],
165
+ coll_name: kill_spec.coll_name,
166
+ db_name: kill_spec.db_name,
167
+ }
168
+ op = Operation::KillCursors.new(spec)
169
+
170
+ server = cluster.servers.detect do |server|
171
+ server.address.seed == server_address_str
145
172
  end
173
+
174
+ unless server
175
+ # TODO We currently don't have a server for the address that the
176
+ # cursor is associated with. We should leave the cursor in the
177
+ # queue to be killed at a later time (when the server comes back).
178
+ next
179
+ end
180
+
181
+ options = {
182
+ server_api: server.options[:server_api],
183
+ service_id: kill_spec.service_id,
184
+ }
185
+ op.execute(server, context: Operation::Context.new(options: options))
146
186
  end
147
187
  end
148
188
  alias :execute :kill_cursors
@@ -1,3 +1,6 @@
1
+ # frozen_string_literal: true
2
+ # encoding: utf-8
3
+
1
4
  # Copyright (C) 2014-2020 MongoDB Inc.
2
5
  #
3
6
  # Licensed under the Apache License, Version 2.0 (the "License");
@@ -1,3 +1,6 @@
1
+ # frozen_string_literal: true
2
+ # encoding: utf-8
3
+
1
4
  # Copyright (C) 2018-2020 MongoDB Inc.
2
5
  #
3
6
  # Licensed under the Apache License, Version 2.0 (the "License");
@@ -102,6 +105,11 @@ class Mongo::Cluster
102
105
  end
103
106
 
104
107
  case topology
108
+ when Topology::LoadBalanced
109
+ @updated_desc = ::Mongo::Server::Description::LoadBalancer.new(
110
+ updated_desc.address,
111
+ )
112
+ update_server_descriptions
105
113
  when Topology::Single
106
114
  if topology.replica_set_name
107
115
  if updated_desc.replica_set_name != topology.replica_set_name
@@ -109,7 +117,7 @@ class Mongo::Cluster
109
117
  "Server #{updated_desc.address.to_s} has an incorrect replica set name '#{updated_desc.replica_set_name}'; expected '#{topology.replica_set_name}'"
110
118
  )
111
119
  @updated_desc = ::Mongo::Server::Description.new(updated_desc.address,
112
- {}, updated_desc.average_round_trip_time)
120
+ {}, average_round_trip_time: updated_desc.average_round_trip_time)
113
121
  update_server_descriptions
114
122
  end
115
123
  end
@@ -178,6 +186,7 @@ class Mongo::Cluster
178
186
  raise ArgumentError, "Unknown topology #{topology.class}"
179
187
  end
180
188
 
189
+ verify_invariants
181
190
  commit_changes
182
191
  disconnect_servers
183
192
  end
@@ -225,7 +234,7 @@ class Mongo::Cluster
225
234
 
226
235
  if stale_primary?
227
236
  @updated_desc = ::Mongo::Server::Description.new(updated_desc.address,
228
- {}, updated_desc.average_round_trip_time)
237
+ {}, average_round_trip_time: updated_desc.average_round_trip_time)
229
238
  update_server_descriptions
230
239
  check_if_has_primary
231
240
  return
@@ -254,7 +263,8 @@ class Mongo::Cluster
254
263
  if server.address != updated_desc.address
255
264
  if server.primary?
256
265
  server.update_description(::Mongo::Server::Description.new(
257
- server.address, {}, server.description.average_round_trip_time))
266
+ server.address, {},
267
+ average_round_trip_time: server.description.average_round_trip_time))
258
268
  end
259
269
  end
260
270
  end
@@ -363,6 +373,9 @@ class Mongo::Cluster
363
373
  end
364
374
  end
365
375
  end
376
+
377
+ verify_invariants
378
+
366
379
  added_servers
367
380
  end
368
381
 
@@ -599,5 +612,15 @@ class Mongo::Cluster
599
612
 
600
613
  @previous_server_descriptions != server_descriptions
601
614
  end
615
+
616
+ def verify_invariants
617
+ if Mongo::Lint.enabled?
618
+ if cluster.topology.single?
619
+ if cluster.servers_list.length > 1
620
+ raise Mongo::Error::LintError, "Trying to create a single topology with multiple servers: #{cluster.servers_list}"
621
+ end
622
+ end
623
+ end
624
+ end
602
625
  end
603
626
  end
@@ -1,3 +1,6 @@
1
+ # frozen_string_literal: true
2
+ # encoding: utf-8
3
+
1
4
  # Copyright (C) 2018-2020 MongoDB Inc.
2
5
  #
3
6
  # Licensed under the Apache License, Version 2.0 (the "License");
@@ -64,17 +67,21 @@ module Mongo
64
67
  @server_descriptions[server.address.to_s] = server.description
65
68
  end
66
69
 
67
- begin
68
- server_descriptions.each do |address_str, desc|
69
- unless desc.unknown?
70
- desc.features.check_driver_support!
70
+ if is_a?(LoadBalanced)
71
+ @compatible = true
72
+ else
73
+ begin
74
+ server_descriptions.each do |address_str, desc|
75
+ unless desc.unknown?
76
+ desc.features.check_driver_support!
77
+ end
71
78
  end
79
+ rescue Error::UnsupportedFeatures => e
80
+ @compatible = false
81
+ @compatibility_error = e
82
+ else
83
+ @compatible = true
72
84
  end
73
- rescue Error::UnsupportedFeatures => e
74
- @compatible = false
75
- @compatibility_error = e
76
- else
77
- @compatible = true
78
85
  end
79
86
 
80
87
  @have_data_bearing_servers = false