mongo 2.17.1 → 2.18.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (692) hide show
  1. checksums.yaml +4 -4
  2. checksums.yaml.gz.sig +0 -0
  3. data/README.md +21 -37
  4. data/lib/mongo/auth/base.rb +8 -1
  5. data/lib/mongo/auth.rb +12 -1
  6. data/lib/mongo/bulk_write/result.rb +10 -1
  7. data/lib/mongo/bulk_write/result_combiner.rb +2 -4
  8. data/lib/mongo/bulk_write.rb +115 -29
  9. data/lib/mongo/client.rb +133 -17
  10. data/lib/mongo/client_encryption.rb +113 -10
  11. data/lib/mongo/cluster/reapers/cursor_reaper.rb +11 -1
  12. data/lib/mongo/cluster.rb +26 -28
  13. data/lib/mongo/collection/helpers.rb +43 -0
  14. data/lib/mongo/collection/queryable_encryption.rb +122 -0
  15. data/lib/mongo/collection/view/aggregation.rb +22 -16
  16. data/lib/mongo/collection/view/change_stream.rb +65 -23
  17. data/lib/mongo/collection/view/explainable.rb +1 -1
  18. data/lib/mongo/collection/view/iterable.rb +4 -3
  19. data/lib/mongo/collection/view/map_reduce.rb +18 -9
  20. data/lib/mongo/collection/view/readable.rb +29 -25
  21. data/lib/mongo/collection/view/writable.rb +133 -40
  22. data/lib/mongo/collection.rb +117 -49
  23. data/lib/mongo/config/options.rb +62 -0
  24. data/lib/mongo/config/validators/option.rb +26 -0
  25. data/lib/mongo/config.rb +42 -0
  26. data/lib/mongo/crypt/auto_encrypter.rb +136 -14
  27. data/lib/mongo/crypt/binding.rb +513 -144
  28. data/lib/mongo/crypt/context.rb +5 -2
  29. data/lib/mongo/crypt/data_key_context.rb +12 -104
  30. data/lib/mongo/crypt/encryption_io.rb +94 -60
  31. data/lib/mongo/crypt/explicit_encrypter.rb +143 -26
  32. data/lib/mongo/crypt/explicit_encryption_context.rb +25 -2
  33. data/lib/mongo/crypt/handle.rb +160 -86
  34. data/lib/mongo/crypt/hooks.rb +25 -2
  35. data/lib/mongo/crypt/kms/aws.rb +136 -0
  36. data/lib/mongo/crypt/kms/azure.rb +144 -0
  37. data/lib/mongo/crypt/kms/credentials.rb +81 -0
  38. data/lib/mongo/crypt/kms/gcp.rb +189 -0
  39. data/lib/mongo/crypt/kms/kmip.rb +116 -0
  40. data/lib/mongo/crypt/kms/local.rb +82 -0
  41. data/lib/mongo/crypt/kms/master_key_document.rb +65 -0
  42. data/lib/mongo/crypt/kms.rb +117 -0
  43. data/lib/mongo/crypt/rewrap_many_data_key_context.rb +46 -0
  44. data/lib/mongo/crypt/rewrap_many_data_key_result.rb +37 -0
  45. data/lib/mongo/crypt/status.rb +8 -2
  46. data/lib/mongo/crypt.rb +3 -0
  47. data/lib/mongo/cursor/kill_spec.rb +27 -6
  48. data/lib/mongo/cursor.rb +26 -11
  49. data/lib/mongo/database/view.rb +6 -3
  50. data/lib/mongo/database.rb +57 -13
  51. data/lib/mongo/dbref.rb +1 -105
  52. data/lib/mongo/error/bulk_write_error.rb +31 -4
  53. data/lib/mongo/error/invalid_config_option.rb +20 -0
  54. data/lib/mongo/error/invalid_replacement_document.rb +27 -9
  55. data/lib/mongo/error/invalid_update_document.rb +27 -7
  56. data/lib/mongo/error/labelable.rb +72 -0
  57. data/lib/mongo/error/missing_connection.rb +25 -0
  58. data/lib/mongo/error/missing_file_chunk.rb +8 -2
  59. data/lib/mongo/error/notable.rb +7 -0
  60. data/lib/mongo/error/operation_failure.rb +34 -86
  61. data/lib/mongo/error/read_write_retryable.rb +108 -0
  62. data/lib/mongo/{operation/kill_cursors/legacy.rb → error/session_not_materialized.rb} +7 -19
  63. data/lib/mongo/error.rb +5 -37
  64. data/lib/mongo/grid/stream/read.rb +6 -0
  65. data/lib/mongo/index/view.rb +23 -7
  66. data/lib/mongo/monitoring/event/command_failed.rb +8 -2
  67. data/lib/mongo/monitoring/event/command_started.rb +1 -1
  68. data/lib/mongo/monitoring/event/command_succeeded.rb +9 -2
  69. data/lib/mongo/monitoring/publishable.rb +9 -5
  70. data/lib/mongo/operation/collections_info/result.rb +5 -2
  71. data/lib/mongo/operation/command/op_msg.rb +6 -0
  72. data/lib/mongo/operation/context.rb +24 -6
  73. data/lib/mongo/operation/count/op_msg.rb +4 -1
  74. data/lib/mongo/operation/create/op_msg.rb +4 -1
  75. data/lib/mongo/operation/create_index/op_msg.rb +2 -1
  76. data/lib/mongo/operation/delete/op_msg.rb +1 -0
  77. data/lib/mongo/operation/delete.rb +0 -1
  78. data/lib/mongo/operation/distinct/op_msg.rb +4 -1
  79. data/lib/mongo/operation/drop_index/op_msg.rb +5 -1
  80. data/lib/mongo/operation/get_more/command_builder.rb +5 -1
  81. data/lib/mongo/operation/insert/bulk_result.rb +5 -1
  82. data/lib/mongo/operation/insert/command.rb +0 -4
  83. data/lib/mongo/operation/insert/op_msg.rb +6 -3
  84. data/lib/mongo/operation/insert/result.rb +6 -3
  85. data/lib/mongo/operation/insert.rb +0 -1
  86. data/lib/mongo/operation/kill_cursors.rb +0 -1
  87. data/lib/mongo/operation/list_collections/op_msg.rb +4 -1
  88. data/lib/mongo/operation/map_reduce/result.rb +16 -0
  89. data/lib/mongo/operation/result.rb +21 -5
  90. data/lib/mongo/operation/shared/executable.rb +21 -6
  91. data/lib/mongo/operation/shared/polymorphic_operation.rb +15 -3
  92. data/lib/mongo/operation/shared/response_handling.rb +6 -5
  93. data/lib/mongo/operation/shared/sessions_supported.rb +7 -3
  94. data/lib/mongo/operation/shared/write.rb +18 -12
  95. data/lib/mongo/operation/update/op_msg.rb +2 -1
  96. data/lib/mongo/operation/update.rb +0 -1
  97. data/lib/mongo/protocol/caching_hash.rb +69 -0
  98. data/lib/mongo/protocol/msg.rb +21 -1
  99. data/lib/mongo/protocol.rb +1 -0
  100. data/lib/mongo/query_cache.rb +27 -2
  101. data/lib/mongo/retryable.rb +78 -30
  102. data/lib/mongo/server/connection.rb +33 -0
  103. data/lib/mongo/server/connection_base.rb +2 -0
  104. data/lib/mongo/server/connection_common.rb +4 -1
  105. data/lib/mongo/server/connection_pool.rb +74 -46
  106. data/lib/mongo/server/description/features.rb +3 -1
  107. data/lib/mongo/server/description.rb +7 -2
  108. data/lib/mongo/server/monitor/connection.rb +11 -4
  109. data/lib/mongo/server/monitor.rb +25 -13
  110. data/lib/mongo/server/push_monitor.rb +13 -3
  111. data/lib/mongo/server.rb +9 -5
  112. data/lib/mongo/session/session_pool.rb +8 -0
  113. data/lib/mongo/session.rb +111 -35
  114. data/lib/mongo/socket/ocsp_verifier.rb +4 -5
  115. data/lib/mongo/socket/tcp.rb +3 -0
  116. data/lib/mongo/srv/resolver.rb +24 -3
  117. data/lib/mongo/uri/options_mapper.rb +2 -0
  118. data/lib/mongo/uri/srv_protocol.rb +1 -1
  119. data/lib/mongo/uri.rb +20 -0
  120. data/lib/mongo/version.rb +1 -1
  121. data/lib/mongo.rb +22 -0
  122. data/mongo.gemspec +10 -4
  123. data/spec/README.md +23 -5
  124. data/spec/integration/aws_lambda_examples_spec.rb +68 -0
  125. data/spec/integration/bulk_write_error_message_spec.rb +32 -0
  126. data/spec/integration/bulk_write_spec.rb +16 -0
  127. data/spec/integration/change_stream_spec.rb +6 -5
  128. data/spec/integration/client_construction_spec.rb +74 -8
  129. data/spec/integration/client_side_encryption/auto_encryption_bulk_writes_spec.rb +9 -9
  130. data/spec/integration/client_side_encryption/auto_encryption_command_monitoring_spec.rb +168 -168
  131. data/spec/integration/client_side_encryption/auto_encryption_mongocryptd_spawn_spec.rb +0 -1
  132. data/spec/integration/client_side_encryption/auto_encryption_reconnect_spec.rb +31 -0
  133. data/spec/integration/client_side_encryption/auto_encryption_spec.rb +108 -1
  134. data/spec/integration/client_side_encryption/bson_size_limit_spec.rb +2 -2
  135. data/spec/integration/client_side_encryption/bypass_mongocryptd_spawn_spec.rb +2 -2
  136. data/spec/integration/client_side_encryption/client_close_spec.rb +1 -1
  137. data/spec/integration/client_side_encryption/corpus_spec.rb +64 -35
  138. data/spec/integration/client_side_encryption/custom_endpoint_spec.rb +39 -42
  139. data/spec/integration/client_side_encryption/data_key_spec.rb +97 -7
  140. data/spec/integration/client_side_encryption/decryption_events_prose_spec.rb +158 -0
  141. data/spec/integration/client_side_encryption/explicit_encryption_spec.rb +59 -0
  142. data/spec/integration/client_side_encryption/explicit_queryable_encryption_spec.rb +147 -0
  143. data/spec/integration/client_side_encryption/external_key_vault_spec.rb +6 -6
  144. data/spec/integration/client_side_encryption/kms_tls_options_spec.rb +436 -0
  145. data/spec/integration/client_side_encryption/kms_tls_spec.rb +92 -0
  146. data/spec/integration/client_side_encryption/queryable_encryption_examples_spec.rb +111 -0
  147. data/spec/integration/client_side_encryption/unique_index_on_key_alt_names_prose_spec.rb +85 -0
  148. data/spec/integration/client_side_encryption/views_spec.rb +1 -1
  149. data/spec/integration/client_update_spec.rb +2 -2
  150. data/spec/integration/crud_spec.rb +12 -0
  151. data/spec/integration/cursor_pinning_spec.rb +3 -3
  152. data/spec/integration/fork_reconnect_spec.rb +15 -8
  153. data/spec/integration/grid_fs_bucket_spec.rb +3 -3
  154. data/spec/integration/ocsp_verifier_spec.rb +3 -0
  155. data/spec/integration/query_cache_spec.rb +193 -30
  156. data/spec/integration/reconnect_spec.rb +2 -0
  157. data/spec/integration/retryable_writes/retryable_writes_36_and_older_spec.rb +1 -1
  158. data/spec/integration/sdam_events_spec.rb +40 -0
  159. data/spec/integration/server_monitor_spec.rb +2 -1
  160. data/spec/integration/size_limit_spec.rb +4 -1
  161. data/spec/integration/snapshot_query_examples_spec.rb +127 -0
  162. data/spec/integration/srv_monitoring_spec.rb +38 -0
  163. data/spec/integration/srv_spec.rb +1 -0
  164. data/spec/integration/step_down_spec.rb +20 -4
  165. data/spec/integration/transaction_pinning_spec.rb +2 -2
  166. data/spec/integration/versioned_api_examples_spec.rb +37 -31
  167. data/spec/lite_spec_helper.rb +19 -9
  168. data/spec/mongo/address/ipv6_spec.rb +7 -0
  169. data/spec/mongo/address_spec.rb +7 -0
  170. data/spec/mongo/auth/scram/conversation_spec.rb +23 -23
  171. data/spec/mongo/auth/scram256/conversation_spec.rb +20 -20
  172. data/spec/mongo/auth/scram_negotiation_spec.rb +1 -0
  173. data/spec/mongo/bulk_write/result_spec.rb +15 -1
  174. data/spec/mongo/bulk_write_spec.rb +141 -20
  175. data/spec/mongo/client_construction_spec.rb +186 -9
  176. data/spec/mongo/client_encryption_spec.rb +10 -22
  177. data/spec/mongo/client_spec.rb +297 -1
  178. data/spec/mongo/cluster/cursor_reaper_spec.rb +21 -3
  179. data/spec/mongo/cluster_spec.rb +0 -44
  180. data/spec/mongo/collection/view/aggregation_spec.rb +121 -2
  181. data/spec/mongo/collection/view/change_stream_spec.rb +2 -2
  182. data/spec/mongo/collection/view/readable_spec.rb +661 -1
  183. data/spec/mongo/collection/view/writable_spec.rb +144 -32
  184. data/spec/mongo/collection_crud_spec.rb +63 -13
  185. data/spec/mongo/collection_spec.rb +32 -0
  186. data/spec/mongo/config/options_spec.rb +75 -0
  187. data/spec/mongo/config_spec.rb +73 -0
  188. data/spec/mongo/crypt/auto_decryption_context_spec.rb +17 -1
  189. data/spec/mongo/crypt/auto_encrypter_spec.rb +256 -5
  190. data/spec/mongo/crypt/auto_encryption_context_spec.rb +17 -1
  191. data/spec/mongo/crypt/binding/context_spec.rb +67 -17
  192. data/spec/mongo/crypt/binding/mongocrypt_spec.rb +17 -46
  193. data/spec/mongo/crypt/binding/version_spec.rb +33 -0
  194. data/spec/mongo/crypt/binding_unloaded_spec.rb +14 -0
  195. data/spec/mongo/crypt/data_key_context_spec.rb +42 -114
  196. data/spec/mongo/crypt/encryption_io_spec.rb +2 -0
  197. data/spec/mongo/crypt/explicit_decryption_context_spec.rb +32 -1
  198. data/spec/mongo/crypt/explicit_encryption_context_spec.rb +94 -1
  199. data/spec/mongo/crypt/handle_spec.rb +172 -156
  200. data/spec/mongo/crypt/hooks_spec.rb +30 -0
  201. data/spec/mongo/crypt/kms/credentials_spec.rb +357 -0
  202. data/spec/mongo/crypt/kms_spec.rb +59 -0
  203. data/spec/mongo/cursor_spec.rb +87 -1
  204. data/spec/mongo/database_spec.rb +66 -1
  205. data/spec/mongo/error/operation_failure_heavy_spec.rb +49 -0
  206. data/spec/mongo/index/view_spec.rb +125 -0
  207. data/spec/mongo/operation/create/op_msg_spec.rb +244 -0
  208. data/spec/mongo/operation/delete/op_msg_spec.rb +13 -4
  209. data/spec/mongo/operation/delete_spec.rb +0 -30
  210. data/spec/mongo/operation/insert/op_msg_spec.rb +18 -10
  211. data/spec/mongo/operation/insert_spec.rb +0 -32
  212. data/spec/mongo/operation/result_spec.rb +20 -0
  213. data/spec/mongo/operation/update/op_msg_spec.rb +13 -4
  214. data/spec/mongo/operation/update_spec.rb +0 -29
  215. data/spec/mongo/protocol/caching_hash_spec.rb +82 -0
  216. data/spec/mongo/protocol/msg_spec.rb +41 -0
  217. data/spec/mongo/query_cache_spec.rb +166 -0
  218. data/spec/mongo/retryable_spec.rb +32 -3
  219. data/spec/mongo/server/connection_auth_spec.rb +3 -1
  220. data/spec/mongo/server/connection_common_spec.rb +13 -1
  221. data/spec/mongo/server/connection_pool_spec.rb +120 -53
  222. data/spec/mongo/server/connection_spec.rb +50 -159
  223. data/spec/mongo/server/description/features_spec.rb +24 -0
  224. data/spec/mongo/server/push_monitor_spec.rb +2 -8
  225. data/spec/mongo/session_spec.rb +26 -6
  226. data/spec/mongo/session_transaction_spec.rb +2 -1
  227. data/spec/mongo/socket/ssl_spec.rb +18 -7
  228. data/spec/mongo/uri/srv_protocol_spec.rb +101 -2
  229. data/spec/mongo/uri_spec.rb +25 -0
  230. data/spec/runners/connection_string.rb +8 -0
  231. data/spec/runners/crud/operation.rb +12 -3
  232. data/spec/runners/crud/requirement.rb +9 -4
  233. data/spec/runners/crud/spec.rb +5 -0
  234. data/spec/runners/crud/test.rb +1 -1
  235. data/spec/runners/crud/verifier.rb +6 -0
  236. data/spec/runners/transactions/spec.rb +2 -2
  237. data/spec/runners/transactions/test.rb +19 -16
  238. data/spec/runners/transactions.rb +11 -8
  239. data/spec/runners/unified/assertions.rb +90 -11
  240. data/spec/runners/unified/change_stream_operations.rb +12 -0
  241. data/spec/runners/unified/client_side_encryption_operations.rb +83 -0
  242. data/spec/runners/unified/crud_operations.rb +67 -4
  243. data/spec/runners/unified/ddl_operations.rb +45 -0
  244. data/spec/runners/unified/error.rb +2 -1
  245. data/spec/runners/unified/grid_fs_operations.rb +21 -0
  246. data/spec/runners/unified/support_operations.rb +5 -2
  247. data/spec/runners/unified/test.rb +78 -5
  248. data/spec/runners/unified.rb +9 -2
  249. data/spec/shared/lib/mrss/constraints.rb +10 -17
  250. data/spec/shared/lib/mrss/docker_runner.rb +23 -3
  251. data/spec/shared/lib/mrss/eg_config_utils.rb +51 -0
  252. data/spec/shared/lib/mrss/event_subscriber.rb +15 -5
  253. data/spec/shared/lib/mrss/lite_constraints.rb +40 -1
  254. data/spec/shared/lib/mrss/session_registry.rb +69 -0
  255. data/spec/shared/lib/mrss/session_registry_legacy.rb +60 -0
  256. data/spec/shared/share/Dockerfile.erb +56 -54
  257. data/spec/shared/shlib/config.sh +27 -0
  258. data/spec/shared/shlib/distro.sh +2 -1
  259. data/spec/shared/shlib/server.sh +46 -21
  260. data/spec/shared/shlib/set_env.sh +43 -5
  261. data/spec/solo/clean_exit_spec.rb +5 -0
  262. data/spec/spec_helper.rb +0 -1
  263. data/spec/spec_tests/client_side_encryption_spec.rb +1 -1
  264. data/spec/spec_tests/client_side_encryption_unified_spec.rb +16 -0
  265. data/spec/spec_tests/crud_spec.rb +0 -10
  266. data/spec/spec_tests/data/change_streams_unified/change-streams-errors.yml +124 -0
  267. data/spec/spec_tests/data/change_streams_unified/change-streams-pre_and_post_images.yml +351 -0
  268. data/spec/spec_tests/data/change_streams_unified/change-streams-resume-allowlist.yml +1171 -0
  269. data/spec/spec_tests/data/change_streams_unified/change-streams-resume-errorLabels.yml +1071 -0
  270. data/spec/spec_tests/data/change_streams_unified/change-streams-showExpandedEvents.yml +298 -0
  271. data/spec/spec_tests/data/change_streams_unified/change-streams.yml +859 -4
  272. data/spec/spec_tests/data/client_side_encryption/aggregate.yml +3 -17
  273. data/spec/spec_tests/data/client_side_encryption/azureKMS.yml +46 -0
  274. data/spec/spec_tests/data/client_side_encryption/badQueries.yml +12 -2
  275. data/spec/spec_tests/data/client_side_encryption/basic.yml +3 -17
  276. data/spec/spec_tests/data/client_side_encryption/bulk.yml +1 -8
  277. data/spec/spec_tests/data/client_side_encryption/bypassAutoEncryption.yml +2 -2
  278. data/spec/spec_tests/data/client_side_encryption/count.yml +1 -8
  279. data/spec/spec_tests/data/client_side_encryption/countDocuments.yml +1 -8
  280. data/spec/spec_tests/data/client_side_encryption/create-and-createIndexes.yml +58 -0
  281. data/spec/spec_tests/data/client_side_encryption/delete.yml +2 -16
  282. data/spec/spec_tests/data/client_side_encryption/distinct.yml +1 -8
  283. data/spec/spec_tests/data/client_side_encryption/explain.yml +1 -8
  284. data/spec/spec_tests/data/client_side_encryption/find.yml +2 -16
  285. data/spec/spec_tests/data/client_side_encryption/findOneAndDelete.yml +1 -8
  286. data/spec/spec_tests/data/client_side_encryption/findOneAndReplace.yml +1 -8
  287. data/spec/spec_tests/data/client_side_encryption/findOneAndUpdate.yml +1 -8
  288. data/spec/spec_tests/data/client_side_encryption/fle2-BypassQueryAnalysis.yml +101 -0
  289. data/spec/spec_tests/data/client_side_encryption/fle2-Compact.yml +80 -0
  290. data/spec/spec_tests/data/client_side_encryption/fle2-CreateCollection.yml +1263 -0
  291. data/spec/spec_tests/data/client_side_encryption/fle2-DecryptExistingData.yml +64 -0
  292. data/spec/spec_tests/data/client_side_encryption/fle2-Delete.yml +107 -0
  293. data/spec/spec_tests/data/client_side_encryption/fle2-EncryptedFields-vs-EncryptedFieldsMap.yml +80 -0
  294. data/spec/spec_tests/data/client_side_encryption/fle2-EncryptedFields-vs-jsonSchema.yml +90 -0
  295. data/spec/spec_tests/data/client_side_encryption/fle2-EncryptedFieldsMap-defaults.yml +57 -0
  296. data/spec/spec_tests/data/client_side_encryption/fle2-FindOneAndUpdate.yml +213 -0
  297. data/spec/spec_tests/data/client_side_encryption/fle2-InsertFind-Indexed.yml +86 -0
  298. data/spec/spec_tests/data/client_side_encryption/fle2-InsertFind-Unindexed.yml +83 -0
  299. data/spec/spec_tests/data/client_side_encryption/fle2-MissingKey.yml +41 -0
  300. data/spec/spec_tests/data/client_side_encryption/fle2-NoEncryption.yml +42 -0
  301. data/spec/spec_tests/data/client_side_encryption/fle2-Update.yml +221 -0
  302. data/spec/spec_tests/data/client_side_encryption/fle2-validatorAndPartialFieldExpression.yml +168 -0
  303. data/spec/spec_tests/data/client_side_encryption/gcpKMS.yml +46 -0
  304. data/spec/spec_tests/data/client_side_encryption/getMore.yml +1 -8
  305. data/spec/spec_tests/data/client_side_encryption/insert.yml +2 -16
  306. data/spec/spec_tests/data/client_side_encryption/keyAltName.yml +1 -8
  307. data/spec/spec_tests/data/client_side_encryption/localKMS.yml +1 -8
  308. data/spec/spec_tests/data/client_side_encryption/localSchema.yml +1 -8
  309. data/spec/spec_tests/data/client_side_encryption/maxWireVersion.yml +2 -0
  310. data/spec/spec_tests/data/client_side_encryption/missingKey.yml +2 -9
  311. data/spec/spec_tests/data/client_side_encryption/noSchema.yml +39 -0
  312. data/spec/spec_tests/data/client_side_encryption/replaceOne.yml +1 -8
  313. data/spec/spec_tests/data/client_side_encryption/types.yml +44 -70
  314. data/spec/spec_tests/data/client_side_encryption/unified/addKeyAltName.yml +194 -0
  315. data/spec/spec_tests/data/client_side_encryption/unified/createDataKey-kms_providers-invalid.yml +67 -0
  316. data/spec/spec_tests/data/client_side_encryption/unified/createDataKey.yml +309 -0
  317. data/spec/spec_tests/data/client_side_encryption/unified/deleteKey.yml +159 -0
  318. data/spec/spec_tests/data/client_side_encryption/unified/getKey.yml +105 -0
  319. data/spec/spec_tests/data/client_side_encryption/unified/getKeyByAltName.yml +104 -0
  320. data/spec/spec_tests/data/client_side_encryption/unified/getKeys.yml +122 -0
  321. data/spec/spec_tests/data/client_side_encryption/unified/removeKeyAltName.yml +157 -0
  322. data/spec/spec_tests/data/client_side_encryption/unified/rewrapManyDataKey-decrypt_failure.yml +69 -0
  323. data/spec/spec_tests/data/client_side_encryption/unified/rewrapManyDataKey-encrypt_failure.yml +122 -0
  324. data/spec/spec_tests/data/client_side_encryption/unified/rewrapManyDataKey.yml +432 -0
  325. data/spec/spec_tests/data/client_side_encryption/updateMany.yml +1 -8
  326. data/spec/spec_tests/data/client_side_encryption/updateOne.yml +1 -8
  327. data/spec/spec_tests/data/client_side_encryption/validatorAndPartialFieldExpression.yml +166 -0
  328. data/spec/spec_tests/data/collection_management/clustered-indexes.yml +135 -0
  329. data/spec/spec_tests/data/collection_management/createCollection-pre_and_post_images.yml +50 -0
  330. data/spec/spec_tests/data/collection_management/modifyCollection-pre_and_post_images.yml +58 -0
  331. data/spec/spec_tests/data/command_monitoring_unified/bulkWrite.yml +68 -0
  332. data/spec/spec_tests/data/command_monitoring_unified/command.yml +50 -0
  333. data/spec/spec_tests/data/command_monitoring_unified/deleteMany.yml +79 -0
  334. data/spec/spec_tests/data/command_monitoring_unified/deleteOne.yml +79 -0
  335. data/spec/spec_tests/data/command_monitoring_unified/find.yml +254 -0
  336. data/spec/spec_tests/data/command_monitoring_unified/insertMany.yml +79 -0
  337. data/spec/spec_tests/data/command_monitoring_unified/insertOne.yml +77 -0
  338. data/spec/spec_tests/data/command_monitoring_unified/pre-42-server-connection-id.yml +56 -0
  339. data/spec/spec_tests/data/command_monitoring_unified/server-connection-id.yml +56 -0
  340. data/spec/spec_tests/data/command_monitoring_unified/unacknowledgedBulkWrite.yml +55 -0
  341. data/spec/spec_tests/data/command_monitoring_unified/updateMany.yml +87 -0
  342. data/spec/spec_tests/data/command_monitoring_unified/updateOne.yml +118 -0
  343. data/spec/spec_tests/data/crud/read/aggregate-collation.yml +1 -1
  344. data/spec/spec_tests/data/crud/read/count-collation.yml +1 -1
  345. data/spec/spec_tests/data/crud/read/distinct-collation.yml +1 -1
  346. data/spec/spec_tests/data/crud/read/find-collation.yml +1 -1
  347. data/spec/spec_tests/data/crud/write/bulkWrite-collation.yml +1 -1
  348. data/spec/spec_tests/data/crud/write/deleteMany-collation.yml +1 -1
  349. data/spec/spec_tests/data/crud/write/deleteOne-collation.yml +1 -1
  350. data/spec/spec_tests/data/crud/write/findOneAndDelete-collation.yml +1 -1
  351. data/spec/spec_tests/data/crud/write/findOneAndReplace-collation.yml +1 -1
  352. data/spec/spec_tests/data/crud/write/findOneAndUpdate-collation.yml +1 -1
  353. data/spec/spec_tests/data/crud/write/replaceOne-collation.yml +1 -1
  354. data/spec/spec_tests/data/crud/write/updateMany-collation.yml +1 -1
  355. data/spec/spec_tests/data/crud/write/updateOne-collation.yml +1 -1
  356. data/spec/spec_tests/data/crud_unified/aggregate-allowdiskuse.yml +75 -0
  357. data/spec/spec_tests/data/crud_unified/aggregate-merge.yml +185 -0
  358. data/spec/spec_tests/data/crud_unified/aggregate-out-readConcern.yml +171 -0
  359. data/spec/spec_tests/data/crud_unified/aggregate.yml +215 -0
  360. data/spec/spec_tests/data/crud_unified/bulkWrite-arrayFilters-clientError.yml +98 -0
  361. data/spec/spec_tests/data/crud_unified/bulkWrite-arrayFilters.yml +174 -0
  362. data/spec/spec_tests/data/crud_unified/bulkWrite-comment.yml +189 -0
  363. data/spec/spec_tests/data/crud_unified/bulkWrite-delete-hint-clientError.yml +113 -0
  364. data/spec/spec_tests/data/crud_unified/bulkWrite-delete-hint-serverError.yml +142 -0
  365. data/spec/spec_tests/data/crud_unified/bulkWrite-delete-hint.yml +154 -0
  366. data/spec/spec_tests/data/crud_unified/bulkWrite-deleteMany-hint-unacknowledged.yml +98 -0
  367. data/spec/spec_tests/data/crud_unified/bulkWrite-deleteMany-let.yml +86 -0
  368. data/spec/spec_tests/data/crud_unified/bulkWrite-deleteOne-hint-unacknowledged.yml +97 -0
  369. data/spec/spec_tests/data/crud_unified/bulkWrite-deleteOne-let.yml +86 -0
  370. data/spec/spec_tests/data/crud_unified/bulkWrite-insertOne-dots_and_dollars.yml +138 -0
  371. data/spec/spec_tests/data/crud_unified/bulkWrite-replaceOne-dots_and_dollars.yml +165 -0
  372. data/spec/spec_tests/data/crud_unified/bulkWrite-replaceOne-hint-unacknowledged.yml +103 -0
  373. data/spec/spec_tests/data/crud_unified/bulkWrite-replaceOne-let.yml +93 -0
  374. data/spec/spec_tests/data/crud_unified/bulkWrite-update-hint-clientError.yml +148 -0
  375. data/spec/spec_tests/data/crud_unified/bulkWrite-update-hint-serverError.yml +239 -0
  376. data/spec/spec_tests/data/crud_unified/bulkWrite-update-hint.yml +256 -0
  377. data/spec/spec_tests/data/crud_unified/bulkWrite-update-validation.yml +73 -0
  378. data/spec/spec_tests/data/crud_unified/bulkWrite-updateMany-dots_and_dollars.yml +150 -0
  379. data/spec/spec_tests/data/crud_unified/bulkWrite-updateMany-hint-unacknowledged.yml +104 -0
  380. data/spec/spec_tests/data/crud_unified/bulkWrite-updateMany-let.yml +96 -0
  381. data/spec/spec_tests/data/crud_unified/bulkWrite-updateOne-dots_and_dollars.yml +150 -0
  382. data/spec/spec_tests/data/crud_unified/bulkWrite-updateOne-hint-unacknowledged.yml +103 -0
  383. data/spec/spec_tests/data/crud_unified/bulkWrite-updateOne-let.yml +95 -0
  384. data/spec/spec_tests/data/crud_unified/countDocuments-comment.yml +92 -0
  385. data/spec/spec_tests/data/crud_unified/db-aggregate.yml +73 -0
  386. data/spec/spec_tests/data/crud_unified/deleteMany-comment.yml +97 -0
  387. data/spec/spec_tests/data/crud_unified/deleteMany-hint-clientError.yml +87 -0
  388. data/spec/spec_tests/data/crud_unified/deleteMany-hint-serverError.yml +107 -0
  389. data/spec/spec_tests/data/crud_unified/deleteMany-hint-unacknowledged.yml +90 -0
  390. data/spec/spec_tests/data/crud_unified/deleteMany-hint.yml +99 -0
  391. data/spec/spec_tests/data/crud_unified/deleteMany-let.yml +2 -0
  392. data/spec/spec_tests/data/crud_unified/deleteOne-comment.yml +98 -0
  393. data/spec/spec_tests/data/crud_unified/deleteOne-hint-clientError.yml +80 -0
  394. data/spec/spec_tests/data/crud_unified/deleteOne-hint-serverError.yml +100 -0
  395. data/spec/spec_tests/data/crud_unified/deleteOne-hint-unacknowledged.yml +89 -0
  396. data/spec/spec_tests/data/crud_unified/deleteOne-hint.yml +95 -0
  397. data/spec/spec_tests/data/crud_unified/deleteOne-let.yml +2 -0
  398. data/spec/spec_tests/data/crud_unified/distinct-comment.yml +98 -0
  399. data/spec/spec_tests/data/crud_unified/estimatedDocumentCount-comment.yml +95 -0
  400. data/spec/spec_tests/data/crud_unified/estimatedDocumentCount.yml +5 -135
  401. data/spec/spec_tests/data/crud_unified/find-allowdiskuse-clientError.yml +55 -0
  402. data/spec/spec_tests/data/crud_unified/find-allowdiskuse-serverError.yml +68 -0
  403. data/spec/spec_tests/data/crud_unified/find-allowdiskuse.yml +79 -0
  404. data/spec/spec_tests/data/crud_unified/find-comment.yml +166 -0
  405. data/spec/spec_tests/data/crud_unified/find.yml +68 -0
  406. data/spec/spec_tests/data/crud_unified/findOneAndDelete-comment.yml +96 -0
  407. data/spec/spec_tests/data/crud_unified/findOneAndDelete-hint-clientError.yml +91 -0
  408. data/spec/spec_tests/data/crud_unified/findOneAndDelete-hint-serverError.yml +107 -0
  409. data/spec/spec_tests/data/crud_unified/findOneAndDelete-hint-unacknowledged.yml +88 -0
  410. data/spec/spec_tests/data/crud_unified/findOneAndDelete-hint.yml +102 -0
  411. data/spec/spec_tests/data/crud_unified/findOneAndDelete-let.yml +2 -4
  412. data/spec/spec_tests/data/crud_unified/findOneAndReplace-comment.yml +101 -0
  413. data/spec/spec_tests/data/crud_unified/findOneAndReplace-dots_and_dollars.yml +140 -0
  414. data/spec/spec_tests/data/crud_unified/findOneAndReplace-hint-clientError.yml +83 -0
  415. data/spec/spec_tests/data/crud_unified/findOneAndReplace-hint-serverError.yml +99 -0
  416. data/spec/spec_tests/data/crud_unified/findOneAndReplace-hint-unacknowledged.yml +96 -0
  417. data/spec/spec_tests/data/crud_unified/findOneAndReplace-hint.yml +98 -0
  418. data/spec/spec_tests/data/crud_unified/findOneAndUpdate-comment.yml +95 -0
  419. data/spec/spec_tests/data/crud_unified/findOneAndUpdate-dots_and_dollars.yml +127 -0
  420. data/spec/spec_tests/data/crud_unified/findOneAndUpdate-hint-clientError.yml +84 -0
  421. data/spec/spec_tests/data/crud_unified/findOneAndUpdate-hint-serverError.yml +100 -0
  422. data/spec/spec_tests/data/crud_unified/findOneAndUpdate-hint-unacknowledged.yml +92 -0
  423. data/spec/spec_tests/data/crud_unified/findOneAndUpdate-hint.yml +99 -0
  424. data/spec/spec_tests/data/crud_unified/insertMany-comment.yml +93 -0
  425. data/spec/spec_tests/data/crud_unified/insertMany-dots_and_dollars.yml +128 -0
  426. data/spec/spec_tests/data/crud_unified/insertOne-comment.yml +91 -0
  427. data/spec/spec_tests/data/crud_unified/insertOne-dots_and_dollars.yml +238 -0
  428. data/spec/spec_tests/data/crud_unified/replaceOne-comment.yml +105 -0
  429. data/spec/spec_tests/data/crud_unified/replaceOne-dots_and_dollars.yml +180 -0
  430. data/spec/spec_tests/data/crud_unified/replaceOne-hint-unacknowledged.yml +95 -0
  431. data/spec/spec_tests/data/crud_unified/replaceOne-hint.yml +108 -0
  432. data/spec/spec_tests/data/crud_unified/replaceOne-let.yml +98 -0
  433. data/spec/spec_tests/data/crud_unified/replaceOne-validation.yml +37 -0
  434. data/spec/spec_tests/data/crud_unified/updateMany-comment.yml +104 -0
  435. data/spec/spec_tests/data/crud_unified/updateMany-dots_and_dollars.yml +138 -0
  436. data/spec/spec_tests/data/crud_unified/updateMany-hint-clientError.yml +91 -0
  437. data/spec/spec_tests/data/crud_unified/updateMany-hint-serverError.yml +115 -0
  438. data/spec/spec_tests/data/crud_unified/updateMany-hint-unacknowledged.yml +96 -0
  439. data/spec/spec_tests/data/crud_unified/updateMany-hint.yml +115 -0
  440. data/spec/spec_tests/data/crud_unified/updateMany-let.yml +5 -1
  441. data/spec/spec_tests/data/crud_unified/updateMany-validation.yml +39 -0
  442. data/spec/spec_tests/data/crud_unified/updateOne-comment.yml +104 -0
  443. data/spec/spec_tests/data/crud_unified/updateOne-dots_and_dollars.yml +138 -0
  444. data/spec/spec_tests/data/crud_unified/updateOne-hint-clientError.yml +85 -0
  445. data/spec/spec_tests/data/crud_unified/updateOne-hint-serverError.yml +109 -0
  446. data/spec/spec_tests/data/crud_unified/updateOne-hint-unacknowledged.yml +95 -0
  447. data/spec/spec_tests/data/crud_unified/updateOne-hint.yml +109 -0
  448. data/spec/spec_tests/data/crud_unified/updateOne-let.yml +5 -1
  449. data/spec/spec_tests/data/crud_unified/updateOne-validation.yml +37 -0
  450. data/spec/spec_tests/data/crud_unified/updateWithPipelines.yml +8 -14
  451. data/spec/spec_tests/data/gridfs_unified/delete.yml +198 -0
  452. data/spec/spec_tests/data/gridfs_unified/download.yml +241 -0
  453. data/spec/spec_tests/data/gridfs_unified/downloadByName.yml +159 -0
  454. data/spec/spec_tests/data/gridfs_unified/upload-disableMD5.yml +92 -0
  455. data/spec/spec_tests/data/gridfs_unified/upload.yml +288 -0
  456. data/spec/spec_tests/data/retryable_reads/{aggregate-merge.yml → legacy/aggregate-merge.yml} +0 -0
  457. data/spec/spec_tests/data/retryable_reads/{aggregate-serverErrors.yml → legacy/aggregate-serverErrors.yml} +0 -0
  458. data/spec/spec_tests/data/retryable_reads/{aggregate.yml → legacy/aggregate.yml} +0 -0
  459. data/spec/spec_tests/data/retryable_reads/{changeStreams-client.watch-serverErrors.yml → legacy/changeStreams-client.watch-serverErrors.yml} +0 -0
  460. data/spec/spec_tests/data/retryable_reads/{changeStreams-client.watch.yml → legacy/changeStreams-client.watch.yml} +0 -0
  461. data/spec/spec_tests/data/retryable_reads/{changeStreams-db.coll.watch-serverErrors.yml → legacy/changeStreams-db.coll.watch-serverErrors.yml} +0 -0
  462. data/spec/spec_tests/data/retryable_reads/{changeStreams-db.coll.watch.yml → legacy/changeStreams-db.coll.watch.yml} +0 -0
  463. data/spec/spec_tests/data/retryable_reads/{changeStreams-db.watch-serverErrors.yml → legacy/changeStreams-db.watch-serverErrors.yml} +0 -0
  464. data/spec/spec_tests/data/retryable_reads/{changeStreams-db.watch.yml → legacy/changeStreams-db.watch.yml} +0 -0
  465. data/spec/spec_tests/data/retryable_reads/{count-serverErrors.yml → legacy/count-serverErrors.yml} +0 -0
  466. data/spec/spec_tests/data/retryable_reads/{count.yml → legacy/count.yml} +0 -0
  467. data/spec/spec_tests/data/retryable_reads/{countDocuments-serverErrors.yml → legacy/countDocuments-serverErrors.yml} +0 -0
  468. data/spec/spec_tests/data/retryable_reads/{countDocuments.yml → legacy/countDocuments.yml} +0 -0
  469. data/spec/spec_tests/data/retryable_reads/{distinct-serverErrors.yml → legacy/distinct-serverErrors.yml} +0 -0
  470. data/spec/spec_tests/data/retryable_reads/{distinct.yml → legacy/distinct.yml} +0 -0
  471. data/spec/spec_tests/data/retryable_reads/{estimatedDocumentCount-serverErrors-pre4.9.yml → legacy/estimatedDocumentCount-serverErrors.yml} +0 -2
  472. data/spec/spec_tests/data/retryable_reads/{estimatedDocumentCount-pre4.9.yml → legacy/estimatedDocumentCount.yml} +0 -2
  473. data/spec/spec_tests/data/retryable_reads/{find-serverErrors.yml → legacy/find-serverErrors.yml} +0 -0
  474. data/spec/spec_tests/data/retryable_reads/{find.yml → legacy/find.yml} +0 -0
  475. data/spec/spec_tests/data/retryable_reads/{findOne-serverErrors.yml → legacy/findOne-serverErrors.yml} +0 -0
  476. data/spec/spec_tests/data/retryable_reads/{findOne.yml → legacy/findOne.yml} +0 -0
  477. data/spec/spec_tests/data/retryable_reads/{gridfs-download-serverErrors.yml → legacy/gridfs-download-serverErrors.yml} +0 -0
  478. data/spec/spec_tests/data/retryable_reads/{gridfs-download.yml → legacy/gridfs-download.yml} +0 -0
  479. data/spec/spec_tests/data/retryable_reads/{gridfs-downloadByName-serverErrors.yml → legacy/gridfs-downloadByName-serverErrors.yml} +0 -0
  480. data/spec/spec_tests/data/retryable_reads/{gridfs-downloadByName.yml → legacy/gridfs-downloadByName.yml} +0 -0
  481. data/spec/spec_tests/data/retryable_reads/{listCollectionNames-serverErrors.yml → legacy/listCollectionNames-serverErrors.yml} +0 -0
  482. data/spec/spec_tests/data/retryable_reads/{listCollectionNames.yml → legacy/listCollectionNames.yml} +0 -0
  483. data/spec/spec_tests/data/retryable_reads/{listCollectionObjects-serverErrors.yml → legacy/listCollectionObjects-serverErrors.yml} +0 -0
  484. data/spec/spec_tests/data/retryable_reads/{listCollectionObjects.yml → legacy/listCollectionObjects.yml} +0 -0
  485. data/spec/spec_tests/data/retryable_reads/{listCollections-serverErrors.yml → legacy/listCollections-serverErrors.yml} +0 -0
  486. data/spec/spec_tests/data/retryable_reads/{listCollections.yml → legacy/listCollections.yml} +0 -0
  487. data/spec/spec_tests/data/retryable_reads/{listDatabaseNames-serverErrors.yml → legacy/listDatabaseNames-serverErrors.yml} +0 -0
  488. data/spec/spec_tests/data/retryable_reads/{listDatabaseNames.yml → legacy/listDatabaseNames.yml} +0 -0
  489. data/spec/spec_tests/data/retryable_reads/{listDatabaseObjects-serverErrors.yml → legacy/listDatabaseObjects-serverErrors.yml} +0 -0
  490. data/spec/spec_tests/data/retryable_reads/{listDatabaseObjects.yml → legacy/listDatabaseObjects.yml} +0 -0
  491. data/spec/spec_tests/data/retryable_reads/{listDatabases-serverErrors.yml → legacy/listDatabases-serverErrors.yml} +0 -0
  492. data/spec/spec_tests/data/retryable_reads/{listDatabases.yml → legacy/listDatabases.yml} +0 -0
  493. data/spec/spec_tests/data/retryable_reads/{listIndexNames-serverErrors.yml → legacy/listIndexNames-serverErrors.yml} +0 -0
  494. data/spec/spec_tests/data/retryable_reads/{listIndexNames.yml → legacy/listIndexNames.yml} +0 -0
  495. data/spec/spec_tests/data/retryable_reads/{listIndexes-serverErrors.yml → legacy/listIndexes-serverErrors.yml} +0 -0
  496. data/spec/spec_tests/data/retryable_reads/{listIndexes.yml → legacy/listIndexes.yml} +0 -0
  497. data/spec/spec_tests/data/retryable_reads/{mapReduce.yml → legacy/mapReduce.yml} +0 -0
  498. data/spec/spec_tests/data/retryable_reads/unified/handshakeError.yml +129 -0
  499. data/spec/spec_tests/data/retryable_writes/{bulkWrite-errorLabels.yml → legacy/bulkWrite-errorLabels.yml} +0 -0
  500. data/spec/spec_tests/data/retryable_writes/{bulkWrite-serverErrors.yml → legacy/bulkWrite-serverErrors.yml} +1 -1
  501. data/spec/spec_tests/data/retryable_writes/{bulkWrite.yml → legacy/bulkWrite.yml} +0 -0
  502. data/spec/spec_tests/data/retryable_writes/{deleteMany.yml → legacy/deleteMany.yml} +0 -0
  503. data/spec/spec_tests/data/retryable_writes/{deleteOne-errorLabels.yml → legacy/deleteOne-errorLabels.yml} +0 -0
  504. data/spec/spec_tests/data/retryable_writes/{deleteOne-serverErrors.yml → legacy/deleteOne-serverErrors.yml} +1 -1
  505. data/spec/spec_tests/data/retryable_writes/{deleteOne.yml → legacy/deleteOne.yml} +0 -0
  506. data/spec/spec_tests/data/retryable_writes/{findOneAndDelete-errorLabels.yml → legacy/findOneAndDelete-errorLabels.yml} +0 -0
  507. data/spec/spec_tests/data/retryable_writes/{findOneAndDelete-serverErrors.yml → legacy/findOneAndDelete-serverErrors.yml} +1 -1
  508. data/spec/spec_tests/data/retryable_writes/{findOneAndDelete.yml → legacy/findOneAndDelete.yml} +0 -0
  509. data/spec/spec_tests/data/retryable_writes/{findOneAndReplace-errorLabels.yml → legacy/findOneAndReplace-errorLabels.yml} +0 -0
  510. data/spec/spec_tests/data/retryable_writes/{findOneAndReplace-serverErrors.yml → legacy/findOneAndReplace-serverErrors.yml} +1 -1
  511. data/spec/spec_tests/data/retryable_writes/{findOneAndReplace.yml → legacy/findOneAndReplace.yml} +0 -0
  512. data/spec/spec_tests/data/retryable_writes/{findOneAndUpdate-errorLabels.yml → legacy/findOneAndUpdate-errorLabels.yml} +0 -0
  513. data/spec/spec_tests/data/retryable_writes/{findOneAndUpdate-serverErrors.yml → legacy/findOneAndUpdate-serverErrors.yml} +1 -1
  514. data/spec/spec_tests/data/retryable_writes/{findOneAndUpdate.yml → legacy/findOneAndUpdate.yml} +0 -0
  515. data/spec/spec_tests/data/retryable_writes/{insertMany-errorLabels.yml → legacy/insertMany-errorLabels.yml} +0 -0
  516. data/spec/spec_tests/data/retryable_writes/{insertMany-serverErrors.yml → legacy/insertMany-serverErrors.yml} +1 -1
  517. data/spec/spec_tests/data/retryable_writes/{insertMany.yml → legacy/insertMany.yml} +0 -0
  518. data/spec/spec_tests/data/retryable_writes/{insertOne-errorLabels.yml → legacy/insertOne-errorLabels.yml} +0 -0
  519. data/spec/spec_tests/data/retryable_writes/{insertOne-serverErrors.yml → legacy/insertOne-serverErrors.yml} +5 -5
  520. data/spec/spec_tests/data/retryable_writes/{insertOne.yml → legacy/insertOne.yml} +0 -0
  521. data/spec/spec_tests/data/retryable_writes/{replaceOne-errorLabels.yml → legacy/replaceOne-errorLabels.yml} +0 -0
  522. data/spec/spec_tests/data/retryable_writes/{replaceOne-serverErrors.yml → legacy/replaceOne-serverErrors.yml} +1 -1
  523. data/spec/spec_tests/data/retryable_writes/{replaceOne.yml → legacy/replaceOne.yml} +0 -0
  524. data/spec/spec_tests/data/retryable_writes/{updateMany.yml → legacy/updateMany.yml} +0 -0
  525. data/spec/spec_tests/data/retryable_writes/{updateOne-errorLabels.yml → legacy/updateOne-errorLabels.yml} +0 -0
  526. data/spec/spec_tests/data/retryable_writes/{updateOne-serverErrors.yml → legacy/updateOne-serverErrors.yml} +1 -1
  527. data/spec/spec_tests/data/retryable_writes/{updateOne.yml → legacy/updateOne.yml} +0 -0
  528. data/spec/spec_tests/data/retryable_writes/unified/bulkWrite-serverErrors.yml +96 -0
  529. data/spec/spec_tests/data/retryable_writes/unified/handshakeError.yml +137 -0
  530. data/spec/spec_tests/data/retryable_writes/unified/insertOne-serverErrors.yml +78 -0
  531. data/spec/spec_tests/data/sdam/errors/prefer-error-code.yml +2 -2
  532. data/spec/spec_tests/data/sdam_integration/hello-command-error.yml +6 -14
  533. data/spec/spec_tests/data/sdam_integration/hello-network-error.yml +4 -14
  534. data/spec/spec_tests/data/sdam_integration/hello-timeout.yml +8 -14
  535. data/spec/spec_tests/data/seed_list_discovery/load-balanced/loadBalanced-no-results.yml +5 -0
  536. data/spec/spec_tests/data/seed_list_discovery/load-balanced/srvMaxHosts-conflicts_with_loadBalanced-true-txt.yml +5 -0
  537. data/spec/spec_tests/data/seed_list_discovery/load-balanced/srvMaxHosts-conflicts_with_loadBalanced-true.yml +5 -0
  538. data/spec/spec_tests/data/seed_list_discovery/load-balanced/srvMaxHosts-zero-txt.yml +10 -0
  539. data/spec/spec_tests/data/seed_list_discovery/load-balanced/srvMaxHosts-zero.yml +10 -0
  540. data/spec/spec_tests/data/seed_list_discovery/replica-set/srv-service-name.yml +11 -0
  541. data/spec/spec_tests/data/seed_list_discovery/replica-set/srvMaxHosts-conflicts_with_replicaSet-txt.yml +5 -0
  542. data/spec/spec_tests/data/seed_list_discovery/replica-set/srvMaxHosts-conflicts_with_replicaSet.yml +5 -0
  543. data/spec/spec_tests/data/seed_list_discovery/replica-set/srvMaxHosts-equal_to_srv_records.yml +16 -0
  544. data/spec/spec_tests/data/seed_list_discovery/replica-set/srvMaxHosts-greater_than_srv_records.yml +15 -0
  545. data/spec/spec_tests/data/seed_list_discovery/replica-set/srvMaxHosts-less_than_srv_records.yml +15 -0
  546. data/spec/spec_tests/data/seed_list_discovery/replica-set/srvMaxHosts-zero-txt.yml +15 -0
  547. data/spec/spec_tests/data/seed_list_discovery/replica-set/srvMaxHosts-zero.yml +15 -0
  548. data/spec/spec_tests/data/seed_list_discovery/sharded/srvMaxHosts-equal_to_srv_records.yml +13 -0
  549. data/spec/spec_tests/data/seed_list_discovery/sharded/srvMaxHosts-greater_than_srv_records.yml +12 -0
  550. data/spec/spec_tests/data/seed_list_discovery/sharded/srvMaxHosts-less_than_srv_records.yml +10 -0
  551. data/spec/spec_tests/data/seed_list_discovery/sharded/srvMaxHosts-zero.yml +11 -0
  552. data/spec/spec_tests/data/server_selection/Unknown/read/ghost.yml +11 -0
  553. data/spec/spec_tests/data/server_selection/Unknown/write/ghost.yml +11 -0
  554. data/spec/spec_tests/data/sessions_unified/driver-sessions-server-support.yml +123 -0
  555. data/spec/spec_tests/data/sessions_unified/snapshot-sessions-not-supported-client-error.yml +9 -3
  556. data/spec/spec_tests/data/transactions/error-labels.yml +1 -1
  557. data/spec/spec_tests/data/transactions/errors-client.yml +8 -9
  558. data/spec/spec_tests/data/transactions/mongos-recovery-token.yml +1 -1
  559. data/spec/spec_tests/data/transactions/retryable-abort-errorLabels.yml +0 -2
  560. data/spec/spec_tests/data/transactions/retryable-abort.yml +7 -9
  561. data/spec/spec_tests/data/transactions/retryable-commit-errorLabels.yml +0 -2
  562. data/spec/spec_tests/data/transactions/retryable-commit.yml +7 -9
  563. data/spec/spec_tests/data/transactions/retryable-writes.yml +0 -2
  564. data/spec/spec_tests/data/transactions_unified/do-not-retry-read-in-transaction.yml +64 -0
  565. data/spec/spec_tests/data/transactions_unified/retryable-abort-handshake.yml +118 -0
  566. data/spec/spec_tests/data/transactions_unified/retryable-commit-handshake.yml +118 -0
  567. data/spec/spec_tests/data/unified/invalid/expectedEventsForClient-ignoreExtraEvents-type.yml +15 -0
  568. data/spec/spec_tests/data/unified/valid-fail/operation-unsupported.yml +13 -0
  569. data/spec/spec_tests/data/unified/valid-pass/expectedEventsForClient-ignoreExtraEvents.yml +78 -0
  570. data/spec/spec_tests/data/unified/valid-pass/poc-change-streams.yml +4 -1
  571. data/spec/spec_tests/data/unified/valid-pass/poc-command-monitoring.yml +3 -3
  572. data/spec/spec_tests/data/unified/valid-pass/poc-transactions.yml +3 -2
  573. data/spec/spec_tests/data/uri_options/srv-options.yml +96 -0
  574. data/spec/spec_tests/data/versioned_api/crud-api-version-1-strict.yml +6 -4
  575. data/spec/spec_tests/data/versioned_api/crud-api-version-1.yml +7 -5
  576. data/spec/spec_tests/gridfs_unified_spec.rb +13 -0
  577. data/spec/spec_tests/retryable_reads_spec.rb +4 -1
  578. data/spec/spec_tests/retryable_reads_unified_spec.rb +22 -0
  579. data/spec/spec_tests/retryable_writes_spec.rb +4 -1
  580. data/spec/spec_tests/retryable_writes_unified_spec.rb +21 -0
  581. data/spec/spec_tests/seed_list_discovery_spec.rb +10 -1
  582. data/spec/spec_tests/unified_spec.rb +6 -1
  583. data/spec/stress/connection_pool_timing_spec.rb +3 -2
  584. data/spec/stress/fork_reconnect_stress_spec.rb +3 -2
  585. data/spec/support/authorization.rb +1 -1
  586. data/spec/support/background_thread_registry.rb +3 -13
  587. data/spec/support/certificates/atlas-ocsp-ca.crt +40 -47
  588. data/spec/support/certificates/atlas-ocsp.crt +101 -106
  589. data/spec/support/certificates/retrieve-atlas-cert +38 -0
  590. data/spec/support/cluster_tools.rb +1 -1
  591. data/spec/support/common_shortcuts.rb +22 -0
  592. data/spec/support/crypt/corpus/corpus-encrypted.json +9515 -0
  593. data/spec/support/crypt/corpus/corpus-key-aws.json +32 -32
  594. data/spec/support/crypt/corpus/corpus-key-azure.json +33 -0
  595. data/spec/support/crypt/corpus/corpus-key-gcp.json +35 -0
  596. data/spec/support/crypt/corpus/corpus-key-kmip.json +32 -0
  597. data/spec/support/crypt/corpus/corpus-key-local.json +30 -30
  598. data/spec/support/crypt/corpus/corpus-schema.json +4399 -121
  599. data/spec/support/crypt/corpus/corpus.json +4999 -37
  600. data/spec/support/crypt/data_keys/key_document_azure.json +33 -0
  601. data/spec/support/crypt/data_keys/key_document_gcp.json +37 -0
  602. data/spec/support/crypt/data_keys/key_document_kmip.json +32 -0
  603. data/spec/support/crypt/encryptedFields.json +33 -0
  604. data/spec/support/crypt/keys/key1-document.json +30 -0
  605. data/spec/support/crypt/schema_maps/schema_map_azure.json +17 -0
  606. data/spec/support/crypt/schema_maps/schema_map_azure_key_alt_names.json +12 -0
  607. data/spec/support/crypt/schema_maps/schema_map_gcp.json +17 -0
  608. data/spec/support/crypt/schema_maps/schema_map_gcp_key_alt_names.json +12 -0
  609. data/spec/support/crypt/schema_maps/schema_map_kmip.json +17 -0
  610. data/spec/support/crypt/schema_maps/schema_map_kmip_key_alt_names.json +12 -0
  611. data/spec/support/crypt.rb +258 -13
  612. data/spec/support/macros.rb +28 -0
  613. data/spec/support/mongos_macros.rb +17 -0
  614. data/spec/support/shared/scram_conversation.rb +2 -1
  615. data/spec/support/shared/session.rb +13 -7
  616. data/spec/support/spec_config.rb +90 -1
  617. data/spec/support/utils.rb +26 -5
  618. data.tar.gz.sig +0 -0
  619. metadata +604 -290
  620. metadata.gz.sig +0 -0
  621. data/lib/mongo/operation/delete/legacy.rb +0 -64
  622. data/lib/mongo/operation/insert/legacy.rb +0 -68
  623. data/lib/mongo/operation/update/legacy/result.rb +0 -112
  624. data/lib/mongo/operation/update/legacy.rb +0 -76
  625. data/spec/mongo/dbref_spec.rb +0 -152
  626. data/spec/mongo/operation/kill_cursors_spec.rb +0 -47
  627. data/spec/spec_tests/change_streams_spec.rb +0 -93
  628. data/spec/spec_tests/command_monitoring_spec.rb +0 -71
  629. data/spec/spec_tests/data/change_streams/change-streams-errors.yml +0 -101
  630. data/spec/spec_tests/data/change_streams/change-streams-resume-allowlist.yml +0 -1173
  631. data/spec/spec_tests/data/change_streams/change-streams-resume-errorLabels.yml +0 -1105
  632. data/spec/spec_tests/data/change_streams/change-streams.yml +0 -535
  633. data/spec/spec_tests/data/command_monitoring/bulkWrite.yml +0 -49
  634. data/spec/spec_tests/data/command_monitoring/command.yml +0 -61
  635. data/spec/spec_tests/data/command_monitoring/deleteMany.yml +0 -55
  636. data/spec/spec_tests/data/command_monitoring/deleteOne.yml +0 -55
  637. data/spec/spec_tests/data/command_monitoring/find.yml +0 -266
  638. data/spec/spec_tests/data/command_monitoring/insertMany.yml +0 -75
  639. data/spec/spec_tests/data/command_monitoring/insertOne.yml +0 -51
  640. data/spec/spec_tests/data/command_monitoring/unacknowledgedBulkWrite.yml +0 -34
  641. data/spec/spec_tests/data/command_monitoring/updateMany.yml +0 -65
  642. data/spec/spec_tests/data/command_monitoring/updateOne.yml +0 -90
  643. data/spec/spec_tests/data/crud_v2/aggregate-merge.yml +0 -103
  644. data/spec/spec_tests/data/crud_v2/aggregate-out-readConcern.yml +0 -111
  645. data/spec/spec_tests/data/crud_v2/bulkWrite-arrayFilters.yml +0 -103
  646. data/spec/spec_tests/data/crud_v2/bulkWrite-delete-hint-clientError.yml +0 -63
  647. data/spec/spec_tests/data/crud_v2/bulkWrite-delete-hint-serverError.yml +0 -92
  648. data/spec/spec_tests/data/crud_v2/bulkWrite-delete-hint.yml +0 -103
  649. data/spec/spec_tests/data/crud_v2/bulkWrite-update-hint-clientError.yml +0 -90
  650. data/spec/spec_tests/data/crud_v2/bulkWrite-update-hint-serverError.yml +0 -147
  651. data/spec/spec_tests/data/crud_v2/bulkWrite-update-hint.yml +0 -164
  652. data/spec/spec_tests/data/crud_v2/db-aggregate.yml +0 -39
  653. data/spec/spec_tests/data/crud_v2/deleteMany-hint-clientError.yml +0 -43
  654. data/spec/spec_tests/data/crud_v2/deleteMany-hint-serverError.yml +0 -62
  655. data/spec/spec_tests/data/crud_v2/deleteMany-hint.yml +0 -58
  656. data/spec/spec_tests/data/crud_v2/deleteOne-hint-clientError.yml +0 -41
  657. data/spec/spec_tests/data/crud_v2/deleteOne-hint-serverError.yml +0 -60
  658. data/spec/spec_tests/data/crud_v2/deleteOne-hint.yml +0 -57
  659. data/spec/spec_tests/data/crud_v2/find-allowdiskuse-clientError.yml +0 -28
  660. data/spec/spec_tests/data/crud_v2/find-allowdiskuse-serverError.yml +0 -44
  661. data/spec/spec_tests/data/crud_v2/find-allowdiskuse.yml +0 -50
  662. data/spec/spec_tests/data/crud_v2/findOneAndDelete-hint-clientError.yml +0 -45
  663. data/spec/spec_tests/data/crud_v2/findOneAndDelete-hint-serverError.yml +0 -60
  664. data/spec/spec_tests/data/crud_v2/findOneAndDelete-hint.yml +0 -56
  665. data/spec/spec_tests/data/crud_v2/findOneAndReplace-hint-clientError.yml +0 -40
  666. data/spec/spec_tests/data/crud_v2/findOneAndReplace-hint-serverError.yml +0 -59
  667. data/spec/spec_tests/data/crud_v2/findOneAndReplace-hint.yml +0 -55
  668. data/spec/spec_tests/data/crud_v2/findOneAndUpdate-hint-clientError.yml +0 -40
  669. data/spec/spec_tests/data/crud_v2/findOneAndUpdate-hint-serverError.yml +0 -58
  670. data/spec/spec_tests/data/crud_v2/findOneAndUpdate-hint.yml +0 -55
  671. data/spec/spec_tests/data/crud_v2/replaceOne-hint.yml +0 -61
  672. data/spec/spec_tests/data/crud_v2/unacknowledged-bulkWrite-delete-hint-clientError.yml +0 -60
  673. data/spec/spec_tests/data/crud_v2/unacknowledged-bulkWrite-update-hint-clientError.yml +0 -88
  674. data/spec/spec_tests/data/crud_v2/unacknowledged-deleteMany-hint-clientError.yml +0 -40
  675. data/spec/spec_tests/data/crud_v2/unacknowledged-deleteOne-hint-clientError.yml +0 -38
  676. data/spec/spec_tests/data/crud_v2/unacknowledged-findOneAndDelete-hint-clientError.yml +0 -42
  677. data/spec/spec_tests/data/crud_v2/unacknowledged-findOneAndReplace-hint-clientError.yml +0 -40
  678. data/spec/spec_tests/data/crud_v2/unacknowledged-findOneAndUpdate-hint-clientError.yml +0 -40
  679. data/spec/spec_tests/data/crud_v2/unacknowledged-replaceOne-hint-clientError.yml +0 -40
  680. data/spec/spec_tests/data/crud_v2/unacknowledged-updateMany-hint-clientError.yml +0 -43
  681. data/spec/spec_tests/data/crud_v2/unacknowledged-updateOne-hint-clientError.yml +0 -40
  682. data/spec/spec_tests/data/crud_v2/updateMany-hint-clientError.yml +0 -45
  683. data/spec/spec_tests/data/crud_v2/updateMany-hint-serverError.yml +0 -66
  684. data/spec/spec_tests/data/crud_v2/updateMany-hint.yml +0 -65
  685. data/spec/spec_tests/data/crud_v2/updateOne-hint-clientError.yml +0 -43
  686. data/spec/spec_tests/data/crud_v2/updateOne-hint-serverError.yml +0 -62
  687. data/spec/spec_tests/data/crud_v2/updateOne-hint.yml +0 -61
  688. data/spec/spec_tests/data/crud_v2/updateWithPipelines.yml +0 -157
  689. data/spec/spec_tests/data/retryable_reads/estimatedDocumentCount-4.9.yml +0 -60
  690. data/spec/spec_tests/data/retryable_reads/estimatedDocumentCount-serverErrors-4.9.yml +0 -146
  691. data/spec/support/crypt/corpus/corpus_encrypted.json +0 -4152
  692. data/spec/support/session_registry.rb +0 -55
