mongo 2.14.0 → 2.15.1

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