mongo 2.12.4 → 2.13.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (854) hide show
  1. checksums.yaml +4 -4
  2. checksums.yaml.gz.sig +0 -0
  3. data.tar.gz.sig +0 -0
  4. data/CONTRIBUTING.md +8 -36
  5. data/LICENSE +1 -1
  6. data/README.md +54 -54
  7. data/Rakefile +16 -10
  8. data/lib/mongo.rb +8 -3
  9. data/lib/mongo/active_support.rb +1 -1
  10. data/lib/mongo/address.rb +40 -13
  11. data/lib/mongo/address/ipv4.rb +32 -5
  12. data/lib/mongo/address/ipv6.rb +32 -5
  13. data/lib/mongo/address/unix.rb +3 -3
  14. data/lib/mongo/address/validator.rb +1 -1
  15. data/lib/mongo/auth.rb +36 -13
  16. data/lib/mongo/auth/aws.rb +37 -0
  17. data/lib/mongo/auth/aws/conversation.rb +128 -0
  18. data/lib/mongo/auth/aws/credentials_retriever.rb +219 -0
  19. data/lib/mongo/auth/aws/request.rb +283 -0
  20. data/lib/mongo/auth/base.rb +129 -0
  21. data/lib/mongo/auth/conversation_base.rb +52 -0
  22. data/lib/mongo/auth/cr.rb +9 -36
  23. data/lib/mongo/auth/cr/conversation.rb +24 -69
  24. data/lib/mongo/auth/credential_cache.rb +1 -1
  25. data/lib/mongo/auth/gssapi.rb +38 -0
  26. data/lib/mongo/auth/gssapi/conversation.rb +108 -0
  27. data/lib/mongo/auth/ldap.rb +9 -34
  28. data/lib/mongo/auth/ldap/conversation.rb +3 -43
  29. data/lib/mongo/auth/roles.rb +1 -1
  30. data/lib/mongo/auth/sasl_conversation_base.rb +111 -0
  31. data/lib/mongo/auth/scram.rb +39 -51
  32. data/lib/mongo/auth/scram/conversation.rb +12 -506
  33. data/lib/mongo/auth/scram256.rb +31 -0
  34. data/lib/mongo/auth/scram256/conversation.rb +63 -0
  35. data/lib/mongo/auth/scram_conversation_base.rb +402 -0
  36. data/lib/mongo/auth/stringprep.rb +5 -4
  37. data/lib/mongo/auth/stringprep/profiles/sasl.rb +2 -1
  38. data/lib/mongo/auth/stringprep/tables.rb +2 -1
  39. data/lib/mongo/auth/stringprep/unicode_normalize/normalize.rb +1 -0
  40. data/lib/mongo/auth/stringprep/unicode_normalize/tables.rb +1 -0
  41. data/lib/mongo/auth/user.rb +2 -2
  42. data/lib/mongo/auth/user/view.rb +1 -1
  43. data/lib/mongo/auth/x509.rb +14 -32
  44. data/lib/mongo/auth/x509/conversation.rb +15 -42
  45. data/lib/mongo/background_thread.rb +11 -2
  46. data/lib/mongo/bson.rb +1 -1
  47. data/lib/mongo/bulk_write.rb +62 -26
  48. data/lib/mongo/bulk_write/combineable.rb +20 -8
  49. data/lib/mongo/bulk_write/ordered_combiner.rb +1 -1
  50. data/lib/mongo/bulk_write/result.rb +1 -1
  51. data/lib/mongo/bulk_write/result_combiner.rb +1 -1
  52. data/lib/mongo/bulk_write/transformable.rb +9 -10
  53. data/lib/mongo/bulk_write/unordered_combiner.rb +1 -1
  54. data/lib/mongo/bulk_write/validatable.rb +5 -1
  55. data/lib/mongo/client.rb +216 -44
  56. data/lib/mongo/client_encryption.rb +1 -1
  57. data/lib/mongo/cluster.rb +177 -69
  58. data/lib/mongo/cluster/periodic_executor.rb +1 -1
  59. data/lib/mongo/cluster/reapers/cursor_reaper.rb +1 -1
  60. data/lib/mongo/cluster/reapers/socket_reaper.rb +1 -1
  61. data/lib/mongo/cluster/sdam_flow.rb +36 -17
  62. data/lib/mongo/cluster/topology.rb +19 -2
  63. data/lib/mongo/cluster/topology/base.rb +1 -1
  64. data/lib/mongo/cluster/topology/no_replica_set_options.rb +1 -1
  65. data/lib/mongo/cluster/topology/replica_set_no_primary.rb +4 -3
  66. data/lib/mongo/cluster/topology/replica_set_with_primary.rb +1 -1
  67. data/lib/mongo/cluster/topology/sharded.rb +2 -2
  68. data/lib/mongo/cluster/topology/single.rb +2 -2
  69. data/lib/mongo/cluster/topology/unknown.rb +1 -1
  70. data/lib/mongo/cluster_time.rb +1 -1
  71. data/lib/mongo/collection.rb +41 -21
  72. data/lib/mongo/collection/view.rb +6 -2
  73. data/lib/mongo/collection/view/aggregation.rb +6 -3
  74. data/lib/mongo/collection/view/builder.rb +1 -1
  75. data/lib/mongo/collection/view/builder/aggregation.rb +1 -1
  76. data/lib/mongo/collection/view/builder/find_command.rb +9 -1
  77. data/lib/mongo/collection/view/builder/flags.rb +1 -1
  78. data/lib/mongo/collection/view/builder/map_reduce.rb +1 -1
  79. data/lib/mongo/collection/view/builder/modifiers.rb +1 -1
  80. data/lib/mongo/collection/view/builder/op_query.rb +1 -1
  81. data/lib/mongo/collection/view/change_stream.rb +3 -6
  82. data/lib/mongo/collection/view/change_stream/retryable.rb +1 -1
  83. data/lib/mongo/collection/view/explainable.rb +1 -1
  84. data/lib/mongo/collection/view/immutable.rb +1 -1
  85. data/lib/mongo/collection/view/iterable.rb +8 -2
  86. data/lib/mongo/collection/view/map_reduce.rb +7 -4
  87. data/lib/mongo/collection/view/readable.rb +10 -2
  88. data/lib/mongo/collection/view/writable.rb +93 -13
  89. data/lib/mongo/crypt.rb +1 -1
  90. data/lib/mongo/crypt/auto_decryption_context.rb +1 -1
  91. data/lib/mongo/crypt/auto_encrypter.rb +1 -1
  92. data/lib/mongo/crypt/auto_encryption_context.rb +1 -1
  93. data/lib/mongo/crypt/binary.rb +1 -1
  94. data/lib/mongo/crypt/binding.rb +1 -1
  95. data/lib/mongo/crypt/context.rb +1 -1
  96. data/lib/mongo/crypt/data_key_context.rb +1 -1
  97. data/lib/mongo/crypt/encryption_io.rb +41 -24
  98. data/lib/mongo/crypt/explicit_decryption_context.rb +1 -1
  99. data/lib/mongo/crypt/explicit_encrypter.rb +1 -1
  100. data/lib/mongo/crypt/explicit_encryption_context.rb +1 -1
  101. data/lib/mongo/crypt/handle.rb +1 -1
  102. data/lib/mongo/crypt/hooks.rb +1 -1
  103. data/lib/mongo/crypt/kms_context.rb +1 -1
  104. data/lib/mongo/crypt/status.rb +1 -1
  105. data/lib/mongo/cursor.rb +3 -3
  106. data/lib/mongo/cursor/builder.rb +1 -1
  107. data/lib/mongo/cursor/builder/get_more_command.rb +1 -1
  108. data/lib/mongo/cursor/builder/kill_cursors_command.rb +1 -1
  109. data/lib/mongo/cursor/builder/op_get_more.rb +1 -1
  110. data/lib/mongo/cursor/builder/op_kill_cursors.rb +1 -1
  111. data/lib/mongo/database.rb +35 -5
  112. data/lib/mongo/database/view.rb +21 -6
  113. data/lib/mongo/dbref.rb +1 -1
  114. data/lib/mongo/distinguishing_semaphore.rb +55 -0
  115. data/lib/mongo/error.rb +28 -2
  116. data/lib/mongo/error/auth_error.rb +1 -1
  117. data/lib/mongo/error/bulk_write_error.rb +1 -1
  118. data/lib/mongo/error/change_stream_resumable.rb +1 -1
  119. data/lib/mongo/error/closed_stream.rb +1 -1
  120. data/lib/mongo/error/connection_check_out_timeout.rb +1 -1
  121. data/lib/mongo/error/connection_perished.rb +23 -0
  122. data/lib/mongo/error/credential_check_error.rb +26 -0
  123. data/lib/mongo/error/extra_file_chunk.rb +1 -1
  124. data/lib/mongo/error/file_not_found.rb +1 -1
  125. data/lib/mongo/error/handshake_error.rb +1 -1
  126. data/lib/mongo/error/insufficient_iteration_count.rb +1 -1
  127. data/lib/mongo/error/invalid_address.rb +1 -1
  128. data/lib/mongo/error/invalid_application_name.rb +1 -1
  129. data/lib/mongo/error/invalid_bulk_operation.rb +1 -1
  130. data/lib/mongo/error/invalid_bulk_operation_type.rb +1 -1
  131. data/lib/mongo/error/invalid_collection_name.rb +1 -1
  132. data/lib/mongo/error/invalid_cursor_operation.rb +1 -1
  133. data/lib/mongo/error/invalid_database_name.rb +1 -1
  134. data/lib/mongo/error/invalid_document.rb +1 -1
  135. data/lib/mongo/error/invalid_file.rb +1 -1
  136. data/lib/mongo/error/invalid_file_revision.rb +1 -1
  137. data/lib/mongo/error/invalid_min_pool_size.rb +1 -1
  138. data/lib/mongo/error/invalid_nonce.rb +2 -2
  139. data/lib/mongo/error/invalid_read_option.rb +1 -1
  140. data/lib/mongo/error/invalid_replacement_document.rb +1 -1
  141. data/lib/mongo/error/invalid_server_auth_host.rb +22 -0
  142. data/lib/mongo/error/invalid_server_auth_response.rb +23 -0
  143. data/lib/mongo/error/invalid_server_preference.rb +6 -1
  144. data/lib/mongo/error/invalid_session.rb +3 -2
  145. data/lib/mongo/error/invalid_signature.rb +1 -1
  146. data/lib/mongo/error/invalid_transaction_operation.rb +1 -1
  147. data/lib/mongo/error/invalid_txt_record.rb +1 -1
  148. data/lib/mongo/error/invalid_update_document.rb +1 -1
  149. data/lib/mongo/error/invalid_uri.rb +1 -1
  150. data/lib/mongo/error/invalid_write_concern.rb +1 -1
  151. data/lib/mongo/error/lint_error.rb +1 -1
  152. data/lib/mongo/error/max_bson_size.rb +1 -1
  153. data/lib/mongo/error/max_message_size.rb +1 -1
  154. data/lib/mongo/error/mismatched_domain.rb +1 -1
  155. data/lib/mongo/error/missing_file_chunk.rb +1 -1
  156. data/lib/mongo/error/missing_password.rb +1 -1
  157. data/lib/mongo/error/missing_resume_token.rb +1 -1
  158. data/lib/mongo/error/missing_scram_server_signature.rb +27 -0
  159. data/lib/mongo/error/multi_index_drop.rb +1 -1
  160. data/lib/mongo/error/need_primary_server.rb +1 -1
  161. data/lib/mongo/error/no_server_available.rb +1 -1
  162. data/lib/mongo/error/no_srv_records.rb +1 -1
  163. data/lib/mongo/error/notable.rb +18 -3
  164. data/lib/mongo/error/operation_failure.rb +68 -49
  165. data/lib/mongo/error/parser.rb +16 -5
  166. data/lib/mongo/error/pool_closed_error.rb +1 -1
  167. data/lib/mongo/error/raise_original_error.rb +29 -0
  168. data/lib/mongo/error/session_ended.rb +1 -1
  169. data/lib/mongo/error/sessions_not_supported.rb +35 -0
  170. data/lib/mongo/error/socket_error.rb +1 -1
  171. data/lib/mongo/error/socket_timeout_error.rb +1 -1
  172. data/lib/mongo/error/unchangeable_collection_option.rb +1 -1
  173. data/lib/mongo/error/unexpected_chunk_length.rb +1 -1
  174. data/lib/mongo/error/unexpected_response.rb +1 -1
  175. data/lib/mongo/error/unknown_payload_type.rb +1 -1
  176. data/lib/mongo/error/unsupported_array_filters.rb +7 -2
  177. data/lib/mongo/error/unsupported_collation.rb +7 -2
  178. data/lib/mongo/error/unsupported_features.rb +1 -1
  179. data/lib/mongo/error/unsupported_message_type.rb +1 -1
  180. data/lib/mongo/error/unsupported_option.rb +99 -0
  181. data/lib/mongo/error/write_retryable.rb +1 -1
  182. data/lib/mongo/event.rb +1 -1
  183. data/lib/mongo/event/base.rb +7 -1
  184. data/lib/mongo/event/listeners.rb +1 -1
  185. data/lib/mongo/event/publisher.rb +1 -1
  186. data/lib/mongo/event/subscriber.rb +1 -1
  187. data/lib/mongo/grid.rb +1 -1
  188. data/lib/mongo/grid/file.rb +1 -1
  189. data/lib/mongo/grid/file/chunk.rb +1 -1
  190. data/lib/mongo/grid/file/info.rb +1 -1
  191. data/lib/mongo/grid/fs_bucket.rb +9 -4
  192. data/lib/mongo/grid/stream.rb +1 -1
  193. data/lib/mongo/grid/stream/read.rb +1 -1
  194. data/lib/mongo/grid/stream/write.rb +1 -1
  195. data/lib/mongo/id.rb +1 -1
  196. data/lib/mongo/index.rb +2 -1
  197. data/lib/mongo/index/view.rb +61 -11
  198. data/lib/mongo/lint.rb +10 -0
  199. data/lib/mongo/loggable.rb +1 -1
  200. data/lib/mongo/logger.rb +1 -1
  201. data/lib/mongo/monitoring.rb +39 -1
  202. data/lib/mongo/monitoring/cmap_log_subscriber.rb +1 -1
  203. data/lib/mongo/monitoring/command_log_subscriber.rb +20 -5
  204. data/lib/mongo/monitoring/event.rb +1 -1
  205. data/lib/mongo/monitoring/event/cmap.rb +1 -1
  206. data/lib/mongo/monitoring/event/cmap/base.rb +1 -1
  207. data/lib/mongo/monitoring/event/cmap/connection_check_out_failed.rb +1 -1
  208. data/lib/mongo/monitoring/event/cmap/connection_check_out_started.rb +1 -1
  209. data/lib/mongo/monitoring/event/cmap/connection_checked_in.rb +1 -1
  210. data/lib/mongo/monitoring/event/cmap/connection_checked_out.rb +1 -1
  211. data/lib/mongo/monitoring/event/cmap/connection_closed.rb +1 -1
  212. data/lib/mongo/monitoring/event/cmap/connection_created.rb +1 -1
  213. data/lib/mongo/monitoring/event/cmap/connection_ready.rb +1 -1
  214. data/lib/mongo/monitoring/event/cmap/pool_cleared.rb +1 -1
  215. data/lib/mongo/monitoring/event/cmap/pool_closed.rb +1 -1
  216. data/lib/mongo/monitoring/event/cmap/pool_created.rb +1 -1
  217. data/lib/mongo/monitoring/event/command_failed.rb +12 -1
  218. data/lib/mongo/monitoring/event/command_started.rb +44 -3
  219. data/lib/mongo/monitoring/event/command_succeeded.rb +12 -1
  220. data/lib/mongo/monitoring/event/secure.rb +8 -2
  221. data/lib/mongo/monitoring/event/server_closed.rb +2 -2
  222. data/lib/mongo/monitoring/event/server_description_changed.rb +28 -5
  223. data/lib/mongo/monitoring/event/server_heartbeat_failed.rb +10 -3
  224. data/lib/mongo/monitoring/event/server_heartbeat_started.rb +10 -3
  225. data/lib/mongo/monitoring/event/server_heartbeat_succeeded.rb +10 -3
  226. data/lib/mongo/monitoring/event/server_opening.rb +2 -2
  227. data/lib/mongo/monitoring/event/topology_changed.rb +2 -2
  228. data/lib/mongo/monitoring/event/topology_closed.rb +2 -2
  229. data/lib/mongo/monitoring/event/topology_opening.rb +2 -2
  230. data/lib/mongo/monitoring/publishable.rb +9 -9
  231. data/lib/mongo/monitoring/sdam_log_subscriber.rb +1 -1
  232. data/lib/mongo/monitoring/server_closed_log_subscriber.rb +1 -1
  233. data/lib/mongo/monitoring/server_description_changed_log_subscriber.rb +10 -2
  234. data/lib/mongo/monitoring/server_opening_log_subscriber.rb +1 -1
  235. data/lib/mongo/monitoring/topology_changed_log_subscriber.rb +2 -2
  236. data/lib/mongo/monitoring/topology_closed_log_subscriber.rb +1 -1
  237. data/lib/mongo/monitoring/topology_opening_log_subscriber.rb +1 -1
  238. data/lib/mongo/monitoring/unified_sdam_log_subscriber.rb +1 -1
  239. data/lib/mongo/operation.rb +1 -0
  240. data/lib/mongo/operation/aggregate.rb +1 -1
  241. data/lib/mongo/operation/aggregate/command.rb +5 -5
  242. data/lib/mongo/operation/aggregate/op_msg.rb +1 -1
  243. data/lib/mongo/operation/aggregate/result.rb +1 -1
  244. data/lib/mongo/operation/collections_info.rb +3 -36
  245. data/lib/mongo/operation/collections_info/command.rb +40 -0
  246. data/lib/mongo/operation/collections_info/result.rb +1 -1
  247. data/lib/mongo/operation/command.rb +1 -1
  248. data/lib/mongo/operation/command/command.rb +3 -3
  249. data/lib/mongo/operation/command/op_msg.rb +1 -1
  250. data/lib/mongo/operation/count.rb +1 -1
  251. data/lib/mongo/operation/count/command.rb +3 -3
  252. data/lib/mongo/operation/count/op_msg.rb +1 -1
  253. data/lib/mongo/operation/create.rb +1 -1
  254. data/lib/mongo/operation/create/command.rb +3 -3
  255. data/lib/mongo/operation/create/op_msg.rb +1 -1
  256. data/lib/mongo/operation/create_index.rb +1 -1
  257. data/lib/mongo/operation/create_index/command.rb +4 -4
  258. data/lib/mongo/operation/create_index/op_msg.rb +6 -3
  259. data/lib/mongo/operation/create_user.rb +1 -1
  260. data/lib/mongo/operation/create_user/command.rb +4 -4
  261. data/lib/mongo/operation/create_user/op_msg.rb +2 -2
  262. data/lib/mongo/operation/delete.rb +1 -1
  263. data/lib/mongo/operation/delete/bulk_result.rb +1 -1
  264. data/lib/mongo/operation/delete/command.rb +4 -4
  265. data/lib/mongo/operation/delete/legacy.rb +2 -2
  266. data/lib/mongo/operation/delete/op_msg.rb +4 -4
  267. data/lib/mongo/operation/delete/result.rb +2 -2
  268. data/lib/mongo/operation/distinct.rb +1 -1
  269. data/lib/mongo/operation/distinct/command.rb +3 -3
  270. data/lib/mongo/operation/distinct/op_msg.rb +1 -1
  271. data/lib/mongo/operation/drop.rb +1 -1
  272. data/lib/mongo/operation/drop/command.rb +3 -3
  273. data/lib/mongo/operation/drop/op_msg.rb +1 -1
  274. data/lib/mongo/operation/drop_database.rb +1 -1
  275. data/lib/mongo/operation/drop_database/command.rb +3 -3
  276. data/lib/mongo/operation/drop_database/op_msg.rb +1 -1
  277. data/lib/mongo/operation/drop_index.rb +1 -1
  278. data/lib/mongo/operation/drop_index/command.rb +4 -4
  279. data/lib/mongo/operation/drop_index/op_msg.rb +2 -2
  280. data/lib/mongo/operation/explain.rb +1 -1
  281. data/lib/mongo/operation/explain/command.rb +3 -3
  282. data/lib/mongo/operation/explain/legacy.rb +3 -3
  283. data/lib/mongo/operation/explain/op_msg.rb +1 -1
  284. data/lib/mongo/operation/explain/result.rb +1 -1
  285. data/lib/mongo/operation/find.rb +1 -1
  286. data/lib/mongo/operation/find/command.rb +3 -3
  287. data/lib/mongo/operation/find/legacy.rb +3 -3
  288. data/lib/mongo/operation/find/legacy/result.rb +1 -1
  289. data/lib/mongo/operation/find/op_msg.rb +2 -12
  290. data/lib/mongo/operation/find/result.rb +1 -1
  291. data/lib/mongo/operation/get_more.rb +1 -1
  292. data/lib/mongo/operation/get_more/command.rb +3 -3
  293. data/lib/mongo/operation/get_more/legacy.rb +2 -2
  294. data/lib/mongo/operation/get_more/op_msg.rb +2 -12
  295. data/lib/mongo/operation/get_more/result.rb +1 -1
  296. data/lib/mongo/operation/indexes.rb +1 -1
  297. data/lib/mongo/operation/indexes/command.rb +3 -3
  298. data/lib/mongo/operation/indexes/legacy.rb +4 -4
  299. data/lib/mongo/operation/indexes/op_msg.rb +1 -1
  300. data/lib/mongo/operation/indexes/result.rb +1 -1
  301. data/lib/mongo/operation/insert.rb +3 -2
  302. data/lib/mongo/operation/insert/bulk_result.rb +6 -2
  303. data/lib/mongo/operation/insert/command.rb +7 -7
  304. data/lib/mongo/operation/insert/legacy.rb +9 -5
  305. data/lib/mongo/operation/insert/op_msg.rb +6 -6
  306. data/lib/mongo/operation/insert/result.rb +7 -4
  307. data/lib/mongo/operation/kill_cursors.rb +1 -1
  308. data/lib/mongo/operation/kill_cursors/command.rb +3 -3
  309. data/lib/mongo/operation/kill_cursors/legacy.rb +2 -2
  310. data/lib/mongo/operation/kill_cursors/op_msg.rb +1 -1
  311. data/lib/mongo/operation/list_collections.rb +1 -1
  312. data/lib/mongo/operation/list_collections/command.rb +4 -4
  313. data/lib/mongo/operation/list_collections/op_msg.rb +2 -2
  314. data/lib/mongo/operation/list_collections/result.rb +1 -1
  315. data/lib/mongo/operation/map_reduce.rb +1 -1
  316. data/lib/mongo/operation/map_reduce/command.rb +3 -3
  317. data/lib/mongo/operation/map_reduce/op_msg.rb +1 -1
  318. data/lib/mongo/operation/map_reduce/result.rb +1 -1
  319. data/lib/mongo/operation/op_msg_base.rb +3 -3
  320. data/lib/mongo/operation/parallel_scan.rb +1 -1
  321. data/lib/mongo/operation/parallel_scan/command.rb +5 -5
  322. data/lib/mongo/operation/parallel_scan/op_msg.rb +2 -2
  323. data/lib/mongo/operation/parallel_scan/result.rb +1 -1
  324. data/lib/mongo/operation/remove_user.rb +1 -1
  325. data/lib/mongo/operation/remove_user/command.rb +4 -4
  326. data/lib/mongo/operation/remove_user/op_msg.rb +2 -2
  327. data/lib/mongo/operation/result.rb +28 -4
  328. data/lib/mongo/operation/shared/bypass_document_validation.rb +10 -4
  329. data/lib/mongo/operation/shared/causal_consistency_supported.rb +3 -3
  330. data/lib/mongo/operation/shared/collections_info_or_list_collections.rb +56 -0
  331. data/lib/mongo/operation/shared/executable.rb +46 -28
  332. data/lib/mongo/operation/shared/executable_no_validate.rb +3 -3
  333. data/lib/mongo/operation/shared/executable_transaction_label.rb +1 -1
  334. data/lib/mongo/operation/shared/idable.rb +1 -1
  335. data/lib/mongo/operation/shared/limited.rb +10 -2
  336. data/lib/mongo/operation/shared/object_id_generator.rb +1 -1
  337. data/lib/mongo/operation/shared/op_msg_or_command.rb +7 -5
  338. data/lib/mongo/operation/shared/op_msg_or_find_command.rb +8 -6
  339. data/lib/mongo/operation/shared/op_msg_or_list_indexes_command.rb +8 -6
  340. data/lib/mongo/operation/shared/polymorphic_lookup.rb +1 -1
  341. data/lib/mongo/operation/shared/polymorphic_result.rb +1 -1
  342. data/lib/mongo/operation/shared/read_preference_supported.rb +19 -16
  343. data/lib/mongo/operation/shared/response_handling.rb +83 -8
  344. data/lib/mongo/operation/shared/result/aggregatable.rb +1 -1
  345. data/lib/mongo/operation/shared/result/use_legacy_error_parser.rb +1 -1
  346. data/lib/mongo/operation/shared/sessions_supported.rb +50 -27
  347. data/lib/mongo/operation/shared/specifiable.rb +32 -20
  348. data/lib/mongo/operation/shared/write.rb +25 -19
  349. data/lib/mongo/operation/shared/write_concern_supported.rb +6 -6
  350. data/lib/mongo/operation/update.rb +1 -1
  351. data/lib/mongo/operation/update/bulk_result.rb +1 -1
  352. data/lib/mongo/operation/update/command.rb +4 -4
  353. data/lib/mongo/operation/update/legacy.rb +2 -2
  354. data/lib/mongo/operation/update/legacy/result.rb +1 -1
  355. data/lib/mongo/operation/update/op_msg.rb +4 -4
  356. data/lib/mongo/operation/update/result.rb +2 -2
  357. data/lib/mongo/operation/update_user.rb +1 -1
  358. data/lib/mongo/operation/update_user/command.rb +4 -4
  359. data/lib/mongo/operation/update_user/op_msg.rb +2 -2
  360. data/lib/mongo/operation/users_info.rb +1 -1
  361. data/lib/mongo/operation/users_info/command.rb +4 -4
  362. data/lib/mongo/operation/users_info/op_msg.rb +2 -2
  363. data/lib/mongo/operation/users_info/result.rb +1 -1
  364. data/lib/mongo/options.rb +1 -1
  365. data/lib/mongo/options/mapper.rb +1 -1
  366. data/lib/mongo/options/redacted.rb +1 -1
  367. data/lib/mongo/protocol/bit_vector.rb +1 -1
  368. data/lib/mongo/protocol/compressed.rb +1 -1
  369. data/lib/mongo/protocol/delete.rb +1 -1
  370. data/lib/mongo/protocol/get_more.rb +1 -1
  371. data/lib/mongo/protocol/insert.rb +1 -1
  372. data/lib/mongo/protocol/kill_cursors.rb +1 -1
  373. data/lib/mongo/protocol/message.rb +37 -18
  374. data/lib/mongo/protocol/msg.rb +19 -5
  375. data/lib/mongo/protocol/query.rb +1 -37
  376. data/lib/mongo/protocol/registry.rb +1 -1
  377. data/lib/mongo/protocol/reply.rb +1 -1
  378. data/lib/mongo/protocol/serializers.rb +1 -1
  379. data/lib/mongo/protocol/update.rb +1 -1
  380. data/lib/mongo/retryable.rb +23 -10
  381. data/lib/mongo/semaphore.rb +1 -1
  382. data/lib/mongo/server.rb +40 -8
  383. data/lib/mongo/server/app_metadata.rb +44 -7
  384. data/lib/mongo/server/connection.rb +37 -133
  385. data/lib/mongo/server/connection_base.rb +27 -10
  386. data/lib/mongo/server/connection_common.rb +75 -1
  387. data/lib/mongo/server/connection_pool.rb +20 -1
  388. data/lib/mongo/server/connection_pool/populator.rb +1 -1
  389. data/lib/mongo/server/context.rb +1 -1
  390. data/lib/mongo/server/description.rb +49 -2
  391. data/lib/mongo/server/description/features.rb +12 -3
  392. data/lib/mongo/server/monitor.rb +145 -69
  393. data/lib/mongo/server/monitor/app_metadata.rb +1 -1
  394. data/lib/mongo/server/monitor/connection.rb +110 -80
  395. data/lib/mongo/server/pending_connection.rb +215 -3
  396. data/lib/mongo/server/push_monitor.rb +173 -0
  397. data/{spec/runners/transactions/context.rb → lib/mongo/server/push_monitor/connection.rb} +9 -14
  398. data/lib/mongo/server/round_trip_time_averager.rb +12 -3
  399. data/lib/mongo/server_selector.rb +2 -2
  400. data/lib/mongo/server_selector/{selectable.rb → base.rb} +159 -86
  401. data/lib/mongo/server_selector/nearest.rb +26 -21
  402. data/lib/mongo/server_selector/primary.rb +24 -28
  403. data/lib/mongo/server_selector/primary_preferred.rb +32 -25
  404. data/lib/mongo/server_selector/secondary.rb +26 -21
  405. data/lib/mongo/server_selector/secondary_preferred.rb +29 -34
  406. data/lib/mongo/session.rb +14 -1
  407. data/lib/mongo/session/server_session.rb +1 -1
  408. data/lib/mongo/session/session_pool.rb +1 -1
  409. data/lib/mongo/socket.rb +121 -41
  410. data/lib/mongo/socket/ssl.rb +98 -35
  411. data/lib/mongo/socket/tcp.rb +39 -31
  412. data/lib/mongo/socket/unix.rb +14 -6
  413. data/lib/mongo/srv.rb +1 -1
  414. data/lib/mongo/srv/monitor.rb +1 -1
  415. data/lib/mongo/srv/resolver.rb +1 -1
  416. data/lib/mongo/srv/result.rb +1 -1
  417. data/lib/mongo/timeout.rb +9 -9
  418. data/lib/mongo/topology_version.rb +89 -0
  419. data/lib/mongo/uri.rb +61 -47
  420. data/lib/mongo/uri/srv_protocol.rb +9 -1
  421. data/lib/mongo/utils.rb +62 -0
  422. data/lib/mongo/version.rb +2 -2
  423. data/lib/mongo/write_concern.rb +1 -1
  424. data/lib/mongo/write_concern/acknowledged.rb +1 -1
  425. data/lib/mongo/write_concern/base.rb +1 -1
  426. data/lib/mongo/write_concern/unacknowledged.rb +1 -1
  427. data/mongo.gemspec +1 -1
  428. data/spec/NOTES.aws-auth.md +291 -0
  429. data/spec/README.aws-auth.md +318 -0
  430. data/spec/README.md +64 -17
  431. data/spec/integration/auth_spec.rb +29 -9
  432. data/spec/integration/awaited_ismaster_spec.rb +28 -0
  433. data/spec/integration/aws_auth_request_spec.rb +74 -0
  434. data/spec/integration/aws_credentials_retriever_spec.rb +103 -0
  435. data/spec/integration/change_stream_examples_spec.rb +6 -2
  436. data/spec/integration/change_stream_spec.rb +123 -51
  437. data/spec/integration/check_clean_slate_spec.rb +16 -0
  438. data/spec/integration/client_authentication_options_spec.rb +0 -37
  439. data/spec/integration/client_construction_aws_auth_spec.rb +191 -0
  440. data/spec/integration/client_construction_spec.rb +2 -1
  441. data/spec/integration/client_side_encryption/auto_encryption_bulk_writes_spec.rb +2 -6
  442. data/spec/integration/collection_indexes_prose_spec.rb +55 -0
  443. data/spec/integration/command_monitoring_spec.rb +30 -6
  444. data/spec/integration/command_spec.rb +11 -9
  445. data/spec/integration/connect_single_rs_name_spec.rb +10 -5
  446. data/spec/integration/connection_spec.rb +7 -3
  447. data/spec/integration/crud_spec.rb +32 -4
  448. data/spec/integration/cursor_reaping_spec.rb +14 -10
  449. data/spec/integration/docs_examples_spec.rb +6 -0
  450. data/spec/integration/fork_reconnect_spec.rb +143 -0
  451. data/spec/integration/get_more_spec.rb +10 -3
  452. data/spec/integration/heartbeat_events_spec.rb +5 -24
  453. data/spec/integration/read_concern_spec.rb +1 -1
  454. data/spec/integration/read_preference_spec.rb +41 -11
  455. data/spec/integration/reconnect_spec.rb +2 -3
  456. data/spec/integration/retryable_errors_spec.rb +33 -14
  457. data/spec/integration/{retryable_writes_spec.rb → retryable_writes/retryable_writes_36_and_older_spec.rb} +55 -51
  458. data/spec/integration/retryable_writes/retryable_writes_40_and_newer_spec.rb +401 -0
  459. data/spec/integration/retryable_writes/shared/adds_diagnostics.rb +15 -0
  460. data/spec/integration/retryable_writes/shared/does_not_support_retries.rb +24 -0
  461. data/spec/integration/retryable_writes/shared/only_supports_legacy_retries.rb +25 -0
  462. data/spec/integration/retryable_writes/shared/performs_legacy_retries.rb +215 -0
  463. data/spec/integration/retryable_writes/shared/performs_modern_retries.rb +232 -0
  464. data/spec/integration/retryable_writes/shared/performs_no_retries.rb +110 -0
  465. data/spec/integration/retryable_writes/shared/supports_legacy_retries.rb +19 -0
  466. data/spec/integration/retryable_writes/shared/supports_modern_retries.rb +25 -0
  467. data/spec/integration/retryable_writes/shared/supports_retries.rb +16 -0
  468. data/spec/integration/sdam_error_handling_spec.rb +142 -22
  469. data/spec/integration/sdam_events_spec.rb +77 -5
  470. data/spec/integration/sdam_prose_spec.rb +64 -0
  471. data/spec/integration/server_monitor_spec.rb +25 -1
  472. data/spec/integration/server_spec.rb +42 -26
  473. data/spec/integration/size_limit_spec.rb +22 -23
  474. data/spec/integration/ssl_uri_options_spec.rb +2 -2
  475. data/spec/integration/step_down_spec.rb +15 -15
  476. data/spec/integration/transactions_api_examples_spec.rb +59 -0
  477. data/spec/integration/transactions_examples_spec.rb +5 -2
  478. data/spec/integration/x509_auth_spec.rb +109 -0
  479. data/spec/kerberos/kerberos_spec.rb +10 -6
  480. data/spec/lite_spec_helper.rb +31 -22
  481. data/spec/mongo/address/ipv4_spec.rb +1 -1
  482. data/spec/mongo/address_spec.rb +2 -2
  483. data/spec/mongo/auth/aws/request_region_spec.rb +42 -0
  484. data/spec/mongo/auth/aws/request_spec.rb +76 -0
  485. data/spec/mongo/auth/cr_spec.rb +7 -7
  486. data/spec/mongo/auth/gssapi/conversation_spec.rb +121 -0
  487. data/spec/mongo/auth/invalid_mechanism_spec.rb +1 -1
  488. data/spec/mongo/auth/ldap/conversation_spec.rb +1 -1
  489. data/spec/mongo/auth/ldap_spec.rb +3 -3
  490. data/spec/mongo/auth/scram/conversation_spec.rb +119 -334
  491. data/spec/mongo/auth/scram256/conversation_spec.rb +171 -0
  492. data/spec/mongo/auth/{scram/negotiation_spec.rb → scram_negotiation_spec.rb} +13 -8
  493. data/spec/mongo/auth/scram_spec.rb +29 -69
  494. data/spec/mongo/auth/user_spec.rb +1 -1
  495. data/spec/mongo/auth/x509/conversation_spec.rb +1 -1
  496. data/spec/mongo/auth/x509_spec.rb +8 -8
  497. data/spec/mongo/auth_spec.rb +4 -4
  498. data/spec/mongo/bulk_write_spec.rb +206 -2
  499. data/spec/mongo/client_construction_spec.rb +609 -86
  500. data/spec/mongo/client_spec.rb +59 -5
  501. data/spec/mongo/cluster/topology/replica_set_spec.rb +52 -9
  502. data/spec/mongo/cluster/topology/single_spec.rb +4 -2
  503. data/spec/mongo/cluster_spec.rb +37 -36
  504. data/spec/mongo/collection/view/aggregation_spec.rb +6 -2
  505. data/spec/mongo/collection/view/builder/find_command_spec.rb +17 -6
  506. data/spec/mongo/collection/view/change_stream_resume_spec.rb +392 -0
  507. data/spec/mongo/collection/view/change_stream_spec.rb +0 -318
  508. data/spec/mongo/collection/view/iterable_spec.rb +38 -0
  509. data/spec/mongo/collection/view/map_reduce_spec.rb +6 -2
  510. data/spec/mongo/collection/view/readable_spec.rb +15 -1
  511. data/spec/mongo/collection/view/writable_spec.rb +208 -1
  512. data/spec/mongo/collection_spec.rb +507 -43
  513. data/spec/mongo/cursor/builder/get_more_command_spec.rb +6 -1
  514. data/spec/mongo/cursor/builder/op_get_more_spec.rb +6 -1
  515. data/spec/mongo/cursor/builder/op_kill_cursors_spec.rb +6 -1
  516. data/spec/mongo/cursor_spec.rb +9 -1
  517. data/spec/mongo/database_spec.rb +251 -10
  518. data/spec/mongo/distinguishing_semaphore_spec.rb +63 -0
  519. data/spec/mongo/error/operation_failure_heavy_spec.rb +58 -0
  520. data/spec/mongo/error/operation_failure_spec.rb +167 -69
  521. data/spec/mongo/error/unsupported_option_spec.rb +54 -0
  522. data/spec/mongo/grid/fs_bucket_spec.rb +18 -0
  523. data/spec/mongo/grid/stream/write_spec.rb +32 -0
  524. data/spec/mongo/index/view_spec.rb +312 -0
  525. data/spec/mongo/monitoring/event/server_description_changed_spec.rb +1 -4
  526. data/spec/mongo/operation/aggregate/result_spec.rb +6 -1
  527. data/spec/mongo/operation/delete/bulk_spec.rb +18 -6
  528. data/spec/mongo/operation/delete/op_msg_spec.rb +22 -14
  529. data/spec/mongo/operation/find/legacy_spec.rb +27 -7
  530. data/spec/mongo/operation/get_more_spec.rb +6 -1
  531. data/spec/mongo/operation/insert/bulk_spec.rb +21 -7
  532. data/spec/mongo/operation/insert/command_spec.rb +4 -0
  533. data/spec/mongo/operation/insert/op_msg_spec.rb +22 -14
  534. data/spec/mongo/operation/limited_spec.rb +5 -3
  535. data/spec/mongo/operation/read_preference_legacy_spec.rb +16 -4
  536. data/spec/mongo/operation/read_preference_op_msg_spec.rb +115 -5
  537. data/spec/mongo/operation/result_spec.rb +6 -1
  538. data/spec/mongo/operation/update/bulk_spec.rb +18 -6
  539. data/spec/mongo/operation/update/command_spec.rb +4 -0
  540. data/spec/mongo/operation/update/op_msg_spec.rb +22 -14
  541. data/spec/mongo/protocol/msg_spec.rb +10 -0
  542. data/spec/mongo/retryable_spec.rb +71 -70
  543. data/spec/mongo/semaphore_spec.rb +51 -0
  544. data/spec/mongo/server/app_metadata_shared.rb +136 -0
  545. data/spec/mongo/server/app_metadata_spec.rb +8 -1
  546. data/spec/mongo/server/connection_auth_spec.rb +33 -14
  547. data/spec/mongo/server/connection_pool_spec.rb +0 -31
  548. data/spec/mongo/server/connection_spec.rb +118 -71
  549. data/spec/mongo/server/monitor/app_metadata_spec.rb +8 -1
  550. data/spec/mongo/server/monitor/connection_spec.rb +1 -82
  551. data/spec/mongo/server/monitor_spec.rb +76 -17
  552. data/spec/mongo/server/round_trip_time_averager_spec.rb +5 -3
  553. data/spec/mongo/server_selector/nearest_spec.rb +24 -23
  554. data/spec/mongo/server_selector/primary_preferred_spec.rb +27 -26
  555. data/spec/mongo/server_selector/primary_spec.rb +27 -9
  556. data/spec/mongo/server_selector/secondary_preferred_spec.rb +40 -23
  557. data/spec/mongo/server_selector/secondary_spec.rb +19 -18
  558. data/spec/mongo/server_selector_spec.rb +4 -5
  559. data/spec/mongo/session/session_pool_spec.rb +7 -3
  560. data/spec/mongo/session_spec.rb +35 -0
  561. data/spec/mongo/socket/ssl_spec.rb +2 -2
  562. data/spec/mongo/socket/tcp_spec.rb +2 -2
  563. data/spec/mongo/socket/unix_spec.rb +2 -2
  564. data/spec/mongo/socket_spec.rb +9 -9
  565. data/spec/mongo/timeout_spec.rb +22 -68
  566. data/spec/mongo/uri_spec.rb +21 -6
  567. data/spec/runners/auth.rb +5 -6
  568. data/spec/runners/change_streams/outcome.rb +42 -0
  569. data/spec/runners/change_streams/spec.rb +57 -0
  570. data/spec/runners/change_streams/test.rb +229 -0
  571. data/spec/runners/cmap.rb +1 -1
  572. data/spec/runners/cmap/verifier.rb +1 -1
  573. data/spec/runners/command_monitoring.rb +4 -35
  574. data/spec/runners/connection_string.rb +3 -2
  575. data/spec/runners/crud.rb +2 -2
  576. data/spec/runners/crud/context.rb +10 -6
  577. data/spec/runners/crud/operation.rb +177 -55
  578. data/spec/runners/crud/outcome.rb +1 -1
  579. data/spec/runners/crud/spec.rb +0 -7
  580. data/spec/runners/crud/test.rb +8 -26
  581. data/spec/runners/crud/test_base.rb +47 -0
  582. data/spec/runners/crud/verifier.rb +21 -3
  583. data/spec/runners/gridfs.rb +1 -1
  584. data/spec/runners/{server_discovery_and_monitoring.rb → sdam.rb} +41 -22
  585. data/spec/runners/sdam/verifier.rb +26 -8
  586. data/spec/runners/server_selection.rb +242 -28
  587. data/spec/runners/transactions.rb +13 -14
  588. data/spec/runners/transactions/operation.rb +155 -25
  589. data/spec/runners/transactions/spec.rb +1 -1
  590. data/spec/runners/transactions/test.rb +103 -65
  591. data/spec/spec_tests/auth_spec.rb +2 -0
  592. data/spec/spec_tests/change_streams_spec.rb +39 -4
  593. data/spec/spec_tests/client_side_encryption_spec.rb +3 -0
  594. data/spec/spec_tests/cmap_spec.rb +5 -0
  595. data/spec/spec_tests/command_monitoring_spec.rb +25 -12
  596. data/spec/spec_tests/connection_string_spec.rb +2 -0
  597. data/spec/spec_tests/crud_spec.rb +3 -1
  598. data/spec/spec_tests/data/auth/connection-string.yml +57 -1
  599. data/spec/spec_tests/data/change_streams/change-streams-errors.yml +27 -1
  600. data/spec/spec_tests/data/change_streams/change-streams-resume-errorLabels.yml +1105 -0
  601. data/spec/spec_tests/data/change_streams/change-streams-resume-whitelist.yml +1173 -0
  602. data/spec/spec_tests/data/change_streams/change-streams.yml +5 -4
  603. data/spec/spec_tests/data/crud_v2/aggregate-merge.yml +1 -1
  604. data/spec/spec_tests/data/crud_v2/bulkWrite-arrayFilters.yml +33 -11
  605. data/spec/spec_tests/data/crud_v2/bulkWrite-delete-hint-clientError.yml +63 -0
  606. data/spec/spec_tests/data/crud_v2/bulkWrite-delete-hint-serverError.yml +92 -0
  607. data/spec/spec_tests/data/crud_v2/bulkWrite-delete-hint.yml +103 -0
  608. data/spec/spec_tests/data/crud_v2/bulkWrite-update-hint-clientError.yml +90 -0
  609. data/spec/spec_tests/data/crud_v2/bulkWrite-update-hint-serverError.yml +147 -0
  610. data/spec/spec_tests/data/crud_v2/bulkWrite-update-hint.yml +164 -0
  611. data/spec/spec_tests/data/crud_v2/deleteMany-hint-clientError.yml +43 -0
  612. data/spec/spec_tests/data/crud_v2/deleteMany-hint-serverError.yml +62 -0
  613. data/spec/spec_tests/data/crud_v2/deleteMany-hint.yml +58 -0
  614. data/spec/spec_tests/data/crud_v2/deleteOne-hint-clientError.yml +41 -0
  615. data/spec/spec_tests/data/crud_v2/deleteOne-hint-serverError.yml +60 -0
  616. data/spec/spec_tests/data/crud_v2/deleteOne-hint.yml +57 -0
  617. data/spec/spec_tests/data/crud_v2/find-allowdiskuse-clientError.yml +28 -0
  618. data/spec/spec_tests/data/crud_v2/find-allowdiskuse-serverError.yml +44 -0
  619. data/spec/spec_tests/data/crud_v2/find-allowdiskuse.yml +50 -0
  620. data/spec/spec_tests/data/crud_v2/findOneAndDelete-hint-clientError.yml +45 -0
  621. data/spec/spec_tests/data/crud_v2/findOneAndDelete-hint-serverError.yml +60 -0
  622. data/spec/spec_tests/data/crud_v2/findOneAndDelete-hint.yml +56 -0
  623. data/spec/spec_tests/data/crud_v2/findOneAndReplace-hint-clientError.yml +40 -0
  624. data/spec/spec_tests/data/crud_v2/findOneAndReplace-hint-serverError.yml +59 -0
  625. data/spec/spec_tests/data/crud_v2/findOneAndReplace-hint.yml +55 -0
  626. data/spec/spec_tests/data/crud_v2/findOneAndUpdate-hint-clientError.yml +40 -0
  627. data/spec/spec_tests/data/crud_v2/findOneAndUpdate-hint-serverError.yml +58 -0
  628. data/spec/spec_tests/data/crud_v2/findOneAndUpdate-hint.yml +55 -0
  629. data/spec/spec_tests/data/crud_v2/replaceOne-hint.yml +61 -0
  630. data/spec/spec_tests/data/crud_v2/unacknowledged-bulkWrite-delete-hint-clientError.yml +60 -0
  631. data/spec/spec_tests/data/crud_v2/unacknowledged-bulkWrite-update-hint-clientError.yml +88 -0
  632. data/spec/spec_tests/data/crud_v2/unacknowledged-deleteMany-hint-clientError.yml +40 -0
  633. data/spec/spec_tests/data/crud_v2/unacknowledged-deleteOne-hint-clientError.yml +38 -0
  634. data/spec/spec_tests/data/crud_v2/unacknowledged-findOneAndDelete-hint-clientError.yml +42 -0
  635. data/spec/spec_tests/data/crud_v2/unacknowledged-findOneAndReplace-hint-clientError.yml +40 -0
  636. data/spec/spec_tests/data/crud_v2/unacknowledged-findOneAndUpdate-hint-clientError.yml +40 -0
  637. data/spec/spec_tests/data/crud_v2/unacknowledged-replaceOne-hint-clientError.yml +40 -0
  638. data/spec/spec_tests/data/crud_v2/unacknowledged-updateMany-hint-clientError.yml +43 -0
  639. data/spec/spec_tests/data/crud_v2/unacknowledged-updateOne-hint-clientError.yml +40 -0
  640. data/spec/spec_tests/data/crud_v2/updateMany-hint-clientError.yml +45 -0
  641. data/spec/spec_tests/data/crud_v2/updateMany-hint-serverError.yml +66 -0
  642. data/spec/spec_tests/data/crud_v2/updateMany-hint.yml +65 -0
  643. data/spec/spec_tests/data/crud_v2/updateOne-hint-clientError.yml +43 -0
  644. data/spec/spec_tests/data/crud_v2/updateOne-hint-serverError.yml +62 -0
  645. data/spec/spec_tests/data/crud_v2/updateOne-hint.yml +61 -0
  646. data/spec/spec_tests/data/crud_v2/updateWithPipelines.yml +65 -0
  647. data/spec/spec_tests/data/dns_seedlist_discovery/direct-connection-false.yml +10 -0
  648. data/spec/spec_tests/data/dns_seedlist_discovery/direct-connection-true.yml +5 -0
  649. data/spec/spec_tests/data/max_staleness/ReplicaSetNoPrimary/MaxStalenessTooSmall.yml +15 -0
  650. data/spec/spec_tests/data/max_staleness/ReplicaSetNoPrimary/NoKnownServers.yml +4 -3
  651. data/spec/spec_tests/data/max_staleness/Unknown/SmallMaxStaleness.yml +1 -0
  652. data/spec/spec_tests/data/read_write_concern/operation/default-write-concern-2.6.yml +215 -0
  653. data/spec/spec_tests/data/read_write_concern/operation/default-write-concern-3.2.yml +58 -0
  654. data/spec/spec_tests/data/read_write_concern/operation/default-write-concern-3.4.yml +95 -0
  655. data/spec/spec_tests/data/read_write_concern/operation/default-write-concern-4.2.yml +36 -0
  656. data/spec/spec_tests/data/retryable_writes/bulkWrite-errorLabels.yml +77 -0
  657. data/spec/spec_tests/data/retryable_writes/bulkWrite-serverErrors.yml +37 -0
  658. data/spec/spec_tests/data/retryable_writes/deleteOne-errorLabels.yml +48 -0
  659. data/spec/spec_tests/data/retryable_writes/deleteOne-serverErrors.yml +22 -0
  660. data/spec/spec_tests/data/retryable_writes/findOneAndDelete-errorLabels.yml +49 -0
  661. data/spec/spec_tests/data/retryable_writes/findOneAndDelete-serverErrors.yml +23 -0
  662. data/spec/spec_tests/data/retryable_writes/findOneAndReplace-errorLabels.yml +52 -0
  663. data/spec/spec_tests/data/retryable_writes/findOneAndReplace-serverErrors.yml +25 -0
  664. data/spec/spec_tests/data/retryable_writes/findOneAndUpdate-errorLabels.yml +52 -0
  665. data/spec/spec_tests/data/retryable_writes/findOneAndUpdate-serverErrors.yml +24 -0
  666. data/spec/spec_tests/data/retryable_writes/insertMany-errorLabels.yml +54 -0
  667. data/spec/spec_tests/data/retryable_writes/insertMany-serverErrors.yml +24 -0
  668. data/spec/spec_tests/data/retryable_writes/insertOne-errorLabels.yml +44 -0
  669. data/spec/spec_tests/data/retryable_writes/insertOne-serverErrors.yml +69 -0
  670. data/spec/spec_tests/data/retryable_writes/replaceOne-errorLabels.yml +53 -0
  671. data/spec/spec_tests/data/retryable_writes/replaceOne-serverErrors.yml +23 -0
  672. data/spec/spec_tests/data/retryable_writes/updateOne-errorLabels.yml +53 -0
  673. data/spec/spec_tests/data/retryable_writes/updateOne-serverErrors.yml +23 -0
  674. data/spec/spec_tests/data/sdam/errors/error_handling_handshake.yml +54 -0
  675. data/spec/spec_tests/data/sdam/errors/non-stale-network-error.yml +46 -0
  676. data/spec/spec_tests/data/sdam/errors/non-stale-network-timeout-error.yml +37 -0
  677. data/spec/spec_tests/data/sdam/errors/non-stale-topologyVersion-greater-InterruptedAtShutdown.yml +60 -0
  678. data/spec/spec_tests/data/sdam/errors/non-stale-topologyVersion-greater-InterruptedDueToReplStateChange.yml +60 -0
  679. data/spec/spec_tests/data/sdam/errors/non-stale-topologyVersion-greater-NotMaster.yml +60 -0
  680. data/spec/spec_tests/data/sdam/errors/non-stale-topologyVersion-greater-NotMasterNoSlaveOk.yml +60 -0
  681. data/spec/spec_tests/data/sdam/errors/non-stale-topologyVersion-greater-NotMasterOrSecondary.yml +60 -0
  682. data/spec/spec_tests/data/sdam/errors/non-stale-topologyVersion-greater-PrimarySteppedDown.yml +60 -0
  683. data/spec/spec_tests/data/sdam/errors/non-stale-topologyVersion-greater-ShutdownInProgress.yml +60 -0
  684. data/spec/spec_tests/data/sdam/errors/non-stale-topologyVersion-missing-InterruptedAtShutdown.yml +51 -0
  685. data/spec/spec_tests/data/sdam/errors/non-stale-topologyVersion-missing-InterruptedDueToReplStateChange.yml +51 -0
  686. data/spec/spec_tests/data/sdam/errors/non-stale-topologyVersion-missing-NotMaster.yml +51 -0
  687. data/spec/spec_tests/data/sdam/errors/non-stale-topologyVersion-missing-NotMasterNoSlaveOk.yml +51 -0
  688. data/spec/spec_tests/data/sdam/errors/non-stale-topologyVersion-missing-NotMasterOrSecondary.yml +51 -0
  689. data/spec/spec_tests/data/sdam/errors/non-stale-topologyVersion-missing-PrimarySteppedDown.yml +51 -0
  690. data/spec/spec_tests/data/sdam/errors/non-stale-topologyVersion-missing-ShutdownInProgress.yml +51 -0
  691. data/spec/spec_tests/data/sdam/errors/non-stale-topologyVersion-proccessId-changed-InterruptedAtShutdown.yml +60 -0
  692. data/spec/spec_tests/data/sdam/errors/non-stale-topologyVersion-proccessId-changed-InterruptedDueToReplStateChange.yml +60 -0
  693. data/spec/spec_tests/data/sdam/errors/non-stale-topologyVersion-proccessId-changed-NotMaster.yml +60 -0
  694. data/spec/spec_tests/data/sdam/errors/non-stale-topologyVersion-proccessId-changed-NotMasterNoSlaveOk.yml +60 -0
  695. data/spec/spec_tests/data/sdam/errors/non-stale-topologyVersion-proccessId-changed-NotMasterOrSecondary.yml +60 -0
  696. data/spec/spec_tests/data/sdam/errors/non-stale-topologyVersion-proccessId-changed-PrimarySteppedDown.yml +60 -0
  697. data/spec/spec_tests/data/sdam/errors/non-stale-topologyVersion-proccessId-changed-ShutdownInProgress.yml +60 -0
  698. data/spec/spec_tests/data/sdam/errors/post-42-InterruptedAtShutdown.yml +46 -0
  699. data/spec/spec_tests/data/sdam/errors/post-42-InterruptedDueToReplStateChange.yml +46 -0
  700. data/spec/spec_tests/data/sdam/errors/post-42-NotMaster.yml +46 -0
  701. data/spec/spec_tests/data/sdam/errors/post-42-NotMasterNoSlaveOk.yml +46 -0
  702. data/spec/spec_tests/data/sdam/errors/post-42-NotMasterOrSecondary.yml +46 -0
  703. data/spec/spec_tests/data/sdam/errors/post-42-PrimarySteppedDown.yml +46 -0
  704. data/spec/spec_tests/data/sdam/errors/post-42-ShutdownInProgress.yml +46 -0
  705. data/spec/spec_tests/data/sdam/errors/pre-42-InterruptedAtShutdown.yml +46 -0
  706. data/spec/spec_tests/data/sdam/errors/pre-42-InterruptedDueToReplStateChange.yml +46 -0
  707. data/spec/spec_tests/data/sdam/errors/pre-42-NotMaster.yml +46 -0
  708. data/spec/spec_tests/data/sdam/errors/pre-42-NotMasterNoSlaveOk.yml +46 -0
  709. data/spec/spec_tests/data/sdam/errors/pre-42-NotMasterOrSecondary.yml +46 -0
  710. data/spec/spec_tests/data/sdam/errors/pre-42-PrimarySteppedDown.yml +46 -0
  711. data/spec/spec_tests/data/sdam/errors/pre-42-ShutdownInProgress.yml +46 -0
  712. data/spec/spec_tests/data/sdam/errors/stale-generation-InterruptedAtShutdown.yml +89 -0
  713. data/spec/spec_tests/data/sdam/errors/stale-generation-InterruptedDueToReplStateChange.yml +89 -0
  714. data/spec/spec_tests/data/sdam/errors/stale-generation-NotMaster.yml +89 -0
  715. data/spec/spec_tests/data/sdam/errors/stale-generation-NotMasterNoSlaveOk.yml +89 -0
  716. data/spec/spec_tests/data/sdam/errors/stale-generation-NotMasterOrSecondary.yml +89 -0
  717. data/spec/spec_tests/data/sdam/errors/stale-generation-PrimarySteppedDown.yml +89 -0
  718. data/spec/spec_tests/data/sdam/errors/stale-generation-ShutdownInProgress.yml +89 -0
  719. data/spec/spec_tests/data/sdam/errors/stale-generation-afterHandshakeCompletes-InterruptedAtShutdown.yml +89 -0
  720. data/spec/spec_tests/data/sdam/errors/stale-generation-afterHandshakeCompletes-InterruptedDueToReplStateChange.yml +89 -0
  721. data/spec/spec_tests/data/sdam/errors/stale-generation-afterHandshakeCompletes-NotMaster.yml +89 -0
  722. data/spec/spec_tests/data/sdam/errors/stale-generation-afterHandshakeCompletes-NotMasterNoSlaveOk.yml +89 -0
  723. data/spec/spec_tests/data/sdam/errors/stale-generation-afterHandshakeCompletes-NotMasterOrSecondary.yml +89 -0
  724. data/spec/spec_tests/data/sdam/errors/stale-generation-afterHandshakeCompletes-PrimarySteppedDown.yml +89 -0
  725. data/spec/spec_tests/data/sdam/errors/stale-generation-afterHandshakeCompletes-ShutdownInProgress.yml +89 -0
  726. data/spec/spec_tests/data/sdam/errors/stale-generation-afterHandshakeCompletes-network.yml +80 -0
  727. data/spec/spec_tests/data/sdam/errors/stale-generation-afterHandshakeCompletes-timeout.yml +80 -0
  728. data/spec/spec_tests/data/sdam/errors/stale-generation-beforeHandshakeCompletes-InterruptedAtShutdown.yml +89 -0
  729. data/spec/spec_tests/data/sdam/errors/stale-generation-beforeHandshakeCompletes-InterruptedDueToReplStateChange.yml +89 -0
  730. data/spec/spec_tests/data/sdam/errors/stale-generation-beforeHandshakeCompletes-NotMaster.yml +89 -0
  731. data/spec/spec_tests/data/sdam/errors/stale-generation-beforeHandshakeCompletes-NotMasterNoSlaveOk.yml +89 -0
  732. data/spec/spec_tests/data/sdam/errors/stale-generation-beforeHandshakeCompletes-NotMasterOrSecondary.yml +89 -0
  733. data/spec/spec_tests/data/sdam/errors/stale-generation-beforeHandshakeCompletes-PrimarySteppedDown.yml +89 -0
  734. data/spec/spec_tests/data/sdam/errors/stale-generation-beforeHandshakeCompletes-ShutdownInProgress.yml +89 -0
  735. data/spec/spec_tests/data/sdam/errors/stale-generation-beforeHandshakeCompletes-network.yml +80 -0
  736. data/spec/spec_tests/data/sdam/errors/stale-generation-beforeHandshakeCompletes-timeout.yml +80 -0
  737. data/spec/spec_tests/data/sdam/errors/stale-topologyVersion-InterruptedAtShutdown.yml +64 -0
  738. data/spec/spec_tests/data/sdam/errors/stale-topologyVersion-InterruptedDueToReplStateChange.yml +64 -0
  739. data/spec/spec_tests/data/sdam/errors/stale-topologyVersion-NotMaster.yml +64 -0
  740. data/spec/spec_tests/data/sdam/errors/stale-topologyVersion-NotMasterNoSlaveOk.yml +64 -0
  741. data/spec/spec_tests/data/sdam/errors/stale-topologyVersion-NotMasterOrSecondary.yml +64 -0
  742. data/spec/spec_tests/data/sdam/errors/stale-topologyVersion-PrimarySteppedDown.yml +64 -0
  743. data/spec/spec_tests/data/sdam/errors/stale-topologyVersion-ShutdownInProgress.yml +64 -0
  744. data/spec/spec_tests/data/sdam/rs/compatible.yml +2 -0
  745. data/spec/spec_tests/data/sdam/rs/compatible_unknown.yml +2 -0
  746. data/spec/spec_tests/data/sdam/rs/discover_arbiters.yml +2 -2
  747. data/spec/spec_tests/data/sdam/rs/discover_arbiters_replicaset.yml +43 -0
  748. data/spec/spec_tests/data/sdam/rs/discover_ghost.yml +35 -0
  749. data/spec/spec_tests/data/sdam/rs/{ghost_discovered.yml → discover_ghost_replicaset.yml} +1 -1
  750. data/spec/spec_tests/data/sdam/rs/discover_hidden.yml +50 -0
  751. data/spec/spec_tests/data/sdam/rs/discover_hidden_replicaset.yml +50 -0
  752. data/spec/spec_tests/data/sdam/rs/discover_passives.yml +2 -2
  753. data/spec/spec_tests/data/sdam/rs/discover_passives_replicaset.yml +81 -0
  754. data/spec/spec_tests/data/sdam/rs/discover_primary.yml +2 -2
  755. data/spec/spec_tests/data/sdam/rs/discover_primary_replicaset.yml +42 -0
  756. data/spec/spec_tests/data/sdam/rs/discover_rsother.yml +49 -0
  757. data/spec/spec_tests/data/sdam/rs/{rsother_discovered.yml → discover_rsother_replicaset.yml} +1 -1
  758. data/spec/spec_tests/data/sdam/rs/discover_secondary.yml +2 -2
  759. data/spec/spec_tests/data/sdam/rs/discover_secondary_replicaset.yml +43 -0
  760. data/spec/spec_tests/data/sdam/rs/incompatible_arbiter.yml +2 -0
  761. data/spec/spec_tests/data/sdam/rs/incompatible_ghost.yml +2 -0
  762. data/spec/spec_tests/data/sdam/rs/incompatible_other.yml +2 -0
  763. data/spec/spec_tests/data/sdam/rs/primary_mismatched_me.yml +23 -27
  764. data/spec/spec_tests/data/sdam/rs/primary_to_no_primary_mismatched_me.yml +79 -55
  765. data/spec/spec_tests/data/sdam/rs/replicaset_rsnp.yml +20 -0
  766. data/spec/spec_tests/data/sdam/rs/secondary_mismatched_me.yml +3 -2
  767. data/spec/spec_tests/data/sdam/rs/too_new.yml +2 -0
  768. data/spec/spec_tests/data/sdam/rs/topology_version_equal.yml +66 -0
  769. data/spec/spec_tests/data/sdam/rs/topology_version_greater.yml +189 -0
  770. data/spec/spec_tests/data/sdam/rs/topology_version_less.yml +62 -0
  771. data/spec/spec_tests/data/sdam/sharded/discover_single_mongos.yml +23 -0
  772. data/spec/spec_tests/data/sdam/single/direct_connection_external_ip.yml +1 -1
  773. data/spec/spec_tests/data/sdam/single/direct_connection_mongos.yml +2 -2
  774. data/spec/spec_tests/data/sdam/single/direct_connection_replicaset.yml +22 -0
  775. data/spec/spec_tests/data/sdam/single/direct_connection_rsarbiter.yml +2 -2
  776. data/spec/spec_tests/data/sdam/single/direct_connection_rsprimary.yml +2 -2
  777. data/spec/spec_tests/data/sdam/single/direct_connection_rssecondary.yml +2 -2
  778. data/spec/spec_tests/data/sdam/single/direct_connection_slave.yml +1 -1
  779. data/spec/spec_tests/data/sdam/single/direct_connection_standalone.yml +2 -2
  780. data/spec/spec_tests/data/sdam/single/{unavailable_seed.yml → direct_connection_unavailable_seed.yml} +2 -2
  781. data/spec/spec_tests/data/sdam/single/direct_connection_wrong_set_name.yml +38 -0
  782. data/spec/spec_tests/data/sdam/single/discover_standalone.yml +34 -0
  783. data/spec/spec_tests/data/sdam/single/discover_unavailable_seed.yml +28 -0
  784. data/spec/spec_tests/data/sdam/single/too_old_then_upgraded.yml +46 -0
  785. data/spec/spec_tests/data/sdam_integration/cancel-server-check.yml +96 -0
  786. data/spec/spec_tests/data/sdam_integration/connectTimeoutMS.yml +88 -0
  787. data/spec/spec_tests/data/sdam_integration/find-network-error.yml +83 -0
  788. data/spec/spec_tests/data/sdam_integration/find-shutdown-error.yml +116 -0
  789. data/spec/spec_tests/data/sdam_integration/insert-network-error.yml +86 -0
  790. data/spec/spec_tests/data/sdam_integration/insert-shutdown-error.yml +115 -0
  791. data/spec/spec_tests/data/sdam_integration/isMaster-command-error.yml +168 -0
  792. data/spec/spec_tests/data/sdam_integration/isMaster-network-error.yml +162 -0
  793. data/spec/spec_tests/data/sdam_integration/isMaster-timeout.yml +229 -0
  794. data/spec/spec_tests/data/sdam_integration/rediscover-quickly-after-step-down.yml +87 -0
  795. data/spec/spec_tests/data/transactions/create-collection.yml +131 -0
  796. data/spec/spec_tests/data/transactions/create-index.yml +152 -0
  797. data/spec/spec_tests/data/transactions/error-labels.yml +87 -21
  798. data/spec/spec_tests/data/transactions/mongos-recovery-token.yml +1 -0
  799. data/spec/spec_tests/data/transactions/retryable-abort-errorLabels.yml +124 -0
  800. data/spec/spec_tests/data/transactions/retryable-abort.yml +17 -2
  801. data/spec/spec_tests/data/transactions/retryable-commit-errorLabels.yml +132 -0
  802. data/spec/spec_tests/data/transactions/retryable-commit.yml +24 -9
  803. data/spec/spec_tests/data/uri_options/connection-options.yml +43 -0
  804. data/spec/spec_tests/data/uri_options/ruby-auth-options.yml +12 -0
  805. data/spec/spec_tests/data/uri_options/ruby-connection-options.yml +57 -0
  806. data/spec/spec_tests/dns_seedlist_discovery_spec.rb +3 -1
  807. data/spec/spec_tests/gridfs_spec.rb +2 -0
  808. data/spec/spec_tests/max_staleness_spec.rb +5 -141
  809. data/spec/spec_tests/read_write_concern_connection_string_spec.rb +2 -0
  810. data/spec/spec_tests/read_write_concern_operaton_spec.rb +10 -0
  811. data/spec/spec_tests/retryable_reads_spec.rb +4 -2
  812. data/spec/spec_tests/retryable_writes_spec.rb +8 -1
  813. data/spec/spec_tests/sdam_integration_spec.rb +13 -0
  814. data/spec/spec_tests/sdam_monitoring_spec.rb +3 -2
  815. data/spec/spec_tests/sdam_spec.rb +70 -1
  816. data/spec/spec_tests/server_selection_rtt_spec.rb +2 -0
  817. data/spec/spec_tests/server_selection_spec.rb +5 -115
  818. data/spec/spec_tests/transactions_api_spec.rb +5 -0
  819. data/spec/spec_tests/transactions_spec.rb +5 -0
  820. data/spec/spec_tests/uri_options_spec.rb +2 -0
  821. data/spec/stress/cleanup_spec.rb +58 -0
  822. data/spec/stress/connection_pool_stress_spec.rb +11 -13
  823. data/spec/stress/connection_pool_timing_spec.rb +3 -6
  824. data/spec/stress/fork_reconnect_stress_spec.rb +109 -0
  825. data/spec/support/authorization.rb +1 -11
  826. data/spec/support/aws_utils.rb +62 -0
  827. data/spec/support/aws_utils/base.rb +134 -0
  828. data/spec/support/aws_utils/inspector.rb +224 -0
  829. data/spec/support/aws_utils/orchestrator.rb +370 -0
  830. data/spec/support/aws_utils/provisioner.rb +360 -0
  831. data/spec/support/background_thread_registry.rb +6 -2
  832. data/spec/support/child_process_helper.rb +78 -0
  833. data/spec/support/client_registry.rb +6 -24
  834. data/spec/support/cluster_config.rb +5 -0
  835. data/spec/support/common_shortcuts.rb +43 -0
  836. data/spec/support/constraints.rb +27 -7
  837. data/spec/support/crypt.rb +1 -1
  838. data/spec/support/event_subscriber.rb +184 -84
  839. data/spec/support/keyword_struct.rb +26 -0
  840. data/spec/support/lite_constraints.rb +47 -0
  841. data/spec/support/shared/scram_conversation.rb +100 -0
  842. data/spec/support/shared/server_selector.rb +93 -1
  843. data/spec/support/shared/session.rb +29 -21
  844. data/spec/support/spec_config.rb +76 -21
  845. data/spec/support/spec_organizer.rb +129 -0
  846. data/spec/support/spec_setup.rb +9 -5
  847. data/spec/support/utils.rb +161 -24
  848. metadata +1185 -744
  849. metadata.gz.sig +0 -0
  850. data/lib/mongo/server/connectable.rb +0 -107
  851. data/spec/runners/change_streams.rb +0 -262
  852. data/spec/runners/change_streams/operation.rb +0 -89
  853. data/spec/runners/sdam_monitoring.rb +0 -89
  854. data/spec/spec_tests/data/sdam/sharded/ruby_discovered_single_mongos.yml +0 -27
