mongo 2.15.0 → 2.17.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (393) hide show
  1. checksums.yaml +4 -4
  2. checksums.yaml.gz.sig +0 -0
  3. data/README.md +1 -1
  4. data/lib/mongo/auth/aws/request.rb +0 -1
  5. data/lib/mongo/bulk_write.rb +2 -2
  6. data/lib/mongo/client.rb +49 -5
  7. data/lib/mongo/cluster/periodic_executor.rb +4 -3
  8. data/lib/mongo/cluster/reapers/cursor_reaper.rb +76 -43
  9. data/lib/mongo/cluster/sdam_flow.rb +9 -3
  10. data/lib/mongo/cluster/topology/base.rb +13 -9
  11. data/lib/mongo/cluster/topology/load_balanced.rb +102 -0
  12. data/lib/mongo/cluster/topology.rb +28 -8
  13. data/lib/mongo/cluster.rb +136 -51
  14. data/lib/mongo/collection/view/aggregation.rb +63 -23
  15. data/lib/mongo/collection/view/builder/aggregation.rb +16 -17
  16. data/lib/mongo/collection/view/builder/map_reduce.rb +12 -49
  17. data/lib/mongo/collection/view/builder.rb +0 -4
  18. data/lib/mongo/collection/view/change_stream.rb +7 -3
  19. data/lib/mongo/collection/view/iterable.rb +60 -27
  20. data/lib/mongo/collection/view/map_reduce.rb +41 -15
  21. data/lib/mongo/collection/view/readable.rb +84 -52
  22. data/lib/mongo/collection/view/writable.rb +201 -175
  23. data/lib/mongo/collection/view.rb +15 -21
  24. data/lib/mongo/collection.rb +34 -14
  25. data/lib/mongo/cursor/kill_spec.rb +38 -0
  26. data/lib/mongo/cursor.rb +72 -31
  27. data/lib/mongo/database/view.rb +5 -3
  28. data/lib/mongo/database.rb +6 -6
  29. data/lib/mongo/error/bad_load_balancer_target.rb +26 -0
  30. data/lib/mongo/error/missing_service_id.rb +26 -0
  31. data/lib/mongo/error/no_service_connection_available.rb +49 -0
  32. data/lib/mongo/error/notable.rb +7 -0
  33. data/lib/mongo/error/snapshot_session_invalid_server_version.rb +31 -0
  34. data/lib/mongo/error/snapshot_session_transaction_prohibited.rb +30 -0
  35. data/lib/mongo/error.rb +5 -0
  36. data/lib/mongo/grid/fs_bucket.rb +21 -2
  37. data/lib/mongo/id.rb +7 -5
  38. data/lib/mongo/index/view.rb +22 -41
  39. data/lib/mongo/monitoring/event/cmap/pool_cleared.rb +7 -4
  40. data/lib/mongo/monitoring/event/command_failed.rb +1 -1
  41. data/lib/mongo/monitoring/event/command_started.rb +2 -0
  42. data/lib/mongo/monitoring/publishable.rb +2 -2
  43. data/lib/mongo/operation/aggregate/command.rb +8 -0
  44. data/lib/mongo/operation/context.rb +19 -1
  45. data/lib/mongo/operation/count/command.rb +6 -0
  46. data/lib/mongo/operation/count/op_msg.rb +6 -0
  47. data/lib/mongo/operation/create/command.rb +7 -1
  48. data/lib/mongo/operation/create/op_msg.rb +7 -0
  49. data/lib/mongo/operation/create_index/command.rb +17 -1
  50. data/lib/mongo/operation/create_index/op_msg.rb +17 -4
  51. data/lib/mongo/operation/delete/command.rb +6 -3
  52. data/lib/mongo/operation/delete/legacy.rb +9 -2
  53. data/lib/mongo/operation/delete/op_msg.rb +9 -1
  54. data/lib/mongo/operation/distinct/command.rb +6 -0
  55. data/lib/mongo/operation/distinct/op_msg.rb +7 -0
  56. data/lib/mongo/operation/explain/command.rb +13 -1
  57. data/lib/mongo/operation/explain/legacy.rb +12 -5
  58. data/lib/mongo/operation/explain/op_msg.rb +9 -1
  59. data/lib/mongo/operation/find/builder/command.rb +111 -0
  60. data/lib/mongo/{collection/view → operation/find}/builder/flags.rb +10 -14
  61. data/lib/mongo/operation/find/builder/legacy.rb +123 -0
  62. data/lib/mongo/{collection/view → operation/find}/builder/modifiers.rb +31 -25
  63. data/lib/mongo/{cursor → operation/find}/builder.rb +4 -4
  64. data/lib/mongo/operation/find/command.rb +9 -0
  65. data/lib/mongo/operation/find/legacy.rb +10 -1
  66. data/lib/mongo/operation/find/op_msg.rb +12 -0
  67. data/lib/mongo/operation/find.rb +1 -0
  68. data/lib/mongo/operation/get_more/command.rb +1 -0
  69. data/lib/mongo/operation/get_more/command_builder.rb +38 -0
  70. data/lib/mongo/operation/get_more/op_msg.rb +1 -0
  71. data/lib/mongo/operation/get_more.rb +1 -0
  72. data/lib/mongo/operation/kill_cursors/command.rb +8 -0
  73. data/lib/mongo/operation/kill_cursors/command_builder.rb +35 -0
  74. data/lib/mongo/operation/kill_cursors/legacy.rb +2 -1
  75. data/lib/mongo/operation/kill_cursors/op_msg.rb +10 -0
  76. data/lib/mongo/operation/kill_cursors.rb +1 -0
  77. data/lib/mongo/operation/map_reduce/command.rb +8 -0
  78. data/lib/mongo/operation/map_reduce/op_msg.rb +1 -1
  79. data/lib/mongo/operation/result.rb +6 -0
  80. data/lib/mongo/operation/shared/executable.rb +19 -1
  81. data/lib/mongo/operation/shared/polymorphic_operation.rb +1 -1
  82. data/lib/mongo/operation/shared/read_preference_supported.rb +3 -1
  83. data/lib/mongo/operation/shared/response_handling.rb +1 -0
  84. data/lib/mongo/operation/shared/sessions_supported.rb +28 -12
  85. data/lib/mongo/operation/shared/specifiable.rb +11 -29
  86. data/lib/mongo/operation/shared/validatable.rb +87 -0
  87. data/lib/mongo/operation/shared/write.rb +1 -1
  88. data/lib/mongo/operation/update/command.rb +6 -3
  89. data/lib/mongo/operation/update/legacy.rb +19 -11
  90. data/lib/mongo/operation/update/op_msg.rb +8 -4
  91. data/lib/mongo/operation/write_command/command.rb +51 -0
  92. data/lib/mongo/operation/write_command/op_msg.rb +43 -0
  93. data/lib/mongo/operation/write_command.rb +32 -0
  94. data/lib/mongo/operation.rb +10 -0
  95. data/lib/mongo/protocol/query.rb +35 -18
  96. data/lib/mongo/server/connection.rb +25 -3
  97. data/lib/mongo/server/connection_base.rb +12 -1
  98. data/lib/mongo/server/connection_common.rb +38 -1
  99. data/lib/mongo/server/connection_pool/generation_manager.rb +71 -0
  100. data/lib/mongo/server/connection_pool.rb +100 -27
  101. data/lib/mongo/server/description/features.rb +20 -17
  102. data/lib/mongo/server/description/load_balancer.rb +33 -0
  103. data/lib/mongo/server/description.rb +85 -6
  104. data/lib/mongo/server/monitor/connection.rb +5 -6
  105. data/lib/mongo/server/monitor.rb +2 -1
  106. data/lib/mongo/server/pending_connection.rb +47 -31
  107. data/lib/mongo/server/push_monitor.rb +10 -1
  108. data/lib/mongo/server.rb +73 -26
  109. data/lib/mongo/server_selector/base.rb +31 -5
  110. data/lib/mongo/session/session_pool.rb +11 -0
  111. data/lib/mongo/session.rb +40 -1
  112. data/lib/mongo/socket/ocsp_cache.rb +2 -3
  113. data/lib/mongo/socket/ocsp_verifier.rb +6 -37
  114. data/lib/mongo/socket.rb +1 -5
  115. data/lib/mongo/uri/options_mapper.rb +1 -0
  116. data/lib/mongo/uri/srv_protocol.rb +6 -8
  117. data/lib/mongo/uri.rb +18 -0
  118. data/lib/mongo/utils.rb +0 -13
  119. data/lib/mongo/version.rb +1 -1
  120. data/mongo.gemspec +1 -1
  121. data/spec/integration/auth_spec.rb +31 -1
  122. data/spec/integration/awaited_ismaster_spec.rb +1 -1
  123. data/spec/integration/bulk_write_spec.rb +1 -1
  124. data/spec/integration/change_stream_spec.rb +3 -3
  125. data/spec/integration/client_construction_spec.rb +54 -0
  126. data/spec/integration/client_side_encryption/auto_encryption_bulk_writes_spec.rb +1 -1
  127. data/spec/integration/client_side_encryption/auto_encryption_command_monitoring_spec.rb +1 -1
  128. data/spec/integration/client_side_encryption/bson_size_limit_spec.rb +1 -1
  129. data/spec/integration/client_side_encryption/data_key_spec.rb +1 -1
  130. data/spec/integration/client_spec.rb +2 -0
  131. data/spec/integration/command_monitoring_spec.rb +1 -1
  132. data/spec/integration/command_spec.rb +1 -1
  133. data/spec/integration/connection_spec.rb +52 -35
  134. data/spec/integration/crud_spec.rb +174 -1
  135. data/spec/integration/cursor_pinning_spec.rb +121 -0
  136. data/spec/integration/cursor_reaping_spec.rb +8 -4
  137. data/spec/integration/fork_reconnect_spec.rb +1 -5
  138. data/spec/integration/get_more_spec.rb +1 -1
  139. data/spec/integration/heartbeat_events_spec.rb +1 -1
  140. data/spec/integration/map_reduce_spec.rb +77 -0
  141. data/spec/integration/query_cache_spec.rb +47 -2
  142. data/spec/integration/query_cache_transactions_spec.rb +1 -1
  143. data/spec/integration/read_concern_spec.rb +1 -1
  144. data/spec/integration/read_preference_spec.rb +17 -13
  145. data/spec/integration/reconnect_spec.rb +30 -12
  146. data/spec/integration/retryable_errors_spec.rb +1 -1
  147. data/spec/integration/retryable_writes/retryable_writes_36_and_older_spec.rb +1 -1
  148. data/spec/integration/retryable_writes/retryable_writes_40_and_newer_spec.rb +1 -1
  149. data/spec/integration/sdam_error_handling_spec.rb +5 -3
  150. data/spec/integration/sdam_events_spec.rb +35 -19
  151. data/spec/integration/sdam_prose_spec.rb +1 -1
  152. data/spec/integration/server_monitor_spec.rb +1 -0
  153. data/spec/integration/server_selector_spec.rb +22 -5
  154. data/spec/integration/server_spec.rb +2 -0
  155. data/spec/integration/srv_monitoring_spec.rb +1 -1
  156. data/spec/integration/step_down_spec.rb +1 -1
  157. data/spec/integration/transaction_pinning_spec.rb +120 -0
  158. data/spec/integration/versioned_api_examples_spec.rb +45 -0
  159. data/spec/integration/x509_auth_spec.rb +1 -1
  160. data/spec/lite_spec_helper.rb +1 -2
  161. data/spec/mongo/address/unix_spec.rb +1 -0
  162. data/spec/mongo/auth/cr_spec.rb +2 -3
  163. data/spec/mongo/auth/ldap_spec.rb +2 -3
  164. data/spec/mongo/auth/scram_spec.rb +2 -3
  165. data/spec/mongo/auth/user/view_spec.rb +1 -1
  166. data/spec/mongo/auth/x509_spec.rb +2 -3
  167. data/spec/mongo/bulk_write_spec.rb +3 -3
  168. data/spec/mongo/client_construction_spec.rb +259 -28
  169. data/spec/mongo/client_spec.rb +6 -4
  170. data/spec/mongo/cluster/cursor_reaper_spec.rb +36 -21
  171. data/spec/mongo/cluster/periodic_executor_spec.rb +3 -1
  172. data/spec/mongo/cluster_spec.rb +44 -3
  173. data/spec/mongo/collection/view/aggregation_spec.rb +72 -96
  174. data/spec/mongo/collection/view/builder/find_command_spec.rb +4 -0
  175. data/spec/mongo/collection/view/builder/op_query_spec.rb +4 -0
  176. data/spec/mongo/collection/view/change_stream_spec.rb +1 -1
  177. data/spec/mongo/collection/view/map_reduce_spec.rb +15 -2
  178. data/spec/mongo/collection_crud_spec.rb +7 -2
  179. data/spec/mongo/collection_ddl_spec.rb +1 -1
  180. data/spec/mongo/collection_spec.rb +1 -1
  181. data/spec/mongo/cursor/builder/get_more_command_spec.rb +4 -0
  182. data/spec/mongo/cursor/builder/op_get_more_spec.rb +4 -0
  183. data/spec/mongo/cursor_spec.rb +15 -5
  184. data/spec/mongo/database_spec.rb +15 -15
  185. data/spec/mongo/error/operation_failure_heavy_spec.rb +1 -1
  186. data/spec/mongo/grid/fs_bucket_spec.rb +18 -12
  187. data/spec/mongo/grid/stream/write_spec.rb +3 -9
  188. data/spec/mongo/grid/stream_spec.rb +1 -1
  189. data/spec/mongo/index/view_spec.rb +2 -2
  190. data/spec/mongo/operation/delete/op_msg_spec.rb +1 -1
  191. data/spec/mongo/{collection/view → operation/find}/builder/flags_spec.rb +2 -2
  192. data/spec/mongo/{collection/view → operation/find}/builder/modifiers_spec.rb +2 -2
  193. data/spec/mongo/operation/find/legacy_spec.rb +1 -0
  194. data/spec/mongo/operation/insert/bulk_spec.rb +1 -1
  195. data/spec/mongo/operation/insert/op_msg_spec.rb +1 -1
  196. data/spec/mongo/operation/kill_cursors_spec.rb +4 -1
  197. data/spec/mongo/operation/read_preference_legacy_spec.rb +4 -0
  198. data/spec/mongo/operation/read_preference_op_msg_spec.rb +26 -1
  199. data/spec/mongo/operation/update/bulk_spec.rb +1 -1
  200. data/spec/mongo/operation/update/op_msg_spec.rb +1 -1
  201. data/spec/mongo/query_cache_spec.rb +6 -2
  202. data/spec/mongo/server/connection_common_spec.rb +62 -11
  203. data/spec/mongo/server/connection_pool_spec.rb +73 -7
  204. data/spec/mongo/server/connection_spec.rb +138 -43
  205. data/spec/mongo/server/description_spec.rb +1 -1
  206. data/spec/mongo/server/monitor/connection_spec.rb +22 -0
  207. data/spec/mongo/server/monitor_spec.rb +4 -3
  208. data/spec/mongo/server/push_monitor_spec.rb +101 -0
  209. data/spec/mongo/server_selector_spec.rb +136 -15
  210. data/spec/mongo/session/session_pool_spec.rb +42 -10
  211. data/spec/mongo/session_transaction_spec.rb +15 -30
  212. data/spec/mongo/socket/ssl_spec.rb +26 -58
  213. data/spec/mongo/socket/unix_spec.rb +1 -0
  214. data/spec/mongo/uri_option_parsing_spec.rb +38 -5
  215. data/spec/mongo/utils_spec.rb +0 -14
  216. data/spec/runners/change_streams/test.rb +1 -1
  217. data/spec/runners/cmap.rb +1 -1
  218. data/spec/runners/connection_string.rb +7 -3
  219. data/spec/runners/crud/operation.rb +5 -3
  220. data/spec/runners/crud/requirement.rb +1 -0
  221. data/spec/runners/crud/verifier.rb +1 -2
  222. data/spec/runners/crud.rb +1 -1
  223. data/spec/runners/sdam.rb +2 -1
  224. data/spec/runners/transactions/test.rb +2 -2
  225. data/spec/runners/unified/assertions.rb +5 -4
  226. data/spec/runners/unified/crud_operations.rb +77 -23
  227. data/spec/runners/unified/ddl_operations.rb +29 -1
  228. data/spec/runners/unified/entity_map.rb +3 -3
  229. data/spec/runners/unified/event_subscriber.rb +2 -2
  230. data/spec/runners/unified/support_operations.rb +16 -3
  231. data/spec/runners/unified/test.rb +18 -3
  232. data/spec/runners/unified.rb +1 -1
  233. data/spec/shared/lib/mrss/cluster_config.rb +6 -1
  234. data/spec/shared/lib/mrss/constraints.rb +11 -5
  235. data/spec/shared/lib/mrss/event_subscriber.rb +200 -0
  236. data/spec/shared/lib/mrss/server_version_registry.rb +17 -12
  237. data/spec/shared/share/Dockerfile.erb +5 -4
  238. data/spec/shared/shlib/server.sh +70 -20
  239. data/spec/spec_tests/change_streams_spec.rb +1 -1
  240. data/spec/spec_tests/cmap_spec.rb +4 -1
  241. data/spec/spec_tests/command_monitoring_spec.rb +2 -2
  242. data/spec/spec_tests/data/command_monitoring/find.yml +9 -9
  243. data/spec/spec_tests/data/crud/read/aggregate-collation.yml +2 -1
  244. data/spec/spec_tests/data/crud/read/aggregate-out.yml +1 -0
  245. data/spec/spec_tests/data/crud/read/count-collation.yml +2 -1
  246. data/spec/spec_tests/data/crud/read/distinct-collation.yml +2 -1
  247. data/spec/spec_tests/data/crud/read/find-collation.yml +2 -1
  248. data/spec/spec_tests/data/crud/write/bulkWrite-collation.yml +2 -1
  249. data/spec/spec_tests/data/crud/write/deleteMany-collation.yml +2 -1
  250. data/spec/spec_tests/data/crud/write/deleteOne-collation.yml +2 -1
  251. data/spec/spec_tests/data/crud/write/findOneAndDelete-collation.yml +3 -2
  252. data/spec/spec_tests/data/crud/write/findOneAndReplace-collation.yml +2 -1
  253. data/spec/spec_tests/data/crud/write/findOneAndUpdate-collation.yml +3 -2
  254. data/spec/spec_tests/data/crud/write/replaceOne-collation.yml +3 -2
  255. data/spec/spec_tests/data/crud/write/updateMany-collation.yml +2 -1
  256. data/spec/spec_tests/data/crud/write/updateOne-collation.yml +2 -1
  257. data/spec/spec_tests/data/crud_unified/aggregate-let.yml +138 -0
  258. data/spec/spec_tests/data/crud_unified/aggregate-write-readPreference.yml +155 -0
  259. data/spec/spec_tests/data/crud_unified/db-aggregate-write-readPreference.yml +151 -0
  260. data/spec/spec_tests/data/crud_unified/deleteMany-let.yml +91 -0
  261. data/spec/spec_tests/data/crud_unified/deleteOne-let.yml +89 -0
  262. data/spec/spec_tests/data/crud_unified/find-let.yml +71 -0
  263. data/spec/spec_tests/data/crud_unified/findOneAndDelete-let.yml +88 -0
  264. data/spec/spec_tests/data/crud_unified/findOneAndReplace-let.yml +94 -0
  265. data/spec/spec_tests/data/crud_unified/findOneAndUpdate-let.yml +96 -0
  266. data/spec/spec_tests/data/crud_unified/updateMany-let.yml +103 -0
  267. data/spec/spec_tests/data/crud_unified/updateOne-let.yml +98 -0
  268. data/spec/spec_tests/data/load_balancers/event-monitoring.yml +99 -0
  269. data/spec/spec_tests/data/load_balancers/lb-connection-establishment.yml +36 -0
  270. data/spec/spec_tests/data/load_balancers/non-lb-connection-establishment.yml +56 -0
  271. data/spec/spec_tests/data/load_balancers/server-selection.yml +50 -0
  272. data/spec/spec_tests/data/max_staleness/ReplicaSetNoPrimary/DefaultNoMaxStaleness.yml +2 -2
  273. data/spec/spec_tests/data/max_staleness/ReplicaSetNoPrimary/LastUpdateTime.yml +3 -3
  274. data/spec/spec_tests/data/max_staleness/ReplicaSetNoPrimary/Nearest.yml +3 -3
  275. data/spec/spec_tests/data/max_staleness/ReplicaSetNoPrimary/Nearest2.yml +3 -3
  276. data/spec/spec_tests/data/max_staleness/ReplicaSetNoPrimary/PrimaryPreferred.yml +2 -2
  277. data/spec/spec_tests/data/max_staleness/ReplicaSetNoPrimary/PrimaryPreferred_tags.yml +2 -2
  278. data/spec/spec_tests/data/max_staleness/ReplicaSetNoPrimary/Secondary.yml +4 -4
  279. data/spec/spec_tests/data/max_staleness/ReplicaSetNoPrimary/SecondaryPreferred.yml +2 -2
  280. data/spec/spec_tests/data/max_staleness/ReplicaSetNoPrimary/SecondaryPreferred_tags.yml +4 -4
  281. data/spec/spec_tests/data/max_staleness/ReplicaSetNoPrimary/ZeroMaxStaleness.yml +2 -2
  282. data/spec/spec_tests/data/max_staleness/ReplicaSetWithPrimary/DefaultNoMaxStaleness.yml +2 -2
  283. data/spec/spec_tests/data/max_staleness/ReplicaSetWithPrimary/LastUpdateTime.yml +3 -3
  284. data/spec/spec_tests/data/max_staleness/ReplicaSetWithPrimary/LongHeartbeat.yml +2 -2
  285. data/spec/spec_tests/data/max_staleness/ReplicaSetWithPrimary/LongHeartbeat2.yml +2 -2
  286. data/spec/spec_tests/data/max_staleness/ReplicaSetWithPrimary/MaxStalenessTooSmall.yml +2 -2
  287. data/spec/spec_tests/data/max_staleness/ReplicaSetWithPrimary/MaxStalenessWithModePrimary.yml +2 -2
  288. data/spec/spec_tests/data/max_staleness/ReplicaSetWithPrimary/Nearest.yml +3 -3
  289. data/spec/spec_tests/data/max_staleness/ReplicaSetWithPrimary/Nearest2.yml +3 -3
  290. data/spec/spec_tests/data/max_staleness/ReplicaSetWithPrimary/Nearest_tags.yml +2 -2
  291. data/spec/spec_tests/data/max_staleness/ReplicaSetWithPrimary/PrimaryPreferred.yml +2 -2
  292. data/spec/spec_tests/data/max_staleness/ReplicaSetWithPrimary/SecondaryPreferred.yml +2 -2
  293. data/spec/spec_tests/data/max_staleness/ReplicaSetWithPrimary/SecondaryPreferred_tags.yml +5 -5
  294. data/spec/spec_tests/data/max_staleness/ReplicaSetWithPrimary/SecondaryPreferred_tags2.yml +3 -3
  295. data/spec/spec_tests/data/max_staleness/ReplicaSetWithPrimary/Secondary_tags.yml +5 -5
  296. data/spec/spec_tests/data/max_staleness/ReplicaSetWithPrimary/Secondary_tags2.yml +3 -3
  297. data/spec/spec_tests/data/max_staleness/ReplicaSetWithPrimary/ZeroMaxStaleness.yml +2 -2
  298. data/spec/spec_tests/data/max_staleness/Sharded/SmallMaxStaleness.yml +2 -2
  299. data/spec/spec_tests/data/max_staleness/Single/SmallMaxStaleness.yml +1 -1
  300. data/spec/spec_tests/data/max_staleness/Unknown/SmallMaxStaleness.yml +1 -1
  301. data/spec/spec_tests/data/retryable_reads/changeStreams-client.watch-serverErrors.yml +1 -1
  302. data/spec/spec_tests/data/retryable_reads/changeStreams-client.watch.yml +1 -1
  303. data/spec/spec_tests/data/retryable_reads/changeStreams-db.coll.watch-serverErrors.yml +1 -1
  304. data/spec/spec_tests/data/retryable_reads/changeStreams-db.coll.watch.yml +1 -1
  305. data/spec/spec_tests/data/retryable_reads/changeStreams-db.watch-serverErrors.yml +1 -1
  306. data/spec/spec_tests/data/retryable_reads/changeStreams-db.watch.yml +1 -1
  307. data/spec/spec_tests/data/retryable_reads/mapReduce.yml +3 -1
  308. data/spec/spec_tests/data/sdam/load-balanced/discover_load_balancer.yml +25 -0
  309. data/spec/spec_tests/data/sdam_integration/find-network-error.yml +2 -0
  310. data/spec/spec_tests/data/sdam_integration/find-shutdown-error.yml +2 -0
  311. data/spec/spec_tests/data/sdam_integration/hello-command-error.yml +3 -1
  312. data/spec/spec_tests/data/sdam_integration/hello-network-error.yml +3 -1
  313. data/spec/spec_tests/data/sdam_integration/hello-timeout.yml +2 -0
  314. data/spec/spec_tests/data/sdam_integration/insert-network-error.yml +2 -0
  315. data/spec/spec_tests/data/sdam_integration/insert-shutdown-error.yml +2 -0
  316. data/spec/spec_tests/data/sdam_monitoring/load_balancer.yml +65 -0
  317. data/spec/spec_tests/data/seed_list_discovery/load-balanced/loadBalanced-directConnection.yml +13 -0
  318. data/spec/spec_tests/data/seed_list_discovery/load-balanced/loadBalanced-replicaSet-errors.yml +6 -0
  319. data/spec/spec_tests/data/seed_list_discovery/load-balanced/loadBalanced-true-multiple-hosts.yml +5 -0
  320. data/spec/spec_tests/data/seed_list_discovery/load-balanced/loadBalanced-true-txt.yml +10 -0
  321. data/spec/spec_tests/data/{dns_seedlist_discovery → seed_list_discovery/replica-set}/direct-connection-false.yml +0 -0
  322. data/spec/spec_tests/data/{dns_seedlist_discovery → seed_list_discovery/replica-set}/direct-connection-true.yml +0 -0
  323. data/spec/spec_tests/data/seed_list_discovery/replica-set/encoded-userinfo-and-db.yml +15 -0
  324. data/spec/spec_tests/data/seed_list_discovery/replica-set/loadBalanced-false-txt.yml +10 -0
  325. data/spec/spec_tests/data/{dns_seedlist_discovery → seed_list_discovery/replica-set}/longer-parent-in-return.yml +0 -0
  326. data/spec/spec_tests/data/{dns_seedlist_discovery → seed_list_discovery/replica-set}/misformatted-option.yml +0 -0
  327. data/spec/spec_tests/data/{dns_seedlist_discovery → seed_list_discovery/replica-set}/no-results.yml +0 -0
  328. data/spec/spec_tests/data/{dns_seedlist_discovery → seed_list_discovery/replica-set}/not-enough-parts.yml +0 -0
  329. data/spec/spec_tests/data/{dns_seedlist_discovery → seed_list_discovery/replica-set}/one-result-default-port.yml +0 -0
  330. data/spec/spec_tests/data/{dns_seedlist_discovery → seed_list_discovery/replica-set}/one-txt-record-multiple-strings.yml +0 -0
  331. data/spec/spec_tests/data/{dns_seedlist_discovery → seed_list_discovery/replica-set}/one-txt-record.yml +0 -0
  332. data/spec/spec_tests/data/{dns_seedlist_discovery → seed_list_discovery/replica-set}/parent-part-mismatch1.yml +0 -0
  333. data/spec/spec_tests/data/{dns_seedlist_discovery → seed_list_discovery/replica-set}/parent-part-mismatch2.yml +0 -0
  334. data/spec/spec_tests/data/{dns_seedlist_discovery → seed_list_discovery/replica-set}/parent-part-mismatch3.yml +0 -0
  335. data/spec/spec_tests/data/{dns_seedlist_discovery → seed_list_discovery/replica-set}/parent-part-mismatch4.yml +0 -0
  336. data/spec/spec_tests/data/{dns_seedlist_discovery → seed_list_discovery/replica-set}/parent-part-mismatch5.yml +0 -0
  337. data/spec/spec_tests/data/{dns_seedlist_discovery → seed_list_discovery/replica-set}/returned-parent-too-short.yml +0 -0
  338. data/spec/spec_tests/data/{dns_seedlist_discovery → seed_list_discovery/replica-set}/returned-parent-wrong.yml +0 -0
  339. data/spec/spec_tests/data/{dns_seedlist_discovery → seed_list_discovery/replica-set}/two-results-default-port.yml +0 -0
  340. data/spec/spec_tests/data/{dns_seedlist_discovery → seed_list_discovery/replica-set}/two-results-nonstandard-port.yml +0 -0
  341. data/spec/spec_tests/data/{dns_seedlist_discovery → seed_list_discovery/replica-set}/two-txt-records.yml +0 -0
  342. data/spec/spec_tests/data/{dns_seedlist_discovery → seed_list_discovery/replica-set}/txt-record-not-allowed-option.yml +0 -0
  343. data/spec/spec_tests/data/{dns_seedlist_discovery → seed_list_discovery/replica-set}/txt-record-with-overridden-ssl-option.yml +0 -0
  344. data/spec/spec_tests/data/{dns_seedlist_discovery → seed_list_discovery/replica-set}/txt-record-with-overridden-uri-option.yml +0 -0
  345. data/spec/spec_tests/data/{dns_seedlist_discovery → seed_list_discovery/replica-set}/txt-record-with-unallowed-option.yml +0 -0
  346. data/spec/spec_tests/data/seed_list_discovery/replica-set/uri-with-admin-database.yml +13 -0
  347. data/spec/spec_tests/data/seed_list_discovery/replica-set/uri-with-auth.yml +12 -0
  348. data/spec/spec_tests/data/{dns_seedlist_discovery → seed_list_discovery/replica-set}/uri-with-port.yml +0 -0
  349. data/spec/spec_tests/data/{dns_seedlist_discovery → seed_list_discovery/replica-set}/uri-with-two-hosts.yml +0 -0
  350. data/spec/spec_tests/data/sessions_unified/snapshot-sessions-not-supported-client-error.yml +69 -0
  351. data/spec/spec_tests/data/sessions_unified/snapshot-sessions-not-supported-server-error.yml +102 -0
  352. data/spec/spec_tests/data/sessions_unified/snapshot-sessions-unsupported-ops.yml +258 -0
  353. data/spec/spec_tests/data/sessions_unified/snapshot-sessions.yml +482 -0
  354. data/spec/spec_tests/data/transactions/retryable-abort-errorLabels.yml +2 -0
  355. data/spec/spec_tests/data/transactions/retryable-abort.yml +2 -0
  356. data/spec/spec_tests/data/transactions/retryable-commit-errorLabels.yml +2 -0
  357. data/spec/spec_tests/data/transactions/retryable-commit.yml +2 -0
  358. data/spec/spec_tests/data/transactions/retryable-writes.yml +2 -0
  359. data/spec/spec_tests/data/uri_options/connection-options.yml +60 -0
  360. data/spec/spec_tests/load_balancers_spec.rb +15 -0
  361. data/spec/spec_tests/retryable_reads_spec.rb +2 -2
  362. data/spec/spec_tests/retryable_writes_spec.rb +1 -1
  363. data/spec/spec_tests/sdam_integration_spec.rb +1 -1
  364. data/spec/spec_tests/sdam_monitoring_spec.rb +10 -5
  365. data/spec/spec_tests/sdam_spec.rb +1 -1
  366. data/spec/spec_tests/seed_list_discovery_spec.rb +118 -0
  367. data/spec/spec_tests/sessions_unified_spec.rb +13 -0
  368. data/spec/spec_tests/uri_options_spec.rb +4 -4
  369. data/spec/stress/fork_reconnect_stress_spec.rb +1 -5
  370. data/spec/stress/push_monitor_close_spec.rb +44 -0
  371. data/spec/support/certificates/atlas-ocsp-ca.crt +82 -90
  372. data/spec/support/certificates/atlas-ocsp.crt +127 -122
  373. data/spec/support/common_shortcuts.rb +2 -3
  374. data/spec/support/matchers.rb +13 -0
  375. data/spec/support/shared/auth_context.rb +16 -0
  376. data/spec/support/shared/session.rb +2 -2
  377. data/spec/support/spec_config.rb +10 -11
  378. data/spec/support/using_hash.rb +31 -0
  379. data/spec/support/utils.rb +1 -1
  380. data.tar.gz.sig +3 -4
  381. metadata +1111 -1029
  382. metadata.gz.sig +2 -3
  383. data/lib/mongo/collection/view/builder/find_command.rb +0 -173
  384. data/lib/mongo/collection/view/builder/op_query.rb +0 -94
  385. data/lib/mongo/cursor/builder/get_more_command.rb +0 -80
  386. data/lib/mongo/cursor/builder/kill_cursors_command.rb +0 -111
  387. data/lib/mongo/cursor/builder/op_get_more.rb +0 -64
  388. data/lib/mongo/cursor/builder/op_kill_cursors.rb +0 -106
  389. data/lib/mongo/server/context.rb +0 -72
  390. data/spec/mongo/cursor/builder/op_kill_cursors_spec.rb +0 -66
  391. data/spec/runners/unified/using_hash.rb +0 -34
  392. data/spec/spec_tests/dns_seedlist_discovery_spec.rb +0 -79
  393. data/spec/support/event_subscriber.rb +0 -221