@@ -83,11 +83,21 @@ describe Mongo::Server::ConnectionPool do
83
83
 
84
84
  context 'when min size exceeds default max size' do
85
85
  let (:options) do
86
- { min_pool_size: 10 }
86
+ { min_pool_size: 50 }
87
87
  end
88
88
 
89
89
  it 'sets max size to equal provided min size' do
90
- expect(pool.max_size).to eq(10)
90
+ expect(pool.max_size).to eq(50)
91
+ end
92
+ end
93
+
94
+ context 'when min size is provided and max size is zero (unlimited)' do
95
+ let (:options) do
96
+ { min_size: 10, max_size: 0 }
97
+ end
98
+
99
+ it 'sets max size to zero (unlimited)' do
100
+ expect(pool.max_size).to eq(0)
91
101
  end
92
102
  end
93
103
 
@@ -155,7 +165,7 @@ describe Mongo::Server::ConnectionPool do
155
165
 
156
166
  context 'when no pool size option is provided' do
157
167
  it 'returns the default size' do
158
- expect(pool.max_size).to eq(5)
168
+ expect(pool.max_size).to eq(20)
159
169
  end
160
170
  end
161
171
 
@@ -165,7 +175,7 @@ describe Mongo::Server::ConnectionPool do
165
175
  end