@@ -1,4 +1,4 @@
1
- # Copyright (C) 2014-2019 MongoDB, Inc.
1
+ # Copyright (C) 2014-2020 MongoDB Inc.
2
2
  #
3
3
  # Licensed under the Apache License, Version 2.0 (the "License");
4
4
  # you may not use this file except in compliance with the License.
@@ -1,4 +1,4 @@
1
- # Copyright (C) 2014-2019 MongoDB, Inc.
1
+ # Copyright (C) 2014-2020 MongoDB Inc.
2
2
  #
3
3
  # Licensed under the Apache License, Version 2.0 (the "License");
4
4
  # you may not use this file except in compliance with the License.
@@ -1,4 +1,4 @@
1
- # Copyright (C) 2014-2019 MongoDB, Inc.
1
+ # Copyright (C) 2014-2020 MongoDB Inc.
2
2
  #
3
3
  # Licensed under the Apache License, Version 2.0 (the "License");
4
4
  # you may not use this file except in compliance with the License.
@@ -1,4 +1,4 @@
1
- # Copyright (C) 2014-2019 MongoDB, Inc.
1
+ # Copyright (C) 2014-2020 MongoDB Inc.
2
2
  #
3
3
  # Licensed under the Apache License, Version 2.0 (the "License");
4
4
  # you may not use this file except in compliance with the License.