@@ -0,0 +1,121 @@
1
+ # frozen_string_literal: true
2
+ # encoding: utf-8
3
+
4
+ require 'spec_helper'
5
+
6
+ describe 'Cursor pinning' do
7
+ let(:client) { authorized_client }
8
+ let(:collection_name) { 'cursor_pinning' }
9
+ let(:collection) { client[collection_name] }
10
+
11
+ before do
12
+ authorized_client[collection_name].insert_many([{test: 1}] * 200)
13
+ end
14
+
15
+ let(:server) { client.cluster.next_primary }
16
+
17
+ clean_slate
18
+
19
+ context 'non-lb' do
20
+ require_topology :single, :replica_set, :sharded
21
+ require_no_multi_mongos
22
+
23
+ # When not in load-balanced topology, iterating a cursor creates
24
+ # new connections as needed.
25
+
26
+ it 'creates new connections for iteration' do
27
+ server.pool.size.should == 0
28
+
29
+ # Use batch_size of 2 until RUBY-2727 is fixed.
30
+ enum = collection.find({}, batch_size: 2).to_enum
31
+ # Still zero because we haven't iterated
32
+ server.pool.size.should == 0
33
+
34
+ enum.next
35
+ enum.next
36
+ server.pool.size.should == 1
37
+
38
+ # Grab the connection that was used
39
+ server.with_connection do
40
+ # This requires a new connection
41
+ enum.next
42
+
43
+ server.pool.size.should == 2
44
+ end
45
+ end
46
+ end
47
+
48
+ context 'lb' do
49
+ require_topology :load_balanced
50
+
51
+ # In load-balanced topology, we cannot create new connections to a
52
+ # particular service.
53
+
54
+ context 'when no connection is available' do
55
+
56
+ it 'raises ConnectionCheckOutTimeout' do
57
+ server.pool.size.should == 0
58
+
59
+ enum = collection.find({}, batch_size: 1).to_enum
60
+ # Still zero because we haven't iterated
61
+ server.pool.size.should == 0
62
+
63
+ enum.next
64
+ server.pool.size.should == 1
65
+
66
+ # Grab the connection that was used
67
+ server.with_connection do
68
+ # This requires a new connection, but we cannot make one.
69
+ lambda do
70
+ enum.next
71
+ end.should raise_error(Mongo::Error::ConnectionCheckOutTimeout)
72
+
73
+ server.pool.size.should == 1
74
+ end
75
+ end
76
+ end
77
+
78
+ context 'when connection is available' do
79
+ require_multi_mongos
80
+
81
+ let(:client) { authorized_client.with(max_pool_size: 4) }
82
+
83
+ it 'uses the available connection' do
84
+ server.pool.size.should == 0
85
+
86
+ # Create 4 connections.
87
+
88
+ enums = []
89
+ connections = []
90
+ service_ids = []
91
+
92
+ 4.times do
93
+ view = collection.find({}, batch_size: 1)
94
+ enum = view.to_enum
95
+
96
+ enum.next
97
+
98
+ enums << enum
99
+ service_ids << view.cursor.initial_result.connection_description.service_id
100
+ connections << server.pool.check_out
101
+ end
102
+
103
+ service_ids.uniq.length.should be > 1
104
+
105
+ server.pool.size.should == 4
106
+
107
+ connections.each do |c|
108
+ server.pool.check_in(c)
109
+ end
110
+
111
+ # At this point, in theory, all connections are equally likely to
112
+ # be chosen, but we have cursors referencing more than one
113
+ # distinct service.
114
+ # Iterate each cursor to ensure they all continue to work.
115
+ enums.each do |enum|
116
+ enum.next
117
+ end
118
+ end
119
+ end
120
+ end
121
+ end
@@ -8,6 +8,8 @@ describe 'Cursor reaping' do
8
8
  # in MRI, I don't currently know how to force GC to run in JRuby
