mongo 2.13.0 → 2.15.0.alpha

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 (375) hide show
  1. checksums.yaml +4 -4
  2. checksums.yaml.gz.sig +1 -4
  3. data.tar.gz.sig +0 -0
  4. data/README.md +4 -1
  5. data/Rakefile +46 -18
  6. data/lib/mongo.rb +32 -0
  7. data/lib/mongo/address.rb +1 -1
  8. data/lib/mongo/address/ipv4.rb +1 -1
  9. data/lib/mongo/address/ipv6.rb +1 -1
  10. data/lib/mongo/auth/aws/conversation.rb +1 -4
  11. data/lib/mongo/auth/base.rb +13 -7
  12. data/lib/mongo/auth/conversation_base.rb +32 -0
  13. data/lib/mongo/auth/cr/conversation.rb +6 -29
  14. data/lib/mongo/auth/gssapi/conversation.rb +4 -15
  15. data/lib/mongo/auth/ldap/conversation.rb +3 -14
  16. data/lib/mongo/auth/sasl_conversation_base.rb +1 -13
  17. data/lib/mongo/auth/scram_conversation_base.rb +7 -34
  18. data/lib/mongo/auth/user/view.rb +16 -9
  19. data/lib/mongo/auth/x509/conversation.rb +4 -25
  20. data/lib/mongo/background_thread.rb +11 -0
  21. data/lib/mongo/bulk_write.rb +38 -18
  22. data/lib/mongo/caching_cursor.rb +74 -0
  23. data/lib/mongo/client.rb +142 -16
  24. data/lib/mongo/cluster.rb +22 -31
  25. data/lib/mongo/cluster/reapers/cursor_reaper.rb +6 -2
  26. data/lib/mongo/cluster/sdam_flow.rb +14 -0
  27. data/lib/mongo/cluster/topology/single.rb +1 -1
  28. data/lib/mongo/collection.rb +58 -18
  29. data/lib/mongo/collection/view.rb +24 -20
  30. data/lib/mongo/collection/view/aggregation.rb +26 -5
  31. data/lib/mongo/collection/view/builder/find_command.rb +38 -18
  32. data/lib/mongo/collection/view/change_stream.rb +1 -1
  33. data/lib/mongo/collection/view/explainable.rb +27 -8
  34. data/lib/mongo/collection/view/iterable.rb +73 -13
  35. data/lib/mongo/collection/view/map_reduce.rb +2 -2
  36. data/lib/mongo/collection/view/readable.rb +57 -21
  37. data/lib/mongo/collection/view/writable.rb +29 -15
  38. data/lib/mongo/crypt/encryption_io.rb +6 -6
  39. data/lib/mongo/cursor.rb +18 -5
  40. data/lib/mongo/database.rb +28 -5
  41. data/lib/mongo/database/view.rb +2 -2
  42. data/lib/mongo/error.rb +11 -1
  43. data/lib/mongo/error/bulk_write_error.rb +17 -3
  44. data/lib/mongo/error/internal_driver_error.rb +22 -0
  45. data/lib/mongo/error/invalid_read_concern.rb +28 -0
  46. data/lib/mongo/error/operation_failure.rb +26 -7
  47. data/lib/mongo/error/parser.rb +65 -12
  48. data/lib/mongo/error/server_api_conflict.rb +23 -0
  49. data/lib/mongo/error/server_api_not_supported.rb +24 -0
  50. data/lib/mongo/error/server_certificate_revoked.rb +22 -0
  51. data/lib/mongo/error/unmet_dependency.rb +21 -0
  52. data/lib/mongo/error/unsupported_option.rb +14 -12
  53. data/lib/mongo/grid/fs_bucket.rb +37 -37
  54. data/lib/mongo/index/view.rb +21 -11
  55. data/lib/mongo/lint.rb +2 -1
  56. data/lib/mongo/logger.rb +3 -3
  57. data/lib/mongo/monitoring.rb +13 -4
  58. data/lib/mongo/monitoring/event/server_heartbeat_failed.rb +27 -16
  59. data/lib/mongo/monitoring/event/server_heartbeat_succeeded.rb +26 -15
  60. data/lib/mongo/operation.rb +4 -2
  61. data/lib/mongo/operation/aggregate/result.rb +9 -8
  62. data/lib/mongo/operation/collections_info.rb +18 -1
  63. data/lib/mongo/operation/collections_info/command.rb +5 -0
  64. data/lib/mongo/operation/collections_info/result.rb +18 -1
  65. data/lib/mongo/operation/context.rb +99 -0
  66. data/lib/mongo/operation/delete/bulk_result.rb +2 -0
  67. data/lib/mongo/operation/delete/result.rb +3 -0
  68. data/lib/mongo/operation/explain/command.rb +4 -0
  69. data/lib/mongo/operation/explain/legacy.rb +4 -0
  70. data/lib/mongo/operation/explain/op_msg.rb +6 -0
  71. data/lib/mongo/operation/explain/result.rb +3 -0
  72. data/lib/mongo/operation/find/legacy/result.rb +2 -0
  73. data/lib/mongo/operation/find/result.rb +13 -0
  74. data/lib/mongo/operation/get_more/result.rb +3 -0
  75. data/lib/mongo/operation/indexes.rb +15 -1
  76. data/lib/mongo/operation/indexes/result.rb +5 -0
  77. data/lib/mongo/operation/insert/bulk_result.rb +5 -0
  78. data/lib/mongo/operation/insert/command.rb +2 -2
  79. data/lib/mongo/operation/insert/legacy.rb +2 -2
  80. data/lib/mongo/operation/insert/op_msg.rb +2 -2
  81. data/lib/mongo/operation/insert/result.rb +5 -0
  82. data/lib/mongo/operation/list_collections/result.rb +9 -1
  83. data/lib/mongo/operation/map_reduce/result.rb +10 -0
  84. data/lib/mongo/operation/parallel_scan/result.rb +4 -0
  85. data/lib/mongo/operation/result.rb +37 -6
  86. data/lib/mongo/operation/shared/bypass_document_validation.rb +1 -0
  87. data/lib/mongo/operation/shared/causal_consistency_supported.rb +1 -0
  88. data/lib/mongo/operation/shared/executable.rb +25 -14
  89. data/lib/mongo/operation/shared/executable_no_validate.rb +2 -2
  90. data/lib/mongo/operation/shared/idable.rb +2 -1
  91. data/lib/mongo/operation/shared/limited.rb +1 -0
  92. data/lib/mongo/operation/shared/object_id_generator.rb +1 -0
  93. data/lib/mongo/operation/shared/op_msg_or_command.rb +1 -7
  94. data/lib/mongo/operation/shared/op_msg_or_find_command.rb +1 -7
  95. data/lib/mongo/operation/shared/polymorphic_operation.rb +39 -0
  96. data/lib/mongo/operation/shared/response_handling.rb +23 -23
  97. data/lib/mongo/operation/shared/result/aggregatable.rb +1 -0
  98. data/lib/mongo/operation/shared/sessions_supported.rb +14 -2
  99. data/lib/mongo/operation/shared/specifiable.rb +1 -0
  100. data/lib/mongo/operation/shared/write.rb +9 -18
  101. data/lib/mongo/operation/shared/write_concern_supported.rb +1 -0
  102. data/lib/mongo/operation/update/legacy/result.rb +7 -0
  103. data/lib/mongo/operation/update/result.rb +8 -0
  104. data/lib/mongo/operation/users_info/result.rb +3 -0
  105. data/lib/mongo/protocol/compressed.rb +51 -5
  106. data/lib/mongo/protocol/message.rb +31 -4
  107. data/lib/mongo/protocol/msg.rb +37 -12
  108. data/lib/mongo/protocol/query.rb +36 -0
  109. data/lib/mongo/query_cache.rb +272 -0
  110. data/lib/mongo/retryable.rb +9 -2
  111. data/lib/mongo/server.rb +12 -16
  112. data/lib/mongo/server/app_metadata.rb +52 -18
  113. data/lib/mongo/server/connection.rb +5 -0
  114. data/lib/mongo/server/connection_base.rb +16 -15
  115. data/lib/mongo/server/connection_common.rb +2 -2
  116. data/lib/mongo/server/connection_pool.rb +9 -4
  117. data/lib/mongo/server/description.rb +12 -1
  118. data/lib/mongo/server/description/features.rb +9 -8
  119. data/lib/mongo/server/monitor.rb +21 -2
  120. data/lib/mongo/server/monitor/app_metadata.rb +1 -1
  121. data/lib/mongo/server/monitor/connection.rb +12 -13
  122. data/lib/mongo/server/pending_connection.rb +26 -8
  123. data/lib/mongo/server/push_monitor.rb +12 -2
  124. data/lib/mongo/server_selector/base.rb +5 -1
  125. data/lib/mongo/session.rb +7 -3
  126. data/lib/mongo/session/session_pool.rb +4 -2
  127. data/lib/mongo/socket.rb +35 -8
  128. data/lib/mongo/socket/ocsp_cache.rb +97 -0
  129. data/lib/mongo/socket/ocsp_verifier.rb +368 -0
  130. data/lib/mongo/socket/ssl.rb +53 -24
  131. data/lib/mongo/srv/monitor.rb +7 -24
  132. data/lib/mongo/srv/resolver.rb +14 -10
  133. data/lib/mongo/timeout.rb +2 -0
  134. data/lib/mongo/uri.rb +21 -390
  135. data/lib/mongo/uri/options_mapper.rb +620 -0
  136. data/lib/mongo/uri/srv_protocol.rb +3 -2
  137. data/lib/mongo/utils.rb +27 -1
  138. data/lib/mongo/version.rb +1 -1
  139. data/spec/NOTES.aws-auth.md +12 -7
  140. data/spec/README.md +87 -2
  141. data/spec/integration/auth_spec.rb +25 -15
  142. data/spec/integration/bson_symbol_spec.rb +4 -2
  143. data/spec/integration/bulk_write_error_message_spec.rb +41 -0
  144. data/spec/integration/bulk_write_spec.rb +48 -0
  145. data/spec/integration/change_stream_spec.rb +5 -5
  146. data/spec/integration/client_authentication_options_spec.rb +92 -28
  147. data/spec/integration/client_side_encryption/auto_encryption_bulk_writes_spec.rb +6 -2
  148. data/spec/integration/command_monitoring_spec.rb +2 -2
  149. data/spec/integration/connection_pool_populator_spec.rb +4 -2
  150. data/spec/integration/connection_spec.rb +2 -0
  151. data/spec/integration/cursor_reaping_spec.rb +54 -18
  152. data/spec/integration/docs_examples_spec.rb +8 -1
  153. data/spec/integration/fork_reconnect_spec.rb +60 -2
  154. data/spec/integration/ocsp_connectivity_spec.rb +26 -0
  155. data/spec/integration/ocsp_verifier_cache_spec.rb +188 -0
  156. data/spec/integration/ocsp_verifier_spec.rb +340 -0
  157. data/spec/integration/operation_failure_code_spec.rb +1 -1
  158. data/spec/integration/operation_failure_message_spec.rb +90 -0
  159. data/spec/integration/query_cache_spec.rb +1045 -0
  160. data/spec/integration/query_cache_transactions_spec.rb +190 -0
  161. data/spec/integration/reconnect_spec.rb +1 -1
  162. data/spec/integration/retryable_writes/retryable_writes_40_and_newer_spec.rb +1 -0
  163. data/spec/integration/retryable_writes/shared/performs_legacy_retries.rb +2 -0
  164. data/spec/integration/sdam_error_handling_spec.rb +86 -1
  165. data/spec/integration/sdam_events_spec.rb +8 -7
  166. data/spec/integration/server_selection_spec.rb +36 -0
  167. data/spec/integration/size_limit_spec.rb +20 -19
  168. data/spec/integration/snappy_compression_spec.rb +25 -0
  169. data/spec/integration/srv_monitoring_spec.rb +39 -4
  170. data/spec/integration/srv_spec.rb +56 -0
  171. data/spec/integration/transactions_examples_spec.rb +23 -7
  172. data/spec/integration/zlib_compression_spec.rb +1 -1
  173. data/spec/integration/zstd_compression_spec.rb +26 -0
  174. data/spec/lite_spec_helper.rb +15 -5
  175. data/spec/mongo/address_spec.rb +16 -12
  176. data/spec/mongo/auth/ldap/conversation_spec.rb +1 -1
  177. data/spec/mongo/auth/ldap_spec.rb +5 -1
  178. data/spec/mongo/auth/scram_negotiation_spec.rb +1 -1
  179. data/spec/mongo/auth/scram_spec.rb +1 -1
  180. data/spec/mongo/auth/user_spec.rb +1 -1
  181. data/spec/mongo/auth/x509/conversation_spec.rb +3 -3
  182. data/spec/mongo/bulk_write_spec.rb +2 -2
  183. data/spec/mongo/caching_cursor_spec.rb +70 -0
  184. data/spec/mongo/client_construction_spec.rb +273 -35
  185. data/spec/mongo/client_encryption_spec.rb +16 -10
  186. data/spec/mongo/client_spec.rb +64 -0
  187. data/spec/mongo/cluster/topology/replica_set_spec.rb +1 -1
  188. data/spec/mongo/cluster/topology/sharded_spec.rb +1 -1
  189. data/spec/mongo/cluster/topology/single_spec.rb +15 -6
  190. data/spec/mongo/cluster/topology/unknown_spec.rb +1 -1
  191. data/spec/mongo/cluster/topology_spec.rb +1 -1
  192. data/spec/mongo/cluster_spec.rb +6 -18
  193. data/spec/mongo/collection/view/change_stream_resume_spec.rb +1 -1
  194. data/spec/mongo/collection/view/explainable_spec.rb +87 -4
  195. data/spec/mongo/collection/view/map_reduce_spec.rb +2 -0
  196. data/spec/mongo/collection/view/readable_spec.rb +50 -0
  197. data/spec/mongo/collection_crud_spec.rb +4357 -0
  198. data/spec/mongo/collection_ddl_spec.rb +534 -0
  199. data/spec/mongo/collection_spec.rb +5 -4787
  200. data/spec/mongo/crypt/auto_decryption_context_spec.rb +1 -1
  201. data/spec/mongo/crypt/auto_encryption_context_spec.rb +1 -1
  202. data/spec/mongo/crypt/binary_spec.rb +1 -6
  203. data/spec/mongo/crypt/binding/binary_spec.rb +1 -6
  204. data/spec/mongo/crypt/binding/context_spec.rb +2 -7
  205. data/spec/mongo/crypt/binding/helpers_spec.rb +1 -6
  206. data/spec/mongo/crypt/binding/mongocrypt_spec.rb +2 -7
  207. data/spec/mongo/crypt/binding/status_spec.rb +1 -6
  208. data/spec/mongo/crypt/binding/version_spec.rb +1 -6
  209. data/spec/mongo/crypt/data_key_context_spec.rb +1 -1
  210. data/spec/mongo/crypt/explicit_decryption_context_spec.rb +1 -1
  211. data/spec/mongo/crypt/explicit_encryption_context_spec.rb +1 -1
  212. data/spec/mongo/crypt/status_spec.rb +1 -6
  213. data/spec/mongo/database_spec.rb +174 -4
  214. data/spec/mongo/error/bulk_write_error_spec.rb +3 -3
  215. data/spec/mongo/error/no_server_available_spec.rb +1 -1
  216. data/spec/mongo/error/parser_spec.rb +37 -6
  217. data/spec/mongo/index/view_spec.rb +8 -2
  218. data/spec/mongo/logger_spec.rb +13 -11
  219. data/spec/mongo/monitoring/event/server_closed_spec.rb +1 -1
  220. data/spec/mongo/monitoring/event/server_heartbeat_failed_spec.rb +1 -1
  221. data/spec/mongo/monitoring/event/server_heartbeat_succeeded_spec.rb +1 -1
  222. data/spec/mongo/monitoring/event/server_opening_spec.rb +1 -1
  223. data/spec/mongo/monitoring/event/topology_changed_spec.rb +1 -1
  224. data/spec/mongo/monitoring/event/topology_closed_spec.rb +1 -1
  225. data/spec/mongo/monitoring/event/topology_opening_spec.rb +1 -1
  226. data/spec/mongo/operation/aggregate_spec.rb +2 -1
  227. data/spec/mongo/operation/collections_info_spec.rb +4 -1
  228. data/spec/mongo/operation/command_spec.rb +6 -3
  229. data/spec/mongo/operation/create_index_spec.rb +6 -3
  230. data/spec/mongo/operation/create_user_spec.rb +6 -3
  231. data/spec/mongo/operation/delete/bulk_spec.rb +9 -6
  232. data/spec/mongo/operation/delete/op_msg_spec.rb +3 -3
  233. data/spec/mongo/operation/delete_spec.rb +11 -7
  234. data/spec/mongo/operation/drop_index_spec.rb +6 -2
  235. data/spec/mongo/operation/find/legacy_spec.rb +3 -1
  236. data/spec/mongo/operation/get_more_spec.rb +3 -1
  237. data/spec/mongo/operation/indexes_spec.rb +5 -1
  238. data/spec/mongo/operation/insert/bulk_spec.rb +10 -7
  239. data/spec/mongo/operation/insert/command_spec.rb +2 -2
  240. data/spec/mongo/operation/insert/op_msg_spec.rb +3 -3
  241. data/spec/mongo/operation/insert_spec.rb +15 -12
  242. data/spec/mongo/operation/map_reduce_spec.rb +5 -2
  243. data/spec/mongo/operation/read_preference_op_msg_spec.rb +1 -1
  244. data/spec/mongo/operation/remove_user_spec.rb +6 -3
  245. data/spec/mongo/operation/result_spec.rb +1 -1
  246. data/spec/mongo/operation/update/bulk_spec.rb +9 -6
  247. data/spec/mongo/operation/update/command_spec.rb +2 -2
  248. data/spec/mongo/operation/update/op_msg_spec.rb +3 -3
  249. data/spec/mongo/operation/update_spec.rb +10 -7
  250. data/spec/mongo/operation/update_user_spec.rb +4 -1
  251. data/spec/mongo/protocol/compressed_spec.rb +26 -12
  252. data/spec/mongo/query_cache_middleware_spec.rb +55 -0
  253. data/spec/mongo/query_cache_spec.rb +280 -0
  254. data/spec/mongo/retryable_spec.rb +3 -2
  255. data/spec/mongo/server/app_metadata_shared.rb +2 -2
  256. data/spec/mongo/server/app_metadata_spec.rb +2 -0
  257. data/spec/mongo/server/connection_pool/populator_spec.rb +3 -1
  258. data/spec/mongo/server/connection_pool_spec.rb +8 -4
  259. data/spec/mongo/server/connection_spec.rb +39 -25
  260. data/spec/mongo/server/description_spec.rb +18 -0
  261. data/spec/mongo/server/monitor/connection_spec.rb +17 -7
  262. data/spec/mongo/server/monitor_spec.rb +9 -1
  263. data/spec/mongo/server_selector_spec.rb +2 -2
  264. data/spec/mongo/server_spec.rb +15 -2
  265. data/spec/mongo/socket/ssl_spec.rb +44 -4
  266. data/spec/mongo/socket_spec.rb +2 -2
  267. data/spec/mongo/tls_context_hooks_spec.rb +37 -0
  268. data/spec/mongo/uri/srv_protocol_spec.rb +64 -33
  269. data/spec/mongo/uri_option_parsing_spec.rb +11 -11
  270. data/spec/mongo/uri_spec.rb +68 -41
  271. data/spec/mongo/utils_spec.rb +39 -0
  272. data/spec/runners/auth.rb +3 -0
  273. data/spec/runners/change_streams/test.rb +1 -1
  274. data/spec/runners/connection_string.rb +31 -124
  275. data/spec/runners/crud/requirement.rb +40 -3
  276. data/spec/runners/crud/test_base.rb +0 -19
  277. data/spec/runners/crud/verifier.rb +8 -0
  278. data/spec/runners/server_selection.rb +1 -1
  279. data/spec/runners/transactions/operation.rb +13 -2
  280. data/spec/runners/transactions/test.rb +3 -2
  281. data/spec/runners/unified.rb +96 -0
  282. data/spec/runners/unified/assertions.rb +249 -0
  283. data/spec/runners/unified/change_stream_operations.rb +26 -0
  284. data/spec/runners/unified/crud_operations.rb +199 -0
  285. data/spec/runners/unified/ddl_operations.rb +96 -0
  286. data/spec/runners/unified/entity_map.rb +39 -0
  287. data/spec/runners/unified/error.rb +25 -0
  288. data/spec/runners/unified/event_subscriber.rb +91 -0
  289. data/spec/runners/unified/exceptions.rb +21 -0
  290. data/spec/runners/unified/grid_fs_operations.rb +55 -0
  291. data/spec/runners/unified/support_operations.rb +250 -0
  292. data/spec/runners/unified/test.rb +393 -0
  293. data/spec/runners/unified/test_group.rb +28 -0
  294. data/spec/runners/unified/using_hash.rb +31 -0
  295. data/spec/shared/LICENSE +20 -0
  296. data/spec/shared/bin/get-mongodb-download-url +17 -0
  297. data/spec/shared/lib/mrss/child_process_helper.rb +80 -0
  298. data/spec/shared/lib/mrss/cluster_config.rb +218 -0
  299. data/spec/shared/lib/mrss/constraints.rb +346 -0
  300. data/spec/shared/lib/mrss/docker_runner.rb +262 -0
  301. data/spec/shared/lib/mrss/lite_constraints.rb +175 -0
  302. data/spec/shared/lib/mrss/server_version_registry.rb +112 -0
  303. data/spec/shared/lib/mrss/spec_organizer.rb +149 -0
  304. data/spec/shared/lib/mrss/utils.rb +15 -0
  305. data/spec/shared/share/Dockerfile.erb +231 -0
  306. data/spec/shared/shlib/distro.sh +73 -0
  307. data/spec/shared/shlib/server.sh +290 -0
  308. data/spec/shared/shlib/set_env.sh +128 -0
  309. data/spec/solo/clean_exit_spec.rb +21 -0
  310. data/spec/spec_helper.rb +7 -2
  311. data/spec/spec_tests/cmap_spec.rb +7 -3
  312. data/spec/spec_tests/crud_unified_spec.rb +10 -0
  313. data/spec/spec_tests/data/change_streams/change-streams-errors.yml +0 -1
  314. data/spec/spec_tests/data/change_streams/change-streams.yml +0 -2
  315. data/spec/spec_tests/data/cmap/pool-checkout-connection.yml +6 -2
  316. data/spec/spec_tests/data/cmap/pool-create-min-size.yml +3 -0
  317. data/spec/spec_tests/data/connection_string/valid-warnings.yml +24 -0
  318. data/spec/spec_tests/data/crud_unified/estimatedDocumentCount.yml +267 -0
  319. data/spec/spec_tests/data/retryable_reads/estimatedDocumentCount-4.9.yml +60 -0
  320. data/spec/spec_tests/data/retryable_reads/{estimatedDocumentCount.yml → estimatedDocumentCount-pre4.9.yml} +2 -0
  321. data/spec/spec_tests/data/retryable_reads/estimatedDocumentCount-serverErrors-4.9.yml +146 -0
  322. data/spec/spec_tests/data/retryable_reads/{estimatedDocumentCount-serverErrors.yml → estimatedDocumentCount-serverErrors-pre4.9.yml} +2 -0
  323. data/spec/spec_tests/data/retryable_reads/listIndexNames.yml +1 -1
  324. data/spec/spec_tests/data/sdam_monitoring/discovered_standalone.yml +1 -3
  325. data/spec/spec_tests/data/sdam_monitoring/standalone.yml +2 -2
  326. data/spec/spec_tests/data/sdam_monitoring/standalone_repeated.yml +2 -2
  327. data/spec/spec_tests/data/sdam_monitoring/standalone_suppress_equal_description_changes.yml +2 -2
  328. data/spec/spec_tests/data/sdam_monitoring/standalone_to_rs_with_me_mismatch.yml +2 -2
  329. data/spec/spec_tests/data/unified/valid-fail/operation-failure.yml +31 -0
  330. data/spec/spec_tests/data/unified/valid-pass/poc-change-streams.yml +220 -0
  331. data/spec/spec_tests/data/unified/valid-pass/poc-command-monitoring.yml +102 -0
  332. data/spec/spec_tests/data/unified/valid-pass/poc-crud.yml +184 -0
  333. data/spec/spec_tests/data/unified/valid-pass/poc-gridfs.yml +155 -0
  334. data/spec/spec_tests/data/unified/valid-pass/poc-retryable-reads.yml +193 -0
  335. data/spec/spec_tests/data/unified/valid-pass/poc-retryable-writes.yml +210 -0
  336. data/spec/spec_tests/data/unified/valid-pass/poc-sessions.yml +215 -0
  337. data/spec/spec_tests/data/unified/valid-pass/poc-transactions-convenient-api.yml +235 -0
  338. data/spec/spec_tests/data/unified/valid-pass/poc-transactions-mongos-pin-auto.yml +169 -0
  339. data/spec/spec_tests/data/unified/valid-pass/poc-transactions.yml +170 -0
  340. data/spec/spec_tests/data/uri_options/auth-options.yml +25 -0
  341. data/spec/spec_tests/data/uri_options/compression-options.yml +7 -4
  342. data/spec/spec_tests/data/uri_options/read-preference-options.yml +24 -0
  343. data/spec/spec_tests/data/uri_options/ruby-connection-options.yml +1 -0
  344. data/spec/spec_tests/data/uri_options/tls-options.yml +160 -4
  345. data/spec/spec_tests/data/versioned_api/crud-api-version-1-strict.yml +416 -0
  346. data/spec/spec_tests/data/versioned_api/crud-api-version-1.yml +409 -0
  347. data/spec/spec_tests/data/versioned_api/runcommand-helper-no-api-version-declared.yml +67 -0
  348. data/spec/spec_tests/data/versioned_api/test-commands-deprecation-errors.yml +47 -0
  349. data/spec/spec_tests/data/versioned_api/test-commands-strict-mode.yml +44 -0
  350. data/spec/spec_tests/data/versioned_api/transaction-handling.yml +180 -0
  351. data/spec/spec_tests/dns_seedlist_discovery_spec.rb +9 -1
  352. data/spec/spec_tests/unified_spec.rb +15 -0
  353. data/spec/spec_tests/uri_options_spec.rb +47 -33
  354. data/spec/spec_tests/versioned_api_spec.rb +10 -0
  355. data/spec/stress/fork_reconnect_stress_spec.rb +1 -1
  356. data/spec/support/certificates/atlas-ocsp-ca.crt +28 -0
  357. data/spec/support/certificates/atlas-ocsp.crt +41 -0
  358. data/spec/support/client_registry_macros.rb +11 -2
  359. data/spec/support/common_shortcuts.rb +59 -0
  360. data/spec/support/constraints.rb +6 -253
  361. data/spec/support/matchers.rb +16 -0
  362. data/spec/support/ocsp +1 -0
  363. data/spec/support/session_registry.rb +52 -0
  364. data/spec/support/shared/session.rb +2 -2
  365. data/spec/support/spec_config.rb +68 -3
  366. data/spec/support/spec_setup.rb +48 -38
  367. data/spec/support/utils.rb +102 -4
  368. metadata +1087 -936
  369. metadata.gz.sig +0 -0
  370. data/lib/mongo/operation/shared/collections_info_or_list_collections.rb +0 -56
  371. data/lib/mongo/operation/shared/op_msg_or_list_indexes_command.rb +0 -47
  372. data/spec/support/child_process_helper.rb +0 -78
  373. data/spec/support/cluster_config.rb +0 -207
  374. data/spec/support/lite_constraints.rb +0 -141
  375. data/spec/support/spec_organizer.rb +0 -129