166
176
 
167
177
  it 'returns max size' do
168
- expect(pool.max_size).to eq(5)
178
+ expect(pool.max_size).to eq(20)
169
179
  end
170
180
  end
171
181
  end
@@ -316,16 +326,22 @@ describe Mongo::Server::ConnectionPool do
316
326
  end
317
327
  end
318
328
 
319
- context 'connection of the same generation as pool' do
320
- # These tests are also applicable to load balancers, but
321
- # require different setup and assertions because load balancers
322
- # do not have a single global generation.
323
- require_topology :single, :replica_set, :sharded
324
-
325
- before do
326
- expect(pool.generation).to eq(connection.generation)
329
+ shared_examples 'does not add connection to pool' do
330
+ it 'disconnects connection and does not add connection to pool' do
331
+ # connection was checked out
332
+ expect(pool.available_count).to eq(0)
333
+ expect(pool.size).to eq(1)
334
+ expect(connection).to receive(:disconnect!)
335
+ pool.check_in(connection)
336
+ # connection is not added to the pool, and no replacement
337
+ # connection has been created at this point
338
+ expect(pool.available_count).to eq(0)
339
+ expect(pool.size).to eq(0)
340
+ expect(pool.check_out).not_to eq(connection)
327
341
  end
342
+ end
328
343
 