9
9
  require_mri
10
10
 
11
+ # Uncomment for debugging this test.
12
+ =begin
11
13
  around(:all) do |example|
12
14
  saved_level = Mongo::Logger.logger.level
13
15
  Mongo::Logger.logger.level = Logger::DEBUG
@@ -17,8 +19,9 @@ describe 'Cursor reaping' do
17
19
  Mongo::Logger.logger.level = saved_level
18
20
  end
19
21
  end
22
+ =end
20
23
 
21
- let(:subscriber) { EventSubscriber.new }
24
+ let(:subscriber) { Mrss::EventSubscriber.new }
22
25
 
23
26
  let(:client) do
24
27
  authorized_client.tap do |client|
@@ -57,10 +60,11 @@ describe 'Cursor reaping' do
57
60
  10.times do
58
61
  scope = collection.find.batch_size(2).no_cursor_timeout
59
62
 
60
- # there is no API for retrieving the cursor
63
+ # Begin iteration, creating the cursor
61
64
  scope.each.first
62
- # and keep the first cursor
63
- cursor_ids << scope.instance_variable_get('@cursor').id
65
+
66
+ scope.cursor.should_not be nil
67
+ cursor_ids << scope.cursor.id
64
68
  end
65
69
  end
66
70
  end
@@ -10,11 +10,7 @@ describe 'fork reconnect' do
10
10
  # On multi-shard sharded clusters a succeeding write request does not
