mongo 2.13.0.beta1 → 2.14.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (339) hide show
  1. checksums.yaml +4 -4
  2. checksums.yaml.gz.sig +0 -0
  3. data.tar.gz.sig +1 -5
  4. data/Rakefile +50 -9
  5. data/lib/mongo.rb +13 -2
  6. data/lib/mongo/address.rb +1 -1
  7. data/lib/mongo/address/ipv4.rb +1 -1
  8. data/lib/mongo/address/ipv6.rb +1 -1
  9. data/lib/mongo/auth/aws/request.rb +31 -5
  10. data/lib/mongo/bulk_write.rb +18 -0
  11. data/lib/mongo/caching_cursor.rb +74 -0
  12. data/lib/mongo/client.rb +238 -31
  13. data/lib/mongo/cluster.rb +56 -20
  14. data/lib/mongo/cluster/sdam_flow.rb +13 -10
  15. data/lib/mongo/cluster/topology/replica_set_no_primary.rb +3 -2
  16. data/lib/mongo/cluster/topology/sharded.rb +1 -1
  17. data/lib/mongo/cluster/topology/single.rb +2 -2
  18. data/lib/mongo/collection.rb +66 -24
  19. data/lib/mongo/collection/view.rb +24 -20
  20. data/lib/mongo/collection/view/aggregation.rb +25 -4
  21. data/lib/mongo/collection/view/builder/find_command.rb +38 -18
  22. data/lib/mongo/collection/view/explainable.rb +27 -8
  23. data/lib/mongo/collection/view/iterable.rb +72 -12
  24. data/lib/mongo/collection/view/readable.rb +19 -3
  25. data/lib/mongo/collection/view/writable.rb +55 -5
  26. data/lib/mongo/crypt/encryption_io.rb +6 -6
  27. data/lib/mongo/cursor.rb +16 -3
  28. data/lib/mongo/database.rb +37 -4
  29. data/lib/mongo/database/view.rb +18 -3
  30. data/lib/mongo/distinguishing_semaphore.rb +55 -0
  31. data/lib/mongo/error.rb +5 -0
  32. data/lib/mongo/error/invalid_read_concern.rb +28 -0
  33. data/lib/mongo/error/invalid_server_auth_host.rb +22 -0
  34. data/lib/mongo/error/invalid_session.rb +2 -1
  35. data/lib/mongo/error/operation_failure.rb +11 -5
  36. data/lib/mongo/error/server_certificate_revoked.rb +22 -0
  37. data/lib/mongo/error/sessions_not_supported.rb +35 -0
  38. data/lib/mongo/error/unsupported_option.rb +14 -12
  39. data/lib/mongo/event/base.rb +6 -0
  40. data/lib/mongo/grid/file.rb +5 -0
  41. data/lib/mongo/grid/file/chunk.rb +2 -0
  42. data/lib/mongo/grid/fs_bucket.rb +15 -13
  43. data/lib/mongo/grid/stream/write.rb +9 -3
  44. data/lib/mongo/index/view.rb +3 -0
  45. data/lib/mongo/lint.rb +2 -1
  46. data/lib/mongo/logger.rb +3 -3
  47. data/lib/mongo/monitoring.rb +38 -0
  48. data/lib/mongo/monitoring/command_log_subscriber.rb +10 -2
  49. data/lib/mongo/monitoring/event/command_failed.rb +11 -0
  50. data/lib/mongo/monitoring/event/command_started.rb +37 -2
  51. data/lib/mongo/monitoring/event/command_succeeded.rb +11 -0
  52. data/lib/mongo/monitoring/event/server_closed.rb +1 -1
  53. data/lib/mongo/monitoring/event/server_description_changed.rb +27 -4
  54. data/lib/mongo/monitoring/event/server_heartbeat_failed.rb +9 -2
  55. data/lib/mongo/monitoring/event/server_heartbeat_started.rb +9 -2
  56. data/lib/mongo/monitoring/event/server_heartbeat_succeeded.rb +9 -2
  57. data/lib/mongo/monitoring/event/server_opening.rb +1 -1
  58. data/lib/mongo/monitoring/event/topology_changed.rb +1 -1
  59. data/lib/mongo/monitoring/event/topology_closed.rb +1 -1
  60. data/lib/mongo/monitoring/event/topology_opening.rb +1 -1
  61. data/lib/mongo/monitoring/publishable.rb +6 -3
  62. data/lib/mongo/monitoring/server_description_changed_log_subscriber.rb +9 -1
  63. data/lib/mongo/monitoring/topology_changed_log_subscriber.rb +1 -1
  64. data/lib/mongo/operation.rb +2 -0
  65. data/lib/mongo/operation/aggregate/result.rb +9 -8
  66. data/lib/mongo/operation/collections_info/command.rb +5 -0
  67. data/lib/mongo/operation/collections_info/result.rb +18 -1
  68. data/lib/mongo/operation/delete/bulk_result.rb +2 -0
  69. data/lib/mongo/operation/delete/result.rb +3 -0
  70. data/lib/mongo/operation/explain/command.rb +4 -0
  71. data/lib/mongo/operation/explain/legacy.rb +4 -0
  72. data/lib/mongo/operation/explain/op_msg.rb +6 -0
  73. data/lib/mongo/operation/explain/result.rb +3 -0
  74. data/lib/mongo/operation/find/legacy/result.rb +2 -0
  75. data/lib/mongo/operation/find/result.rb +13 -0
  76. data/lib/mongo/operation/get_more/result.rb +3 -0
  77. data/lib/mongo/operation/indexes/result.rb +5 -0
  78. data/lib/mongo/operation/insert/bulk_result.rb +5 -0
  79. data/lib/mongo/operation/insert/result.rb +5 -0
  80. data/lib/mongo/operation/list_collections/result.rb +5 -0
  81. data/lib/mongo/operation/map_reduce/result.rb +10 -0
  82. data/lib/mongo/operation/parallel_scan/result.rb +4 -0
  83. data/lib/mongo/operation/result.rb +35 -6
  84. data/lib/mongo/operation/shared/bypass_document_validation.rb +1 -0
  85. data/lib/mongo/operation/shared/causal_consistency_supported.rb +1 -0
  86. data/lib/mongo/operation/shared/collections_info_or_list_collections.rb +2 -0
  87. data/lib/mongo/operation/shared/executable.rb +1 -0
  88. data/lib/mongo/operation/shared/idable.rb +2 -1
  89. data/lib/mongo/operation/shared/limited.rb +1 -0
  90. data/lib/mongo/operation/shared/object_id_generator.rb +1 -0
  91. data/lib/mongo/operation/shared/result/aggregatable.rb +1 -0
  92. data/lib/mongo/operation/shared/sessions_supported.rb +1 -0
  93. data/lib/mongo/operation/shared/specifiable.rb +1 -0
  94. data/lib/mongo/operation/shared/write.rb +1 -0
  95. data/lib/mongo/operation/shared/write_concern_supported.rb +1 -0
  96. data/lib/mongo/operation/update/legacy/result.rb +7 -0
  97. data/lib/mongo/operation/update/result.rb +8 -0
  98. data/lib/mongo/operation/users_info/result.rb +3 -0
  99. data/lib/mongo/protocol/message.rb +47 -10
  100. data/lib/mongo/protocol/msg.rb +34 -1
  101. data/lib/mongo/protocol/query.rb +36 -0
  102. data/lib/mongo/protocol/serializers.rb +5 -2
  103. data/lib/mongo/query_cache.rb +242 -0
  104. data/lib/mongo/retryable.rb +8 -1
  105. data/lib/mongo/server.rb +15 -4
  106. data/lib/mongo/server/app_metadata.rb +27 -3
  107. data/lib/mongo/server/connection.rb +4 -4
  108. data/lib/mongo/server/connection_base.rb +38 -12
  109. data/lib/mongo/server/connection_common.rb +2 -2
  110. data/lib/mongo/server/connection_pool.rb +3 -0
  111. data/lib/mongo/server/description.rb +13 -1
  112. data/lib/mongo/server/monitor.rb +76 -44
  113. data/lib/mongo/server/monitor/connection.rb +57 -9
  114. data/lib/mongo/server/pending_connection.rb +14 -4
  115. data/lib/mongo/server/push_monitor.rb +173 -0
  116. data/{spec/runners/transactions/context.rb → lib/mongo/server/push_monitor/connection.rb} +9 -14
  117. data/lib/mongo/server_selector.rb +0 -1
  118. data/lib/mongo/server_selector/base.rb +583 -1
  119. data/lib/mongo/server_selector/nearest.rb +1 -6
  120. data/lib/mongo/server_selector/primary.rb +1 -6
  121. data/lib/mongo/server_selector/primary_preferred.rb +7 -10
  122. data/lib/mongo/server_selector/secondary.rb +1 -6
  123. data/lib/mongo/server_selector/secondary_preferred.rb +1 -7
  124. data/lib/mongo/session.rb +7 -1
  125. data/lib/mongo/socket.rb +26 -12
  126. data/lib/mongo/socket/ocsp_cache.rb +97 -0
  127. data/lib/mongo/socket/ocsp_verifier.rb +368 -0
  128. data/lib/mongo/socket/ssl.rb +46 -25
  129. data/lib/mongo/socket/tcp.rb +1 -1
  130. data/lib/mongo/srv/monitor.rb +7 -13
  131. data/lib/mongo/srv/resolver.rb +14 -10
  132. data/lib/mongo/timeout.rb +2 -0
  133. data/lib/mongo/topology_version.rb +9 -0
  134. data/lib/mongo/uri.rb +21 -390
  135. data/lib/mongo/uri/options_mapper.rb +582 -0
  136. data/lib/mongo/uri/srv_protocol.rb +3 -2
  137. data/lib/mongo/utils.rb +73 -0
  138. data/lib/mongo/version.rb +1 -1
  139. data/spec/NOTES.aws-auth.md +12 -7
  140. data/spec/README.aws-auth.md +2 -2
  141. data/spec/README.md +63 -1
  142. data/spec/integration/awaited_ismaster_spec.rb +28 -0
  143. data/spec/integration/bson_symbol_spec.rb +4 -2
  144. data/spec/integration/bulk_write_spec.rb +67 -0
  145. data/spec/integration/change_stream_examples_spec.rb +6 -2
  146. data/spec/integration/change_stream_spec.rb +1 -1
  147. data/spec/integration/check_clean_slate_spec.rb +16 -0
  148. data/spec/integration/client_authentication_options_spec.rb +92 -28
  149. data/spec/integration/client_construction_spec.rb +1 -0
  150. data/spec/integration/client_side_encryption/auto_encryption_bulk_writes_spec.rb +9 -5
  151. data/spec/integration/connect_single_rs_name_spec.rb +5 -2
  152. data/spec/integration/connection_pool_populator_spec.rb +4 -2
  153. data/spec/integration/connection_spec.rb +7 -4
  154. data/spec/integration/crud_spec.rb +4 -4
  155. data/spec/integration/cursor_reaping_spec.rb +54 -18
  156. data/spec/integration/docs_examples_spec.rb +6 -0
  157. data/spec/integration/fork_reconnect_spec.rb +56 -1
  158. data/spec/integration/grid_fs_bucket_spec.rb +48 -0
  159. data/spec/integration/heartbeat_events_spec.rb +4 -23
  160. data/spec/integration/ocsp_connectivity_spec.rb +26 -0
  161. data/spec/integration/ocsp_verifier_cache_spec.rb +188 -0
  162. data/spec/integration/ocsp_verifier_spec.rb +334 -0
  163. data/spec/integration/query_cache_spec.rb +1045 -0
  164. data/spec/integration/query_cache_transactions_spec.rb +190 -0
  165. data/spec/integration/read_concern_spec.rb +1 -1
  166. data/spec/integration/retryable_errors_spec.rb +1 -1
  167. data/spec/integration/retryable_writes/retryable_writes_40_and_newer_spec.rb +1 -0
  168. data/spec/integration/retryable_writes/shared/performs_legacy_retries.rb +4 -2
  169. data/spec/integration/retryable_writes/shared/performs_modern_retries.rb +3 -3
  170. data/spec/integration/retryable_writes/shared/performs_no_retries.rb +2 -2
  171. data/spec/integration/sdam_error_handling_spec.rb +122 -15
  172. data/spec/integration/sdam_events_spec.rb +80 -6
  173. data/spec/integration/sdam_prose_spec.rb +64 -0
  174. data/spec/integration/server_monitor_spec.rb +25 -1
  175. data/spec/integration/server_selection_spec.rb +36 -0
  176. data/spec/integration/size_limit_spec.rb +23 -5
  177. data/spec/integration/srv_monitoring_spec.rb +38 -3
  178. data/spec/integration/srv_spec.rb +56 -0
  179. data/spec/integration/ssl_uri_options_spec.rb +2 -2
  180. data/spec/integration/transactions_examples_spec.rb +17 -7
  181. data/spec/integration/zlib_compression_spec.rb +25 -0
  182. data/spec/lite_spec_helper.rb +20 -9
  183. data/spec/mongo/address_spec.rb +1 -1
  184. data/spec/mongo/auth/aws/request_region_spec.rb +42 -0
  185. data/spec/mongo/auth/aws/request_spec.rb +76 -0
  186. data/spec/mongo/auth/scram_spec.rb +1 -1
  187. data/spec/mongo/auth/user_spec.rb +1 -1
  188. data/spec/mongo/bulk_write_spec.rb +2 -2
  189. data/spec/mongo/caching_cursor_spec.rb +70 -0
  190. data/spec/mongo/client_construction_spec.rb +386 -3
  191. data/spec/mongo/client_encryption_spec.rb +16 -10
  192. data/spec/mongo/client_spec.rb +85 -3
  193. data/spec/mongo/cluster/topology/replica_set_spec.rb +53 -10
  194. data/spec/mongo/cluster/topology/sharded_spec.rb +1 -1
  195. data/spec/mongo/cluster/topology/single_spec.rb +19 -8
  196. data/spec/mongo/cluster/topology/unknown_spec.rb +1 -1
  197. data/spec/mongo/cluster/topology_spec.rb +1 -1
  198. data/spec/mongo/cluster_spec.rb +37 -35
  199. data/spec/mongo/collection/view/change_stream_resume_spec.rb +7 -7
  200. data/spec/mongo/collection/view/explainable_spec.rb +87 -4
  201. data/spec/mongo/collection/view/map_reduce_spec.rb +2 -0
  202. data/spec/mongo/collection/view/readable_spec.rb +36 -0
  203. data/spec/mongo/collection_spec.rb +572 -0
  204. data/spec/mongo/crypt/auto_decryption_context_spec.rb +1 -1
  205. data/spec/mongo/crypt/auto_encryption_context_spec.rb +1 -1
  206. data/spec/mongo/crypt/binary_spec.rb +1 -6
  207. data/spec/mongo/crypt/binding/binary_spec.rb +1 -6
  208. data/spec/mongo/crypt/binding/context_spec.rb +2 -7
  209. data/spec/mongo/crypt/binding/helpers_spec.rb +1 -6
  210. data/spec/mongo/crypt/binding/mongocrypt_spec.rb +2 -7
  211. data/spec/mongo/crypt/binding/status_spec.rb +1 -6
  212. data/spec/mongo/crypt/binding/version_spec.rb +1 -6
  213. data/spec/mongo/crypt/data_key_context_spec.rb +1 -1
  214. data/spec/mongo/crypt/explicit_decryption_context_spec.rb +1 -1
  215. data/spec/mongo/crypt/explicit_encryption_context_spec.rb +1 -1
  216. data/spec/mongo/crypt/status_spec.rb +1 -6
  217. data/spec/mongo/database_spec.rb +353 -8
  218. data/spec/mongo/distinguishing_semaphore_spec.rb +63 -0
  219. data/spec/mongo/error/no_server_available_spec.rb +1 -1
  220. data/spec/mongo/error/operation_failure_spec.rb +40 -0
  221. data/spec/mongo/index/view_spec.rb +148 -2
  222. data/spec/mongo/logger_spec.rb +13 -11
  223. data/spec/mongo/monitoring/event/server_closed_spec.rb +1 -1
  224. data/spec/mongo/monitoring/event/server_description_changed_spec.rb +1 -4
  225. data/spec/mongo/monitoring/event/server_opening_spec.rb +1 -1
  226. data/spec/mongo/monitoring/event/topology_changed_spec.rb +1 -1
  227. data/spec/mongo/monitoring/event/topology_closed_spec.rb +1 -1
  228. data/spec/mongo/monitoring/event/topology_opening_spec.rb +1 -1
  229. data/spec/mongo/operation/delete/op_msg_spec.rb +3 -3
  230. data/spec/mongo/operation/insert/command_spec.rb +2 -2
  231. data/spec/mongo/operation/insert/op_msg_spec.rb +3 -3
  232. data/spec/mongo/operation/read_preference_op_msg_spec.rb +1 -1
  233. data/spec/mongo/operation/update/command_spec.rb +2 -2
  234. data/spec/mongo/operation/update/op_msg_spec.rb +3 -3
  235. data/spec/mongo/protocol/msg_spec.rb +10 -0
  236. data/spec/mongo/query_cache_spec.rb +280 -0
  237. data/spec/mongo/semaphore_spec.rb +51 -0
  238. data/spec/mongo/server/app_metadata_shared.rb +82 -2
  239. data/spec/mongo/server/connection_auth_spec.rb +2 -2
  240. data/spec/mongo/server/connection_pool_spec.rb +7 -3
  241. data/spec/mongo/server/connection_spec.rb +15 -8
  242. data/spec/mongo/server/description_spec.rb +18 -0
  243. data/spec/mongo/server_selector/nearest_spec.rb +23 -23
  244. data/spec/mongo/server_selector/primary_preferred_spec.rb +26 -26
  245. data/spec/mongo/server_selector/primary_spec.rb +9 -9
  246. data/spec/mongo/server_selector/secondary_preferred_spec.rb +22 -22
  247. data/spec/mongo/server_selector/secondary_spec.rb +18 -18
  248. data/spec/mongo/server_selector_spec.rb +6 -6
  249. data/spec/mongo/session_spec.rb +35 -0
  250. data/spec/mongo/socket/ssl_spec.rb +4 -4
  251. data/spec/mongo/socket_spec.rb +1 -1
  252. data/spec/mongo/uri/srv_protocol_spec.rb +64 -33
  253. data/spec/mongo/uri_option_parsing_spec.rb +11 -11
  254. data/spec/mongo/uri_spec.rb +68 -41
  255. data/spec/mongo/utils_spec.rb +39 -0
  256. data/spec/runners/auth.rb +3 -0
  257. data/spec/runners/change_streams/test.rb +3 -3
  258. data/spec/runners/cmap.rb +1 -1
  259. data/spec/runners/command_monitoring.rb +3 -34
  260. data/spec/runners/connection_string.rb +35 -124
  261. data/spec/runners/crud/context.rb +9 -5
  262. data/spec/runners/crud/operation.rb +59 -27
  263. data/spec/runners/crud/spec.rb +0 -8
  264. data/spec/runners/crud/test.rb +1 -1
  265. data/spec/runners/crud/test_base.rb +0 -19
  266. data/spec/runners/sdam.rb +2 -2
  267. data/spec/runners/server_selection.rb +242 -28
  268. data/spec/runners/transactions.rb +12 -12
  269. data/spec/runners/transactions/operation.rb +151 -25
  270. data/spec/runners/transactions/test.rb +62 -18
  271. data/spec/shared/LICENSE +20 -0
  272. data/spec/shared/lib/mrss/child_process_helper.rb +80 -0
  273. data/spec/shared/lib/mrss/constraints.rb +303 -0
  274. data/spec/shared/lib/mrss/lite_constraints.rb +175 -0
  275. data/spec/shared/lib/mrss/spec_organizer.rb +149 -0
  276. data/spec/spec_helper.rb +3 -1
  277. data/spec/spec_tests/cmap_spec.rb +7 -3
  278. data/spec/spec_tests/command_monitoring_spec.rb +22 -12
  279. data/spec/spec_tests/crud_spec.rb +1 -1
  280. data/spec/spec_tests/data/change_streams/change-streams-errors.yml +4 -9
  281. data/spec/spec_tests/data/change_streams/change-streams-resume-whitelist.yml +66 -0
  282. data/spec/spec_tests/data/change_streams/change-streams.yml +0 -1
  283. data/spec/spec_tests/data/cmap/pool-checkout-connection.yml +6 -2
  284. data/spec/spec_tests/data/cmap/pool-create-min-size.yml +3 -0
  285. data/spec/spec_tests/data/connection_string/valid-warnings.yml +24 -0
  286. data/spec/spec_tests/data/max_staleness/ReplicaSetNoPrimary/MaxStalenessTooSmall.yml +15 -0
  287. data/spec/spec_tests/data/max_staleness/ReplicaSetNoPrimary/NoKnownServers.yml +4 -3
  288. data/spec/spec_tests/data/max_staleness/Unknown/SmallMaxStaleness.yml +1 -0
  289. data/spec/spec_tests/data/sdam_integration/cancel-server-check.yml +96 -0
  290. data/spec/spec_tests/data/sdam_integration/connectTimeoutMS.yml +88 -0
  291. data/spec/spec_tests/data/sdam_integration/find-network-error.yml +83 -0
  292. data/spec/spec_tests/data/sdam_integration/find-shutdown-error.yml +116 -0
  293. data/spec/spec_tests/data/sdam_integration/insert-network-error.yml +86 -0
  294. data/spec/spec_tests/data/sdam_integration/insert-shutdown-error.yml +115 -0
  295. data/spec/spec_tests/data/sdam_integration/isMaster-command-error.yml +168 -0
  296. data/spec/spec_tests/data/sdam_integration/isMaster-network-error.yml +162 -0
  297. data/spec/spec_tests/data/sdam_integration/isMaster-timeout.yml +229 -0
  298. data/spec/spec_tests/data/sdam_integration/rediscover-quickly-after-step-down.yml +87 -0
  299. data/spec/spec_tests/data/sdam_monitoring/discovered_standalone.yml +1 -3
  300. data/spec/spec_tests/data/sdam_monitoring/standalone.yml +2 -2
  301. data/spec/spec_tests/data/sdam_monitoring/standalone_repeated.yml +2 -2
  302. data/spec/spec_tests/data/sdam_monitoring/standalone_suppress_equal_description_changes.yml +2 -2
  303. data/spec/spec_tests/data/sdam_monitoring/standalone_to_rs_with_me_mismatch.yml +2 -2
  304. data/spec/spec_tests/data/uri_options/auth-options.yml +25 -0
  305. data/spec/spec_tests/data/uri_options/compression-options.yml +6 -3
  306. data/spec/spec_tests/data/uri_options/read-preference-options.yml +24 -0
  307. data/spec/spec_tests/data/uri_options/ruby-connection-options.yml +1 -0
  308. data/spec/spec_tests/data/uri_options/tls-options.yml +160 -4
  309. data/spec/spec_tests/dns_seedlist_discovery_spec.rb +9 -1
  310. data/spec/spec_tests/max_staleness_spec.rb +4 -142
  311. data/spec/spec_tests/retryable_reads_spec.rb +2 -2
  312. data/spec/spec_tests/sdam_integration_spec.rb +13 -0
  313. data/spec/spec_tests/sdam_monitoring_spec.rb +1 -2
  314. data/spec/spec_tests/server_selection_spec.rb +4 -116
  315. data/spec/spec_tests/uri_options_spec.rb +31 -33
  316. data/spec/stress/cleanup_spec.rb +17 -2
  317. data/spec/stress/connection_pool_stress_spec.rb +10 -8
  318. data/spec/stress/fork_reconnect_stress_spec.rb +1 -1
  319. data/spec/support/certificates/atlas-ocsp-ca.crt +28 -0
  320. data/spec/support/certificates/atlas-ocsp.crt +41 -0
  321. data/spec/support/client_registry.rb +1 -0
  322. data/spec/support/client_registry_macros.rb +11 -2
  323. data/spec/support/cluster_config.rb +4 -0
  324. data/spec/support/common_shortcuts.rb +45 -0
  325. data/spec/support/constraints.rb +6 -253
  326. data/spec/support/event_subscriber.rb +123 -33
  327. data/spec/support/keyword_struct.rb +26 -0
  328. data/spec/support/matchers.rb +16 -0
  329. data/spec/support/ocsp +1 -0
  330. data/spec/support/session_registry.rb +52 -0
  331. data/spec/support/shared/server_selector.rb +13 -1
  332. data/spec/support/spec_config.rb +60 -13
  333. data/spec/support/spec_setup.rb +1 -1
  334. data/spec/support/utils.rb +84 -1
  335. metadata +1027 -937
  336. metadata.gz.sig +0 -0
  337. data/lib/mongo/server_selector/selectable.rb +0 -560
  338. data/spec/runners/sdam_monitoring.rb +0 -89
  339. data/spec/support/lite_constraints.rb +0 -141