344
+ shared_examples 'adds connection to the pool' do
329
345
  it 'adds the connection to the pool' do
330
346
  # connection is checked out
331
347
  expect(pool.available_count).to eq(0)
@@ -338,19 +354,17 @@ describe Mongo::Server::ConnectionPool do
338
354
  end
339
355
  end
340
356
 
341
- shared_examples 'does not add connection to pool' do
342
- it 'disconnects connection and does not add connection to pool' do
343
- # connection was checked out
344
- expect(pool.available_count).to eq(0)
345
- expect(pool.size).to eq(1)
346
- expect(connection).to receive(:disconnect!)
347
- pool.check_in(connection)
348
- # connection is not added to the pool, and no replacement
349
- # connection has been created at this point
350
- expect(pool.available_count).to eq(0)
351
- expect(pool.size).to eq(0)
352
- expect(pool.check_out).not_to eq(connection)
357
+ context 'connection of the same generation as pool' do
358
+ # These tests are also applicable to load balancers, but
359
+ # require different setup and assertions because load balancers
360
+ # do not have a single global generation.
361
+ require_topology :single, :replica_set, :sharded
362
+
363
+ before do
364
+ expect(pool.generation).to eq(connection.generation)
353
365
  end
366
+
367
+ it_behaves_like 'adds connection to the pool'
354
368
  end