11
11
  # guarantee that the next operation will succeed (since it could be sent to
12
12
  # another shard with a dead connection).
13
- require_no_multi_shard
14
-
15
- # On Ruby 2.3 $?.exitstatus is sometimes nil after Process.wait returns which
16
- # is not supposed to happen.
17
- ruby_version_gte '2.4'
13
+ require_no_multi_mongos
18
14
 
19
15
  let(:client) { authorized_client }
20
16
  let(:server) { client.cluster.next_primary }
@@ -7,7 +7,7 @@ describe 'getMore operation' do
7
7
  # https://jira.mongodb.org/browse/RUBY-1987
8
8
  min_server_fcv '3.2'
9
9
 
10
- let(:subscriber) { EventSubscriber.new }
10
+ let(:subscriber) { Mrss::EventSubscriber.new }
11
11
 
12
12
  let(:client) do
13
13
  authorized_client.tap do |client|
@@ -11,7 +11,7 @@ describe 'Heartbeat events' do
11
11
 
12
12
  clean_slate_for_all
13
13
 
14
- let(:subscriber) { EventSubscriber.new }
14
+ let(:subscriber) { Mrss::EventSubscriber.new }
15
15
 
16
16
  before do
17
17
  Mongo::Monitoring::Global.subscribe(Mongo::Monitoring::SERVER_HEARTBEAT, subscriber)
