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
@@ -68,7 +68,7 @@ describe Mongo::ClientEncryption do
68
68
  it 'raises an exception' do
69
69
  expect do
70
70
  client_encryption
71
- end.to raise_error(ArgumentError, /kms_providers option must have one of the following keys/)
71
+ end.to raise_error(ArgumentError, /KMS providers options must have one of the following keys/)
72
72
  end
73
73
  end
74
74
  end
@@ -144,17 +144,7 @@ describe Mongo::ClientEncryption do
144
144
  it 'raises an exception' do
145
145
  expect do
146
146
  data_key_id
147
- end.to raise_error(ArgumentError, /options cannot be nil/)
148
- end
149
- end
150
-
151
- context 'with empty options' do
152
- let(:options) { {} }
153
-
154
- it 'raises an exception' do
155
- expect do
156
- data_key_id
157
- end.to raise_error(ArgumentError, /options Hash must contain a key named :master_key/)
147
+ end.to raise_error(ArgumentError, /Key document options must not be nil/)
158
148
  end
159
149
  end
160
150
 
@@ -164,7 +154,7 @@ describe Mongo::ClientEncryption do
164
154
  it 'raises an exception' do
165
155
  expect do
166
156
  data_key_id
167
- end.to raise_error(ArgumentError, /The :master_key option cannot be nil/)
157
+ end.to raise_error(ArgumentError, /Key document options must contain a key named :master_key with a Hash value/)
168
158
  end
169
159
  end
170
160
 
@@ -174,7 +164,7 @@ describe Mongo::ClientEncryption do
174
164
  it 'raises an exception' do
175
165
  expect do
176
166
  data_key_id
177
- end.to raise_error(ArgumentError, /master-key is an invalid :master_key option/)
167
+ end.to raise_error(ArgumentError, /Key document options must contain a key named :master_key with a Hash value/)
178
168
  end
179
169
  end
180
170
 
@@ -184,7 +174,7 @@ describe Mongo::ClientEncryption do
184
174
  it 'raises an exception' do
185
175
  expect do
186
176
  data_key_id
187
- end.to raise_error(ArgumentError, /The value of :region option of the :master_key options hash cannot be nil/)
177
+ end.to raise_error(ArgumentError, /The specified KMS provider options are invalid: {}. AWS key document must be in the format: { region: 'REGION', key: 'KEY' }/)
188
178
  end
189
179
  end
190
180
 
@@ -194,7 +184,7 @@ describe Mongo::ClientEncryption do
194
184
  it 'raises an exception' do
195
185
  expect do
196
186
  data_key_id
197
- end.to raise_error(ArgumentError, /The value of :region option of the :master_key options hash cannot be nil/)
187
+ end.to raise_error(ArgumentError, /The region option must be a String with at least one character; currently have nil/)
198
188
  end
199
189
  end
200
190
 
@@ -204,7 +194,7 @@ describe Mongo::ClientEncryption do
204
194
  it 'raises an exception' do
205
195
  expect do
206
196
  data_key_id
207
- end.to raise_error(ArgumentError, /5 is an invalid AWS master_key region. The value of :region option of the :master_key options hash must be a String/)
197
+ end.to raise_error(ArgumentError, /The region option must be a String with at least one character; currently have 5/)
208
198
  end
209
199
  end
210
200
 
@@ -214,7 +204,7 @@ describe Mongo::ClientEncryption do
214
204
  it 'raises an exception' do
215
205
  expect do
216
206
  data_key_id
217
- end.to raise_error(ArgumentError, /The value of :key option of the :master_key options hash cannot be nil/)
207
+ end.to raise_error(ArgumentError, /The key option must be a String with at least one character; currently have nil/)
218
208
  end
219
209
  end
220
210
 
@@ -224,7 +214,7 @@ describe Mongo::ClientEncryption do
224
214
  it 'raises an exception' do
225
215
  expect do
226
216
  data_key_id
227
- end.to raise_error(ArgumentError, /5 is an invalid AWS master_key key. The value of :key option of the :master_key options hash must be a String/)
217
+ end.to raise_error(ArgumentError, /The key option must be a String with at least one character; currently have 5/)
228
218
  end
229
219
  end
230
220
 
@@ -234,7 +224,7 @@ describe Mongo::ClientEncryption do
234
224
  it 'raises an exception' do
235
225
  expect do