355
369
 
356
370
  context 'connection of earlier generation than pool' do
@@ -359,18 +373,37 @@ describe Mongo::Server::ConnectionPool do
359
373
  # do not have a single global generation.
360
374
  require_topology :single, :replica_set, :sharded
361
375
 
362
- let(:connection) do
363
- pool.check_out.tap do |connection|
364
- expect(connection).to receive(:generation).at_least(:once).and_return(0)
365
- expect(connection).not_to receive(:record_checkin!)
376
+ context 'when connection is not pinned' do
377
+ let(:connection) do
378
+ pool.check_out.tap do |connection|
379
+ expect(connection).to receive(:generation).at_least(:once).and_return(0)
380
+ expect(connection).not_to receive(:record_checkin!)
381
+ end
366
382
  end
383
+
384
+ before do
385
+ expect(connection.generation).to be < pool.generation
386
+ end
387
+
388
+ it_behaves_like 'does not add connection to pool'
367
389
  end
368
390
 
369
- before do
370
- expect(connection.generation).to be < pool.generation
391
+ context 'when connection is pinned' do
392
+ let(:connection) do
393
+ pool.check_out.tap do |connection|
394
+ allow(connection).to receive(:pinned?).and_return(true)
395
+ expect(connection).to receive(:generation).at_least(:once).and_return(0)
396
+ expect(connection).to receive(:record_checkin!)
397
+ end
398
+ end
399
+
400
+ before do
401
+ expect(connection.generation).to be < pool.generation
402
+ end
403
+
404
+ it_behaves_like 'adds connection to the pool'
371
405
  end