@@ -0,0 +1,77 @@
1
+ # frozen_string_literal: true
2
+ # encoding: utf-8
3
+
4
+ require 'spec_helper'
5
+
6
+ describe 'Map-reduce operations' do
7
+ let(:client) { authorized_client }
8
+ let(:collection) { client['mr_integration'] }
9
+
10
+ let(:subscriber) { Mrss::EventSubscriber.new }
11
+
12
+ let(:find_options) { {} }
13
+
14
+ let(:operation) do
15
+ collection.find({}, find_options).map_reduce('function(){}', 'function(){}')
16
+ end
17
+
18
+ before do
19
+ collection.insert_one(test: 1)
20
+ client.subscribe(Mongo::Monitoring::COMMAND, subscriber)
21
+ end
22
+
23
+ let(:event) { subscriber.single_command_started_event('mapReduce') }
24
+
25
+ context 'read preference' do
26
+ require_topology :sharded
27
+
28
+ context 'specified on client' do
29
+ let(:client) { authorized_client.with(read: {mode: :secondary_preferred }) }
30
+
31
+ # RUBY-2706: read preference is not sent on pre-3.6 servers
32
+ min_server_fcv '3.6'
33
+
34
+ it 'is sent' do
35
+ operation.to_a
36
+
37
+ event.command['$readPreference'].should == {'mode' => 'secondaryPreferred'}
38
+ end
39
+ end
40
+
41
+ context 'specified on collection' do
42
+ let(:collection) { client['mr_integration', read: {mode: :secondary_preferred }] }
43
+
44
+ # RUBY-2706: read preference is not sent on pre-3.6 servers
45
+ min_server_fcv '3.6'
46
+
47
+ it 'is sent' do
48
+ operation.to_a
49
+
50
+ event.command['$readPreference'].should == {'mode' => 'secondaryPreferred'}
51
+ end
52
+ end
53
+
54
+ context 'specified on operation' do
55
+ let(:find_options) { {read: {mode: :secondary_preferred }} }
56
+
57
+ # RUBY-2706: read preference is not sent on pre-3.6 servers
58
+ min_server_fcv '3.6'
59
+
60
+ it 'is sent' do
61
+ operation.to_a
62
+
63
+ event.command['$readPreference'].should == {'mode' => 'secondaryPreferred'}
64
+ end
65
+ end
66
+ end
67
+
68
+ context 'session' do
69
+ min_server_fcv '3.6'
70
+
71
+ it 'is sent' do
72
+ operation.to_a
73
+
74
+ event.command['lsid'].should_not be nil
75
+ end
76
+ end
77
+ end
@@ -28,7 +28,7 @@ describe 'QueryCache' do
28
28
  SessionRegistry.instance.verify_sessions_ended!