@@ -1,4 +1,4 @@
1
- # Copyright (C) 2014-2019 MongoDB, Inc.
1
+ # Copyright (C) 2014-2020 MongoDB Inc.
2
2
  #
3
3
  # Licensed under the Apache License, Version 2.0 (the "License");
4
4
  # you may not use this file except in compliance with the License.
@@ -177,19 +177,10 @@ module Mongo
177
177
  #
178
178
  # @param buffer [String] buffer where the message should be inserted
179
179
  # @return [String] buffer containing the serialized message
180
- def serialize(buffer = BSON::ByteBuffer.new, max_bson_size = nil, bson_overhead = nil)
181
- max_size =
182
- if max_bson_size && bson_overhead
183
- max_bson_size + bson_overhead
184
- elsif max_bson_size
185
- max_bson_size
186
- else
187
- nil
188
- end
189
-
180
+ def serialize(buffer = BSON::ByteBuffer.new, max_bson_size = nil)
190
181
  start = buffer.length
191
182
  serialize_header(buffer)
192
- serialize_fields(buffer, max_size)
183
+ serialize_fields(buffer, max_bson_size)
193
184
  buffer.replace_int32(start, buffer.length - start)
194
185
  end
195
186
 
@@ -208,10 +199,33 @@ module Mongo
208
199
  # @option options [ Boolean ] :deserialize_as_bson Whether to deserialize