372
406
 
373
- it_behaves_like 'does not add connection to pool'
374
407
  end
375
408
 
376
409
  context 'connection of later generation than pool' do
@@ -437,6 +470,18 @@ describe Mongo::Server::ConnectionPool do
437
470
  server.pool
438
471
  end
439
472
 
473
+ context 'when max_size is zero (unlimited)' do
474
+ let(:options) do
475
+ { max_size: 0 }
476
+ end
477
+
478
+ it 'checks out a connection' do
479
+ expect do
480
+ pool.check_out
481
+ end.not_to raise_error
482
+ end
483
+ end
484
+
440
485
  context 'when a connection is checked out on a different thread' do
441
486
 
442
487
  let!(:connection) do
@@ -473,23 +518,45 @@ describe Mongo::Server::ConnectionPool do
473
518
  { max_pool_size: 2, max_idle_time: 0.1 }
474
519
  end
475
520
 
476
- let(:connection) do
477
- pool.check_out.tap do |connection|
478
- allow(connection).to receive(:generation).and_return(pool.generation)
479
- allow(connection).to receive(:record_checkin!).and_return(connection)
480
- expect(connection).to receive(:last_checkin).at_least(:once).and_return(Time.now - 10)
521
+ context 'when connection is not pinned' do
522
+ let(:connection) do
523
+ pool.check_out.tap do |connection|
524
+ allow(connection).to receive(:generation).and_return(pool.generation)
525
+ allow(connection).to receive(:record_checkin!).and_return(connection)
526
+ expect(connection).to receive(:last_checkin).at_least(:once).and_return(Time.now - 10)
527
+ end
481
528
  end