29
29
  end
30
30
 
31
- let(:subscriber) { EventSubscriber.new }
31
+ let(:subscriber) { Mrss::EventSubscriber.new }
32
32
 
33
33
  let(:client) do
34
34
  authorized_client.tap do |client|
@@ -969,7 +969,7 @@ describe 'QueryCache' do
969
969
 
970
970
  context 'when find command fails and retries' do
971
971
  require_fail_command
972
- require_no_multi_shard
972
+ require_no_multi_mongos
973
973
  require_warning_clean
974
974
 
975
975
  before do
@@ -1045,4 +1045,49 @@ describe 'QueryCache' do
1045
1045
  expect(events.length).to eq(2)
1046
1046
  end
1047
1047
  end
1048
+
1049
+ context 'when result set has multiple documents and cursor is iterated partially' do
1050
+
1051
+ before do
1052
+ Mongo::QueryCache.enabled = false
1053
+ 5.times do
1054
+ authorized_collection.insert_one({ name: 'testing' })
1055
+ end
1056
+ end
1057
+
1058
+ shared_examples 'retrieves full result set on second iteration' do
1059
+ it 'retrieves full result set on second iteration' do
1060
+ Mongo::QueryCache.clear
1061
+ Mongo::QueryCache.enabled = true
1062
+
1063
+ partial_first_iteration
1064
+
1065
+ authorized_collection.find.to_a.length.should == 5
1066
+ end
1067
+
1068
+ end
1069
+
1070
+ context 'using each & break' do
1071
+ let(:partial_first_iteration) do
1072
+ called = false
1073
+ authorized_collection.find.each do
1074
+ called = true
1075
+ break
1076
+ end
1077
+ called.should be true
1078
+ end
1079
+
1080
+ include_examples 'retrieves full result set on second iteration'
1081
+ end
1082
+
1083
+ context 'using next' do
1084
+ let(:partial_first_iteration) do
1085
+ # #next is executed in its own fiber, and query cache is disabled
1086
+ # for that operation.
1087
+ authorized_collection.find.to_enum.next
1088
+ end
1089
+
1090
+ include_examples 'retrieves full result set on second iteration'
1091
+ end
1092
+ end
1048
1093
  end