209
200
  # this message using BSON types instead of native Ruby types wherever
210
201
  # possible.
202
+ # @option options [ Numeric ] :socket_timeout The timeout to use for
203
+ # each read operation.
211
204
  #
212
205
  # @return [ Message ] Instance of a Message class
213
- def self.deserialize(io, max_message_size = MAX_MESSAGE_SIZE, expected_response_to = nil, options = {})
214
- length, _request_id, response_to, _op_code = deserialize_header(BSON::ByteBuffer.new(io.read(16)))
206
+ #
207
+ # @api private
208
+ def self.deserialize(io,
209
+ max_message_size = MAX_MESSAGE_SIZE,
210
+ expected_response_to = nil,
211
+ options = {}
212
+ )
213
+ # io is usually a Mongo::Socket instance, which supports the
214
+ # timeout option. For compatibility with whoever might call this
215
+ # method with some other IO-like object, pass options only when they
216
+ # are not empty.
217
+ read_options = {}
218
+ if timeout = options[:socket_timeout]
219
+ read_options[:timeout] = timeout
220
+ end
221
+
222
+ if read_options.empty?
223
+ chunk = io.read(16)
224
+ else
225
+ chunk = io.read(16, **read_options)
226
+ end
227
+ buf = BSON::ByteBuffer.new(chunk)
228
+ length, _request_id, response_to, _op_code = deserialize_header(buf)
215
229
 