@@ -0,0 +1,229 @@
1
+ # Test SDAM error handling.
2
+ runOn:
3
+ # failCommand appName requirements
4
+ - minServerVersion: "4.4"
5
+
6
+ database_name: &database_name "sdam-tests"
7
+ collection_name: &collection_name "isMaster-timeout"
8
+
9
+ data: []
10
+
11
+ tests:
12
+ - description: Network timeout on Monitor handshake
13
+ # Configure the initial handshake to fail with a timeout.
14
+ # Use times: 2 so that the RTT isMaster is blocked as well.
15
+ failPoint:
16
+ configureFailPoint: failCommand
17
+ mode: { times: 2 }
18
+ data:
19
+ failCommands: ["isMaster"]
20
+ appName: timeoutMonitorHandshakeTest
21
+ blockConnection: true
22
+ blockTimeMS: 1000
23
+ clientOptions:
24
+ retryWrites: false
25
+ connectTimeoutMS: 250
26
+ heartbeatFrequencyMS: 500
27
+ appname: timeoutMonitorHandshakeTest
28
+ operations:
29
+ # The network error on the initial handshake should mark the server
30
+ # Unknown (emitting a ServerDescriptionChangedEvent) and clear the pool.
31
+ - name: waitForEvent
32
+ object: testRunner
33
+ arguments:
34
+ event: ServerMarkedUnknownEvent
35
+ count: 1
36
+ # https://jira.mongodb.org/browse/DRIVERS-1314
37
+ # - name: waitForEvent
38
+ # object: testRunner
39
+ # arguments:
40
+ # event: PoolClearedEvent
41
+ # count: 1
42
+ # Perform an operation to ensure the node is discovered.
43
+ - name: insertMany
44
+ object: collection
45
+ arguments:
46
+ documents:
47
+ - _id: 1
48
+ - _id: 2
49
+ # We cannot assert the server was marked Unknown and pool was cleared an
50
+ # exact number of times because the RTT isMaster may or may not have
51
+ # triggered this failpoint as well.
52
+ # - name: assertEventCount
53
+ # object: testRunner
54
+ # arguments:
55
+ # event: ServerMarkedUnknownEvent
56
+ # count: 1
57
+ # - name: assertEventCount
58
+ # object: testRunner
59
+ # arguments:
60
+ # event: PoolClearedEvent
61
+ # count: 1
62
+
63
+ expectations:
64
+ - command_started_event:
65
+ command:
66
+ insert: *collection_name
67
+ documents:
68
+ - _id: 1
69
+ - _id: 2
70
+ command_name: insert
71
+ database_name: *database_name
72
+
73
+ outcome:
74
+ collection:
75
+ data:
76
+ - {_id: 1}
77
+ - {_id: 2}
78
+
79
+ - description: Network timeout on Monitor check
80
+ clientOptions:
81
+ retryWrites: false
82
+ connectTimeoutMS: 750
83
+ heartbeatFrequencyMS: 500
84
+ appname: timeoutMonitorCheckTest
85
+ operations:
86
+ # Perform an operation to ensure the node is discovered.
87
+ - name: insertMany
88
+ object: collection
89
+ arguments:
90
+ documents:
91
+ - _id: 1
92
+ - _id: 2
93
+ # Configure the next streaming isMaster check to fail with a timeout
94
+ # Use times: 2 so that the RTT isMaster is blocked as well.
95
+ - name: configureFailPoint
96
+ object: testRunner
97
+ arguments:
98
+ failPoint:
99
+ configureFailPoint: failCommand
100
+ mode: { times: 2 }
101
+ data:
102
+ failCommands: ["isMaster"]
103
+ appName: timeoutMonitorCheckTest
104
+ blockConnection: true
105
+ # blockTimeMS is evaluated after the waiting for heartbeatFrequencyMS server-side, so this value only
106
+ # needs to be greater than connectTimeoutMS. The driver will wait for (500+750)ms and the server will
107
+ # respond after (500+1000)ms.
108
+ blockTimeMS: 1000
109
+ # The network error on the next check should mark the server Unknown and
110
+ # clear the pool.
111
+ - name: waitForEvent
112
+ object: testRunner
113
+ arguments:
114
+ event: ServerMarkedUnknownEvent
115
+ count: 1
116
+ - name: waitForEvent
117
+ object: testRunner
118
+ arguments:
119
+ event: PoolClearedEvent
120
+ count: 1
121
+ # Perform an operation to ensure the node is rediscovered.
122
+ - name: insertMany
123
+ object: collection
124
+ arguments:
125
+ documents:
126
+ - _id: 3
127
+ - _id: 4
128
+ # Assert the server was marked Unknown and pool was cleared exactly once.
129
+ - name: assertEventCount
130
+ object: testRunner
131
+ arguments:
132
+ event: ServerMarkedUnknownEvent
133
+ count: 1
134
+ - name: assertEventCount
135
+ object: testRunner
136
+ arguments:
137
+ event: PoolClearedEvent
138
+ count: 1
139
+
140
+ expectations:
141
+ - command_started_event:
142
+ command:
143
+ insert: *collection_name
144
+ documents:
145
+ - _id: 1
146
+ - _id: 2
147
+ command_name: insert
148
+ database_name: *database_name
149
+ - command_started_event:
150
+ command:
151
+ insert: *collection_name
152
+ documents:
153
+ - _id: 3
154
+ - _id: 4
155
+ command_name: insert
156
+ database_name: *database_name
157
+
158
+ outcome:
159
+ collection:
160
+ data:
161
+ - {_id: 1}
162
+ - {_id: 2}
163
+ - {_id: 3}
164
+ - {_id: 4}
165
+
166
+ - description: Driver extends timeout while streaming
167
+ clientOptions:
168
+ retryWrites: false
169
+ connectTimeoutMS: 250
170
+ heartbeatFrequencyMS: 500
171
+ appname: extendsTimeoutTest
172
+ operations:
173
+ # Perform an operation to ensure the node is discovered.
174
+ - name: insertMany
175
+ object: collection
176
+ arguments:
177
+ documents:
178
+ - _id: 1
179
+ - _id: 2
180
+ # Wait for multiple monitor checks to complete.
181
+ - name: wait
182
+ object: testRunner
183
+ arguments:
184
+ ms: 2000
185
+ # Perform an operation to ensure the node is still selectable.
186
+ - name: insertMany
187
+ object: collection
188
+ arguments:
189
+ documents:
190
+ - _id: 3
191
+ - _id: 4
192
+ # Assert that the server was never marked Unknown and the pool was never
193
+ # cleared.
194
+ - name: assertEventCount
195
+ object: testRunner
196
+ arguments:
197
+ event: ServerMarkedUnknownEvent
198
+ count: 0
199
+ - name: assertEventCount
200
+ object: testRunner
201
+ arguments:
202
+ event: PoolClearedEvent
203
+ count: 0
204
+
205
+ expectations:
206
+ - command_started_event:
207
+ command:
208
+ insert: *collection_name
209
+ documents:
210
+ - _id: 1
211
+ - _id: 2
212
+ command_name: insert
213
+ database_name: *database_name
214
+ - command_started_event:
215
+ command:
216
+ insert: *collection_name
217
+ documents:
218
+ - _id: 3
219
+ - _id: 4
220
+ command_name: insert
221
+ database_name: *database_name
222
+
223
+ outcome:
224
+ collection:
225
+ data:
226
+ - {_id: 1}
227
+ - {_id: 2}
228
+ - {_id: 3}
229
+ - {_id: 4}
@@ -0,0 +1,87 @@
1
+ runOn:
2
+ # 4.4 is required for streaming.
3
+ # A replica set is required for replSetStepDown.
4
+ - minServerVersion: "4.4"
5
+ topology: ["replicaset"]
6
+
7
+ database_name: &database_name "sdam-tests"
8
+ collection_name: &collection_name "test-replSetStepDown"
9
+
10
+ data: &data
11
+ - {_id: 1}
12
+ - {_id: 2}
13
+
14
+ tests:
15
+ - description: Rediscover quickly after replSetStepDown
16
+ clientOptions:
17
+ appname: replSetStepDownTest
18
+ # Configure a large heartbeatFrequencyMS
19
+ heartbeatFrequencyMS: 60000
20
+ # Configure a much smaller server selection timeout so that the test
21
+ # will error when it cannot discover the new primary soon.
22
+ serverSelectionTimeoutMS: 5000
23
+ w: majority
24
+ operations:
25
+ # Discover the primary.
26
+ - name: insertMany
27
+ object: collection
28
+ arguments:
29
+ documents:
30
+ - _id: 3
31
+ - _id: 4
32
+ - name: recordPrimary
33
+ object: testRunner
34
+ # Run replSetStepDown on the meta client.
35
+ - name: runAdminCommand
36
+ object: testRunner
37
+ command_name: replSetStepDown
38
+ arguments:
39
+ command:
40
+ replSetStepDown: 1
41
+ secondaryCatchUpPeriodSecs: 1
42
+ force: false
43
+ - name: waitForPrimaryChange
44
+ object: testRunner
45
+ arguments:
46
+ timeoutMS: 5000
47
+ # Rediscover the new primary.
48
+ - name: insertMany
49
+ object: collection
50
+ arguments:
51
+ documents:
52
+ - _id: 5
53
+ - _id: 6
54
+ # Assert that no pools were cleared.
55
+ - name: assertEventCount
56
+ object: testRunner
57
+ arguments:
58
+ event: PoolClearedEvent
59
+ count: 0
60
+
61
+ expectations:
62
+ - command_started_event:
63
+ command:
64
+ insert: *collection_name
65
+ documents:
66
+ - _id: 3
67
+ - _id: 4
68
+ command_name: insert
69
+ database_name: *database_name
70
+ - command_started_event:
71
+ command:
72
+ insert: *collection_name
73
+ documents:
74
+ - _id: 5
75
+ - _id: 6
76
+ command_name: insert
77
+ database_name: *database_name
78
+
79
+ outcome:
80
+ collection:
81
+ data:
82
+ - {_id: 1}
83
+ - {_id: 2}
84
+ - {_id: 3}
85
+ - {_id: 4}
86
+ - {_id: 5}
87
+ - {_id: 6}
@@ -1,7 +1,5 @@
1
- # This is a Ruby driver-specific test because other drivers
2
- # do not allow discovering a standalone topology.
3
1
  description: "Monitoring a discovered standalone connection"