482
- end
483
529
 
484
- before do
485
- pool.check_in(connection)
530
+ before do
531
+ pool.check_in(connection)
532
+ end
533
+
534
+ it 'closes stale connection and creates a new one' do
535
+ expect(connection).to receive(:disconnect!)
536
+ expect(Mongo::Server::Connection).to receive(:new).and_call_original
537
+ pool.check_out
538
+ end
486
539
  end
487
540
 
488
- it 'closes stale connection and creates a new one' do
489
- expect(connection).to receive(:disconnect!)
490
- expect(Mongo::Server::Connection).to receive(:new).and_call_original
491
- pool.check_out
541
+ context 'when connection is pinned' do
542
+ let(:connection) do
543
+ pool.check_out.tap do |connection|
544
+ allow(connection).to receive(:generation).and_return(pool.generation)
545
+ allow(connection).to receive(:record_checkin!).and_return(connection)
546
+ expect(connection).to receive(:pinned?).and_return(true)
547
+ end
548
+ end
549
+
550
+ before do
551
+ pool.check_in(connection)
552
+ end
553
+
554
+ it 'does not close stale connection' do
555
+ expect(connection).not_to receive(:disconnect!)
556
+ pool.check_out
557
+ end
492
558
  end
559
+
493
560
  end
494
561
 
495
562
  context 'when there are no available connections' do
@@ -520,24 +587,24 @@ describe Mongo::Server::ConnectionPool do
520
587
  end
521
588
  end
522
589
 
523
- context 'with service_id' do
590
+ context 'with connection_global_id' do
524
591
  require_topology :load_balanced
525
592
 
526
- let(:service_id) do
593
+ let(:connection_global_id) do
527
594
  pool.with_connection do |connection|
528
- connection.service_id.should_not be nil
529
- connection.service_id
595
+ connection.global_id.should_not be nil
596
+ connection.global_id
530
597
  end
531
598
  end
532
599
 
533
600
  it 'raises a timeout error' do
534
601
  expect(Mongo::Server::Connection).to receive(:new).once.and_call_original
535
- service_id
602
+ connection_global_id
536
603
 
537
- pool.check_out(service_id: service_id)
604
+ pool.check_out(connection_global_id: connection_global_id)
538
605
 
539
606
  expect {
540
- pool.check_out(service_id: service_id)
607
+ pool.check_out(connection_global_id: connection_global_id)
541
608
  }.to raise_error(Mongo::Error::ConnectionCheckOutTimeout)
542
609
 
543
610
  expect(pool.size).to eq(1)
@@ -545,13 +612,13 @@ describe Mongo::Server::ConnectionPool do
545
612
 
546
613
  it 'waits for the timeout' do
547
614
  expect(Mongo::Server::Connection).to receive(:new).once.and_call_original
548
- service_id
615
+ connection_global_id
549
616
 
550
- pool.check_out(service_id: service_id)
617
+ pool.check_out(connection_global_id: connection_global_id)
551
618
 
552
619
  start_time = Mongo::Utils.monotonic_time
553
620
  expect {
554
- pool.check_out(service_id: service_id)
621
+ pool.check_out(connection_global_id: connection_global_id)
555
622
  }.to raise_error(Mongo::Error::ConnectionCheckOutTimeout)
556
623
  elapsed_time = Mongo::Utils.monotonic_time - start_time
557
624
 
@@ -612,6 +612,7 @@ describe Mongo::Server::Connection do
612
612
  end
613
613
 
614
614
  describe '#dispatch' do
615
+ require_no_required_api_version
615
616
 
616
617
  let(:server) { monitored_server }
617
618
 
@@ -634,50 +635,31 @@ describe Mongo::Server::Connection do
634
635
  end
635
636
  end
636
637
 
637
- let(:documents) do
638
- [{ 'name' => 'testing' }]
639
- end
640
-
641
- let(:insert) do
642
- Mongo::Protocol::Insert.new(SpecConfig.instance.test_db, TEST_COLL, documents)
643
- end
644
-
645
- let(:query) do
646
- Mongo::Protocol::Query.new(SpecConfig.instance.test_db, TEST_COLL, { 'name' => 'testing' })
638
+ (0..2).each do |i|
639
+ let("msg#{i}".to_sym) do
640
+ Mongo::Protocol::Msg.new(
641
+ [],
642
+ {},
643
+ {ping: 1, :$db => SpecConfig.instance.test_db}
644
+ )
645
+ end
647
646
  end
648
647
 
649
648
  context 'when providing a single message' do
650
649
 
651
650
  let(:reply) do
652
- connection.dispatch([ query ], context)
653
- end
654
-
655
- before do
656
- authorized_collection.delete_many
657
- authorized_collection.insert_one(name: 'testing')
651
+ connection.dispatch([ msg0 ], context)
658
652
  end
659
653
 
660
654
  it 'it dispatches the message to the socket' do
661
- expect(reply.documents.first['name']).to eq('testing')
655
+ expect(reply.payload['reply']['ok']).to eq(1.0)
662
656
  end
663
657
  end
664
658
 
665
659
  context 'when providing multiple messages' do
666
660
 
667
- let(:selector) do
668
- { :getlasterror => 1 }
669
- end
670
-
671
- let(:command) do
672
- Mongo::Protocol::Query.new(SpecConfig.instance.test_db, '$cmd', selector, :limit => -1)
673
- end
674
-
675
661
  let(:reply) do
676
- connection.dispatch([ insert, command ], context)
677
- end
678
-
679
- before do
680
- authorized_collection.delete_many
662
+ connection.dispatch([ msg0, msg1 ], context)
681
663
  end
682
664
 
683
665
  it 'raises ArgumentError' do
@@ -689,43 +671,23 @@ describe Mongo::Server::Connection do
689
671
 
690
672
  context 'when the response_to does not match the request_id' do
691
673
 
692
- let(:documents) do
693
- [{ 'name' => 'bob' }, { 'name' => 'alice' }]
694
- end
695
-
696
- let(:insert) do
697
- Mongo::Protocol::Insert.new(SpecConfig.instance.test_db, TEST_COLL, documents)
698
- end
699
-
700
- let(:query_bob) do
701
- Mongo::Protocol::Query.new(SpecConfig.instance.test_db, TEST_COLL, { name: 'bob' })
702
- end
703
-
704
- let(:query_alice) do
705
- Mongo::Protocol::Query.new(SpecConfig.instance.test_db, TEST_COLL, { name: 'alice' })
706
- end
707
-
708
674
  before do