@@ -23,7 +23,7 @@ describe 'QueryCache with transactions' do
23
23
  # leak sessions independently of the query cache. This will be resolved by
24
24
  # RUBY-2391.
25
25
 
26
- let(:subscriber) { EventSubscriber.new }
26
+ let(:subscriber) { Mrss::EventSubscriber.new }
27
27
 
28
28
  let(:client) do
29
29
  authorized_client.tap do |client|
@@ -7,7 +7,7 @@ describe 'read concern' do
7
7
  min_server_version '3.2'
8
8
 
9
9
  let(:subscriber) do
10
- EventSubscriber.new
10
+ Mrss::EventSubscriber.new
11
11
  end
12
12
 
13
13
  let(:specified_read_concern) do
@@ -16,7 +16,7 @@ describe 'Read preference' do
16
16
  authorized_client.with(client_options)
17
17
  end
18
18
 
19
- let(:subscriber) { EventSubscriber.new }
19
+ let(:subscriber) { Mrss::EventSubscriber.new }
20
20
 
21
21
  before do
22
22
  client.subscribe(Mongo::Monitoring::COMMAND, subscriber)
@@ -45,16 +45,6 @@ describe 'Read preference' do
45
45
  {}
46
46
  end
47
47
 
48
- shared_examples_for 'sends expected read preference when reading' do
49
- it 'sends expected read preference when reading' do
50
- read_operation
51
-
52
- event = subscriber.single_command_started_event('find')
53
- actual_preference = event.command['$readPreference']
54
- expect(actual_preference).to eq(expected_read_preference)
55
- end
56
- end
57
-
58
48
  shared_examples_for 'does not send read preference when reading' do
59
49
  it 'does not send read preference when reading' do
60
50
  read_operation
@@ -95,7 +85,17 @@ describe 'Read preference' do
95
85
  context 'server supporting OP_MSG' do
96
86
  min_server_fcv '3.6'
97
87
 
98
- it_behaves_like 'sends expected read preference when reading'
88
+ it 'sends expected read preference when reading' do
89
+ read_operation
90
+
91
+ event = subscriber.single_command_started_event('find')
92
+ actual_preference = event.command['$readPreference']
93
+ if expected_read_preference&.[]("mode") == "primary"
94
+ expect(actual_preference).to be_nil
95
+ else
96
+ expect(actual_preference).to eq(expected_read_preference)
97
+ end
98
+ end
99
99
  end
100
100
  end
101
101
 
@@ -307,7 +307,11 @@ describe 'Read preference' do
307
307
 
308
308
  event = subscriber.single_command_started_event('find')
309
309
  actual_preference = event.command['$readPreference']
310
- expect(actual_preference).to eq(expected_read_preference)
310
+ if expected_read_preference&.[]("mode") == "primary"
311
+ expect(actual_preference).to be_nil
312
+ else
313
+ expect(actual_preference).to eq(expected_read_preference)
314
+ end
311
315
  end
312
316
  end
313
317
  end
@@ -16,20 +16,38 @@ describe 'Client after reconnect' do
16
16
  expect(doc['testk']).to eq('testv')
17
17
  end
18
18
 
19
- it 'recreates monitor thread' do
20
- thread = client.cluster.servers.first.monitor.instance_variable_get('@thread')
21
- expect(thread).to be_alive
19
+ context 'non-lb' do
20
+ require_topology :single, :replica_set, :sharded
22
21
 
23
- thread.kill
24
- # context switch to let the thread get killed
25
- sleep 0.1
26
- expect(thread).not_to be_alive
22
+ it 'recreates monitor thread' do
23
+ thread = client.cluster.servers.first.monitor.instance_variable_get('@thread')
24
+ expect(thread).to be_alive
27
25
 
28
- client.reconnect
26
+ thread.kill
27
+ # context switch to let the thread get killed
28
+ sleep 0.1
29
+ expect(thread).not_to be_alive
30
+
31
+ client.reconnect
32
+
33
+ new_thread = client.cluster.servers.first.monitor.instance_variable_get('@thread')
34
+ expect(new_thread).not_to eq(thread)
35
+ expect(new_thread).to be_alive
36
+ end
37
+ end
38
+
39
+ context 'lb' do
40
+ require_topology :load_balanced
29
41
 
30
- new_thread = client.cluster.servers.first.monitor.instance_variable_get('@thread')
31
- expect(new_thread).not_to eq(thread)
32
- expect(new_thread).to be_alive
42
+ it 'does not recreate monitor thread' do
43
+ thread = client.cluster.servers.first.monitor.instance_variable_get('@thread')
44
+ expect(thread).to be nil
45
+
46
+ client.reconnect
47
+
48
+ new_thread = client.cluster.servers.first.monitor.instance_variable_get('@thread')
49
+ expect(new_thread).to be nil
50
+ end
33
51
  end
34
52
 
35
53
  context 'with min_pool_size > 0' do
@@ -114,7 +132,7 @@ describe 'Client after reconnect' do
114
132
  context 'in sharded topology' do
115
133
  require_topology :sharded
116
134
  require_default_port_deployment
117
- require_multi_shard
135
+ require_multi_mongos
118
136
 
119
137
  let(:expected_topology_cls) { Mongo::Cluster::Topology::Sharded }
120
138
 
@@ -7,7 +7,7 @@ describe 'Failing retryable operations' do
7
7
  # Requirement for fail point
8
8
  min_server_fcv '4.0'
9
9
 
10
- let(:subscriber) { EventSubscriber.new }
10
+ let(:subscriber) { Mrss::EventSubscriber.new }
11
11
 
12
12
  let(:client_options) do