4
- uri: "mongodb://a:27017"
2
+ uri: "mongodb://a:27017/?directConnection=false"
5
3
  phases:
6
4
  -
7
5
  responses:
@@ -1,5 +1,5 @@
1
- description: "Monitoring a forced standalone connection"
2
- uri: "mongodb://a:27017/?connect=direct"
1
+ description: "Monitoring a direct connection"
2
+ uri: "mongodb://a:27017/?directConnection=true"
3
3
  phases:
4
4
  -
5
5
  responses:
@@ -1,5 +1,5 @@
1
- description: "Monitoring a forced standalone connection with repeated ismaster response"
2
- uri: "mongodb://a:27017/?connect=direct"
1
+ description: "Monitoring a direct connection with repeated ismaster response"
2
+ uri: "mongodb://a:27017/?directConnection=true"
3
3
  phases:
4
4
  # phase 1
5
5
  - responses: []
@@ -1,5 +1,5 @@
1
- description: "Monitoring a forced standalone connection - suppress update events for equal server descriptions"
2
- uri: "mongodb://a:27017/?connect=direct"
1
+ description: "Monitoring a direct connection - suppress update events for equal server descriptions"
2
+ uri: "mongodb://a:27017/?directConnection=true"
3
3
  phases:
4
4
  -