@@ -22,9 +22,13 @@ describe 'Cmap' do
22
22
  end
23
23
 
24
24
  let(:options) do
25
- SpecConfig.instance.ssl_options.merge(SpecConfig.instance.compressor_options)
26
- .merge(SpecConfig.instance.retry_writes_options).merge(SpecConfig.instance.auth_options)
27
- .merge(monitoring_io: false)
25
+ Mongo::Utils.shallow_symbolize_keys(Mongo::Client.canonicalize_ruby_options(
26
+ SpecConfig.instance.all_test_options,
27
+ )).update(monitoring_io: false).tap do |options|
28
+ # We have a wait queue timeout set in the test suite options, but having
29
+ # this option set interferes with assertions in the cmap spec tests.
30
+ options.delete(:wait_queue_timeout)
31
+ end
28
32
  end
29
33
 
30
34
  CMAP_TESTS.each do |file|
@@ -0,0 +1,10 @@
1
+ require 'spec_helper'
2
+
3
+ require 'runners/unified'
4
+
5
+ base = "#{CURRENT_PATH}/spec_tests/data/crud_unified"
6
+ CRUD_UNIFIED_TESTS = Dir.glob("#{base}/**/*.yml").sort
7
+
8
+ describe 'CRUD unified spec tests' do
9
+ define_unified_spec_tests(base, CRUD_UNIFIED_TESTS)
10
+ end
@@ -12,7 +12,6 @@ tests:
12
12
  changeStreamPipeline: []