216
230
  # Protection from potential DOS man-in-the-middle attacks. See
217
231
  # DRIVERS-276.
@@ -225,14 +239,19 @@ module Mongo
225
239
  raise Error::UnexpectedResponse.new(expected_response_to, response_to)
226
240
  end
227
241
 
228
- message = Registry.get(_op_code).allocate
229
- buffer = BSON::ByteBuffer.new(io.read(length - 16))
242
+ if read_options.empty?
243
+ chunk = io.read(length - 16)
244
+ else
245
+ chunk = io.read(length - 16, **read_options)
246
+ end
247
+ buf = BSON::ByteBuffer.new(chunk)
230
248
 
249
+ message = Registry.get(_op_code).allocate
231
250
  message.send(:fields).each do |field|
232
251
  if field[:multi]
233
- deserialize_array(message, buffer, field, options)
252
+ deserialize_array(message, buf, field, options)
234
253
  else
235
- deserialize_field(message, buffer, field, options)
254
+ deserialize_field(message, buf, field, options)
236
255
  end
237
256
  end
238
257
  if message.is_a?(Msg)
@@ -1,4 +1,4 @@
1
- # Copyright (C) 2017-2019 MongoDB, Inc.
1
+ # Copyright (C) 2017-2020 MongoDB Inc.
2
2
  #