5
5
  responses:
@@ -1,5 +1,5 @@
1
- description: "Standalone connection to a replica set node with a me mismatch"
2
- uri: "mongodb://a/?connect=direct"
1
+ description: "Direct connection to a replica set node with a me mismatch"
2
+ uri: "mongodb://a/?directConnection=true"
3
3
  phases:
4
4
  -
5
5
  responses: []
@@ -12,6 +12,31 @@ tests:
12
12
  SERVICE_NAME: "other"
13
13
  CANONICALIZE_HOST_NAME: true
14
14
  authSource: "$external"
15
+ -
16
+ description: "Mixed case in auth mechanism properties is preserved"
17
+ uri: "mongodb://foo:bar@example.com/?authMechanism=GSSAPI&authMechanismProperties=PropertyName:PropertyValue&authSource=$external"
18
+ valid: true
19
+ warning: false
20
+ hosts: ~
21
+ auth: ~
22
+ options:
23
+ authMechanism: "GSSAPI"
24
+ authMechanismProperties:
25
+ PropertyName: PropertyValue
26
+ service_name: mongodb
27
+ authSource: "$external"
28
+ -
29
+ description: "Auth mechanism properties are all invalid"
30
+ uri: "mongodb://foo:bar@example.com/?authMechanism=GSSAPI&authMechanismProperties=PropertyName&authSource=$external"
31
+ valid: true
32
+ warning: true
33
+ hosts: ~
34
+ auth: ~
35
+ options:
36
+ authMechanism: "GSSAPI"
37
+ authMechanismProperties:
38
+ service_name: mongodb
39
+ authSource: "$external"
15
40
  -