13
13
  changeStreamOptions: {}
14
14
  operations: []
15
- # https://jira.mongodb.org/browse/SPEC-1462
16
15
  expectations: ~
17
16
  result:
18
17
  error:
@@ -58,7 +58,6 @@ tests:
58
58
  arguments:
59
59
  document:
60
60
  x: 1
61
- # https://jira.mongodb.org/browse/SPEC-1462
62
61
  expectations: ~
63
62
  result:
64
63
  success:
@@ -372,7 +371,6 @@ tests:
372
371
  db: *database_name
373
372
  coll: *collection_name
374
373
  updateDescription:
375
- removedFields: []
376
374
  updatedFields:
377
375
  x:
378
376
  $numberInt: "2"
@@ -6,10 +6,14 @@ operations:
6
6
  events:
7
7
  - type: ConnectionCheckOutStarted
8
8
  address: 42
9
+ - type: ConnectionCreated
10
+ connectionId: 1
11
+ address: 42
12
+ - type: ConnectionReady
13
+ connectionId: 1
14
+ address: 42
9
15
  - type: ConnectionCheckedOut
10
16
  connectionId: 1
11
17
  address: 42
12
18
  ignore:
13
19
  - ConnectionPoolCreated
14
- - ConnectionCreated
15
- - ConnectionReady
@@ -7,6 +7,9 @@ operations:
7
7
  - name: waitForEvent