236
226
  data_key_id
237
- end.to raise_error(ArgumentError, /5 is an invalid AWS master_key endpoint. The value of :endpoint option of the :master_key options hash must be a String/)
227
+ end.to raise_error(ArgumentError, /The endpoint option must be a String with at least one character; currently have 5/)
238
228
  end
239
229
  end
240
230
 
@@ -297,8 +287,6 @@ describe Mongo::ClientEncryption do
297
287
  end
298
288
 
299
289
  it 'raises an exception' do
300
- # RUBY-2129: This error message could be more specific and inform the user
301
- # that there is a problem with their KMS endpoint
302
290
  expect do
303
291
  data_key_id
304
292
  end.to raise_error(Mongo::Error::KmsError, /SocketError/)
@@ -8,6 +8,14 @@ require 'spec_helper'
8
8
 
9
9
  describe Mongo::Client do
10
10
 
11
+ let(:subscriber) { Mrss::EventSubscriber.new }
12
+
13
+ let(:monitored_client) do
14
+ root_authorized_client.tap do |client|
15
+ client.subscribe(Mongo::Monitoring::COMMAND, subscriber)
16
+ end
17
+ end
18
+
11
19
  describe '#==' do
12
20
 
13
21
  let(:client) do
@@ -584,6 +592,18 @@ describe Mongo::Client do
584
592
  expect(result.first).to eq(filter[:name])
585
593
  end
586
594
  end
595
+
596
+ context 'with comment' do
597
+ min_server_version '4.4'
598
+
599
+ it 'returns a list of database names and send comment' do
600
+ result = monitored_client.database_names({}, comment: "comment")
601
+ expect(result).to include('admin')
602
+ command = subscriber.command_started_events("listDatabases").last&.command
603
+ expect(command).not_to be_nil
604
+ expect(command["comment"]).to eq("comment")
605
+ end
606
+ end
587
607
  end
588
608
 
589
609
  describe '#list_databases' do
@@ -677,6 +697,20 @@ describe Mongo::Client do
677
697
  expect(command[:authorizedDatabases]).to be_nil
678
698
  end
679
699
  end
700
+
701
+ context 'with comment' do
702
+ min_server_version '4.4'
703
+
704
+ it 'returns a list of database names and send comment' do
705
+ result = monitored_client.list_databases({}, false, comment: "comment").collect do |i|
706
+ i['name']
707
+ end
708
+ expect(result).to include('admin')
709
+ command = subscriber.command_started_events("listDatabases").last&.command
710
+ expect(command).not_to be_nil
711
+ expect(command["comment"]).to eq("comment")
712
+ end
713
+ end
680
714
  end
681
715
 
682
716
  describe '#list_mongo_databases' do
@@ -719,6 +753,18 @@ describe Mongo::Client do
719
753
  expect(result.first.name).to eq(filter[:name])
720
754
  end
721
755
  end
756
+
757
+ context 'with comment' do
758
+ min_server_version '4.4'
759
+
760
+ it 'returns a list of database names and send comment' do
761
+ result = monitored_client.list_mongo_databases({}, comment: "comment")
762
+ expect(result).to all(be_a(Mongo::Database))
763
+ command = subscriber.command_started_events("listDatabases").last&.command
764
+ expect(command).not_to be_nil
765
+ expect(command["comment"]).to eq("comment")
766
+ end
767
+ end
722
768
  end
723
769
 
724
770
  describe '#close' do
@@ -790,7 +836,8 @@ describe Mongo::Client do
790
836
  expect(session).to be_a(Mongo::Session)
791
837
  end
792
838
 
793
- it 'sets the last use field to the current time', retry: 4 do
839
+ retry_test tries: 4
840
+ it 'sets the last use field to the current time' do
794
841
  expect(session.instance_variable_get(:@server_session).last_use).to be_within(1).of(Time.now)
795
842
  end
796
843
 
@@ -873,6 +920,255 @@ describe Mongo::Client do
873
920
  expect(before_last_use).to be < (pool.instance_variable_get(:@queue)[0].last_use)
874
921
  end
875
922
  end