709
- authorized_collection.delete_many
710
- end
711
-
712
- before do
713
- connection.dispatch([ insert ], context)
675
+ connection.dispatch([ msg0 ], context)
714
676
  # Fake a query for which we did not read the response. See RUBY-1117
715
- allow(query_bob).to receive(:replyable?) { false }
716
- connection.dispatch([ query_bob ], context)
677
+ allow(msg1).to receive(:replyable?) { false }
678
+ connection.dispatch([ msg1 ], context)
717
679
  end
718
680
 
719
681
  it 'raises an UnexpectedResponse error' do
720
682
  expect {
721
- connection.dispatch([ query_alice ], context)
683
+ connection.dispatch([ msg0 ], context)
722
684
  }.to raise_error(Mongo::Error::UnexpectedResponse,
723
685
  /Got response for request ID \d+ but expected response for request ID \d+/)
724
686
  end
725
687
 
726
688
  it 'marks connection perished' do
727
689
  expect {
728
- connection.dispatch([ query_alice ], context)
690
+ connection.dispatch([ msg0 ], context)
729
691
  }.to raise_error(Mongo::Error::UnexpectedResponse)
730
692
 
731
693
  connection.should be_error
@@ -733,11 +695,11 @@ describe Mongo::Server::Connection do
733
695
 
734
696
  it 'makes the connection no longer usable' do
735
697
  expect {
736
- connection.dispatch([ query_alice ], context)
698
+ connection.dispatch([ msg0 ], context)
737
699
  }.to raise_error(Mongo::Error::UnexpectedResponse)
738
700
 
739
701
  expect {
740
- connection.dispatch([ query_alice ], context)
702
+ connection.dispatch([ msg0 ], context)
741
703
  }.to raise_error(Mongo::Error::ConnectionPerished)
742
704
  end
743
705
  end
@@ -745,92 +707,47 @@ describe Mongo::Server::Connection do
745
707
  context 'when a request is interrupted (Thread.kill)' do
746
708
  require_no_required_api_version
747
709
 
748
- let(:documents) do
749
- [{ 'name' => 'bob' }, { 'name' => 'alice' }]
750
- end
751
-
752
- let(:insert) do
753
- Mongo::Protocol::Insert.new(SpecConfig.instance.test_db, TEST_COLL, documents)
754
- end
755
-
756
- let(:query_bob) do
757
- Mongo::Protocol::Query.new(SpecConfig.instance.test_db, TEST_COLL, { name: 'bob' })
758
- end
759
-
760
- let(:query_alice) do
761
- Mongo::Protocol::Query.new(SpecConfig.instance.test_db, TEST_COLL, { name: 'alice' })
762
- end
763
-
764
710
  before do
765
711
  authorized_collection.delete_many
766
- connection.dispatch([ insert ], context)
712
+ connection.dispatch([ msg0 ], context)
767
713
  end
768
714
 
769
715
  it 'closes the socket and does not use it for subsequent requests' do
770
716
  t = Thread.new {
771
717
  # Kill the thread just before the reply is read
772
718
  allow(Mongo::Protocol::Reply).to receive(:deserialize_header) { t.kill && !t.alive? }
773
- connection.dispatch([ query_bob ], context)
719
+ connection.dispatch([ msg1 ], context)
774
720
  }
775
721
  t.join
776
722
  allow(Mongo::Protocol::Message).to receive(:deserialize_header).and_call_original
777
- resp = connection.dispatch([ query_alice ], context)
778
- expect(resp.documents.first['name']).to eq('alice')
723
+ resp = connection.dispatch([ msg2 ], context)
724
+ expect(resp.payload['reply']['ok']).to eq(1.0)
779
725
  end
780
726
  end
781
727
 
782
728
  context 'when the message exceeds the max size' do
729
+ require_no_linting
783
730
 
784
- context 'when the message is an insert' do
785
-
786
- before do
787
- allow(connection).to receive(:max_message_size).and_return(200)
788
- end
789
-
790
- let(:documents) do
791
- [{ 'name' => 'testing' } ] * 10
792
- end
793
-
794
- let(:reply) do
795
- connection.dispatch([ insert ], context)
796
- end
797
-
798
- it 'checks the size against the max message size' do
799
- expect {
800
- reply
801
- }.to raise_exception(Mongo::Error::MaxMessageSize)
802
- end
731
+ let(:command) do
732
+ Mongo::Protocol::Msg.new(
733
+ [],
734
+ {},
735
+ {ping: 1, padding: 'x'*16384, :$db => SpecConfig.instance.test_db}
736
+ )
803
737
  end
804
738
 
805
- context 'when the message is a command' do
806
- # Server description is frozen when linting is enabled, which is
807
- # incompatible with expectations set on it in this test
808
- require_no_linting
809
-
810
- let(:selector) do
811
- # The driver allows up to 16KiB for command overhead on top of
812
- # the max bson object size reported by the server.
813
- # Add that much padding.
814
- { :getlasterror => '1', 'padding' => 'x'*16384 }
815
- end
816
-
817
- let(:command) do
818
- Mongo::Protocol::Query.new(SpecConfig.instance.test_db, '$cmd', selector, :limit => -1)
819
- end
820
-
821
- let(:reply) do
822
- connection.dispatch([ command ], context)
823
- end
739
+ let(:reply) do
740
+ connection.dispatch([ command ], context)
741
+ end
824
742
 
825
- it 'checks the size against the max bson size' do
826
- # 100 works for non-x509 auth.
827
- # 10 is needed for x509 auth due to smaller payloads, apparently.
828
- expect_any_instance_of(Mongo::Server::Description).to receive(
829
- :max_bson_object_size).at_least(:once).and_return(10)
830
- expect do
831
- reply
832
- end.to raise_exception(Mongo::Error::MaxBSONSize)
833
- end
743
+ it 'checks the size against the max bson size' do
744
+ # 100 works for non-x509 auth.
745
+ # 10 is needed for x509 auth due to smaller payloads, apparently.
746
+ expect_any_instance_of(Mongo::Server::Description).to receive(
747
+ :max_bson_object_size).at_least(:once).and_return(10)
748
+ expect do
749
+ reply
750
+ end.to raise_exception(Mongo::Error::MaxBSONSize)
834
751
  end
835
752
  end
836
753
 
@@ -861,7 +778,7 @@ describe Mongo::Server::Connection do
861
778
 
862
779
  let(:result) do
863
780
  expect do
864
- connection.dispatch([ insert ], context)
781
+ connection.dispatch([ msg0 ], context)
865
782
  end.to raise_error(Mongo::Error::SocketError)
866
783
  end
867
784
 
@@ -874,10 +791,12 @@ describe Mongo::Server::Connection do
874
791
  require_topology :load_balanced
875
792
 
876
793
  it 'disconnects connection pool for service id' do
877
- connection.service_id.should_not be nil
794
+ connection.global_id.should_not be nil
878
795
 
879
796
  RSpec::Mocks.with_temporary_scope do
880
- expect(server.pool).to receive(:disconnect!).with(service_id: connection.service_id)
797
+ expect(server.pool).to receive(:disconnect!).with(
798
+ service_id: connection.service_id
799
+ )
881
800
  result
882
801
  end
883
802
  end
@@ -918,7 +837,7 @@ describe Mongo::Server::Connection do
918
837
 
919
838
  let(:result) do
920
839
  expect do
921
- connection.dispatch([ insert ], context)
840
+ connection.dispatch([ msg0 ], context)
922
841
  end.to raise_error(Mongo::Error::SocketTimeoutError)
923
842
  end
924
843
 
@@ -991,20 +910,16 @@ describe Mongo::Server::Connection do
991
910
  end
992
911
  end
993
912
 
994
- let(:message) do
995
- insert
996
- end
997
-
998
913
  before do
999
- expect(message).to receive(:replyable?) { false }
1000
- connection.send(:deliver, message, context)
914
+ expect(msg0).to receive(:replyable?) { false }
915
+ connection.send(:deliver, msg0, context)
1001
916
 
1002
917
  connection.send(:socket).instance_variable_set(:@timeout, -(Time.now.to_i))
1003
918
  end
1004
919
 
1005
920
  let(:reply) do
1006
921
  Mongo::Protocol::Message.deserialize(connection.send(:socket),
1007
- 16*1024*1024, message.request_id)
922
+ 16*1024*1024, msg0.request_id)
1008
923
  end
1009
924
 
1010
925
  it 'raises a timeout error' do
@@ -1014,30 +929,6 @@ describe Mongo::Server::Connection do
1014
929
  end
1015
930
  end
1016
931
  end
1017
-
1018
- =begin this is now handled by connection pool
1019
- context 'when the process is forked' do
1020
-
1021
- let(:insert) do
1022
- Mongo::Protocol::Insert.new(SpecConfig.instance.test_db, TEST_COLL, documents)
1023
- end
1024
-
1025
- before do
1026
- authorized_collection.delete_many
1027
- expect(Process).to receive(:pid).at_least(:once).and_return(1)
1028
- end
1029
-
1030
- it 'disconnects the connection' do
1031
- expect(connection).to receive(:disconnect!).and_call_original
1032
- connection.dispatch([ insert ])
1033
- end
1034
-
1035
- it 'sets a new pid' do
1036
- connection.dispatch([ insert ])
1037
- expect(connection.send(:pid)).to eq(1)
1038
- end
1039
- end
1040
- =end
1041
932
  end
1042
933
 
1043
934
  describe '#initialize' do
@@ -247,4 +247,28 @@ describe Mongo::Server::Description::Features do
247
247
  end
248
248
  end
249
249
  end
250
+
251
+ describe '#get_more_comment_enabled?' do
252
+ context 'when the wire range includes 9' do
253
+
254
+ let(:wire_versions) do
255
+ 0..9
256
+ end
257
+
258
+ it 'returns true' do
259
+ expect(features).to be_get_more_comment_enabled
260
+ end
261
+ end
262
+
263
+ context 'when the wire range does not include 9' do
264
+
265
+ let(:wire_versions) do
266
+ 0..8
267
+ end
268
+
269
+ it 'returns false' do
270
+ expect(features).to_not be_get_more_comment_enabled
271
+ end
272
+ end
273
+ end
250
274
  end
@@ -77,7 +77,7 @@ describe Mongo::Server::PushMonitor do
77
77
  end.should_not raise_error
78
78
  end
79
79
 
80
- it 'throttles checks' do
80
+ it 'stops the monitoring' do
81
81
  push_monitor
82
82
 
83
83
  start = Mongo::Utils.monotonic_time
@@ -87,13 +87,7 @@ describe Mongo::Server::PushMonitor do
87
87
  push_monitor.do_work
88
88
  end.should_not raise_error
89
89
 
90
- expect(Socket).to receive(:getaddrinfo).and_raise(SocketError.new('Test exception'))
91
- lambda do
92
- push_monitor.do_work
93
- end.should_not raise_error
94
-
95
- elapsed = Mongo::Utils.monotonic_time - start
96
- elapsed.should > 0.5
90
+ push_monitor.running?.should be false
97
91
  end
98
92
  end
99
93
  end