8
8
  event: ConnectionCreated
9
9
  count: 3
10
+ - name: waitForEvent
11
+ event: ConnectionReady
12
+ count: 3
10
13
  - name: checkOut
11
14
  events:
12
15
  - type: ConnectionPoolCreated
@@ -49,3 +49,27 @@ tests:
49
49
  auth: ~
50
50
  options:
51
51
  wtimeoutms: 10
52
+ -
53
+ description: "Empty integer option values are ignored"
54
+ uri: "mongodb://localhost/?maxIdleTimeMS="
55
+ valid: true
56
+ warning: true
57
+ hosts:
58
+ -
59
+ type: "hostname"
60
+ host: "localhost"
61
+ port: ~
62
+ auth: ~
63
+ options: ~
64
+ -
65
+ description: "Empty boolean option value are ignored"
66
+ uri: "mongodb://localhost/?journal="
67
+ valid: true
68
+ warning: true
69
+ hosts:
70
+ -
71
+ type: "hostname"
72
+ host: "localhost"
73
+ port: ~
74
+ auth: ~
75
+ options: ~
@@ -0,0 +1,267 @@
1
+ description: "estimatedDocumentCount"
2
+
3
+ schemaVersion: "1.0"
4
+
5
+ createEntities:
6
+ - client:
7
+ id: &client0 client0
8
+ useMultipleMongoses: false # Avoid setting fail points with multiple mongoses
9
+ uriOptions: { retryReads: false } # Avoid retrying fail points with closeConnection
10
+ observeEvents: [ commandStartedEvent ]
11
+ - database:
12
+ id: &database0 database0
13
+ client: *client0
14
+ databaseName: &database0Name edc-tests
15
+ - collection:
16
+ id: &collection0 collection0
17
+ database: *database0
18
+ collectionName: &collection0Name coll0
19
+ - collection:
20
+ # Nonexistent collection intentionally omitted from initialData
21
+ id: &collection1 collection1
22
+ database: *database0
23
+ collectionName: &collection1Name coll1
24
+
25
+ initialData:
26
+ - collectionName: *collection0Name
27
+ databaseName: *database0Name
28
+ documents:
29
+ - { _id: 1, x: 11 }
30
+ - { _id: 2, x: 22 }
31
+ - { _id: 3, x: 33 }
32
+
33
+ tests:
34
+ - description: "estimatedDocumentCount uses $collStats on 4.9.0 or greater"
35
+ runOnRequirements:
36
+ - minServerVersion: "4.9.0"
37
+ operations:
38
+ - name: estimatedDocumentCount
39
+ object: *collection0
40
+ expectResult: 3
41
+ expectEvents:
42
+ - client: *client0
43
+ events:
44
+ - commandStartedEvent:
45
+ command:
46
+ aggregate: *collection0Name
47
+ pipeline: &pipeline
48
+ - $collStats: { count: {} }
49
+ - $group: { _id: 1, n: { $sum: $count }}
50
+ commandName: aggregate
51
+ databaseName: *database0Name
52
+
53
+ - description: "estimatedDocumentCount with maxTimeMS on 4.9.0 or greater"
54
+ runOnRequirements:
55
+ - minServerVersion: "4.9.0"
56
+ operations:
57
+ - name: estimatedDocumentCount
58
+ object: *collection0
59
+ arguments:
60
+ maxTimeMS: 6000
61
+ expectResult: 3
62
+ expectEvents:
63
+ - client: *client0
64
+ events:
65
+ - commandStartedEvent:
66
+ command:
67
+ aggregate: *collection0Name
68
+ pipeline: &pipeline
69
+ - $collStats: { count: {} }
70
+ - $group: { _id: 1, n: { $sum: $count }}
71
+ maxTimeMS: 6000
72
+ commandName: aggregate
73
+ databaseName: *database0Name
74
+
75
+ - description: "estimatedDocumentCount on non-existent collection on 4.9.0 or greater"
76
+ runOnRequirements:
77
+ - minServerVersion: "4.9.0"
78
+ operations:
79
+ - name: estimatedDocumentCount
80
+ object: *collection1
81
+ expectResult: 0
82
+ expectEvents:
83
+ - client: *client0
84
+ events:
85
+ - commandStartedEvent:
86
+ command:
87
+ aggregate: *collection1Name
88
+ pipeline: &pipeline
89
+ - $collStats: { count: {} }
90
+ - $group: { _id: 1, n: { $sum: $count }}
91
+ commandName: aggregate
92
+ databaseName: *database0Name
93
+
94
+ - description: "estimatedDocumentCount errors correctly on 4.9.0 or greater--command error"
95
+ runOnRequirements:
96
+ - minServerVersion: "4.9.0"
97
+ operations:
98
+ - name: failPoint
99
+ object: testRunner
100
+ arguments:
101
+ client: *client0
102
+ failPoint:
103
+ configureFailPoint: failCommand
104
+ mode: { times: 1 }
105
+ data:
106
+ failCommands: [ aggregate ]
107
+ errorCode: 8 # UnknownError
108
+ - name: estimatedDocumentCount
109
+ object: *collection0
110
+ expectError:
111
+ errorCode: 8 # UnknownError
112
+ expectEvents:
113
+ - client: *client0
114
+ events:
115
+ - commandStartedEvent:
116
+ command:
117
+ aggregate: *collection0Name
118
+ pipeline: &pipeline
119
+ - $collStats: { count: {} }
120
+ - $group: { _id: 1, n: { $sum: $count }}
121
+ commandName: aggregate
122
+ databaseName: *database0Name
123
+
124
+ - description: "estimatedDocumentCount errors correctly on 4.9.0 or greater--socket error"
125
+ runOnRequirements:
126
+ - minServerVersion: "4.9.0"
127
+ operations:
128
+ - name: failPoint
129
+ object: testRunner
130
+ arguments:
131
+ client: *client0
132
+ failPoint:
133
+ configureFailPoint: failCommand
134
+ mode: { times: 1 }
135
+ data:
136
+ failCommands: [ aggregate ]
137
+ closeConnection: true
138
+ - name: estimatedDocumentCount
139
+ object: *collection0
140
+ expectError:
141
+ isError: true
142
+ expectEvents:
143
+ - client: *client0
144
+ events:
145
+ - commandStartedEvent:
146
+ command:
147
+ aggregate: *collection0Name
148
+ pipeline: &pipeline
149
+ - $collStats: { count: {} }
150
+ - $group: { _id: 1, n: { $sum: $count }}
151
+ commandName: aggregate
152
+ databaseName: *database0Name
153
+
154
+ - description: "estimatedDocumentCount uses count on less than 4.9.0"
155
+ runOnRequirements:
156
+ - maxServerVersion: "4.8.99"
157
+ operations:
158
+ - name: estimatedDocumentCount
159
+ object: *collection0
160
+ expectResult: 3
161
+ expectEvents:
162
+ - client: *client0
163
+ events:
164
+ - commandStartedEvent:
165
+ command:
166
+ count: *collection0Name
167
+ commandName: count
168
+ databaseName: *database0Name
169
+
170
+ - description: "estimatedDocumentCount with maxTimeMS on less than 4.9.0"
171
+ runOnRequirements:
172
+ - maxServerVersion: "4.8.99"
173
+ operations:
174
+ - name: estimatedDocumentCount
175
+ object: *collection0
176
+ arguments:
177
+ maxTimeMS: 6000
178
+ expectResult: 3
179
+ expectEvents:
180
+ - client: *client0
181
+ events:
182
+ - commandStartedEvent:
183
+ command:
184
+ count: *collection0Name
185
+ maxTimeMS: 6000
186
+ commandName: count
187
+ databaseName: *database0Name
188
+
189
+ - description: "estimatedDocumentCount on non-existent collection on less than 4.9.0"
190
+ runOnRequirements:
191
+ - maxServerVersion: "4.8.99"
192
+ operations:
193
+ - name: estimatedDocumentCount
194
+ object: *collection1
195
+ expectResult: 0
196
+ expectEvents:
197
+ - client: *client0
198
+ events:
199
+ - commandStartedEvent:
200
+ command:
201
+ count: *collection1Name
202
+ commandName: count
203
+ databaseName: *database0Name
204
+
205
+ - description: "estimatedDocumentCount errors correctly on less than 4.9.0--command error"
206
+ runOnRequirements:
207
+ - minServerVersion: "4.0.0"
208
+ maxServerVersion: "4.8.99"
209
+ topologies: [ single, replicaset ]
210
+ - minServerVersion: "4.2.0"
211
+ maxServerVersion: "4.8.99"
212
+ topologies: [ sharded ]
213
+ operations:
214
+ - name: failPoint
215
+ object: testRunner
216
+ arguments:
217
+ client: *client0
218
+ failPoint:
219
+ configureFailPoint: failCommand
220
+ mode: { times: 1 }
221
+ data:
222
+ failCommands: [ count ]
223
+ errorCode: 8 # UnknownError
224
+ - name: estimatedDocumentCount
225
+ object: *collection0
226
+ expectError:
227
+ errorCode: 8 # UnknownError
228
+ expectEvents:
229
+ - client: *client0
230
+ events:
231
+ - commandStartedEvent:
232
+ command:
233
+ count: *collection0Name
234
+ commandName: count
235
+ databaseName: *database0Name
236
+
237
+ - description: "estimatedDocumentCount errors correctly on less than 4.9.0--socket error"
238
+ runOnRequirements:
239
+ - minServerVersion: "4.0.0"
240
+ maxServerVersion: "4.8.99"
241
+ topologies: [ single, replicaset ]
242
+ - minServerVersion: "4.2.0"
243
+ maxServerVersion: "4.8.99"
244
+ topologies: [ sharded ]
245
+ operations:
246
+ - name: failPoint
247
+ object: testRunner
248
+ arguments:
249
+ client: *client0
250
+ failPoint:
251
+ configureFailPoint: failCommand
252
+ mode: { times: 1 }
253
+ data:
254
+ failCommands: [ count ]
255
+ closeConnection: true
256
+ - name: estimatedDocumentCount
257
+ object: *collection0
258
+ expectError:
259
+ isError: true
260
+ expectEvents:
261
+ - client: *client0
262
+ events:
263
+ - commandStartedEvent:
264
+ command:
265
+ count: *collection0Name
266
+ commandName: count
267
+ databaseName: *database0Name
@@ -0,0 +1,60 @@
1
+ runOn:
2
+ - minServerVersion: "4.9.0"
3
+
4
+ database_name: &database_name "retryable-reads-tests"
5
+ collection_name: &collection_name "coll"
6
+
7
+ data:
8
+ - { _id: 1, x: 11 }
9
+ - { _id: 2, x: 22 }
10
+
11
+ tests:
12
+ -
13
+ description: "EstimatedDocumentCount succeeds on first attempt"
14
+ operations:
15
+ - &retryable_operation_succeeds
16
+ <<: &retryable_operation
17
+ name: estimatedDocumentCount
18
+ object: collection
19
+ result: 2
20
+ expectations:
21
+ - &retryable_command_started_event
22
+ command_started_event:
23
+ command:
24
+ aggregate: *collection_name
25
+ pipeline: &pipeline
26
+ - $collStats: { count: {} }
27
+ - $group: { _id: 1, n: { $sum: $count }}
28
+ database_name: *database_name
29
+ -
30
+ description: "EstimatedDocumentCount succeeds on second attempt"
31
+ failPoint: &failCommand_failPoint
32
+ configureFailPoint: failCommand
33
+ mode: { times: 1 }
34
+ data:
35
+ failCommands: [aggregate]
36
+ closeConnection: true
37
+ operations: [*retryable_operation_succeeds]
38
+ expectations:
39
+ - *retryable_command_started_event
40
+ - *retryable_command_started_event
41
+ -
42
+ description: "EstimatedDocumentCount fails on first attempt"
43
+ clientOptions:
44
+ retryReads: false
45
+ failPoint: *failCommand_failPoint
46
+ operations:
47
+ - &retryable_operation_fails
48
+ <<: *retryable_operation
49
+ error: true
50
+ expectations:
51
+ - *retryable_command_started_event
52
+ -
53
+ description: "EstimatedDocumentCount fails on second attempt"
54
+ failPoint:
55
+ <<: *failCommand_failPoint
56
+ mode: { times: 2 }
57
+ operations: [*retryable_operation_fails]
58
+ expectations:
59
+ - *retryable_command_started_event
60
+ - *retryable_command_started_event
@@ -1,9 +1,11 @@
1
1
  runOn:
2
2
  -
3
3
  minServerVersion: "4.0"
4
+ maxServerVersion: "4.8.99"
4
5
  topology: ["single", "replicaset"]
5
6
  -
6
7
  minServerVersion: "4.1.7"
8
+ maxServerVersion: "4.8.99"
7
9
  topology: ["sharded"]
8
10
 
9
11
  database_name: &database_name "retryable-reads-tests"