16
41
  description: "Valid auth options are parsed correctly (SCRAM-SHA-1)"
17
42
  uri: "mongodb://foo:bar@example.com/?authMechanism=SCRAM-SHA-1&authSource=authSourceDB"
@@ -28,7 +28,8 @@ tests:
28
28
  warning: true
29
29
  hosts: ~
30
30
  auth: ~
31
- options: {}
31
+ # https://jira.mongodb.org/browse/DRIVERS-1368
32
+ options: ~
32
33
  -
33
34
  description: "Too low zlibCompressionLevel causes a warning"
34
35
  uri: "mongodb://example.com/?compressors=zlib&zlibCompressionLevel=-2"
@@ -36,7 +37,8 @@ tests:
36
37
  warning: true
37
38
  hosts: ~
38
39
  auth: ~
39
- options: {}
40
+ # https://jira.mongodb.org/browse/DRIVERS-1368
41
+ options: ~
40
42
  -
41
43
  description: "Too high zlibCompressionLevel causes a warning"
42
44
  uri: "mongodb://example.com/?compressors=zlib&zlibCompressionLevel=10"
@@ -44,5 +46,6 @@ tests:
44
46
  warning: true
45
47
  hosts: ~
46
48
  auth: ~
47
- options: {}
49
+ # https://jira.mongodb.org/browse/DRIVERS-1368
50
+ options: ~
48
51
 