3
3
  # Licensed under the Apache License, Version 2.0 (the "License");
4
4
  # you may not use this file except in compliance with the License.
@@ -60,6 +60,13 @@ module Mongo
60
60
  #
61
61
  # @since 2.5.0
62
62
  def initialize(flags, options, main_document, *sequences)
63
+ if flags
64
+ flags.each do |flag|
65
+ unless KNOWN_FLAGS.key?(flag)
66
+ raise ArgumentError, "Unknown flag: #{flag.inspect}"
67
+ end
68
+ end
69
+ end
63
70
  @flags = flags || []
64
71
  @options = options
65
72
  unless main_document.is_a?(Hash)
@@ -139,7 +146,7 @@ module Mongo
139
146
  # @return [ BSON::ByteBuffer ] buffer containing the serialized message.
140
147
  #
141
148
  # @since 2.5.0
142
- def serialize(buffer = BSON::ByteBuffer.new, max_bson_size = nil, bson_overhead = nil)
149
+ def serialize(buffer = BSON::ByteBuffer.new, max_bson_size = nil)
143
150
  validate_document_size!(max_bson_size)
144
151
 
145
152
  super
@@ -197,15 +204,15 @@ module Mongo
197
204
  #
198
205
  # @return [ Mongo::Protocol::Msg ] The encrypted message, or the original