923
+
924
+ context 'when an implicit session is used without enough connections' do
925
+ require_no_multi_mongos
926
+ require_wired_tiger
927
+
928
+ let(:client) do
929
+ authorized_client.with(options).tap do |cl|
930
+ cl.subscribe(Mongo::Monitoring::COMMAND, subscriber)
931
+ end
932
+ end
933
+
934
+ let(:options) do
935
+ { :max_pool_size => 1, :retry_writes => true }
936
+ end
937
+
938
+ shared_examples "a single connection" do
939
+ # JRuby, due to being concurrent, does not like rspec setting mocks
940
+ # in threads while other threads are calling the methods being mocked.
941
+ # My theory is that rspec removes & redefines methods as part of
942
+ # the mocking process, but while a method is undefined JRuby is
943
+ # running another thread that calls it leading to this exception:
944
+ # NoMethodError: undefined method `with_connection' for #<Mongo::Server:0x5386 address=localhost:27017 PRIMARY>
945
+ fails_on_jruby
946
+
947
+ before do
948
+ sessions_checked_out = 0
949
+
950
+ allow_any_instance_of(Mongo::Server).to receive(:with_connection).and_wrap_original do |m, *args, &block|
951
+ m.call(*args) do |connection|
952
+ sessions_checked_out = 0
953
+ res = block.call(connection)
954
+ expect(sessions_checked_out).to be < 2
955
+ res
956
+ end
957
+ end
958
+
959
+ allow_any_instance_of(Mongo::Session).to receive(:materialize).and_wrap_original do |m, *args|
960
+ sessions_checked_out += 1
961
+ m.call(*args).tap do
962
+ checked_out_connections = args[0].connection_pool.instance_variable_get("@checked_out_connections")
963
+ expect(checked_out_connections.length).to eq 1
964
+ end
965
+ end
966
+ end
967
+
968
+ it 'doesn\'t have any live sessions' do
969
+ threads.each do |thread|
970
+ thread.join
971
+ end
972
+ end
973
+ end
974
+
975
+ context "when doing three inserts" do
976
+ let(:threads) do
977
+ (1..3).map do |i|
978
+ Thread.new do
979
+ client['test'].insert_one({test: "test#{i}"})
980
+ end
981
+ end
982
+ end
983
+
984
+ include_examples "a single connection"
985
+ end
986
+
987
+ context "when doing an insert and two updates" do
988
+ let(:threads) do
989
+ threads = []
990
+ threads << Thread.new do
991
+ client['test'].insert_one({test: "test"})
992
+ end
993
+ threads << Thread.new do
994
+ client['test'].update_one({test: "test"}, { "$set" => { test: "test2" } })
995
+ end
996
+ threads << Thread.new do
997
+ client['test'].update_one({test: "test"}, { "$set" => { test: "test2" } })
998
+ end
999
+ threads
1000
+ end
1001
+
1002
+ include_examples "a single connection"
1003
+ end
1004
+
1005
+ context "when doing an insert, update and delete" do
1006
+ let(:threads) do
1007
+ threads = []
1008
+ threads << Thread.new do
1009
+ client['test'].insert_one({test: "test"})
1010
+ end
1011
+ threads << Thread.new do
1012
+ client['test'].update_one({test: "test"}, { "$set" => { test: "test2" } })
1013
+ end
1014
+ threads << Thread.new do
1015
+ client['test'].delete_one({test: "test"})
1016
+ end
1017
+ threads
1018
+ end
1019
+
1020
+ include_examples "a single connection"
1021
+ end
1022
+
1023
+ context "when doing an insert, update and find" do
1024
+ let(:threads) do
1025
+ threads = []
1026
+ threads << Thread.new do
1027
+ client['test'].insert_one({test: "test"})
1028
+ end
1029
+ threads << Thread.new do
1030
+ client['test'].update_one({test: "test"}, { "$set" => { test: "test2" } })
1031
+ end
1032
+ threads << Thread.new do
1033
+ client['test'].find({test: "test"}).to_a
1034
+ end
1035
+ threads
1036
+ end
1037
+
1038
+ include_examples "a single connection"
1039
+ end
1040
+
1041
+ context "when doing an insert, update and bulk write" do
1042
+ let(:threads) do
1043
+ threads = []
1044
+ threads << Thread.new do
1045
+ client['test'].insert_one({test: "test"})
1046
+ end
1047
+ threads << Thread.new do
1048
+ client['test'].update_one({test: "test"}, { "$set" => { test: "test2" } })
1049
+ end
1050
+ threads << Thread.new do
1051
+ client['test'].bulk_write([{ insert_one: { test: "test1" } },
1052
+ { update_one: { filter: { test: "test1" }, update: { "$set" => { test: "test2" } } } } ])
1053
+ end
1054
+ threads
1055
+ end
1056
+
1057
+ include_examples "a single connection"
1058
+ end
1059
+
1060
+ context "when doing an insert, update and find_one_and_delete" do
1061
+ let(:threads) do
1062
+ threads = []
1063
+ threads << Thread.new do
1064
+ client['test'].insert_one({test: "test"})
1065
+ end
1066
+ threads << Thread.new do
1067
+ client['test'].update_one({test: "test"}, { "$set" => { test: "test2" } })
1068
+ end
1069
+ threads << Thread.new do
1070
+ client['test'].find_one_and_delete({test: "test"})
1071
+ end
1072
+ threads
1073
+ end
1074
+
1075
+ include_examples "a single connection"
1076
+ end
1077
+
1078
+ context "when doing an insert, update and find_one_and_update" do
1079
+ let(:threads) do
1080
+ threads = []
1081
+ threads << Thread.new do
1082
+ client['test'].insert_one({test: "test"})
1083
+ end
1084
+ threads << Thread.new do
1085
+ client['test'].update_one({test: "test"}, { "$set" => { test: "test2" } })
1086
+ end
1087
+ threads << Thread.new do
1088
+ client['test'].find_one_and_update({test: "test"}, {test: "test2"})
1089
+ end
1090
+ threads
1091
+ end
1092
+
1093
+ include_examples "a single connection"
1094
+ end
1095
+
1096
+ context "when doing an insert, update and find_one_and_replace" do
1097
+ let(:threads) do
1098
+ threads = []
1099
+ threads << Thread.new do
1100
+ client['test'].insert_one({test: "test"})
1101
+ end
1102
+ threads << Thread.new do
1103
+ client['test'].update_one({test: "test"}, { "$set" => { test: "test2" } })
1104
+ end
1105
+ threads << Thread.new do
1106
+ client['test'].find_one_and_replace({test: "test"}, {test: "test2"})
1107
+ end
1108
+ threads
1109
+ end
1110
+
1111
+ include_examples "a single connection"
1112
+ end
1113
+
1114
+ context "when doing an insert, update and a replace" do
1115
+ let(:threads) do
1116
+ threads = []
1117
+ threads << Thread.new do
1118
+ client['test'].insert_one({test: "test"})
1119
+ end
1120
+ threads << Thread.new do
1121
+ client['test'].update_one({test: "test"}, { "$set" => { test: "test2" } })
1122
+ end
1123
+ threads << Thread.new do
1124
+ client['test'].replace_one({test: "test"}, {test: "test2"})
1125
+ end
1126
+ threads
1127
+ end
1128
+
1129
+ include_examples "a single connection"
1130
+ end
1131
+
1132
+ context "when doing all of the operations" do
1133
+ let(:threads) do
1134
+ threads = []
1135
+ threads << Thread.new do
1136
+ client['test'].insert_one({test: "test"})
1137
+ end
1138
+ threads << Thread.new do
1139
+ client['test'].update_one({ test: "test" }, { "$set" => { test: 1 } })
1140
+ end
1141
+ threads << Thread.new do
1142
+ client['test'].find_one_and_replace({test: "test"}, {test: "test2"})
1143
+ end
1144
+ threads << Thread.new do
1145
+ client['test'].delete_one({test: "test"})
1146
+ end
1147
+ threads << Thread.new do
1148
+ client['test'].find({test: "test"}).to_a
1149
+ end
1150
+ threads << Thread.new do
1151
+ client['test'].bulk_write([{ insert_one: { test: "test1" } },
1152
+ { update_one: { filter: { test: "test1" }, update: { "$set" => { test: "test2" } } } } ])
1153
+ end
1154
+ threads << Thread.new do
1155
+ client['test'].find_one_and_delete({test: "test"})
1156
+ end
1157
+ threads << Thread.new do
1158
+ client['test'].find_one_and_update({test: "test"}, {test: "test2"})
1159
+ end
1160
+ threads << Thread.new do
1161
+ client['test'].find_one_and_replace({test: "test"}, {test: "test2"})
1162
+ end
1163
+ threads << Thread.new do
1164
+ client['test'].replace_one({test: "test"}, {test: "test2"})
1165
+ end
1166
+ threads
1167
+ end
1168
+
1169
+ include_examples "a single connection"
1170
+ end
1171
+ end
876
1172
  end