@@ -15,6 +15,18 @@ tests:
15
15
  -
16
16
  dc: "ny"
17
17
  maxStalenessSeconds: 120
18
+ -
19
+ description: "Case is preserved in read preference tag names and values"
20
+ uri: "mongodb://example.com/?readPreference=secondary&readPreferenceTags=DataCenter:NewYork"
21
+ valid: true
22
+ warning: false
23
+ hosts: ~
24
+ auth: ~
25
+ options:
26
+ readPreference: "secondary"
27
+ readPreferenceTags:
28
+ -
29
+ DataCenter: NewYork
18
30
  -
19
31
  description: "Invalid readPreferenceTags causes a warning"
20
32
  uri: "mongodb://example.com/?readPreferenceTags=invalid"
@@ -23,6 +35,18 @@ tests:
23
35
  hosts: ~
24
36
  auth: ~
25
37
  options: {}
38
+ # https://jira.mongodb.org/browse/DRIVERS-1369
39
+ -
40
+ description: "Valid and invalid readPreferenceTags mix"
41
+ uri: "mongodb://example.com/?readPreferenceTags=a:b,invalid"
42
+ valid: true
43
+ warning: true
44
+ hosts: ~
45
+ auth: ~
46
+ options:
47
+ readPreferenceTags:
48
+ -
49
+ a: b
26
50
  -
27
51
  description: "Non-numeric maxStalenessSeconds causes a warning"
28
52
  uri: "mongodb://example.com/?maxStalenessSeconds=invalid"