199
206
  # message if encryption was not possible or necessary.
200
- def maybe_encrypt(server, client)
207
+ def maybe_encrypt(connection, client)
201
208
  # TODO verify compression happens later, i.e. when this method runs
202
209
  # the message is not compressed.
203
210
  if client && client.encrypter && client.encrypter.encrypt?
204
- if server.max_wire_version < 8
211
+ if connection.description.max_wire_version < 8
205
212
  raise Error::CryptError.new(
206
213
  "Cannot perform encryption against a MongoDB server older than " +
207
214
  "4.2 (wire version less than 8). Currently connected to server " +
208
- "with max wire version #{server.max_wire_version}} " +
215
+ "with max wire version #{connection.description.max_wire_version}} " +
209
216
  "(Auto-encryption requires a minimum MongoDB version of 4.2)"
210
217
  )
211
218
  end
@@ -332,10 +339,17 @@ module Mongo
332
339
  # @since 2.5.0
333
340
  OP_CODE = 2013
334
341
 
342
+ KNOWN_FLAGS = {
343
+ checksum_present: true,
344
+ more_to_come: true,
345
+ exhaust_allowed: true,
346
+ }
347
+
335
348
  # Available flags for a OP_MSG message.
336
349
  FLAGS = Array.new(16).tap do |arr|
337
350
  arr[0] = :checksum_present
338
351
  arr[1] = :more_to_come
352
+ arr[16] = :exhaust_allowed
339
353
  end.freeze
340
354
 
341
355
  # @!attribute
@@ -1,4 +1,4 @@
1
- # Copyright (C) 2014-2019 MongoDB, Inc.
1
+ # Copyright (C) 2014-2020 MongoDB Inc.
2
2
  #
3
3
  # Licensed under the Apache License, Version 2.0 (the "License");
4
4
  # you may not use this file except in compliance with the License.
@@ -115,48 +115,12 @@ module Mongo
115
115
  compress_if_possible(selector.keys.first, compressor, zlib_compression_level)
116
116
  end
117
117
 
118
- # Serializes message into bytes that can be sent on the wire.
119
- #
120
- # @param [ BSON::ByteBuffer ] buffer where the message should be inserted.
121
- # @param [ Integer ] max_bson_size The maximum bson object size.
122
- #
123
- # @return [ BSON::ByteBuffer ] buffer containing the serialized message.
124
- def serialize(buffer = BSON::ByteBuffer.new, max_bson_size = nil, bson_overhead = nil)
125
- validate_document_size!(max_bson_size)
126
-
127
- super
128
- end
129
-
130
118
  protected
131
119
 
132
120
  attr_reader :upconverter
133
121
 
134
122
  private
135
123
 
136
- # Validate that the documents in this message are all smaller than the
137
- # maxBsonObjectSize. If not, raise an exception.
138
- def validate_document_size!(max_bson_size)
139
- max_bson_size ||= Mongo::Server::ConnectionBase::DEFAULT_MAX_BSON_OBJECT_SIZE
140
-
141
- documents = if @selector.key?(:documents)
142
- @selector[:documents]
143
- elsif @selector.key?(:deletes)
144
- @selector[:deletes]
145
- elsif @selector.key?(:updates)
146
- @selector[:updates]
147
- else
148
- []
149
- end
150
-
151
- contains_too_large_document = documents.any? do |doc|
152
- doc.to_bson.length > max_bson_size
153
- end
154
-
155
- if contains_too_large_document
156
- raise Error::MaxBSONSize.new('The document exceeds maximum allowed BSON object size after serialization')
157
- end
158
- end
159
-
160
124
  # The operation code required to specify a Query message.