877
1173
 
878
1174
  context 'when two clients have the same cluster' do
@@ -38,15 +38,28 @@ describe Mongo::Cluster::CursorReaper do
38
38
  allow(server).to receive(:address).and_return(address)
39
39
  end
40
40
  end
41
+ let(:session) do
42
+ double(Mongo::Session)
43
+ end
41
44
  let(:cursor_id) { 1 }
42
45
  let(:cursor_kill_spec_1) do
43
46
  Mongo::Cursor::KillSpec.new(
44
- cursor_id: cursor_id, coll_name: 'c', db_name: 'd', service_id: nil, server_address: address
47
+ cursor_id: cursor_id,
48
+ coll_name: 'c',
49
+ db_name: 'd',
50
+ server_address: address,
51
+ connection_global_id: 1,
52
+ session: session,
45
53
  )
46
54
  end
47
55
  let(:cursor_kill_spec_2) do
48
56
  Mongo::Cursor::KillSpec.new(
49
- cursor_id: cursor_id, coll_name: 'c', db_name: 'q', service_id: nil, server_address: address
57
+ cursor_id: cursor_id,
58
+ coll_name: 'c',
59
+ db_name: 'q',
60
+ server_address: address,
61
+ connection_global_id: 1,
62
+ session: session,
50
63
  )