13
13
  {}
@@ -20,7 +20,7 @@ describe 'Retryable writes integration tests' do
20
20
 
21
21
  # These tests override server selector, which fails if there are multiple
22
22
  # eligible servers as would be the case in a multi-shard sharded cluster
23
- require_no_multi_shard
23
+ require_no_multi_mongos
24
24
 
25
25
  # Note: these tests are deprecated in favor of the tests in the file
26
26
  # spec/integration/retryable_writes/retryable_writes_40_and_newer_spec.rb
@@ -10,7 +10,7 @@ require_relative './shared/does_not_support_retries'
10
10
  describe 'Retryable Writes' do
11
11
  require_fail_command
12
12
  require_wired_tiger
13
- require_no_multi_shard
13
+ require_no_multi_mongos
14
14
  require_warning_clean
15
15
 
16
16
  let(:client) do
@@ -4,6 +4,8 @@
4
4
  require 'spec_helper'
5
5
 
6
6
  describe 'SDAM error handling' do
7
+ require_topology :single, :replica_set, :sharded
8
+
7
9
  clean_slate
8
10
 
9
11
  after do
@@ -14,9 +16,9 @@ describe 'SDAM error handling' do
14
16
 
15
17
  # These tests operate on specific servers, and don't work in a multi
16
18
  # shard cluster where multiple servers are equally eligible
17
- require_no_multi_shard
19
+ require_no_multi_mongos
18
20
 
19
- let(:diagnostic_subscriber) { VerboseEventSubscriber.new }
21
+ let(:diagnostic_subscriber) { Mrss::VerboseEventSubscriber.new }
20
22
 
21
23
  let(:client) do
22
24
  new_local_client(SpecConfig.instance.addresses,
@@ -288,7 +290,7 @@ describe 'SDAM error handling' do
288
290
  describe 'when there is an error on monitoring connection' do
289
291
  clean_slate_for_all
290
292
 
291
- let(:subscriber) { EventSubscriber.new }
293
+ let(:subscriber) { Mrss::EventSubscriber.new }
292
294
 
293
295
  let(:set_subscribers) do
294
296
  client.subscribe(Mongo::Monitoring::SERVER_DESCRIPTION_CHANGED, subscriber)
@@ -4,7 +4,7 @@
4
4
  require 'spec_helper'
5
5
 
6
6
  describe 'SDAM events' do
7
- let(:subscriber) { EventSubscriber.new }
7
+ let(:subscriber) { Mrss::EventSubscriber.new }
8
8
 
9
9
  describe 'server closed event' do
10
10
  it 'is published when client is closed' do
@@ -50,13 +50,20 @@ describe 'SDAM events' do
50
50
  context 'pre-4.4 servers' do
51
51
  max_server_version '4.2'
52
52
 
53
+ let(:sdam_proc) do
54
+ Proc.new do |client|
55
+ client.subscribe(Mongo::Monitoring::SERVER_HEARTBEAT, subscriber)
56
+ end
57
+ end
58
+
53
59
  let(:client) do
54
60
  new_local_client(SpecConfig.instance.addresses,
55
61
  # Heartbeat interval is bound by 500 ms
56
- SpecConfig.instance.test_options.merge(heartbeat_frequency: 0.5),
57
- ).tap do |client|
58
- client.subscribe(Mongo::Monitoring::SERVER_HEARTBEAT, subscriber)
59
- end
62
+ SpecConfig.instance.test_options.merge(
63
+ heartbeat_frequency: 0.5,
64
+ sdam_proc: sdam_proc
65
+ ),
66
+ )
60
67
  end
61
68
 
62
69
  it 'is published every heartbeat interval' do
@@ -78,13 +85,20 @@ describe 'SDAM events' do
78
85
  context '4.4+ servers' do
79
86
  min_server_fcv '4.4'
80
87
 
88
+ let(:sdam_proc) do
89
+ Proc.new do |client|
90
+ client.subscribe(Mongo::Monitoring::SERVER_HEARTBEAT, subscriber)
91
+ end
92
+ end
93
+
81
94
  let(:client) do
82
95
  new_local_client(SpecConfig.instance.addresses,
83
96
  # Heartbeat interval is bound by 500 ms
84
- SpecConfig.instance.test_options.merge(heartbeat_frequency: 0.5),
85
- ).tap do |client|
86
- client.subscribe(Mongo::Monitoring::SERVER_HEARTBEAT, subscriber)
87
- end
97
+ SpecConfig.instance.test_options.merge(
98
+ heartbeat_frequency: 0.5,
99
+ sdam_proc: sdam_proc
100
+ ),
101
+ )
88
102
  end
89
103
 
90
104
  it 'is published up to twice every heartbeat interval' do
@@ -92,23 +106,25 @@ describe 'SDAM events' do
92
106
  sleep 3
93
107
  client.close
94
108
 
95
- events = subscriber.select_started_events(Mongo::Monitoring::Event::ServerHeartbeatStarted)
109
+ started_events = subscriber.select_started_events(
110
+ Mongo::Monitoring::Event::ServerHeartbeatStarted
111
+ )
96
112
  # We could have up to 16 events and should have no fewer than 8 events.
97
113
  # Whenever an awaited hello succeeds while the regular monitor is
98
114
  # waiting, the regular monitor's next scan is pushed forward.
99
- events.length.should >= 6
100
- events.length.should <= 18
101
- (started_awaited = events.select(&:awaited?)).should_not be_empty
102
- (started_regular = events.reject(&:awaited?)).should_not be_empty
115
+ started_events.length.should >= 6
116
+ started_events.length.should <= 18
117
+ (started_awaited = started_events.select(&:awaited?)).should_not be_empty
118
+ (started_regular = started_events.reject(&:awaited?)).should_not be_empty
103
119
 
104
- events = subscriber.select_completed_events(
120
+ completed_events = subscriber.select_completed_events(
105
121
  Mongo::Monitoring::Event::ServerHeartbeatSucceeded,
106
122
  Mongo::Monitoring::Event::ServerHeartbeatFailed,
107
123
  )
108
- events.length.should >= 6
109
- events.length.should <= 18
110
- (succeeded_awaited = events.select(&:awaited?)).should_not be_empty
111
- (succeeded_regular = events.reject(&:awaited?)).should_not be_empty
124
+ completed_events.length.should >= 6
125
+ completed_events.length.should <= 18
126
+ (succeeded_awaited = completed_events.select(&:awaited?)).should_not be_empty
127
+ (succeeded_regular = completed_events.reject(&:awaited?)).should_not be_empty
112
128
 
113
129
  # There may be in-flight hellos that don't complete, both
114
130
  # regular and awaited.
@@ -11,7 +11,7 @@ describe 'SDAM prose tests' do
11
11
  min_server_fcv '4.4'
12
12
  require_topology :single
13
13
 
14
- let(:subscriber) { EventSubscriber.new }
14
+ let(:subscriber) { Mrss::EventSubscriber.new }
15
15
 
16
16
  let(:client) do
17
17
  new_local_client(SpecConfig.instance.addresses,
@@ -4,6 +4,7 @@
4
4
  require 'spec_helper'
5
5
 
6
6
  describe 'Server::Monitor' do
7
+ require_topology :single, :replica_set, :sharded
7
8
 
8
9
  let(:client) do
9
10
  new_local_client([ClusterConfig.instance.primary_address_str],