161
125
  # @return [Fixnum] the operation code.
162
126
  #
@@ -1,4 +1,4 @@
1
- # Copyright (C) 2009-2019 MongoDB Inc.
1
+ # Copyright (C) 2009-2020 MongoDB Inc.
2
2
  #
3
3
  # Licensed under the Apache License, Version 2.0 (the "License");
4
4
  # you may not use this file except in compliance with the License.
@@ -1,4 +1,4 @@
1
- # Copyright (C) 2014-2019 MongoDB, Inc.
1
+ # Copyright (C) 2014-2020 MongoDB Inc.
2
2
  #
3
3
  # Licensed under the Apache License, Version 2.0 (the "License");
4
4
  # you may not use this file except in compliance with the License.
@@ -1,4 +1,4 @@
1
- # Copyright (C) 2014-2019 MongoDB, Inc.
1
+ # Copyright (C) 2014-2020 MongoDB Inc.
2
2
  #
3
3
  # Licensed under the Apache License, Version 2.0 (the "License");
4
4
  # you may not use this file except in compliance with the License.
@@ -1,4 +1,4 @@
1
- # Copyright (C) 2014-2019 MongoDB, Inc.
1
+ # Copyright (C) 2014-2020 MongoDB Inc.
2
2
  #
3
3
  # Licensed under the Apache License, Version 2.0 (the "License");
4
4
  # you may not use this file except in compliance with the License.
@@ -1,4 +1,4 @@
1
- # Copyright (C) 2015-2019 MongoDB, Inc.
1
+ # Copyright (C) 2015-2020 MongoDB Inc.
2
2
  #
3
3
  # Licensed under the Apache License, Version 2.0 (the "License");
4
4
  # you may not use this file except in compliance with the License.
@@ -221,7 +221,7 @@ module Mongo
221
221
  rescue Error::SocketError, Error::SocketTimeoutError => e
222
222
  e.add_note('modern retry')
223
223
  e.add_note("attempt 1")
224
- if session.in_transaction? && !ending_transaction
224
+ if !e.label?('RetryableWriteError')
225
225
  raise e
226
226
  end
227
227
  retry_write(e, session, txn_num, &block)
@@ -230,7 +230,7 @@ module Mongo
230
230
  e.add_note("attempt 1")
231
231
  if e.unsupported_retryable_write?
232
232
  raise_unsupported_error(e)
233
- elsif (session.in_transaction? && !ending_transaction) || !e.write_retryable?
233
+ elsif !e.label?('RetryableWriteError')
234
234
  raise e
235
235
  end
236
236
 
@@ -298,7 +298,7 @@ module Mongo
298
298
  if attempt > client.max_write_retries
299
299
  raise e
300
300
  end
301
- if e.write_retryable? && !(session && session.in_transaction?)
301
+ if e.label?('RetryableWriteError')
302
302
  log_retry(e, message: 'Legacy write retry')
303
303
  cluster.scan!(false)
304
304
  retry
@@ -381,9 +381,11 @@ module Mongo
381
381
  def retry_read(original_error, server_selector, session, &block)
382
382
  begin
383
383
  server = select_server(cluster, server_selector, session)
384
- rescue => e
384
+ rescue Error, Error::AuthError => e
385
385
  original_error.add_note("later retry failed: #{e.class}: #{e}")
386
- raise original_error
386
+
387
+ # See the corresponding note below in retry_write.
388
+ raise Error::RaiseOriginalError
387
389
  end
388
390
 
389
391
  log_retry(original_error, message: 'Read retry')
@@ -402,11 +404,13 @@ module Mongo
402
404
  end
403
405
  e.add_note("attempt 2")
404
406
  raise e
405
- rescue => e
407
+ rescue Error, Error::AuthError => e
406
408
  e.add_note('modern retry')
407
409
  original_error.add_note("later retry failed: #{e.class}: #{e}")
408
410
  raise original_error
409
411
  end
412
+ rescue Error::RaiseOriginalError
413
+ raise original_error
410
414
  end
411
415
 
412
416
  def retry_write(original_error, session, txn_num, &block)
@@ -420,7 +424,14 @@ module Mongo
420
424
  # Do not need to add "modern retry" here, it should already be on
421
425
  # the first exception.
422
426
  original_error.add_note('did not retry because server selected for retry does not supoprt retryable writes')
423
- raise original_error
427
+
428
+ # When we want to raise the original error, we must not run the
429
+ # rescue blocks below that add diagnostics because the diagnostics
430
+ # added would either be rendundant (e.g. modern retry note) or wrong
431
+ # (e.g. "attempt 2", we are raising the exception produced in the
432
+ # first attempt and haven't attempted the second time). Use the
433
+ # special marker class to bypass the ordinarily applicable rescues.
434
+ raise Error::RaiseOriginalError
424
435
  end
425
436
  log_retry(original_error, message: 'Write retry')
426
437
  yield(server, txn_num, true)
@@ -430,18 +441,20 @@ module Mongo
430
441
  raise e
431
442
  rescue Error::OperationFailure => e
432
443
  e.add_note('modern retry')
433
- if e.write_retryable?
444
+ if e.label?('RetryableWriteError')
434
445
  e.add_note('attempt 2')
435
446
  raise e
436
447
  else
437
448
  original_error.add_note("later retry failed: #{e.class}: #{e}")
438
449
  raise original_error
439
450
  end
440
- rescue => e
451
+ rescue Error, Error::AuthError => e
441
452
  # Do not need to add "modern retry" here, it should already be on
442
453
  # the first exception.
443
454
  original_error.add_note("later retry failed: #{e.class}: #{e}")
444
455
  raise original_error
456
+ rescue Error::RaiseOriginalError
457
+ raise original_error
445
458
  end
446
459
 
447
460
  # This is a separate method to make it possible for the test suite to
@@ -1,4 +1,4 @@
1
- # Copyright (C) 2018-2019 MongoDB, Inc.
1
+ # Copyright (C) 2018-2020 MongoDB Inc.
2
2
  #
3
3
  # Licensed under the Apache License, Version 2.0 (the "License");
4
4
  # you may not use this file except in compliance with the License.
data/lib/mongo/server.rb CHANGED
@@ -1,4 +1,4 @@
1
- # Copyright (C) 2014-2019 MongoDB, Inc.
1
+ # Copyright (C) 2014-2020 MongoDB Inc.
2
2
  #
3
3
  # Licensed under the Apache License, Version 2.0 (the "License");
4
4
  # you may not use this file except in compliance with the License.
@@ -64,7 +64,7 @@ module Mongo
64
64
  @connection_id_gen = Class.new do
65
65
  include Id
66
66
  end
67
- @scan_semaphore = Semaphore.new
67
+ @scan_semaphore = DistinguishingSemaphore.new
68
68
  @round_trip_time_averager = RoundTripTimeAverager.new
69
69
  @description = Description.new(address, {})
70
70
  @last_scan = nil
@@ -72,6 +72,7 @@ module Mongo
72
72
  @monitor = Monitor.new(self, event_listeners, monitoring,
73
73
  options.merge(
74
74
  app_metadata: Monitor::AppMetadata.new(cluster.options),
75
+ heartbeat_interval: cluster.heartbeat_interval,
75
76
  ))
76
77
  unless _monitor == false
77
78
  start_monitoring
@@ -121,6 +122,8 @@ module Mongo
121
122
  # @deprecated
122
123
  alias :heartbeat_frequency_seconds :heartbeat_frequency
123
124
 
125
+ # Performs an immediate, synchronous check of the server.
126
+ #
124
127
  # @deprecated
125
128
  def_delegators :monitor, :scan!
126
129
 
@@ -428,8 +431,8 @@ module Mongo
428
431
  # @api private
429
432
  def handle_handshake_failure!
430
433
  yield
431
- rescue Mongo::Error::SocketError, Mongo::Error::SocketTimeoutError
432
- unknown!
434
+ rescue Mongo::Error::SocketError, Mongo::Error::SocketTimeoutError => e
435
+ unknown!(generation: e.generation, stop_push_monitor: true)
433
436
  raise
434
437
  end
435
438
 
@@ -450,9 +453,9 @@ module Mongo
450
453
  rescue Mongo::Error::SocketTimeoutError
451
454
  # possibly cluster is slow, do not give up on it
452
455
  raise
453
- rescue Mongo::Error::SocketError
456
+ rescue Mongo::Error::SocketError => e
454
457
  # non-timeout network error
455
- unknown!
458
+ unknown!(generation: e.generation, stop_push_monitor: true)
456
459
  raise
457
460
  rescue Auth::Unauthorized
458
461
  # auth error, keep server description and topology as they are
@@ -485,19 +488,48 @@ module Mongo
485
488
  # Marks server unknown and publishes the associated SDAM event
486
489
  # (server description changed).
487
490
  #
491
+ # If the generation is passed in options, the server will only be marked
492
+ # unknown if the passed generation is no older than the current generation
493
+ # of the server's connection pool.
494
+ #
488
495
  # @param [ Hash ] options Options.
489
496
  #
497
+ # @option options [ Integer ] :generation Connection pool generation of
498
+ # the connection that was used for the operation that produced the error.
490
499
  # @option options [ true | false ] :keep_connection_pool Usually when the
491
500
  # new server description is unknown, the connection pool on the
492
501
  # respective server is cleared. Set this option to true to keep the
493
502
  # existing connection pool (required when handling not master errors
494
503
  # on 4.2+ servers).
504
+ # @option options [ TopologyVersion ] :topology_version Topology version
505
+ # of the error response that is causing the server to be marked unknown.
506
+ # @option options [ true | false ] :stop_push_monitor Whether to stop
507
+ # the PushMonitor associated with the server, if any.
495
508
  #
496
509
  # @since 2.4.0, SDAM events are sent as of version 2.7.0
497
510
  def unknown!(options = {})
511
+ if options[:generation] && options[:generation] < pool.generation
512
+ return
513
+ end
514
+
515
+ if options[:topology_version] && description.topology_version &&
516
+ !options[:topology_version].gt?(description.topology_version)
517
+ then
518
+ return
519
+ end
520
+
521
+ if options[:stop_push_monitor]
522
+ monitor&.stop_push_monitor!
523
+ end
524
+
498
525
  # SDAM flow will update description on the server without in-place
499
526
  # mutations and invoke SDAM transitions as needed.
500
- cluster.run_sdam_flow(description, Description.new(address), options)
527
+ config = {}
528
+ if options[:topology_version]
529
+ config['topologyVersion'] = options[:topology_version]
530
+ end
531
+ new_description = Description.new(address, config)
532
+ cluster.run_sdam_flow(description, new_description, options)
501
533
  end
502
534
 
503
535
  # @api private
@@ -527,7 +559,6 @@ module Mongo
527
559
  end
528
560
 
529
561
  require 'mongo/server/app_metadata'
530
- require 'mongo/server/connectable'
531
562
  require 'mongo/server/connection_common'
532
563
  require 'mongo/server/connection_base'
533
564
  require 'mongo/server/pending_connection'
@@ -537,3 +568,4 @@ require 'mongo/server/context'
537
568
  require 'mongo/server/description'
538
569
  require 'mongo/server/monitor'
539
570
  require 'mongo/server/round_trip_time_averager'
571
+ require 'mongo/server/push_monitor'