51
64
  end
52
65
  let(:to_kill) { reaper.instance_variable_get(:@to_kill)}
@@ -206,7 +219,12 @@ describe Mongo::Cluster::CursorReaper do
206
219
  it 'schedules the kill cursor op' do
207
220
  expect {
208
221
  cursor.to_a
209
- }.to raise_exception(Mongo::Error::OperationFailure)
222
+ # Mongo::Error::SessionEnded is raised here because the periodic executor
223
+ # called in around block kills the cursor and closes the session.
224
+ # This code is normally scheduled in cursor finalizer, so the cursor object
225
+ # is garbage collected when the code is executed. So, a user won't get
226
+ # this exception.
227
+ }.to raise_exception(Mongo::Error::SessionEnded)
210
228
  end
211
229
  end
212
230
  end
@@ -631,50 +631,6 @@ describe Mongo::Cluster do
631
631
  end
632
632
  end
633
633
 
634
- context 'when client has not contacted any servers' do
635
-
636
- let(:cluster) do
637
- described_class.new(SpecConfig.instance.addresses, monitoring,
638
- SpecConfig.instance.test_options.merge(
639
- monitoring_io: false, server_selection_timeout: 0.183))
640
- end
641
-
642
- context 'in load-balanced topology' do
643
- require_topology :load_balanced
644
-
645
- it_behaves_like 'supports sessions'
646
- end
647
-
648
- context 'not in load-balanced topology' do
649
- require_topology :single, :replica_set, :sharded
650
-
651
- it_behaves_like 'does not support sessions'
652
- end
653
- end
654
-
655
- context 'when client has contacted servers and then disconnected' do
656
- min_server_fcv '3.6'
657
- require_wired_tiger
658
- require_topology :sharded, :replica_set
659
-
660
- let(:cluster) do
661
- described_class.new(SpecConfig.instance.addresses, monitoring,
662
- SpecConfig.instance.test_options.merge(
663
- server_selection_timeout: 0.183)
664
- ).tap do |cluster|
665
- register_cluster(cluster)
666
- end
667
- end
668
-
669
- before do
670
- cluster.next_primary
671
- cluster.servers_list.map(&:disconnect!)
672
- cluster.servers_list.map(&:unknown!)
673
- end
674
-
675
- it_behaves_like 'supports sessions'
676
- end
677
-
678
634
  context 'in server < 3.6' do
679
635
  max_server_version '3.4'
680
636
 
@@ -38,7 +38,7 @@ describe Mongo::Collection::View::Aggregation do
38
38
  end
39
39
 
40
40
  let(:aggregation_spec) do
41
- aggregation.send(:aggregate_spec, server, session, nil)
41
+ aggregation.send(:aggregate_spec, session, nil)
42
42
  end
43
43
 
44
44
  before do
@@ -366,7 +366,7 @@ describe Mongo::Collection::View::Aggregation do
366
366
  end
367
367
 
368
368
  it 'includes the read preference in the spec' do
369
- spec = aggregation.send(:aggregate_spec, server, session, read_preference)
369
+ spec = aggregation.send(:aggregate_spec, session, read_preference)
370
370
  expect(spec[:read]).to eq(read_preference)
371
371
  end
372
372
  end
@@ -651,4 +651,123 @@ describe Mongo::Collection::View::Aggregation do
651
651
  end
652
652
  end
653
653
  end
654
+
655
+ context "when there is a filter on the view" do
656
+
657
+ context "when broken_view_aggregate is turned off" do
658
+ config_override :broken_view_aggregate, false
659
+
660
+ let(:documents) do
661
+ [
662
+ { city: "Berlin", pop: 18913, neighborhood: "Kreuzberg" },
663
+ { city: "Berlin", pop: 84143, neighborhood: "Mitte" },
664
+ { city: "New York", pop: 40270, neighborhood: "Brooklyn" }
665
+ ]
666
+ end
667
+
668
+ let(:pipeline) do
669
+ [{
670
+ "$project" => {
671
+ city: 1
672
+ }
673
+ }]
674
+ end
675
+
676
+ let(:view) do
677
+ authorized_collection.find(city: "Berlin")
678
+ end
679
+
680
+ before do
681
+ authorized_collection.delete_many
682
+ authorized_collection.insert_many(documents)
683
+ end
684
+
685
+ it "uses the filter on the view" do
686
+ expect(aggregation.to_a.length).to eq(2)
687
+ end
688
+
689
+ it "adds a match stage" do
690
+ expect(aggregation.pipeline.length).to eq(2)
691
+ expect(aggregation.pipeline.first).to eq({ :$match => { "city" => "Berlin" } })
692
+ end
693
+ end
694
+
695
+ context "when broken_view_aggregate is turned on" do
696
+ config_override :broken_view_aggregate, true
697
+
698
+ let(:documents) do
699
+ [
700
+ { city: "Berlin", pop: 18913, neighborhood: "Kreuzberg" },
701
+ { city: "Berlin", pop: 84143, neighborhood: "Mitte" },
702
+ { city: "New York", pop: 40270, neighborhood: "Brooklyn" }
703
+ ]
704
+ end
705
+
706
+ let(:pipeline) do
707
+ [{
708
+ "$project" => {
709
+ city: 1
710
+ }
711
+ }]
712
+ end
713
+
714
+ let(:view) do
715
+ authorized_collection.find(city: "Berlin")
716
+ end
717
+
718
+ before do
719
+ authorized_collection.delete_many
720
+ authorized_collection.insert_many(documents)
721
+ end
722
+
723
+ it "ignores the view filter" do
724
+ expect(aggregation.to_a.length).to eq(3)
725
+ end
726
+
727
+ it "does not add a match stage" do
728
+ expect(aggregation.pipeline.length).to eq(1)
729
+ expect(aggregation.pipeline).to eq([ { "$project" => { city: 1 } } ])
730
+ end
731
+ end
732
+ end
733
+
734
+ context "when there is no filter on the view" do
735
+
736
+ with_config_values :broken_view_aggregate, true, false do
737
+
738
+ let(:documents) do
739
+ [
740
+ { city: "Berlin", pop: 18913, neighborhood: "Kreuzberg" },
741
+ { city: "Berlin", pop: 84143, neighborhood: "Mitte" },
742
+ { city: "New York", pop: 40270, neighborhood: "Brooklyn" }
743
+ ]
744
+ end
745
+
746
+ let(:pipeline) do
747
+ [{
748
+ "$project" => {
749
+ city: 1
750
+ }
751
+ }]
752
+ end
753
+
754
+ let(:view) do
755
+ authorized_collection.find
756
+ end
757
+
758
+ before do
759
+ authorized_collection.delete_many
760
+ authorized_collection.insert_many(documents)
761
+ end
762
+
763
+ it "ignores the view filter" do
764
+ expect(aggregation.to_a.length).to eq(3)
765
+ end
766
+
767
+ it "does not add a match stage" do
768
+ expect(aggregation.pipeline.length).to eq(1)
769
+ expect(aggregation.pipeline).to eq([ { "$project" => { city: 1 } } ])
770
+ end
771
+ end
772
+ end
654
773
  end