mongo 2.14.0 → 2.15.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- checksums.yaml +4 -4
- checksums.yaml.gz.sig +0 -0
- data/README.md +5 -2
- data/Rakefile +8 -15
- data/lib/mongo/active_support.rb +3 -0
- data/lib/mongo/address/ipv4.rb +3 -0
- data/lib/mongo/address/ipv6.rb +3 -0
- data/lib/mongo/address/unix.rb +3 -0
- data/lib/mongo/address/validator.rb +3 -0
- data/lib/mongo/address.rb +3 -0
- data/lib/mongo/auth/aws/conversation.rb +4 -4
- data/lib/mongo/auth/aws/credentials_retriever.rb +3 -0
- data/lib/mongo/auth/aws/request.rb +3 -0
- data/lib/mongo/auth/aws.rb +3 -0
- data/lib/mongo/auth/base.rb +17 -8
- data/lib/mongo/auth/conversation_base.rb +35 -0
- data/lib/mongo/auth/cr/conversation.rb +9 -29
- data/lib/mongo/auth/cr.rb +3 -0
- data/lib/mongo/auth/credential_cache.rb +3 -0
- data/lib/mongo/auth/gssapi/conversation.rb +7 -15
- data/lib/mongo/auth/gssapi.rb +3 -0
- data/lib/mongo/auth/ldap/conversation.rb +6 -14
- data/lib/mongo/auth/ldap.rb +3 -0
- data/lib/mongo/auth/roles.rb +3 -0
- data/lib/mongo/auth/sasl_conversation_base.rb +4 -13
- data/lib/mongo/auth/scram/conversation.rb +3 -0
- data/lib/mongo/auth/scram.rb +5 -2
- data/lib/mongo/auth/scram256/conversation.rb +3 -0
- data/lib/mongo/auth/scram256.rb +3 -0
- data/lib/mongo/auth/scram_conversation_base.rb +10 -34
- data/lib/mongo/auth/stringprep/profiles/sasl.rb +3 -0
- data/lib/mongo/auth/stringprep/tables.rb +3 -0
- data/lib/mongo/auth/stringprep/unicode_normalize/normalize.rb +2 -2
- data/lib/mongo/auth/stringprep/unicode_normalize/tables.rb +1 -1
- data/lib/mongo/auth/stringprep.rb +4 -1
- data/lib/mongo/auth/user/view.rb +19 -9
- data/lib/mongo/auth/user.rb +3 -0
- data/lib/mongo/auth/x509/conversation.rb +7 -25
- data/lib/mongo/auth/x509.rb +3 -0
- data/lib/mongo/auth.rb +4 -1
- data/lib/mongo/background_thread.rb +16 -2
- data/lib/mongo/bson.rb +3 -0
- data/lib/mongo/bulk_write/combineable.rb +3 -0
- data/lib/mongo/bulk_write/ordered_combiner.rb +3 -0
- data/lib/mongo/bulk_write/result.rb +3 -0
- data/lib/mongo/bulk_write/result_combiner.rb +3 -0
- data/lib/mongo/bulk_write/transformable.rb +3 -0
- data/lib/mongo/bulk_write/unordered_combiner.rb +3 -0
- data/lib/mongo/bulk_write/validatable.rb +3 -0
- data/lib/mongo/bulk_write.rb +24 -18
- data/lib/mongo/caching_cursor.rb +3 -0
- data/lib/mongo/client.rb +86 -7
- data/lib/mongo/client_encryption.rb +3 -0
- data/lib/mongo/cluster/periodic_executor.rb +3 -0
- data/lib/mongo/cluster/reapers/cursor_reaper.rb +9 -2
- data/lib/mongo/cluster/reapers/socket_reaper.rb +3 -0
- data/lib/mongo/cluster/sdam_flow.rb +17 -0
- data/lib/mongo/cluster/topology/base.rb +3 -0
- data/lib/mongo/cluster/topology/no_replica_set_options.rb +3 -0
- data/lib/mongo/cluster/topology/replica_set_no_primary.rb +3 -0
- data/lib/mongo/cluster/topology/replica_set_with_primary.rb +3 -0
- data/lib/mongo/cluster/topology/sharded.rb +3 -0
- data/lib/mongo/cluster/topology/single.rb +3 -0
- data/lib/mongo/cluster/topology/unknown.rb +3 -0
- data/lib/mongo/cluster/topology.rb +3 -0
- data/lib/mongo/cluster.rb +29 -35
- data/lib/mongo/cluster_time.rb +3 -0
- data/lib/mongo/collection/view/aggregation.rb +4 -1
- data/lib/mongo/collection/view/builder/aggregation.rb +3 -0
- data/lib/mongo/collection/view/builder/find_command.rb +3 -0
- data/lib/mongo/collection/view/builder/flags.rb +3 -0
- data/lib/mongo/collection/view/builder/map_reduce.rb +3 -0
- data/lib/mongo/collection/view/builder/modifiers.rb +3 -0
- data/lib/mongo/collection/view/builder/op_query.rb +3 -0
- data/lib/mongo/collection/view/builder.rb +3 -0
- data/lib/mongo/collection/view/change_stream/retryable.rb +3 -0
- data/lib/mongo/collection/view/change_stream.rb +5 -2
- data/lib/mongo/collection/view/explainable.rb +3 -0
- data/lib/mongo/collection/view/immutable.rb +3 -0
- data/lib/mongo/collection/view/iterable.rb +20 -7
- data/lib/mongo/collection/view/map_reduce.rb +5 -2
- data/lib/mongo/collection/view/readable.rb +52 -21
- data/lib/mongo/collection/view/writable.rb +17 -14
- data/lib/mongo/collection/view.rb +3 -0
- data/lib/mongo/collection.rb +43 -17
- data/lib/mongo/crypt/auto_decryption_context.rb +3 -0
- data/lib/mongo/crypt/auto_encrypter.rb +4 -1
- data/lib/mongo/crypt/auto_encryption_context.rb +3 -0
- data/lib/mongo/crypt/binary.rb +3 -0
- data/lib/mongo/crypt/binding.rb +4 -1
- data/lib/mongo/crypt/context.rb +3 -0
- data/lib/mongo/crypt/data_key_context.rb +3 -0
- data/lib/mongo/crypt/encryption_io.rb +3 -0
- data/lib/mongo/crypt/explicit_decryption_context.rb +3 -0
- data/lib/mongo/crypt/explicit_encrypter.rb +3 -0
- data/lib/mongo/crypt/explicit_encryption_context.rb +3 -0
- data/lib/mongo/crypt/handle.rb +3 -0
- data/lib/mongo/crypt/hooks.rb +3 -0
- data/lib/mongo/crypt/kms_context.rb +3 -0
- data/lib/mongo/crypt/status.rb +3 -0
- data/lib/mongo/crypt.rb +3 -0
- data/lib/mongo/cursor/builder/get_more_command.rb +3 -0
- data/lib/mongo/cursor/builder/kill_cursors_command.rb +3 -0
- data/lib/mongo/cursor/builder/op_get_more.rb +3 -0
- data/lib/mongo/cursor/builder/op_kill_cursors.rb +3 -0
- data/lib/mongo/cursor/builder.rb +3 -0
- data/lib/mongo/cursor.rb +16 -2
- data/lib/mongo/database/view.rb +4 -1
- data/lib/mongo/database.rb +26 -6
- data/lib/mongo/dbref.rb +3 -0
- data/lib/mongo/distinguishing_semaphore.rb +3 -0
- data/lib/mongo/error/auth_error.rb +3 -0
- data/lib/mongo/error/bulk_write_error.rb +20 -3
- data/lib/mongo/error/change_stream_resumable.rb +3 -0
- data/lib/mongo/error/closed_stream.rb +3 -0
- data/lib/mongo/error/connection_check_out_timeout.rb +3 -0
- data/lib/mongo/error/connection_perished.rb +3 -0
- data/lib/mongo/error/credential_check_error.rb +3 -0
- data/lib/mongo/error/crypt_error.rb +3 -0
- data/lib/mongo/error/extra_file_chunk.rb +3 -0
- data/lib/mongo/error/failed_string_prep_validation.rb +3 -0
- data/lib/mongo/error/file_not_found.rb +3 -0
- data/lib/mongo/error/handshake_error.rb +3 -0
- data/lib/mongo/error/insufficient_iteration_count.rb +3 -0
- data/lib/mongo/error/internal_driver_error.rb +25 -0
- data/lib/mongo/error/invalid_address.rb +3 -0
- data/lib/mongo/error/invalid_application_name.rb +3 -0
- data/lib/mongo/error/invalid_bulk_operation.rb +3 -0
- data/lib/mongo/error/invalid_bulk_operation_type.rb +3 -0
- data/lib/mongo/error/invalid_collection_name.rb +3 -0
- data/lib/mongo/error/invalid_cursor_operation.rb +3 -0
- data/lib/mongo/error/invalid_database_name.rb +3 -0
- data/lib/mongo/error/invalid_document.rb +3 -0
- data/lib/mongo/error/invalid_file.rb +3 -0
- data/lib/mongo/error/invalid_file_revision.rb +3 -0
- data/lib/mongo/error/invalid_min_pool_size.rb +3 -0
- data/lib/mongo/error/invalid_nonce.rb +3 -0
- data/lib/mongo/error/invalid_read_concern.rb +3 -0
- data/lib/mongo/error/invalid_read_option.rb +3 -0
- data/lib/mongo/error/invalid_replacement_document.rb +3 -0
- data/lib/mongo/error/invalid_server_auth_host.rb +3 -0
- data/lib/mongo/error/invalid_server_auth_response.rb +3 -0
- data/lib/mongo/error/invalid_server_preference.rb +3 -0
- data/lib/mongo/error/invalid_session.rb +3 -0
- data/lib/mongo/error/invalid_signature.rb +3 -0
- data/lib/mongo/error/invalid_transaction_operation.rb +3 -0
- data/lib/mongo/error/invalid_txt_record.rb +3 -0
- data/lib/mongo/error/invalid_update_document.rb +3 -0
- data/lib/mongo/error/invalid_uri.rb +3 -0
- data/lib/mongo/error/invalid_write_concern.rb +3 -0
- data/lib/mongo/error/kms_error.rb +3 -0
- data/lib/mongo/error/lint_error.rb +3 -0
- data/lib/mongo/error/max_bson_size.rb +3 -0
- data/lib/mongo/error/max_message_size.rb +3 -0
- data/lib/mongo/error/mismatched_domain.rb +3 -0
- data/lib/mongo/error/missing_file_chunk.rb +3 -0
- data/lib/mongo/error/missing_password.rb +3 -0
- data/lib/mongo/error/missing_resume_token.rb +3 -0
- data/lib/mongo/error/missing_scram_server_signature.rb +3 -0
- data/lib/mongo/error/mongocryptd_spawn_error.rb +3 -0
- data/lib/mongo/error/multi_index_drop.rb +3 -0
- data/lib/mongo/error/need_primary_server.rb +3 -0
- data/lib/mongo/error/no_server_available.rb +3 -0
- data/lib/mongo/error/no_srv_records.rb +3 -0
- data/lib/mongo/error/notable.rb +3 -0
- data/lib/mongo/error/operation_failure.rb +26 -4
- data/lib/mongo/error/parser.rb +69 -13
- data/lib/mongo/error/pool_closed_error.rb +3 -0
- data/lib/mongo/error/raise_original_error.rb +3 -0
- data/lib/mongo/error/sdam_error_detection.rb +16 -5
- data/lib/mongo/error/server_api_conflict.rb +26 -0
- data/lib/mongo/error/server_api_not_supported.rb +27 -0
- data/lib/mongo/error/server_certificate_revoked.rb +3 -0
- data/lib/mongo/error/session_ended.rb +3 -0
- data/lib/mongo/error/sessions_not_supported.rb +3 -0
- data/lib/mongo/error/socket_error.rb +3 -0
- data/lib/mongo/error/socket_timeout_error.rb +3 -0
- data/lib/mongo/error/unchangeable_collection_option.rb +3 -0
- data/lib/mongo/error/unexpected_chunk_length.rb +3 -0
- data/lib/mongo/error/unexpected_response.rb +3 -0
- data/lib/mongo/error/unknown_payload_type.rb +3 -0
- data/lib/mongo/error/unmet_dependency.rb +24 -0
- data/lib/mongo/error/unsupported_array_filters.rb +3 -0
- data/lib/mongo/error/unsupported_collation.rb +3 -0
- data/lib/mongo/error/unsupported_features.rb +3 -0
- data/lib/mongo/error/unsupported_message_type.rb +3 -0
- data/lib/mongo/error/unsupported_option.rb +3 -0
- data/lib/mongo/error/write_retryable.rb +3 -0
- data/lib/mongo/error.rb +12 -1
- data/lib/mongo/event/base.rb +3 -0
- data/lib/mongo/event/listeners.rb +3 -0
- data/lib/mongo/event/publisher.rb +3 -0
- data/lib/mongo/event/subscriber.rb +3 -0
- data/lib/mongo/event.rb +3 -0
- data/lib/mongo/grid/file/chunk.rb +4 -1
- data/lib/mongo/grid/file/info.rb +3 -0
- data/lib/mongo/grid/file.rb +3 -0
- data/lib/mongo/grid/fs_bucket.rb +65 -44
- data/lib/mongo/grid/stream/read.rb +22 -7
- data/lib/mongo/grid/stream/write.rb +3 -0
- data/lib/mongo/grid/stream.rb +3 -0
- data/lib/mongo/grid.rb +3 -0
- data/lib/mongo/id.rb +3 -0
- data/lib/mongo/index/view.rb +24 -11
- data/lib/mongo/index.rb +3 -0
- data/lib/mongo/lint.rb +3 -0
- data/lib/mongo/loggable.rb +3 -0
- data/lib/mongo/logger.rb +3 -0
- data/lib/mongo/monitoring/cmap_log_subscriber.rb +3 -0
- data/lib/mongo/monitoring/command_log_subscriber.rb +3 -0
- data/lib/mongo/monitoring/event/cmap/base.rb +3 -0
- data/lib/mongo/monitoring/event/cmap/connection_check_out_failed.rb +3 -0
- data/lib/mongo/monitoring/event/cmap/connection_check_out_started.rb +3 -0
- data/lib/mongo/monitoring/event/cmap/connection_checked_in.rb +3 -0
- data/lib/mongo/monitoring/event/cmap/connection_checked_out.rb +3 -0
- data/lib/mongo/monitoring/event/cmap/connection_closed.rb +3 -0
- data/lib/mongo/monitoring/event/cmap/connection_created.rb +3 -0
- data/lib/mongo/monitoring/event/cmap/connection_ready.rb +3 -0
- data/lib/mongo/monitoring/event/cmap/pool_cleared.rb +3 -0
- data/lib/mongo/monitoring/event/cmap/pool_closed.rb +3 -0
- data/lib/mongo/monitoring/event/cmap/pool_created.rb +3 -0
- data/lib/mongo/monitoring/event/cmap.rb +3 -0
- data/lib/mongo/monitoring/event/command_failed.rb +32 -5
- data/lib/mongo/monitoring/event/command_started.rb +20 -2
- data/lib/mongo/monitoring/event/command_succeeded.rb +29 -3
- data/lib/mongo/monitoring/event/secure.rb +39 -5
- data/lib/mongo/monitoring/event/server_closed.rb +3 -0
- data/lib/mongo/monitoring/event/server_description_changed.rb +4 -1
- data/lib/mongo/monitoring/event/server_heartbeat_failed.rb +32 -18
- data/lib/mongo/monitoring/event/server_heartbeat_started.rb +3 -0
- data/lib/mongo/monitoring/event/server_heartbeat_succeeded.rb +30 -16
- data/lib/mongo/monitoring/event/server_opening.rb +3 -0
- data/lib/mongo/monitoring/event/topology_changed.rb +3 -0
- data/lib/mongo/monitoring/event/topology_closed.rb +3 -0
- data/lib/mongo/monitoring/event/topology_opening.rb +3 -0
- data/lib/mongo/monitoring/event.rb +3 -0
- data/lib/mongo/monitoring/publishable.rb +32 -10
- data/lib/mongo/monitoring/sdam_log_subscriber.rb +3 -0
- data/lib/mongo/monitoring/server_closed_log_subscriber.rb +3 -0
- data/lib/mongo/monitoring/server_description_changed_log_subscriber.rb +3 -0
- data/lib/mongo/monitoring/server_opening_log_subscriber.rb +3 -0
- data/lib/mongo/monitoring/topology_changed_log_subscriber.rb +3 -0
- data/lib/mongo/monitoring/topology_closed_log_subscriber.rb +3 -0
- data/lib/mongo/monitoring/topology_opening_log_subscriber.rb +3 -0
- data/lib/mongo/monitoring/unified_sdam_log_subscriber.rb +3 -0
- data/lib/mongo/monitoring.rb +20 -8
- data/lib/mongo/operation/aggregate/command.rb +3 -0
- data/lib/mongo/operation/aggregate/op_msg.rb +3 -0
- data/lib/mongo/operation/aggregate/result.rb +3 -0
- data/lib/mongo/operation/aggregate.rb +3 -0
- data/lib/mongo/operation/collections_info/command.rb +5 -2
- data/lib/mongo/operation/collections_info/result.rb +3 -0
- data/lib/mongo/operation/collections_info.rb +21 -1
- data/lib/mongo/operation/command/command.rb +3 -0
- data/lib/mongo/operation/command/op_msg.rb +3 -0
- data/lib/mongo/operation/command.rb +3 -0
- data/lib/mongo/operation/context.rb +102 -0
- data/lib/mongo/operation/count/command.rb +3 -0
- data/lib/mongo/operation/count/op_msg.rb +3 -0
- data/lib/mongo/operation/count.rb +3 -0
- data/lib/mongo/operation/create/command.rb +3 -0
- data/lib/mongo/operation/create/op_msg.rb +3 -0
- data/lib/mongo/operation/create.rb +3 -0
- data/lib/mongo/operation/create_index/command.rb +3 -0
- data/lib/mongo/operation/create_index/op_msg.rb +3 -0
- data/lib/mongo/operation/create_index.rb +3 -0
- data/lib/mongo/operation/create_user/command.rb +3 -0
- data/lib/mongo/operation/create_user/op_msg.rb +3 -0
- data/lib/mongo/operation/create_user.rb +3 -0
- data/lib/mongo/operation/delete/bulk_result.rb +3 -0
- data/lib/mongo/operation/delete/command.rb +3 -0
- data/lib/mongo/operation/delete/legacy.rb +3 -0
- data/lib/mongo/operation/delete/op_msg.rb +3 -0
- data/lib/mongo/operation/delete/result.rb +3 -0
- data/lib/mongo/operation/delete.rb +3 -0
- data/lib/mongo/operation/distinct/command.rb +3 -0
- data/lib/mongo/operation/distinct/op_msg.rb +3 -0
- data/lib/mongo/operation/distinct.rb +3 -0
- data/lib/mongo/operation/drop/command.rb +3 -0
- data/lib/mongo/operation/drop/op_msg.rb +3 -0
- data/lib/mongo/operation/drop.rb +3 -0
- data/lib/mongo/operation/drop_database/command.rb +3 -0
- data/lib/mongo/operation/drop_database/op_msg.rb +3 -0
- data/lib/mongo/operation/drop_database.rb +3 -0
- data/lib/mongo/operation/drop_index/command.rb +3 -0
- data/lib/mongo/operation/drop_index/op_msg.rb +3 -0
- data/lib/mongo/operation/drop_index.rb +3 -0
- data/lib/mongo/operation/explain/command.rb +3 -0
- data/lib/mongo/operation/explain/legacy.rb +3 -0
- data/lib/mongo/operation/explain/op_msg.rb +3 -0
- data/lib/mongo/operation/explain/result.rb +3 -0
- data/lib/mongo/operation/explain.rb +3 -0
- data/lib/mongo/operation/find/command.rb +3 -0
- data/lib/mongo/operation/find/legacy/result.rb +3 -0
- data/lib/mongo/operation/find/legacy.rb +3 -0
- data/lib/mongo/operation/find/op_msg.rb +3 -0
- data/lib/mongo/operation/find/result.rb +3 -0
- data/lib/mongo/operation/find.rb +3 -0
- data/lib/mongo/operation/get_more/command.rb +3 -0
- data/lib/mongo/operation/get_more/legacy.rb +3 -0
- data/lib/mongo/operation/get_more/op_msg.rb +3 -0
- data/lib/mongo/operation/get_more/result.rb +3 -0
- data/lib/mongo/operation/get_more.rb +3 -0
- data/lib/mongo/operation/indexes/command.rb +3 -0
- data/lib/mongo/operation/indexes/legacy.rb +3 -0
- data/lib/mongo/operation/indexes/op_msg.rb +3 -0
- data/lib/mongo/operation/indexes/result.rb +3 -0
- data/lib/mongo/operation/indexes.rb +18 -1
- data/lib/mongo/operation/insert/bulk_result.rb +3 -0
- data/lib/mongo/operation/insert/command.rb +5 -2
- data/lib/mongo/operation/insert/legacy.rb +5 -2
- data/lib/mongo/operation/insert/op_msg.rb +5 -2
- data/lib/mongo/operation/insert/result.rb +3 -0
- data/lib/mongo/operation/insert.rb +3 -0
- data/lib/mongo/operation/kill_cursors/command.rb +3 -0
- data/lib/mongo/operation/kill_cursors/legacy.rb +3 -0
- data/lib/mongo/operation/kill_cursors/op_msg.rb +3 -0
- data/lib/mongo/operation/kill_cursors.rb +3 -0
- data/lib/mongo/operation/list_collections/command.rb +3 -0
- data/lib/mongo/operation/list_collections/op_msg.rb +3 -0
- data/lib/mongo/operation/list_collections/result.rb +7 -1
- data/lib/mongo/operation/list_collections.rb +3 -0
- data/lib/mongo/operation/map_reduce/command.rb +3 -0
- data/lib/mongo/operation/map_reduce/op_msg.rb +3 -0
- data/lib/mongo/operation/map_reduce/result.rb +3 -0
- data/lib/mongo/operation/map_reduce.rb +3 -0
- data/lib/mongo/operation/op_msg_base.rb +3 -0
- data/lib/mongo/operation/parallel_scan/command.rb +4 -2
- data/lib/mongo/operation/parallel_scan/op_msg.rb +3 -0
- data/lib/mongo/operation/parallel_scan/result.rb +3 -0
- data/lib/mongo/operation/parallel_scan.rb +3 -0
- data/lib/mongo/operation/remove_user/command.rb +3 -0
- data/lib/mongo/operation/remove_user/op_msg.rb +3 -0
- data/lib/mongo/operation/remove_user.rb +3 -0
- data/lib/mongo/operation/result.rb +5 -0
- data/lib/mongo/operation/shared/bypass_document_validation.rb +3 -0
- data/lib/mongo/operation/shared/causal_consistency_supported.rb +3 -0
- data/lib/mongo/operation/shared/executable.rb +24 -14
- data/lib/mongo/operation/shared/executable_no_validate.rb +5 -2
- data/lib/mongo/operation/shared/executable_transaction_label.rb +3 -0
- data/lib/mongo/operation/shared/idable.rb +3 -0
- data/lib/mongo/operation/shared/limited.rb +3 -0
- data/lib/mongo/operation/shared/object_id_generator.rb +3 -0
- data/lib/mongo/operation/shared/op_msg_or_command.rb +4 -7
- data/lib/mongo/operation/shared/op_msg_or_find_command.rb +4 -7
- data/lib/mongo/operation/shared/polymorphic_lookup.rb +3 -0
- data/lib/mongo/operation/shared/polymorphic_operation.rb +42 -0
- data/lib/mongo/operation/shared/polymorphic_result.rb +3 -0
- data/lib/mongo/operation/shared/read_preference_supported.rb +41 -36
- data/lib/mongo/operation/shared/response_handling.rb +26 -23
- data/lib/mongo/operation/shared/result/aggregatable.rb +3 -0
- data/lib/mongo/operation/shared/result/use_legacy_error_parser.rb +3 -0
- data/lib/mongo/operation/shared/sessions_supported.rb +19 -4
- data/lib/mongo/operation/shared/specifiable.rb +3 -0
- data/lib/mongo/operation/shared/write.rb +11 -18
- data/lib/mongo/operation/shared/write_concern_supported.rb +3 -0
- data/lib/mongo/operation/update/bulk_result.rb +3 -0
- data/lib/mongo/operation/update/command.rb +3 -0
- data/lib/mongo/operation/update/legacy/result.rb +3 -0
- data/lib/mongo/operation/update/legacy.rb +3 -0
- data/lib/mongo/operation/update/op_msg.rb +3 -0
- data/lib/mongo/operation/update/result.rb +3 -0
- data/lib/mongo/operation/update.rb +3 -0
- data/lib/mongo/operation/update_user/command.rb +3 -0
- data/lib/mongo/operation/update_user/op_msg.rb +3 -0
- data/lib/mongo/operation/update_user.rb +3 -0
- data/lib/mongo/operation/users_info/command.rb +3 -0
- data/lib/mongo/operation/users_info/op_msg.rb +3 -0
- data/lib/mongo/operation/users_info/result.rb +3 -0
- data/lib/mongo/operation/users_info.rb +3 -0
- data/lib/mongo/operation.rb +5 -2
- data/lib/mongo/options/mapper.rb +3 -0
- data/lib/mongo/options/redacted.rb +3 -0
- data/lib/mongo/options.rb +3 -0
- data/lib/mongo/protocol/bit_vector.rb +3 -0
- data/lib/mongo/protocol/compressed.rb +54 -5
- data/lib/mongo/protocol/delete.rb +3 -0
- data/lib/mongo/protocol/get_more.rb +3 -0
- data/lib/mongo/protocol/insert.rb +3 -0
- data/lib/mongo/protocol/kill_cursors.rb +3 -0
- data/lib/mongo/protocol/message.rb +23 -2
- data/lib/mongo/protocol/msg.rb +39 -16
- data/lib/mongo/protocol/query.rb +18 -14
- data/lib/mongo/protocol/registry.rb +3 -0
- data/lib/mongo/protocol/reply.rb +3 -0
- data/lib/mongo/protocol/serializers.rb +3 -0
- data/lib/mongo/protocol/update.rb +3 -0
- data/lib/mongo/protocol.rb +3 -0
- data/lib/mongo/query_cache.rb +33 -0
- data/lib/mongo/retryable.rb +4 -1
- data/lib/mongo/semaphore.rb +3 -0
- data/lib/mongo/server/app_metadata.rb +89 -33
- data/lib/mongo/server/connection.rb +9 -1
- data/lib/mongo/server/connection_base.rb +35 -20
- data/lib/mongo/server/connection_common.rb +34 -1
- data/lib/mongo/server/connection_pool/populator.rb +3 -0
- data/lib/mongo/server/connection_pool.rb +11 -6
- data/lib/mongo/server/context.rb +3 -0
- data/lib/mongo/server/description/features.rb +13 -9
- data/lib/mongo/server/description.rb +27 -10
- data/lib/mongo/server/monitor/app_metadata.rb +4 -1
- data/lib/mongo/server/monitor/connection.rb +57 -47
- data/lib/mongo/server/monitor.rb +26 -13
- data/lib/mongo/server/pending_connection.rb +37 -20
- data/lib/mongo/server/push_monitor/connection.rb +3 -0
- data/lib/mongo/server/push_monitor.rb +38 -17
- data/lib/mongo/server/round_trip_time_averager.rb +6 -3
- data/lib/mongo/server.rb +24 -15
- data/lib/mongo/server_selector/base.rb +6 -3
- data/lib/mongo/server_selector/nearest.rb +6 -4
- data/lib/mongo/server_selector/primary.rb +6 -4
- data/lib/mongo/server_selector/primary_preferred.rb +6 -4
- data/lib/mongo/server_selector/secondary.rb +6 -4
- data/lib/mongo/server_selector/secondary_preferred.rb +8 -11
- data/lib/mongo/server_selector.rb +3 -0
- data/lib/mongo/session/server_session.rb +3 -0
- data/lib/mongo/session/session_pool.rb +7 -2
- data/lib/mongo/session.rb +18 -11
- data/lib/mongo/socket/ocsp_cache.rb +3 -0
- data/lib/mongo/socket/ocsp_verifier.rb +9 -1
- data/lib/mongo/socket/ssl.rb +11 -0
- data/lib/mongo/socket/tcp.rb +3 -0
- data/lib/mongo/socket/unix.rb +3 -0
- data/lib/mongo/socket.rb +36 -6
- data/lib/mongo/srv/monitor.rb +3 -11
- data/lib/mongo/srv/resolver.rb +3 -0
- data/lib/mongo/srv/result.rb +3 -0
- data/lib/mongo/srv.rb +3 -0
- data/lib/mongo/timeout.rb +3 -0
- data/lib/mongo/topology_version.rb +4 -1
- data/lib/mongo/uri/options_mapper.rb +41 -0
- data/lib/mongo/uri/srv_protocol.rb +3 -0
- data/lib/mongo/uri.rb +3 -0
- data/lib/mongo/utils.rb +45 -0
- data/lib/mongo/version.rb +4 -1
- data/lib/mongo/write_concern/acknowledged.rb +3 -0
- data/lib/mongo/write_concern/base.rb +3 -0
- data/lib/mongo/write_concern/unacknowledged.rb +3 -0
- data/lib/mongo/write_concern.rb +3 -0
- data/lib/mongo.rb +26 -0
- data/spec/README.md +24 -1
- data/spec/atlas/atlas_connectivity_spec.rb +3 -0
- data/spec/atlas/operations_spec.rb +3 -0
- data/spec/integration/auth_spec.rb +28 -15
- data/spec/integration/awaited_ismaster_spec.rb +8 -5
- data/spec/integration/aws_auth_request_spec.rb +3 -0
- data/spec/integration/aws_credentials_retriever_spec.rb +3 -0
- data/spec/integration/bson_symbol_spec.rb +4 -1
- data/spec/integration/bulk_insert_spec.rb +3 -0
- data/spec/integration/bulk_write_error_message_spec.rb +41 -0
- data/spec/integration/bulk_write_spec.rb +3 -0
- data/spec/integration/change_stream_examples_spec.rb +3 -0
- data/spec/integration/change_stream_spec.rb +7 -4
- data/spec/integration/check_clean_slate_spec.rb +3 -0
- data/spec/integration/client_authentication_options_spec.rb +21 -8
- data/spec/integration/client_connectivity_spec.rb +4 -1
- data/spec/integration/client_construction_aws_auth_spec.rb +3 -0
- data/spec/integration/client_construction_spec.rb +3 -0
- data/spec/integration/client_side_encryption/auto_encryption_bulk_writes_spec.rb +3 -0
- data/spec/integration/client_side_encryption/auto_encryption_command_monitoring_spec.rb +3 -0
- data/spec/integration/client_side_encryption/auto_encryption_mongocryptd_spawn_spec.rb +3 -0
- data/spec/integration/client_side_encryption/auto_encryption_old_wire_version_spec.rb +3 -0
- data/spec/integration/client_side_encryption/auto_encryption_reconnect_spec.rb +3 -0
- data/spec/integration/client_side_encryption/auto_encryption_spec.rb +3 -0
- data/spec/integration/client_side_encryption/bson_size_limit_spec.rb +3 -0
- data/spec/integration/client_side_encryption/bypass_mongocryptd_spawn_spec.rb +4 -1
- data/spec/integration/client_side_encryption/client_close_spec.rb +3 -0
- data/spec/integration/client_side_encryption/corpus_spec.rb +3 -0
- data/spec/integration/client_side_encryption/custom_endpoint_spec.rb +3 -0
- data/spec/integration/client_side_encryption/data_key_spec.rb +3 -0
- data/spec/integration/client_side_encryption/explicit_encryption_spec.rb +3 -0
- data/spec/integration/client_side_encryption/external_key_vault_spec.rb +3 -0
- data/spec/integration/client_side_encryption/views_spec.rb +3 -0
- data/spec/integration/client_spec.rb +5 -2
- data/spec/integration/client_update_spec.rb +3 -0
- data/spec/integration/collection_indexes_prose_spec.rb +3 -0
- data/spec/integration/command_monitoring_spec.rb +63 -25
- data/spec/integration/command_spec.rb +3 -0
- data/spec/integration/connect_single_rs_name_spec.rb +6 -3
- data/spec/integration/connection_pool_populator_spec.rb +3 -0
- data/spec/integration/connection_spec.rb +12 -7
- data/spec/integration/crud_spec.rb +31 -0
- data/spec/integration/cursor_reaping_spec.rb +3 -0
- data/spec/integration/docs_examples_spec.rb +11 -1
- data/spec/integration/error_detection_spec.rb +3 -0
- data/spec/integration/fork_reconnect_spec.rb +8 -2
- data/spec/integration/get_more_spec.rb +3 -0
- data/spec/integration/grid_fs_bucket_spec.rb +4 -1
- data/spec/integration/heartbeat_events_spec.rb +7 -4
- data/spec/integration/mmapv1_spec.rb +3 -0
- data/spec/integration/mongos_pinning_spec.rb +3 -0
- data/spec/integration/ocsp_connectivity_spec.rb +3 -0
- data/spec/integration/ocsp_verifier_cache_spec.rb +3 -0
- data/spec/integration/ocsp_verifier_spec.rb +29 -8
- data/spec/integration/operation_failure_code_spec.rb +4 -1
- data/spec/integration/operation_failure_message_spec.rb +90 -0
- data/spec/integration/query_cache_spec.rb +48 -0
- data/spec/integration/query_cache_transactions_spec.rb +3 -0
- data/spec/integration/read_concern_spec.rb +3 -0
- data/spec/integration/read_preference_spec.rb +3 -0
- data/spec/integration/reconnect_spec.rb +4 -1
- data/spec/integration/retryable_errors_spec.rb +3 -0
- data/spec/integration/retryable_writes/retryable_writes_36_and_older_spec.rb +3 -0
- data/spec/integration/retryable_writes/retryable_writes_40_and_newer_spec.rb +3 -0
- data/spec/integration/retryable_writes/shared/adds_diagnostics.rb +3 -0
- data/spec/integration/retryable_writes/shared/does_not_support_retries.rb +3 -0
- data/spec/integration/retryable_writes/shared/only_supports_legacy_retries.rb +3 -0
- data/spec/integration/retryable_writes/shared/performs_legacy_retries.rb +3 -0
- data/spec/integration/retryable_writes/shared/performs_modern_retries.rb +3 -0
- data/spec/integration/retryable_writes/shared/performs_no_retries.rb +3 -0
- data/spec/integration/retryable_writes/shared/supports_legacy_retries.rb +3 -0
- data/spec/integration/retryable_writes/shared/supports_modern_retries.rb +3 -0
- data/spec/integration/retryable_writes/shared/supports_retries.rb +3 -0
- data/spec/integration/retryable_writes_errors_spec.rb +3 -0
- data/spec/integration/sdam_error_handling_spec.rb +6 -3
- data/spec/integration/sdam_events_spec.rb +14 -10
- data/spec/integration/sdam_prose_spec.rb +4 -1
- data/spec/integration/secondary_reads_spec.rb +102 -0
- data/spec/integration/server_description_spec.rb +3 -0
- data/spec/integration/server_monitor_spec.rb +4 -1
- data/spec/integration/server_selection_spec.rb +3 -0
- data/spec/integration/server_selector_spec.rb +3 -0
- data/spec/integration/server_spec.rb +3 -0
- data/spec/integration/shell_examples_spec.rb +3 -0
- data/spec/integration/size_limit_spec.rb +3 -0
- data/spec/integration/snappy_compression_spec.rb +28 -0
- data/spec/integration/srv_monitoring_spec.rb +4 -1
- data/spec/integration/srv_spec.rb +3 -0
- data/spec/integration/ssl_uri_options_spec.rb +3 -0
- data/spec/integration/step_down_spec.rb +3 -0
- data/spec/integration/time_zone_querying_spec.rb +3 -0
- data/spec/integration/transactions_api_examples_spec.rb +3 -0
- data/spec/integration/transactions_examples_spec.rb +9 -0
- data/spec/integration/truncated_utf8_spec.rb +26 -0
- data/spec/integration/versioned_api_examples_spec.rb +69 -0
- data/spec/integration/x509_auth_spec.rb +4 -1
- data/spec/integration/zlib_compression_spec.rb +4 -1
- data/spec/integration/zstd_compression_spec.rb +29 -0
- data/spec/kerberos/kerberos_spec.rb +3 -0
- data/spec/lite_spec_helper.rb +11 -1
- data/spec/mongo/address/ipv4_spec.rb +3 -0
- data/spec/mongo/address/ipv6_spec.rb +3 -0
- data/spec/mongo/address/unix_spec.rb +3 -0
- data/spec/mongo/address/validator_spec.rb +3 -0
- data/spec/mongo/address_spec.rb +18 -11
- data/spec/mongo/auth/aws/request_region_spec.rb +3 -0
- data/spec/mongo/auth/aws/request_spec.rb +3 -0
- data/spec/mongo/auth/cr_spec.rb +3 -0
- data/spec/mongo/auth/gssapi/conversation_spec.rb +3 -0
- data/spec/mongo/auth/invalid_mechanism_spec.rb +3 -0
- data/spec/mongo/auth/ldap/conversation_spec.rb +4 -1
- data/spec/mongo/auth/ldap_spec.rb +8 -1
- data/spec/mongo/auth/scram/conversation_spec.rb +3 -0
- data/spec/mongo/auth/scram256/conversation_spec.rb +3 -0
- data/spec/mongo/auth/scram_negotiation_spec.rb +4 -1
- data/spec/mongo/auth/scram_spec.rb +4 -1
- data/spec/mongo/auth/stringprep/profiles/sasl_spec.rb +3 -0
- data/spec/mongo/auth/stringprep_spec.rb +3 -0
- data/spec/mongo/auth/user/view_spec.rb +3 -0
- data/spec/mongo/auth/user_spec.rb +3 -0
- data/spec/mongo/auth/x509/conversation_spec.rb +6 -3
- data/spec/mongo/auth/x509_spec.rb +3 -0
- data/spec/mongo/auth_spec.rb +3 -0
- data/spec/mongo/bson_spec.rb +3 -0
- data/spec/mongo/bulk_write/ordered_combiner_spec.rb +3 -0
- data/spec/mongo/bulk_write/result_spec.rb +3 -0
- data/spec/mongo/bulk_write/unordered_combiner_spec.rb +3 -0
- data/spec/mongo/bulk_write_spec.rb +3 -0
- data/spec/mongo/caching_cursor_spec.rb +3 -0
- data/spec/mongo/client_construction_spec.rb +213 -34
- data/spec/mongo/client_encryption_spec.rb +3 -0
- data/spec/mongo/client_spec.rb +20 -0
- data/spec/mongo/cluster/cursor_reaper_spec.rb +3 -0
- data/spec/mongo/cluster/periodic_executor_spec.rb +3 -0
- data/spec/mongo/cluster/socket_reaper_spec.rb +3 -0
- data/spec/mongo/cluster/topology/replica_set_spec.rb +12 -9
- data/spec/mongo/cluster/topology/sharded_spec.rb +5 -2
- data/spec/mongo/cluster/topology/single_spec.rb +5 -2
- data/spec/mongo/cluster/topology/unknown_spec.rb +3 -0
- data/spec/mongo/cluster/topology_spec.rb +3 -0
- data/spec/mongo/cluster_spec.rb +7 -18
- data/spec/mongo/cluster_time_spec.rb +3 -0
- data/spec/mongo/collection/view/aggregation_spec.rb +3 -0
- data/spec/mongo/collection/view/builder/find_command_spec.rb +3 -0
- data/spec/mongo/collection/view/builder/flags_spec.rb +3 -0
- data/spec/mongo/collection/view/builder/modifiers_spec.rb +3 -0
- data/spec/mongo/collection/view/builder/op_query_spec.rb +3 -0
- data/spec/mongo/collection/view/change_stream_resume_spec.rb +7 -2
- data/spec/mongo/collection/view/change_stream_spec.rb +16 -0
- data/spec/mongo/collection/view/explainable_spec.rb +4 -1
- data/spec/mongo/collection/view/immutable_spec.rb +3 -0
- data/spec/mongo/collection/view/iterable_spec.rb +3 -0
- data/spec/mongo/collection/view/map_reduce_spec.rb +3 -0
- data/spec/mongo/collection/view/readable_spec.rb +51 -18
- data/spec/mongo/collection/view/writable_spec.rb +3 -0
- data/spec/mongo/collection/view_spec.rb +3 -0
- data/spec/mongo/collection_crud_spec.rb +4360 -0
- data/spec/mongo/collection_ddl_spec.rb +537 -0
- data/spec/mongo/collection_spec.rb +8 -4859
- data/spec/mongo/crypt/auto_decryption_context_spec.rb +3 -0
- data/spec/mongo/crypt/auto_encrypter_spec.rb +3 -0
- data/spec/mongo/crypt/auto_encryption_context_spec.rb +3 -0
- data/spec/mongo/crypt/binary_spec.rb +3 -0
- data/spec/mongo/crypt/binding/binary_spec.rb +3 -0
- data/spec/mongo/crypt/binding/context_spec.rb +3 -0
- data/spec/mongo/crypt/binding/helpers_spec.rb +3 -0
- data/spec/mongo/crypt/binding/mongocrypt_spec.rb +3 -0
- data/spec/mongo/crypt/binding/status_spec.rb +3 -0
- data/spec/mongo/crypt/binding/version_spec.rb +3 -0
- data/spec/mongo/crypt/binding_unloaded_spec.rb +3 -0
- data/spec/mongo/crypt/data_key_context_spec.rb +3 -0
- data/spec/mongo/crypt/encryption_io_spec.rb +3 -0
- data/spec/mongo/crypt/explicit_decryption_context_spec.rb +3 -0
- data/spec/mongo/crypt/explicit_encryption_context_spec.rb +3 -0
- data/spec/mongo/crypt/handle_spec.rb +3 -0
- data/spec/mongo/crypt/helpers/mongo_crypt_spec_helper.rb +3 -0
- data/spec/mongo/crypt/status_spec.rb +3 -0
- data/spec/mongo/cursor/builder/get_more_command_spec.rb +7 -2
- data/spec/mongo/cursor/builder/op_get_more_spec.rb +7 -2
- data/spec/mongo/cursor/builder/op_kill_cursors_spec.rb +7 -2
- data/spec/mongo/cursor_spec.rb +74 -7
- data/spec/mongo/database_spec.rb +75 -10
- data/spec/mongo/dbref_spec.rb +3 -0
- data/spec/mongo/distinguishing_semaphore_spec.rb +3 -0
- data/spec/mongo/error/bulk_write_error_spec.rb +6 -3
- data/spec/mongo/error/crypt_error_spec.rb +3 -0
- data/spec/mongo/error/max_bson_size_spec.rb +3 -0
- data/spec/mongo/error/no_server_available_spec.rb +3 -0
- data/spec/mongo/error/notable_spec.rb +3 -0
- data/spec/mongo/error/operation_failure_heavy_spec.rb +3 -0
- data/spec/mongo/error/operation_failure_spec.rb +94 -31
- data/spec/mongo/error/parser_spec.rb +40 -6
- data/spec/mongo/error/unsupported_option_spec.rb +3 -0
- data/spec/mongo/event/publisher_spec.rb +3 -0
- data/spec/mongo/event/subscriber_spec.rb +3 -0
- data/spec/mongo/grid/file/chunk_spec.rb +7 -4
- data/spec/mongo/grid/file/info_spec.rb +3 -0
- data/spec/mongo/grid/file_spec.rb +4 -1
- data/spec/mongo/grid/fs_bucket_spec.rb +22 -5
- data/spec/mongo/grid/stream/read_spec.rb +33 -10
- data/spec/mongo/grid/stream/write_spec.rb +3 -0
- data/spec/mongo/grid/stream_spec.rb +3 -0
- data/spec/mongo/id_spec.rb +3 -0
- data/spec/mongo/index/view_spec.rb +11 -2
- data/spec/mongo/lint_spec.rb +3 -0
- data/spec/mongo/logger_spec.rb +3 -0
- data/spec/mongo/monitoring/command_log_subscriber_spec.rb +3 -0
- data/spec/mongo/monitoring/event/cmap/connection_check_out_failed_spec.rb +3 -0
- data/spec/mongo/monitoring/event/cmap/connection_check_out_started_spec.rb +3 -0
- data/spec/mongo/monitoring/event/cmap/connection_checked_in_spec.rb +3 -0
- data/spec/mongo/monitoring/event/cmap/connection_checked_out_spec.rb +3 -0
- data/spec/mongo/monitoring/event/cmap/connection_closed_spec.rb +3 -0
- data/spec/mongo/monitoring/event/cmap/connection_created_spec.rb +3 -0
- data/spec/mongo/monitoring/event/cmap/connection_ready_spec.rb +3 -0
- data/spec/mongo/monitoring/event/cmap/pool_cleared_spec.rb +3 -0
- data/spec/mongo/monitoring/event/cmap/pool_closed_spec.rb +3 -0
- data/spec/mongo/monitoring/event/cmap/pool_created_spec.rb +3 -0
- data/spec/mongo/monitoring/event/command_failed_spec.rb +59 -2
- data/spec/mongo/monitoring/event/command_started_spec.rb +3 -0
- data/spec/mongo/monitoring/event/command_succeeded_spec.rb +46 -6
- data/spec/mongo/monitoring/event/secure_spec.rb +28 -4
- data/spec/mongo/monitoring/event/server_closed_spec.rb +3 -0
- data/spec/mongo/monitoring/event/server_description_changed_spec.rb +3 -0
- data/spec/mongo/monitoring/event/server_heartbeat_failed_spec.rb +4 -1
- data/spec/mongo/monitoring/event/server_heartbeat_started_spec.rb +3 -0
- data/spec/mongo/monitoring/event/server_heartbeat_succeeded_spec.rb +4 -1
- data/spec/mongo/monitoring/event/server_opening_spec.rb +3 -0
- data/spec/mongo/monitoring/event/topology_changed_spec.rb +3 -0
- data/spec/mongo/monitoring/event/topology_closed_spec.rb +3 -0
- data/spec/mongo/monitoring/event/topology_opening_spec.rb +3 -0
- data/spec/mongo/monitoring_spec.rb +3 -0
- data/spec/mongo/operation/aggregate/result_spec.rb +7 -2
- data/spec/mongo/operation/aggregate_spec.rb +5 -1
- data/spec/mongo/operation/collections_info_spec.rb +7 -1
- data/spec/mongo/operation/command_spec.rb +11 -5
- data/spec/mongo/operation/create_index_spec.rb +9 -3
- data/spec/mongo/operation/create_user_spec.rb +9 -3
- data/spec/mongo/operation/delete/bulk_spec.rb +12 -6
- data/spec/mongo/operation/delete/command_spec.rb +3 -0
- data/spec/mongo/operation/delete/op_msg_spec.rb +3 -0
- data/spec/mongo/operation/delete_spec.rb +14 -7
- data/spec/mongo/operation/drop_index_spec.rb +9 -2
- data/spec/mongo/operation/find/legacy_spec.rb +7 -2
- data/spec/mongo/operation/get_more_spec.rb +6 -1
- data/spec/mongo/operation/indexes_spec.rb +8 -1
- data/spec/mongo/operation/insert/bulk_spec.rb +13 -7
- data/spec/mongo/operation/insert/command_spec.rb +3 -0
- data/spec/mongo/operation/insert/op_msg_spec.rb +3 -0
- data/spec/mongo/operation/insert_spec.rb +18 -12
- data/spec/mongo/operation/kill_cursors_spec.rb +3 -0
- data/spec/mongo/operation/limited_spec.rb +3 -0
- data/spec/mongo/operation/map_reduce_spec.rb +8 -2
- data/spec/mongo/operation/read_preference_legacy_spec.rb +35 -42
- data/spec/mongo/operation/read_preference_op_msg_spec.rb +6 -3
- data/spec/mongo/operation/remove_user_spec.rb +9 -3
- data/spec/mongo/operation/result_spec.rb +10 -5
- data/spec/mongo/operation/specifiable_spec.rb +3 -0
- data/spec/mongo/operation/update/bulk_spec.rb +12 -6
- data/spec/mongo/operation/update/command_spec.rb +3 -0
- data/spec/mongo/operation/update/op_msg_spec.rb +3 -0
- data/spec/mongo/operation/update_spec.rb +13 -7
- data/spec/mongo/operation/update_user_spec.rb +7 -1
- data/spec/mongo/options/redacted_spec.rb +3 -0
- data/spec/mongo/protocol/compressed_spec.rb +29 -12
- data/spec/mongo/protocol/delete_spec.rb +3 -0
- data/spec/mongo/protocol/get_more_spec.rb +3 -0
- data/spec/mongo/protocol/insert_spec.rb +3 -0
- data/spec/mongo/protocol/kill_cursors_spec.rb +3 -0
- data/spec/mongo/protocol/msg_spec.rb +4 -1
- data/spec/mongo/protocol/query_spec.rb +6 -3
- data/spec/mongo/protocol/registry_spec.rb +3 -0
- data/spec/mongo/protocol/reply_spec.rb +3 -0
- data/spec/mongo/protocol/update_spec.rb +3 -0
- data/spec/mongo/query_cache_middleware_spec.rb +55 -0
- data/spec/mongo/query_cache_spec.rb +3 -0
- data/spec/mongo/retryable_spec.rb +6 -2
- data/spec/mongo/semaphore_spec.rb +3 -0
- data/spec/mongo/server/app_metadata_spec.rb +46 -21
- data/spec/mongo/server/connection_auth_spec.rb +6 -9
- data/spec/mongo/server/connection_common_spec.rb +24 -0
- data/spec/mongo/server/connection_pool/populator_spec.rb +6 -1
- data/spec/mongo/server/connection_pool_spec.rb +4 -1
- data/spec/mongo/server/connection_spec.rb +33 -17
- data/spec/mongo/server/description/features_spec.rb +3 -0
- data/spec/mongo/server/description_query_methods_spec.rb +4 -1
- data/spec/mongo/server/description_spec.rb +624 -611
- data/spec/mongo/server/monitor/app_metadata_spec.rb +3 -1
- data/spec/mongo/server/monitor/connection_spec.rb +57 -7
- data/spec/mongo/server/monitor_spec.rb +22 -11
- data/spec/mongo/server/round_trip_time_averager_spec.rb +3 -0
- data/spec/mongo/server_selector/nearest_spec.rb +8 -2
- data/spec/mongo/server_selector/primary_preferred_spec.rb +8 -2
- data/spec/mongo/server_selector/primary_spec.rb +8 -2
- data/spec/mongo/server_selector/secondary_preferred_spec.rb +14 -8
- data/spec/mongo/server_selector/secondary_spec.rb +8 -2
- data/spec/mongo/server_selector_spec.rb +5 -1
- data/spec/mongo/server_spec.rb +18 -2
- data/spec/mongo/session/server_session_spec.rb +3 -0
- data/spec/mongo/session/session_pool_spec.rb +3 -0
- data/spec/mongo/session_spec.rb +3 -0
- data/spec/mongo/session_transaction_spec.rb +7 -12
- data/spec/mongo/socket/ssl_spec.rb +43 -0
- data/spec/mongo/socket/tcp_spec.rb +3 -0
- data/spec/mongo/socket/unix_spec.rb +3 -0
- data/spec/mongo/socket_spec.rb +5 -2
- data/spec/mongo/srv/monitor_spec.rb +3 -0
- data/spec/mongo/srv/result_spec.rb +3 -0
- data/spec/mongo/timeout_spec.rb +3 -0
- data/spec/mongo/tls_context_hooks_spec.rb +40 -0
- data/spec/mongo/uri/srv_protocol_spec.rb +4 -0
- data/spec/mongo/uri_option_parsing_spec.rb +3 -0
- data/spec/mongo/uri_spec.rb +3 -0
- data/spec/mongo/utils_spec.rb +17 -0
- data/spec/mongo/write_concern/acknowledged_spec.rb +3 -0
- data/spec/mongo/write_concern/unacknowledged_spec.rb +3 -0
- data/spec/mongo/write_concern_spec.rb +3 -0
- data/spec/runners/auth.rb +22 -1
- data/spec/runners/change_streams/outcome.rb +3 -0
- data/spec/runners/change_streams/spec.rb +3 -0
- data/spec/runners/change_streams/test.rb +3 -0
- data/spec/runners/cmap/verifier.rb +3 -0
- data/spec/runners/cmap.rb +3 -0
- data/spec/runners/command_monitoring.rb +3 -0
- data/spec/runners/connection_string.rb +3 -4
- data/spec/runners/crud/context.rb +3 -0
- data/spec/runners/crud/operation.rb +3 -0
- data/spec/runners/crud/outcome.rb +3 -0
- data/spec/runners/crud/requirement.rb +67 -3
- data/spec/runners/crud/spec.rb +3 -0
- data/spec/runners/crud/test.rb +3 -0
- data/spec/runners/crud/test_base.rb +3 -0
- data/spec/runners/crud/verifier.rb +11 -0
- data/spec/runners/crud.rb +22 -0
- data/spec/runners/gridfs.rb +3 -0
- data/spec/runners/read_write_concern_document.rb +3 -0
- data/spec/runners/sdam/verifier.rb +3 -0
- data/spec/runners/sdam.rb +6 -3
- data/spec/runners/server_selection.rb +3 -0
- data/spec/runners/server_selection_rtt.rb +4 -1
- data/spec/runners/transactions/operation.rb +16 -2
- data/spec/runners/transactions/spec.rb +3 -0
- data/spec/runners/transactions/test.rb +4 -0
- data/spec/runners/transactions.rb +3 -0
- data/spec/runners/unified/assertions.rb +282 -0
- data/spec/runners/unified/change_stream_operations.rb +29 -0
- data/spec/runners/unified/crud_operations.rb +206 -0
- data/spec/runners/unified/ddl_operations.rb +106 -0
- data/spec/runners/unified/entity_map.rb +42 -0
- data/spec/runners/unified/error.rb +28 -0
- data/spec/runners/unified/event_subscriber.rb +104 -0
- data/spec/runners/unified/exceptions.rb +24 -0
- data/spec/runners/unified/grid_fs_operations.rb +58 -0
- data/spec/runners/unified/support_operations.rb +253 -0
- data/spec/runners/unified/test.rb +423 -0
- data/spec/runners/unified/test_group.rb +31 -0
- data/spec/runners/unified/using_hash.rb +34 -0
- data/spec/runners/unified.rb +99 -0
- data/spec/shared/bin/get-mongodb-download-url +17 -0
- data/spec/shared/bin/s3-copy +45 -0
- data/spec/shared/bin/s3-upload +69 -0
- data/spec/shared/lib/mrss/cluster_config.rb +226 -0
- data/spec/shared/lib/mrss/constraints.rb +82 -6
- data/spec/shared/lib/mrss/docker_runner.rb +271 -0
- data/spec/shared/lib/mrss/lite_constraints.rb +16 -0
- data/spec/shared/lib/mrss/server_version_registry.rb +115 -0
- data/spec/shared/lib/mrss/spec_organizer.rb +32 -2
- data/spec/shared/lib/mrss/utils.rb +15 -0
- data/spec/shared/share/Dockerfile.erb +322 -0
- data/spec/shared/share/haproxy-1.conf +16 -0
- data/spec/shared/share/haproxy-2.conf +17 -0
- data/spec/shared/shlib/distro.sh +73 -0
- data/spec/shared/shlib/server.sh +317 -0
- data/spec/shared/shlib/set_env.sh +131 -0
- data/spec/solo/clean_exit_spec.rb +24 -0
- data/spec/spec_helper.rb +8 -3
- data/spec/spec_tests/auth_spec.rb +30 -13
- data/spec/spec_tests/change_streams_spec.rb +3 -0
- data/spec/spec_tests/change_streams_unified_spec.rb +13 -0
- data/spec/spec_tests/client_side_encryption_spec.rb +3 -0
- data/spec/spec_tests/cmap_spec.rb +3 -0
- data/spec/spec_tests/collection_management_spec.rb +13 -0
- data/spec/spec_tests/command_monitoring_spec.rb +31 -26
- data/spec/spec_tests/command_monitoring_unified_spec.rb +13 -0
- data/spec/spec_tests/connection_string_spec.rb +3 -0
- data/spec/spec_tests/crud_spec.rb +3 -0
- data/spec/spec_tests/crud_unified_spec.rb +13 -0
- data/spec/spec_tests/data/change_streams/change-streams-errors.yml +5 -5
- data/spec/spec_tests/data/change_streams/{change-streams-resume-whitelist.yml → change-streams-resume-allowlist.yml} +58 -58
- data/spec/spec_tests/data/change_streams/change-streams-resume-errorLabels.yml +46 -46
- data/spec/spec_tests/data/change_streams/change-streams.yml +0 -1
- data/spec/spec_tests/data/change_streams_unified/change-streams.yml +72 -0
- data/spec/spec_tests/data/collection_management/timeseries-collection.yml +129 -0
- data/spec/spec_tests/data/command_monitoring_unified/redacted-commands.yml +340 -0
- data/spec/spec_tests/data/crud/write/bulkWrite.yml +26 -22
- data/spec/spec_tests/data/crud/write/insertMany.yml +26 -22
- data/spec/spec_tests/data/crud_unified/estimatedDocumentCount.yml +267 -0
- data/spec/spec_tests/data/crud_unified/updateWithPipelines.yml +305 -0
- data/spec/spec_tests/data/crud_v2/aggregate-out-readConcern.yml +1 -0
- data/spec/spec_tests/data/crud_v2/db-aggregate.yml +1 -0
- data/spec/spec_tests/data/retryable_reads/aggregate-serverErrors.yml +1 -1
- data/spec/spec_tests/data/retryable_reads/changeStreams-client.watch-serverErrors.yml +6 -5
- data/spec/spec_tests/data/retryable_reads/changeStreams-client.watch.yml +1 -0
- data/spec/spec_tests/data/retryable_reads/changeStreams-db.coll.watch-serverErrors.yml +6 -5
- data/spec/spec_tests/data/retryable_reads/changeStreams-db.coll.watch.yml +1 -0
- data/spec/spec_tests/data/retryable_reads/changeStreams-db.watch-serverErrors.yml +6 -5
- data/spec/spec_tests/data/retryable_reads/changeStreams-db.watch.yml +1 -0
- data/spec/spec_tests/data/retryable_reads/count-serverErrors.yml +1 -1
- data/spec/spec_tests/data/retryable_reads/countDocuments-serverErrors.yml +1 -1
- data/spec/spec_tests/data/retryable_reads/distinct-serverErrors.yml +1 -1
- data/spec/spec_tests/data/retryable_reads/estimatedDocumentCount-4.9.yml +60 -0
- data/spec/spec_tests/data/retryable_reads/{estimatedDocumentCount.yml → estimatedDocumentCount-pre4.9.yml} +2 -0
- data/spec/spec_tests/data/retryable_reads/estimatedDocumentCount-serverErrors-4.9.yml +146 -0
- data/spec/spec_tests/data/retryable_reads/{estimatedDocumentCount-serverErrors.yml → estimatedDocumentCount-serverErrors-pre4.9.yml} +3 -1
- data/spec/spec_tests/data/retryable_reads/find-serverErrors.yml +1 -1
- data/spec/spec_tests/data/retryable_reads/findOne-serverErrors.yml +1 -1
- data/spec/spec_tests/data/retryable_reads/gridfs-download-serverErrors.yml +1 -1
- data/spec/spec_tests/data/retryable_reads/gridfs-downloadByName-serverErrors.yml +1 -1
- data/spec/spec_tests/data/retryable_reads/listCollectionNames-serverErrors.yml +1 -1
- data/spec/spec_tests/data/retryable_reads/listCollectionObjects-serverErrors.yml +1 -1
- data/spec/spec_tests/data/retryable_reads/listCollections-serverErrors.yml +1 -1
- data/spec/spec_tests/data/retryable_reads/listDatabaseNames-serverErrors.yml +1 -1
- data/spec/spec_tests/data/retryable_reads/listDatabaseObjects-serverErrors.yml +1 -1
- data/spec/spec_tests/data/retryable_reads/listDatabases-serverErrors.yml +1 -1
- data/spec/spec_tests/data/retryable_reads/listIndexNames-serverErrors.yml +1 -1
- data/spec/spec_tests/data/retryable_reads/listIndexNames.yml +1 -1
- data/spec/spec_tests/data/retryable_reads/listIndexes-serverErrors.yml +1 -1
- data/spec/spec_tests/data/retryable_writes/bulkWrite.yml +30 -24
- data/spec/spec_tests/data/retryable_writes/insertOne-serverErrors.yml +5 -4
- data/spec/spec_tests/data/sdam/errors/error_handling_handshake.yml +2 -1
- data/spec/spec_tests/data/sdam/errors/non-stale-network-error.yml +2 -1
- data/spec/spec_tests/data/sdam/errors/non-stale-network-timeout-error.yml +2 -1
- data/spec/spec_tests/data/sdam/errors/non-stale-topologyVersion-greater-InterruptedAtShutdown.yml +2 -1
- data/spec/spec_tests/data/sdam/errors/non-stale-topologyVersion-greater-InterruptedDueToReplStateChange.yml +2 -1
- data/spec/spec_tests/data/sdam/errors/non-stale-topologyVersion-greater-LegacyNotPrimary.yml +61 -0
- data/spec/spec_tests/data/sdam/errors/{non-stale-topologyVersion-greater-NotMasterNoSlaveOk.yml → non-stale-topologyVersion-greater-NotPrimaryNoSecondaryOk.yml} +5 -4
- data/spec/spec_tests/data/sdam/errors/{non-stale-topologyVersion-greater-NotMasterOrSecondary.yml → non-stale-topologyVersion-greater-NotPrimaryOrSecondary.yml} +5 -4
- data/spec/spec_tests/data/sdam/errors/{non-stale-topologyVersion-greater-NotMaster.yml → non-stale-topologyVersion-greater-NotWritablePrimary.yml} +5 -4
- data/spec/spec_tests/data/sdam/errors/non-stale-topologyVersion-greater-PrimarySteppedDown.yml +2 -1
- data/spec/spec_tests/data/sdam/errors/non-stale-topologyVersion-greater-ShutdownInProgress.yml +2 -1
- data/spec/spec_tests/data/sdam/errors/non-stale-topologyVersion-missing-InterruptedAtShutdown.yml +2 -1
- data/spec/spec_tests/data/sdam/errors/non-stale-topologyVersion-missing-InterruptedDueToReplStateChange.yml +2 -1
- data/spec/spec_tests/data/sdam/errors/non-stale-topologyVersion-missing-LegacyNotPrimary.yml +52 -0
- data/spec/spec_tests/data/sdam/errors/{non-stale-topologyVersion-missing-NotMasterNoSlaveOk.yml → non-stale-topologyVersion-missing-NotPrimaryNoSecondaryOk.yml} +5 -4
- data/spec/spec_tests/data/sdam/errors/{non-stale-topologyVersion-missing-NotMasterOrSecondary.yml → non-stale-topologyVersion-missing-NotPrimaryOrSecondary.yml} +5 -4
- data/spec/spec_tests/data/sdam/errors/{non-stale-topologyVersion-missing-NotMaster.yml → non-stale-topologyVersion-missing-NotWritablePrimary.yml} +5 -4
- data/spec/spec_tests/data/sdam/errors/non-stale-topologyVersion-missing-PrimarySteppedDown.yml +2 -1
- data/spec/spec_tests/data/sdam/errors/non-stale-topologyVersion-missing-ShutdownInProgress.yml +2 -1
- data/spec/spec_tests/data/sdam/errors/non-stale-topologyVersion-proccessId-changed-InterruptedAtShutdown.yml +2 -1
- data/spec/spec_tests/data/sdam/errors/non-stale-topologyVersion-proccessId-changed-InterruptedDueToReplStateChange.yml +2 -1
- data/spec/spec_tests/data/sdam/errors/non-stale-topologyVersion-proccessId-changed-LegacyNotPrimary.yml +61 -0
- data/spec/spec_tests/data/sdam/errors/{non-stale-topologyVersion-proccessId-changed-NotMasterNoSlaveOk.yml → non-stale-topologyVersion-proccessId-changed-NotPrimaryNoSecondaryOk.yml} +5 -4
- data/spec/spec_tests/data/sdam/errors/{non-stale-topologyVersion-proccessId-changed-NotMasterOrSecondary.yml → non-stale-topologyVersion-proccessId-changed-NotPrimaryOrSecondary.yml} +5 -4
- data/spec/spec_tests/data/sdam/errors/{non-stale-topologyVersion-proccessId-changed-NotMaster.yml → non-stale-topologyVersion-proccessId-changed-NotWritablePrimary.yml} +5 -4
- data/spec/spec_tests/data/sdam/errors/non-stale-topologyVersion-proccessId-changed-PrimarySteppedDown.yml +2 -1
- data/spec/spec_tests/data/sdam/errors/non-stale-topologyVersion-proccessId-changed-ShutdownInProgress.yml +2 -1
- data/spec/spec_tests/data/sdam/errors/post-42-InterruptedAtShutdown.yml +2 -1
- data/spec/spec_tests/data/sdam/errors/post-42-InterruptedDueToReplStateChange.yml +2 -1
- data/spec/spec_tests/data/sdam/errors/post-42-LegacyNotPrimary.yml +47 -0
- data/spec/spec_tests/data/sdam/errors/{post-42-NotMasterNoSlaveOk.yml → post-42-NotPrimaryNoSecondaryOk.yml} +5 -4
- data/spec/spec_tests/data/sdam/errors/{post-42-NotMasterOrSecondary.yml → post-42-NotPrimaryOrSecondary.yml} +5 -4
- data/spec/spec_tests/data/sdam/errors/{post-42-NotMaster.yml → post-42-NotWritablePrimary.yml} +5 -4
- data/spec/spec_tests/data/sdam/errors/post-42-PrimarySteppedDown.yml +2 -1
- data/spec/spec_tests/data/sdam/errors/post-42-ShutdownInProgress.yml +2 -1
- data/spec/spec_tests/data/sdam/errors/pre-42-InterruptedAtShutdown.yml +2 -1
- data/spec/spec_tests/data/sdam/errors/pre-42-InterruptedDueToReplStateChange.yml +2 -1
- data/spec/spec_tests/data/sdam/errors/{pre-42-NotMaster.yml → pre-42-LegacyNotPrimary.yml} +6 -5
- data/spec/spec_tests/data/sdam/errors/pre-42-NotPrimaryNoSecondaryOk.yml +47 -0
- data/spec/spec_tests/data/sdam/errors/{pre-42-NotMasterOrSecondary.yml → pre-42-NotPrimaryOrSecondary.yml} +5 -4
- data/spec/spec_tests/data/sdam/errors/{pre-42-NotMasterNoSlaveOk.yml → pre-42-NotWritablePrimary.yml} +6 -5
- data/spec/spec_tests/data/sdam/errors/pre-42-PrimarySteppedDown.yml +2 -1
- data/spec/spec_tests/data/sdam/errors/pre-42-ShutdownInProgress.yml +2 -1
- data/spec/spec_tests/data/sdam/errors/prefer-error-code.yml +54 -0
- data/spec/spec_tests/data/sdam/errors/stale-generation-InterruptedAtShutdown.yml +4 -2
- data/spec/spec_tests/data/sdam/errors/stale-generation-InterruptedDueToReplStateChange.yml +4 -2
- data/spec/spec_tests/data/sdam/errors/{stale-generation-NotMasterNoSlaveOk.yml → stale-generation-NotPrimaryNoSecondaryOk.yml} +7 -5
- data/spec/spec_tests/data/sdam/errors/{stale-generation-NotMasterOrSecondary.yml → stale-generation-NotPrimaryOrSecondary.yml} +7 -5
- data/spec/spec_tests/data/sdam/errors/{stale-generation-NotMaster.yml → stale-generation-NotWritablePrimary.yml} +7 -5
- data/spec/spec_tests/data/sdam/errors/stale-generation-PrimarySteppedDown.yml +4 -2
- data/spec/spec_tests/data/sdam/errors/stale-generation-ShutdownInProgress.yml +4 -2
- data/spec/spec_tests/data/sdam/errors/stale-generation-afterHandshakeCompletes-InterruptedAtShutdown.yml +4 -2
- data/spec/spec_tests/data/sdam/errors/stale-generation-afterHandshakeCompletes-InterruptedDueToReplStateChange.yml +4 -2
- data/spec/spec_tests/data/sdam/errors/{stale-generation-afterHandshakeCompletes-NotMaster.yml → stale-generation-afterHandshakeCompletes-LegacyNotPrimary.yml} +8 -6
- data/spec/spec_tests/data/sdam/errors/stale-generation-afterHandshakeCompletes-NotPrimaryNoSecondaryOk.yml +91 -0
- data/spec/spec_tests/data/sdam/errors/{stale-generation-afterHandshakeCompletes-NotMasterOrSecondary.yml → stale-generation-afterHandshakeCompletes-NotPrimaryOrSecondary.yml} +7 -5
- data/spec/spec_tests/data/sdam/errors/{stale-generation-afterHandshakeCompletes-NotMasterNoSlaveOk.yml → stale-generation-afterHandshakeCompletes-NotWritablePrimary.yml} +8 -6
- data/spec/spec_tests/data/sdam/errors/stale-generation-afterHandshakeCompletes-PrimarySteppedDown.yml +4 -2
- data/spec/spec_tests/data/sdam/errors/stale-generation-afterHandshakeCompletes-ShutdownInProgress.yml +4 -2
- data/spec/spec_tests/data/sdam/errors/stale-generation-afterHandshakeCompletes-network.yml +6 -4
- data/spec/spec_tests/data/sdam/errors/stale-generation-afterHandshakeCompletes-timeout.yml +6 -4
- data/spec/spec_tests/data/sdam/errors/stale-generation-beforeHandshakeCompletes-InterruptedAtShutdown.yml +4 -2
- data/spec/spec_tests/data/sdam/errors/stale-generation-beforeHandshakeCompletes-InterruptedDueToReplStateChange.yml +4 -2
- data/spec/spec_tests/data/sdam/errors/{stale-generation-beforeHandshakeCompletes-NotMaster.yml → stale-generation-beforeHandshakeCompletes-LegacyNotPrimary.yml} +8 -6
- data/spec/spec_tests/data/sdam/errors/stale-generation-beforeHandshakeCompletes-NotPrimaryNoSecondaryOk.yml +91 -0
- data/spec/spec_tests/data/sdam/errors/{stale-generation-beforeHandshakeCompletes-NotMasterOrSecondary.yml → stale-generation-beforeHandshakeCompletes-NotPrimaryOrSecondary.yml} +7 -5
- data/spec/spec_tests/data/sdam/errors/{stale-generation-beforeHandshakeCompletes-NotMasterNoSlaveOk.yml → stale-generation-beforeHandshakeCompletes-NotWritablePrimary.yml} +8 -6
- data/spec/spec_tests/data/sdam/errors/stale-generation-beforeHandshakeCompletes-PrimarySteppedDown.yml +4 -2
- data/spec/spec_tests/data/sdam/errors/stale-generation-beforeHandshakeCompletes-ShutdownInProgress.yml +4 -2
- data/spec/spec_tests/data/sdam/errors/stale-generation-beforeHandshakeCompletes-network.yml +6 -4
- data/spec/spec_tests/data/sdam/errors/stale-generation-beforeHandshakeCompletes-timeout.yml +6 -4
- data/spec/spec_tests/data/sdam/errors/stale-topologyVersion-InterruptedAtShutdown.yml +2 -1
- data/spec/spec_tests/data/sdam/errors/stale-topologyVersion-InterruptedDueToReplStateChange.yml +2 -1
- data/spec/spec_tests/data/sdam/errors/stale-topologyVersion-LegacyNotPrimary.yml +65 -0
- data/spec/spec_tests/data/sdam/errors/{stale-topologyVersion-NotMasterNoSlaveOk.yml → stale-topologyVersion-NotPrimaryNoSecondaryOk.yml} +7 -6
- data/spec/spec_tests/data/sdam/errors/{stale-topologyVersion-NotMasterOrSecondary.yml → stale-topologyVersion-NotPrimaryOrSecondary.yml} +7 -6
- data/spec/spec_tests/data/sdam/errors/{stale-topologyVersion-NotMaster.yml → stale-topologyVersion-NotWritablePrimary.yml} +7 -6
- data/spec/spec_tests/data/sdam/errors/stale-topologyVersion-PrimarySteppedDown.yml +2 -1
- data/spec/spec_tests/data/sdam/errors/stale-topologyVersion-ShutdownInProgress.yml +2 -1
- data/spec/spec_tests/data/sdam/errors/write_errors_ignored.yml +42 -0
- data/spec/spec_tests/data/sdam/rs/compatible.yml +4 -2
- data/spec/spec_tests/data/sdam/rs/compatible_unknown.yml +2 -1
- data/spec/spec_tests/data/sdam/rs/discover_arbiters.yml +2 -1
- data/spec/spec_tests/data/sdam/rs/discover_arbiters_replicaset.yml +2 -1
- data/spec/spec_tests/data/sdam/rs/discover_ghost.yml +2 -1
- data/spec/spec_tests/data/sdam/rs/discover_ghost_replicaset.yml +2 -1
- data/spec/spec_tests/data/sdam/rs/discover_hidden.yml +2 -1
- data/spec/spec_tests/data/sdam/rs/discover_hidden_replicaset.yml +2 -1
- data/spec/spec_tests/data/sdam/rs/discover_passives.yml +4 -2
- data/spec/spec_tests/data/sdam/rs/discover_passives_replicaset.yml +4 -2
- data/spec/spec_tests/data/sdam/rs/discover_primary.yml +2 -1
- data/spec/spec_tests/data/sdam/rs/discover_primary_replicaset.yml +2 -1
- data/spec/spec_tests/data/sdam/rs/discover_rsother.yml +2 -1
- data/spec/spec_tests/data/sdam/rs/discover_rsother_replicaset.yml +4 -2
- data/spec/spec_tests/data/sdam/rs/discover_secondary.yml +2 -1
- data/spec/spec_tests/data/sdam/rs/discover_secondary_replicaset.yml +2 -1
- data/spec/spec_tests/data/sdam/rs/discovery.yml +8 -4
- data/spec/spec_tests/data/sdam/rs/equal_electionids.yml +4 -2
- data/spec/spec_tests/data/sdam/rs/hosts_differ_from_seeds.yml +2 -1
- data/spec/spec_tests/data/sdam/rs/incompatible_arbiter.yml +3 -1
- data/spec/spec_tests/data/sdam/rs/incompatible_ghost.yml +3 -1
- data/spec/spec_tests/data/sdam/rs/incompatible_other.yml +3 -1
- data/spec/spec_tests/data/sdam/rs/ls_timeout.yml +12 -6
- data/spec/spec_tests/data/sdam/rs/member_reconfig.yml +4 -2
- data/spec/spec_tests/data/sdam/rs/member_standalone.yml +4 -2
- data/spec/spec_tests/data/sdam/rs/new_primary.yml +4 -2
- data/spec/spec_tests/data/sdam/rs/new_primary_new_electionid.yml +6 -3
- data/spec/spec_tests/data/sdam/rs/new_primary_new_setversion.yml +6 -3
- data/spec/spec_tests/data/sdam/rs/new_primary_wrong_set_name.yml +4 -2
- data/spec/spec_tests/data/sdam/rs/non_rs_member.yml +1 -0
- data/spec/spec_tests/data/sdam/rs/normalize_case.yml +2 -1
- data/spec/spec_tests/data/sdam/rs/normalize_case_me.yml +4 -2
- data/spec/spec_tests/data/sdam/rs/null_election_id.yml +8 -4
- data/spec/spec_tests/data/sdam/rs/primary_becomes_ghost.yml +4 -2
- data/spec/spec_tests/data/sdam/rs/primary_becomes_mongos.yml +4 -2
- data/spec/spec_tests/data/sdam/rs/primary_becomes_standalone.yml +2 -1
- data/spec/spec_tests/data/sdam/rs/primary_changes_set_name.yml +4 -2
- data/spec/spec_tests/data/sdam/rs/primary_disconnect.yml +2 -1
- data/spec/spec_tests/data/sdam/rs/primary_disconnect_electionid.yml +10 -5
- data/spec/spec_tests/data/sdam/rs/primary_disconnect_setversion.yml +10 -5
- data/spec/spec_tests/data/sdam/rs/primary_hint_from_secondary_with_mismatched_me.yml +4 -2
- data/spec/spec_tests/data/sdam/rs/primary_mismatched_me.yml +2 -1
- data/spec/spec_tests/data/sdam/rs/primary_mismatched_me_not_removed.yml +5 -3
- data/spec/spec_tests/data/sdam/rs/primary_reports_new_member.yml +8 -4
- data/spec/spec_tests/data/sdam/rs/primary_to_no_primary_mismatched_me.yml +4 -2
- data/spec/spec_tests/data/sdam/rs/primary_wrong_set_name.yml +2 -1
- data/spec/spec_tests/data/sdam/rs/repeated.yml +9 -5
- data/spec/spec_tests/data/sdam/rs/replicaset_rsnp.yml +2 -1
- data/spec/spec_tests/data/sdam/rs/response_from_removed.yml +4 -2
- data/spec/spec_tests/data/sdam/rs/sec_not_auth.yml +4 -2
- data/spec/spec_tests/data/sdam/rs/secondary_ignore_ok_0.yml +4 -2
- data/spec/spec_tests/data/sdam/rs/secondary_mismatched_me.yml +2 -1
- data/spec/spec_tests/data/sdam/rs/secondary_wrong_set_name.yml +2 -1
- data/spec/spec_tests/data/sdam/rs/secondary_wrong_set_name_with_primary.yml +4 -2
- data/spec/spec_tests/data/sdam/rs/setversion_without_electionid.yml +4 -2
- data/spec/spec_tests/data/sdam/rs/stepdown_change_set_name.yml +4 -2
- data/spec/spec_tests/data/sdam/rs/too_new.yml +4 -2
- data/spec/spec_tests/data/sdam/rs/too_old.yml +4 -2
- data/spec/spec_tests/data/sdam/rs/topology_version_equal.yml +4 -2
- data/spec/spec_tests/data/sdam/rs/topology_version_greater.yml +10 -5
- data/spec/spec_tests/data/sdam/rs/topology_version_less.yml +4 -2
- data/spec/spec_tests/data/sdam/rs/unexpected_mongos.yml +2 -1
- data/spec/spec_tests/data/sdam/rs/use_setversion_without_electionid.yml +6 -3
- data/spec/spec_tests/data/sdam/rs/wrong_set_name.yml +2 -1
- data/spec/spec_tests/data/sdam/sharded/compatible.yml +4 -2
- data/spec/spec_tests/data/sdam/sharded/discover_single_mongos.yml +2 -1
- data/spec/spec_tests/data/sdam/sharded/ls_timeout_mongos.yml +9 -5
- data/spec/spec_tests/data/sdam/sharded/mongos_disconnect.yml +6 -3
- data/spec/spec_tests/data/sdam/sharded/multiple_mongoses.yml +4 -2
- data/spec/spec_tests/data/sdam/sharded/non_mongos_removed.yml +4 -2
- data/spec/spec_tests/data/sdam/sharded/too_new.yml +4 -2
- data/spec/spec_tests/data/sdam/sharded/too_old.yml +4 -2
- data/spec/spec_tests/data/sdam/single/compatible.yml +2 -1
- data/spec/spec_tests/data/sdam/single/direct_connection_external_ip.yml +2 -1
- data/spec/spec_tests/data/sdam/single/direct_connection_mongos.yml +2 -1
- data/spec/spec_tests/data/sdam/single/direct_connection_replicaset.yml +2 -1
- data/spec/spec_tests/data/sdam/single/direct_connection_rsarbiter.yml +2 -1
- data/spec/spec_tests/data/sdam/single/direct_connection_rsprimary.yml +2 -1
- data/spec/spec_tests/data/sdam/single/direct_connection_rssecondary.yml +2 -1
- data/spec/spec_tests/data/sdam/single/direct_connection_standalone.yml +2 -1
- data/spec/spec_tests/data/sdam/single/direct_connection_wrong_set_name.yml +4 -2
- data/spec/spec_tests/data/sdam/single/discover_standalone.yml +2 -1
- data/spec/spec_tests/data/sdam/single/ls_timeout_standalone.yml +2 -1
- data/spec/spec_tests/data/sdam/single/not_ok_response.yml +5 -3
- data/spec/spec_tests/data/sdam/single/standalone_removed.yml +2 -1
- data/spec/spec_tests/data/sdam/single/{direct_connection_slave.yml → standalone_using_legacy_hello.yml} +3 -3
- data/spec/spec_tests/data/sdam/single/too_new.yml +2 -1
- data/spec/spec_tests/data/sdam/single/too_old.yml +2 -1
- data/spec/spec_tests/data/sdam/single/too_old_then_upgraded.yml +4 -2
- data/spec/spec_tests/data/sdam_integration/cancel-server-check.yml +1 -1
- data/spec/spec_tests/data/sdam_integration/connectTimeoutMS.yml +2 -2
- data/spec/spec_tests/data/sdam_integration/{isMaster-command-error.yml → hello-command-error.yml} +19 -29
- data/spec/spec_tests/data/sdam_integration/{isMaster-network-error.yml → hello-network-error.yml} +9 -15
- data/spec/spec_tests/data/sdam_integration/{isMaster-timeout.yml → hello-timeout.yml} +7 -13
- data/spec/spec_tests/data/sdam_integration/rediscover-quickly-after-step-down.yml +14 -3
- data/spec/spec_tests/data/sdam_monitoring/discovered_standalone.yml +1 -1
- data/spec/spec_tests/data/sdam_monitoring/replica_set_with_no_primary.yml +2 -1
- data/spec/spec_tests/data/sdam_monitoring/replica_set_with_primary.yml +2 -1
- data/spec/spec_tests/data/sdam_monitoring/replica_set_with_removal.yml +3 -2
- data/spec/spec_tests/data/sdam_monitoring/required_replica_set.yml +2 -1
- data/spec/spec_tests/data/sdam_monitoring/standalone.yml +1 -1
- data/spec/spec_tests/data/sdam_monitoring/standalone_suppress_equal_description_changes.yml +2 -2
- data/spec/spec_tests/data/transactions/error-labels.yml +3 -0
- data/spec/spec_tests/data/transactions/mongos-pin-auto.yml +3 -0
- data/spec/spec_tests/data/transactions/mongos-recovery-token.yml +2 -0
- data/spec/spec_tests/data/transactions/pin-mongos.yml +6 -3
- data/spec/spec_tests/data/transactions_unified/mongos-unpin.yml +172 -0
- data/spec/spec_tests/data/unified/valid-fail/operation-failure.yml +31 -0
- data/spec/spec_tests/data/unified/valid-pass/poc-change-streams.yml +220 -0
- data/spec/spec_tests/data/unified/valid-pass/poc-command-monitoring.yml +102 -0
- data/spec/spec_tests/data/unified/valid-pass/poc-crud.yml +184 -0
- data/spec/spec_tests/data/unified/valid-pass/poc-gridfs.yml +155 -0
- data/spec/spec_tests/data/unified/valid-pass/poc-retryable-reads.yml +193 -0
- data/spec/spec_tests/data/unified/valid-pass/poc-retryable-writes.yml +210 -0
- data/spec/spec_tests/data/unified/valid-pass/poc-sessions.yml +215 -0
- data/spec/spec_tests/data/unified/valid-pass/poc-transactions-convenient-api.yml +235 -0
- data/spec/spec_tests/data/unified/valid-pass/poc-transactions-mongos-pin-auto.yml +169 -0
- data/spec/spec_tests/data/unified/valid-pass/poc-transactions.yml +170 -0
- data/spec/spec_tests/data/uri_options/compression-options.yml +1 -1
- data/spec/spec_tests/data/versioned_api/crud-api-version-1-strict.yml +417 -0
- data/spec/spec_tests/data/versioned_api/crud-api-version-1.yml +411 -0
- data/spec/spec_tests/data/versioned_api/runcommand-helper-no-api-version-declared.yml +75 -0
- data/spec/spec_tests/data/versioned_api/test-commands-deprecation-errors.yml +47 -0
- data/spec/spec_tests/data/versioned_api/test-commands-strict-mode.yml +46 -0
- data/spec/spec_tests/data/versioned_api/transaction-handling.yml +128 -0
- data/spec/spec_tests/dns_seedlist_discovery_spec.rb +3 -0
- data/spec/spec_tests/gridfs_spec.rb +3 -0
- data/spec/spec_tests/max_staleness_spec.rb +3 -0
- data/spec/spec_tests/read_write_concern_connection_string_spec.rb +3 -0
- data/spec/spec_tests/read_write_concern_document_spec.rb +3 -0
- data/spec/spec_tests/read_write_concern_operaton_spec.rb +3 -0
- data/spec/spec_tests/retryable_reads_spec.rb +3 -0
- data/spec/spec_tests/retryable_writes_spec.rb +9 -6
- data/spec/spec_tests/sdam_integration_spec.rb +3 -0
- data/spec/spec_tests/sdam_monitoring_spec.rb +4 -1
- data/spec/spec_tests/sdam_spec.rb +4 -1
- data/spec/spec_tests/server_selection_rtt_spec.rb +3 -0
- data/spec/spec_tests/server_selection_spec.rb +3 -0
- data/spec/spec_tests/transactions_api_spec.rb +3 -0
- data/spec/spec_tests/transactions_spec.rb +3 -0
- data/spec/spec_tests/transactions_unified_spec.rb +13 -0
- data/spec/spec_tests/unified_spec.rb +18 -0
- data/spec/spec_tests/uri_options_spec.rb +19 -0
- data/spec/spec_tests/versioned_api_spec.rb +13 -0
- data/spec/stress/cleanup_spec.rb +3 -0
- data/spec/stress/connection_pool_stress_spec.rb +3 -0
- data/spec/stress/connection_pool_timing_spec.rb +3 -0
- data/spec/stress/fork_reconnect_stress_spec.rb +6 -3
- data/spec/stress/push_monitor_close_spec.rb +44 -0
- data/spec/support/authorization.rb +3 -0
- data/spec/support/aws_utils/base.rb +3 -0
- data/spec/support/aws_utils/inspector.rb +3 -0
- data/spec/support/aws_utils/orchestrator.rb +3 -0
- data/spec/support/aws_utils/provisioner.rb +3 -0
- data/spec/support/aws_utils.rb +3 -0
- data/spec/support/background_thread_registry.rb +4 -1
- data/spec/support/certificates/README.md +3 -2
- data/spec/support/certificates/atlas-ocsp-ca.crt +116 -26
- data/spec/support/certificates/atlas-ocsp.crt +150 -39
- data/spec/support/client_registry.rb +12 -5
- data/spec/support/client_registry_macros.rb +7 -4
- data/spec/support/cluster_tools.rb +4 -1
- data/spec/support/common_shortcuts.rb +40 -7
- data/spec/support/constraints.rb +3 -0
- data/spec/support/crypt.rb +3 -0
- data/spec/support/dns.rb +3 -0
- data/spec/support/event_subscriber.rb +9 -0
- data/spec/support/json_ext_formatter.rb +3 -0
- data/spec/support/keyword_struct.rb +3 -0
- data/spec/support/local_resource_registry.rb +3 -0
- data/spec/support/matchers.rb +4 -1
- data/spec/support/monitoring_ext.rb +3 -0
- data/spec/support/primary_socket.rb +3 -0
- data/spec/support/sdam_formatter_integration.rb +3 -0
- data/spec/support/session_registry.rb +3 -0
- data/spec/{mongo/server/app_metadata_shared.rb → support/shared/app_metadata.rb} +38 -7
- data/spec/support/shared/protocol.rb +3 -0
- data/spec/support/shared/scram_conversation.rb +3 -0
- data/spec/support/shared/server_selector.rb +6 -3
- data/spec/support/shared/session.rb +5 -2
- data/spec/support/spec_config.rb +89 -12
- data/spec/support/spec_setup.rb +51 -38
- data/spec/support/utils.rb +68 -4
- data.tar.gz.sig +0 -0
- metadata +1195 -1027
- metadata.gz.sig +0 -0
- data/lib/mongo/operation/shared/collections_info_or_list_collections.rb +0 -58
- data/lib/mongo/operation/shared/op_msg_or_list_indexes_command.rb +0 -47
- data/spec/support/cluster_config.rb +0 -207
|
@@ -1,3 +1,6 @@
|
|
|
1
|
+
# frozen_string_literal: true
|
|
2
|
+
# encoding: utf-8
|
|
3
|
+
|
|
1
4
|
# Copyright (C) 2015-2020 MongoDB Inc.
|
|
2
5
|
#
|
|
3
6
|
# Licensed under the Apache License, Version 2.0 (the "License");
|
|
@@ -23,44 +26,6 @@ module Mongo
|
|
|
23
26
|
class Connection < Server::ConnectionCommon
|
|
24
27
|
include Loggable
|
|
25
28
|
|
|
26
|
-
# The command used for determining server status.
|
|
27
|
-
#
|
|
28
|
-
# The case matters here for fail points.
|
|
29
|
-
#
|
|
30
|
-
# @since 2.2.0
|
|
31
|
-
ISMASTER = { isMaster: 1 }.freeze
|
|
32
|
-
|
|
33
|
-
# The command used for determining server status formatted for an
|
|
34
|
-
# OP_MSG (server versions >= 3.6).
|
|
35
|
-
#
|
|
36
|
-
# The case matters here for fail points.
|
|
37
|
-
#
|
|
38
|
-
# @since 2.5.0
|
|
39
|
-
ISMASTER_OP_MSG = {
|
|
40
|
-
isMaster: 1,
|
|
41
|
-
'$db' => Database::ADMIN,
|
|
42
|
-
}.freeze
|
|
43
|
-
|
|
44
|
-
# The constant for the ismaster command.
|
|
45
|
-
#
|
|
46
|
-
# @since 2.2.0
|
|
47
|
-
ISMASTER_MESSAGE = Protocol::Query.new(Database::ADMIN, Database::COMMAND, ISMASTER, :limit => -1)
|
|
48
|
-
|
|
49
|
-
# The constant for the ismaster command as an OP_MSG (server versions >= 3.6).
|
|
50
|
-
#
|
|
51
|
-
# @since 2.5.0
|
|
52
|
-
ISMASTER_OP_MSG_MESSAGE = Protocol::Msg.new([], {}, ISMASTER_OP_MSG)
|
|
53
|
-
|
|
54
|
-
# The raw bytes for the ismaster message.
|
|
55
|
-
#
|
|
56
|
-
# @since 2.2.0
|
|
57
|
-
ISMASTER_BYTES = ISMASTER_MESSAGE.serialize.to_s.freeze
|
|
58
|
-
|
|
59
|
-
# The raw bytes for the ismaster OP_MSG message (server versions >= 3.6).
|
|
60
|
-
#
|
|
61
|
-
# @since 2.5.0
|
|
62
|
-
ISMASTER_OP_MSG_BYTES = ISMASTER_OP_MSG_MESSAGE.serialize.to_s.freeze
|
|
63
|
-
|
|
64
29
|
# Creates a new connection object to the specified target address
|
|
65
30
|
# with the specified options.
|
|
66
31
|
#
|
|
@@ -83,7 +48,7 @@ module Mongo
|
|
|
83
48
|
# @option options [ Array<String> ] :compressors A list of potential
|
|
84
49
|
# compressors to use, in order of preference. The driver chooses the
|
|
85
50
|
# first compressor that is also supported by the server. Currently the
|
|
86
|
-
# driver only supports 'zlib'.
|
|
51
|
+
# driver only supports 'zstd', 'snappy' and 'zlib'.
|
|
87
52
|
# @option options [ Float ] :connect_timeout The timeout, in seconds,
|
|
88
53
|
# to use for network operations. This timeout is used for all
|
|
89
54
|
# socket operations rather than connect calls only, contrary to
|
|
@@ -93,10 +58,13 @@ module Mongo
|
|
|
93
58
|
def initialize(address, options = {})
|
|
94
59
|
@address = address
|
|
95
60
|
@options = options.dup.freeze
|
|
96
|
-
@app_metadata = options[:app_metadata]
|
|
61
|
+
unless @app_metadata = options[:app_metadata]
|
|
62
|
+
raise ArgumentError, 'App metadata is required'
|
|
63
|
+
end
|
|
97
64
|
@socket = nil
|
|
98
65
|
@pid = Process.pid
|
|
99
66
|
@compressor = nil
|
|
67
|
+
@hello_ok = false
|
|
100
68
|
end
|
|
101
69
|
|
|
102
70
|
# @return [ Hash ] options The passed in options.
|
|
@@ -220,16 +188,26 @@ module Mongo
|
|
|
220
188
|
true
|
|
221
189
|
end
|
|
222
190
|
|
|
191
|
+
# Send handshake command to connected host and validate the response.
|
|
192
|
+
#
|
|
193
|
+
# @return [BSON::Document] Handshake response from server
|
|
194
|
+
#
|
|
195
|
+
# @raise [Mongo::Error] If handshake failed.
|
|
223
196
|
def handshake!
|
|
224
|
-
|
|
225
|
-
@app_metadata
|
|
226
|
-
|
|
227
|
-
|
|
228
|
-
|
|
229
|
-
|
|
197
|
+
document = handshake_document(
|
|
198
|
+
@app_metadata,
|
|
199
|
+
server_api: options[:server_api]
|
|
200
|
+
)
|
|
201
|
+
# TODO (DR): OP_MSG should be used if api version is declared.
|
|
202
|
+
# See https://github.com/mongodb/specifications/blob/master/source/message/OP_MSG.rst#id5
|
|
203
|
+
command = Protocol::Query.new(Database::ADMIN, Database::COMMAND, document, :limit => -1)
|
|
204
|
+
payload = command.serialize.to_s
|
|
230
205
|
message = dispatch_bytes(payload)
|
|
231
|
-
|
|
206
|
+
result = Operation::Result.new(message)
|
|
207
|
+
result.validate!
|
|
208
|
+
reply = result.documents.first
|
|
232
209
|
set_compressor!(reply)
|
|
210
|
+
set_hello_ok!(reply)
|
|
233
211
|
@server_connection_id = reply['connectionId']
|
|
234
212
|
reply
|
|
235
213
|
rescue => exc
|
|
@@ -242,6 +220,25 @@ module Mongo
|
|
|
242
220
|
raise
|
|
243
221
|
end
|
|
244
222
|
|
|
223
|
+
# Build a document that should be used for connection check.
|
|
224
|
+
#
|
|
225
|
+
# @return [BSON::Document] Document that should be sent to a server
|
|
226
|
+
# for connection check.
|
|
227
|
+
#
|
|
228
|
+
# @api private
|
|
229
|
+
def check_document
|
|
230
|
+
server_api = @app_metadata.server_api || options[:server_api]
|
|
231
|
+
if hello_ok? || server_api
|
|
232
|
+
doc = HELLO_DOC
|
|
233
|
+
if server_api
|
|
234
|
+
doc = doc.merge(Utils.transform_server_api(server_api))
|
|
235
|
+
end
|
|
236
|
+
doc
|
|
237
|
+
else
|
|
238
|
+
LEGACY_HELLO_DOC
|
|
239
|
+
end
|
|
240
|
+
end
|
|
241
|
+
|
|
245
242
|
private
|
|
246
243
|
|
|
247
244
|
def add_server_connection_id
|
|
@@ -253,6 +250,19 @@ module Mongo
|
|
|
253
250
|
end
|
|
254
251
|
raise e
|
|
255
252
|
end
|
|
253
|
+
|
|
254
|
+
# Update @hello_ok flag according to server reply to legacy hello
|
|
255
|
+
# command. The flag will be set to true if connected server supports
|
|
256
|
+
# hello command, otherwise the flag will be set to false.
|
|
257
|
+
#
|
|
258
|
+
# @param [ BSON::Document ] reply Server reply to legacy hello command.
|
|
259
|
+
def set_hello_ok!(reply)
|
|
260
|
+
@hello_ok = !!reply[:helloOk]
|
|
261
|
+
end
|
|
262
|
+
|
|
263
|
+
def hello_ok?
|
|
264
|
+
@hello_ok
|
|
265
|
+
end
|
|
256
266
|
end
|
|
257
267
|
end
|
|
258
268
|
end
|
data/lib/mongo/server/monitor.rb
CHANGED
|
@@ -1,3 +1,6 @@
|
|
|
1
|
+
# frozen_string_literal: true
|
|
2
|
+
# encoding: utf-8
|
|
3
|
+
|
|
1
4
|
# Copyright (C) 2014-2020 MongoDB Inc.
|
|
2
5
|
#
|
|
3
6
|
# Licensed under the Apache License, Version 2.0 (the "License");
|
|
@@ -15,7 +18,7 @@
|
|
|
15
18
|
module Mongo
|
|
16
19
|
class Server
|
|
17
20
|
|
|
18
|
-
# Responsible for periodically polling a server via
|
|
21
|
+
# Responsible for periodically polling a server via hello commands to
|
|
19
22
|
# keep the server's status up to date.
|
|
20
23
|
#
|
|
21
24
|
# Does all work in a background thread so as to not interfere with other
|
|
@@ -63,6 +66,10 @@ module Mongo
|
|
|
63
66
|
# @option options [ Float ] :heartbeat_interval The interval between
|
|
64
67
|
# regular server checks.
|
|
65
68
|
# @option options [ Logger ] :logger A custom logger to use.
|
|
69
|
+
# @option options [ Mongo::Server::Monitor::AppMetadata ] :monitor_app_metadata
|
|
70
|
+
# The metadata to use for regular monitoring connection.
|
|
71
|
+
# @option options [ Mongo::Server::Monitor::AppMetadata ] :push_monitor_app_metadata
|
|
72
|
+
# The metadata to use for push monitor's connection.
|
|
66
73
|
# @option options [ Float ] :socket_timeout The timeout, in seconds, to
|
|
67
74
|
# execute operations on the monitoring connection.
|
|
68
75
|
#
|
|
@@ -72,6 +79,12 @@ module Mongo
|
|
|
72
79
|
unless monitoring.is_a?(Monitoring)
|
|
73
80
|
raise ArgumentError, "Wrong monitoring type: #{monitoring.inspect}"
|
|
74
81
|
end
|
|
82
|
+
unless options[:app_metadata]
|
|
83
|
+
raise ArgumentError, 'App metadata is required'
|
|
84
|
+
end
|
|
85
|
+
unless options[:push_monitor_app_metadata]
|
|
86
|
+
raise ArgumentError, 'Push monitor app metadata is required'
|
|
87
|
+
end
|
|
75
88
|
@server = server
|
|
76
89
|
@event_listeners = event_listeners
|
|
77
90
|
@monitoring = monitoring
|
|
@@ -119,13 +132,7 @@ module Mongo
|
|
|
119
132
|
end
|
|
120
133
|
end
|
|
121
134
|
|
|
122
|
-
#
|
|
123
|
-
# server.
|
|
124
|
-
#
|
|
125
|
-
# @example Run the monitor.
|
|
126
|
-
# monitor.run
|
|
127
|
-
#
|
|
128
|
-
# @return [ Thread ] The thread the monitor runs on.
|
|
135
|
+
# Perform a check of the server.
|
|
129
136
|
#
|
|
130
137
|
# @since 2.0.0
|
|
131
138
|
def do_work
|
|
@@ -177,7 +184,7 @@ module Mongo
|
|
|
177
184
|
#
|
|
178
185
|
# If the server was checked less than MIN_SCAN_INTERVAL seconds
|
|
179
186
|
# ago, sleep until MIN_SCAN_INTERVAL seconds have passed since the last
|
|
180
|
-
# check. Then perform the check which involves running
|
|
187
|
+
# check. Then perform the check which involves running hello
|
|
181
188
|
# on the server being monitored and updating the server description
|
|
182
189
|
# as a result.
|
|
183
190
|
#
|
|
@@ -250,10 +257,10 @@ module Mongo
|
|
|
250
257
|
def do_scan
|
|
251
258
|
begin
|
|
252
259
|
monitoring.publish_heartbeat(server) do
|
|
253
|
-
|
|
260
|
+
check
|
|
254
261
|
end
|
|
255
262
|
rescue => exc
|
|
256
|
-
msg = "Error
|
|
263
|
+
msg = "Error checking #{server.address}"
|
|
257
264
|
Utils.warn_bg_exception(msg, exc,
|
|
258
265
|
logger: options[:logger],
|
|
259
266
|
log_prefix: options[:log_prefix],
|
|
@@ -263,7 +270,7 @@ module Mongo
|
|
|
263
270
|
end
|
|
264
271
|
end
|
|
265
272
|
|
|
266
|
-
def
|
|
273
|
+
def check
|
|
267
274
|
if @connection && @connection.pid != Process.pid
|
|
268
275
|
log_warn("Detected PID change - Mongo client should have been reconnected (old pid #{@connection.pid}, new pid #{Process.pid}")
|
|
269
276
|
@connection.disconnect!
|
|
@@ -273,7 +280,11 @@ module Mongo
|
|
|
273
280
|
if @connection
|
|
274
281
|
result = server.round_trip_time_averager.measure do
|
|
275
282
|
begin
|
|
276
|
-
|
|
283
|
+
doc = @connection.check_document
|
|
284
|
+
cmd = Protocol::Query.new(
|
|
285
|
+
Database::ADMIN, Database::COMMAND, doc, :limit => -1
|
|
286
|
+
)
|
|
287
|
+
message = @connection.dispatch_bytes(cmd.serialize.to_s)
|
|
277
288
|
message.documents.first
|
|
278
289
|
rescue Mongo::Error
|
|
279
290
|
@connection.disconnect!
|
|
@@ -297,6 +308,8 @@ module Mongo
|
|
|
297
308
|
monitoring,
|
|
298
309
|
**Utils.shallow_symbolize_keys(options.merge(
|
|
299
310
|
socket_timeout: heartbeat_interval + connection.socket_timeout,
|
|
311
|
+
app_metadata: options[:push_monitor_app_metadata],
|
|
312
|
+
check_document: @connection.check_document
|
|
300
313
|
)),
|
|
301
314
|
)
|
|
302
315
|
end
|
|
@@ -1,3 +1,6 @@
|
|
|
1
|
+
# frozen_string_literal: true
|
|
2
|
+
# encoding: utf-8
|
|
3
|
+
|
|
1
4
|
# Copyright (C) 2019-2020 MongoDB Inc.
|
|
2
5
|
#
|
|
3
6
|
# Licensed under the Apache License, Version 2.0 (the "License");
|
|
@@ -63,6 +66,11 @@ module Mongo
|
|
|
63
66
|
end
|
|
64
67
|
|
|
65
68
|
result = handshake!(speculative_auth_doc: speculative_auth_doc)
|
|
69
|
+
|
|
70
|
+
if description.unknown?
|
|
71
|
+
raise Error::InternalDriverError, "Connection description cannot be unknown after successful handshake: #{description.inspect}"
|
|
72
|
+
end
|
|
73
|
+
|
|
66
74
|
if speculative_auth_doc && (speculative_auth_result = result['speculativeAuthenticate'])
|
|
67
75
|
unless description.features.scram_sha_1_enabled?
|
|
68
76
|
raise Error::InvalidServerAuthResponse, "Speculative auth succeeded on a pre-3.0 server"
|
|
@@ -80,42 +88,51 @@ module Mongo
|
|
|
80
88
|
speculative_auth_result: speculative_auth_result,
|
|
81
89
|
)
|
|
82
90
|
else
|
|
83
|
-
raise
|
|
91
|
+
raise Error::InternalDriverError, "Speculative auth unexpectedly succeeded for mechanism #{speculative_auth_user.mechanism.inspect}"
|
|
84
92
|
end
|
|
85
93
|
elsif !description.arbiter?
|
|
86
94
|
authenticate!
|
|
87
95
|
end
|
|
96
|
+
|
|
97
|
+
if description.unknown?
|
|
98
|
+
raise Error::InternalDriverError, "Connection description cannot be unknown after successful authentication: #{description.inspect}"
|
|
99
|
+
end
|
|
88
100
|
end
|
|
89
101
|
|
|
90
102
|
private
|
|
91
103
|
|
|
92
104
|
# @param [ BSON::Document | nil ] speculative_auth_doc The document to
|
|
93
|
-
# provide in speculativeAuthenticate field of
|
|
105
|
+
# provide in speculativeAuthenticate field of handshake command.
|
|
94
106
|
#
|
|
95
|
-
# @return [ BSON::Document ] The document of the
|
|
107
|
+
# @return [ BSON::Document ] The document of the handshake response for
|
|
96
108
|
# this particular connection.
|
|
97
109
|
def handshake!(speculative_auth_doc: nil)
|
|
98
110
|
unless socket
|
|
99
|
-
raise Error::
|
|
111
|
+
raise Error::InternalDriverError, "Cannot handshake because there is no usable socket (for #{address})"
|
|
100
112
|
end
|
|
101
113
|
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
|
|
114
|
+
hello_doc = handshake_document(
|
|
115
|
+
app_metadata,
|
|
116
|
+
speculative_auth_doc: speculative_auth_doc,
|
|
117
|
+
server_api: options[:server_api],
|
|
118
|
+
)
|
|
106
119
|
|
|
107
|
-
|
|
108
|
-
|
|
120
|
+
# TODO (DR): OP_MSG should be used if api version is declared.
|
|
121
|
+
# See https://github.com/mongodb/specifications/blob/master/source/message/OP_MSG.rst#id5
|
|
122
|
+
hello_command = Protocol::Query.new(Database::ADMIN, Database::COMMAND, hello_doc, :limit => -1)
|
|
109
123
|
|
|
110
|
-
|
|
124
|
+
doc = nil
|
|
111
125
|
@server.handle_handshake_failure! do
|
|
112
126
|
begin
|
|
113
127
|
response = @server.round_trip_time_averager.measure do
|
|
114
128
|
add_server_diagnostics do
|
|
115
|
-
socket.write(
|
|
116
|
-
Protocol::Message.deserialize(socket, Protocol::Message::MAX_MESSAGE_SIZE)
|
|
129
|
+
socket.write(hello_command.serialize.to_s)
|
|
130
|
+
Protocol::Message.deserialize(socket, Protocol::Message::MAX_MESSAGE_SIZE)
|
|
117
131
|
end
|
|
118
132
|
end
|
|
133
|
+
result = Operation::Result.new([response])
|
|
134
|
+
result.validate!
|
|
135
|
+
doc = result.documents.first
|
|
119
136
|
rescue => exc
|
|
120
137
|
msg = "Failed to handshake with #{address}"
|
|
121
138
|
Utils.warn_bg_exception(msg, exc,
|
|
@@ -127,9 +144,9 @@ module Mongo
|
|
|
127
144
|
end
|
|
128
145
|
end
|
|
129
146
|
|
|
130
|
-
post_handshake(
|
|
147
|
+
post_handshake(doc, @server.round_trip_time_averager.average_round_trip_time)
|
|
131
148
|
|
|
132
|
-
|
|
149
|
+
doc
|
|
133
150
|
end
|
|
134
151
|
|
|
135
152
|
# @param [ String | nil ] speculative_auth_client_nonce The client
|
|
@@ -139,7 +156,7 @@ module Mongo
|
|
|
139
156
|
# for speculative auth, if speculative auth succeeded. If speculative
|
|
140
157
|
# auth was not performed or it failed, this must be nil.
|
|
141
158
|
# @param [ BSON::Document | nil ] speculative_auth_result The
|
|
142
|
-
# value of speculativeAuthenticate field of
|
|
159
|
+
# value of speculativeAuthenticate field of hello response of
|
|
143
160
|
# the handshake on this connection.
|
|
144
161
|
def authenticate!(
|
|
145
162
|
speculative_auth_client_nonce: nil,
|
|
@@ -176,12 +193,12 @@ module Mongo
|
|
|
176
193
|
# This is a separate method to keep the nesting level down.
|
|
177
194
|
#
|
|
178
195
|
# @return [ Server::Description ] The server description calculated from
|
|
179
|
-
#
|
|
196
|
+
# hello response for this particular connection.
|
|
180
197
|
def post_handshake(response, average_rtt)
|
|
181
198
|
if response["ok"] == 1
|
|
182
199
|
# Auth mechanism is entirely dependent on the contents of
|
|
183
|
-
#
|
|
184
|
-
#
|
|
200
|
+
# hello response *for this connection*.
|
|
201
|
+
# Hello received by the monitoring connection should advertise
|
|
185
202
|
# the same wire protocol, but if it doesn't, we use whatever
|
|
186
203
|
# the monitoring connection advertised for filling out the
|
|
187
204
|
# server description and whatever the non-monitoring connection
|
|
@@ -215,7 +232,7 @@ module Mongo
|
|
|
215
232
|
user_options = Options::Redacted.new(
|
|
216
233
|
# When speculative auth is performed, we always use SCRAM-SHA-256.
|
|
217
234
|
# At the same time we perform SCRAM mechanism negotiation in the
|
|
218
|
-
#
|
|
235
|
+
# hello request.
|
|
219
236
|
# If the credentials we are trying to authenticate with do not
|
|
220
237
|
# map to an existing user, SCRAM mechanism negotiation will not
|
|
221
238
|
# return anything which would cause the driver to use
|
|
@@ -1,3 +1,6 @@
|
|
|
1
|
+
# frozen_string_literal: true
|
|
2
|
+
# encoding: utf-8
|
|
3
|
+
|
|
1
4
|
# Copyright (C) 2020 MongoDB Inc.
|
|
2
5
|
#
|
|
3
6
|
# Licensed under the Apache License, Version 2.0 (the "License");
|
|
@@ -15,11 +18,11 @@
|
|
|
15
18
|
module Mongo
|
|
16
19
|
class Server
|
|
17
20
|
|
|
18
|
-
# A monitor utilizing server-pushed
|
|
21
|
+
# A monitor utilizing server-pushed hello requests.
|
|
19
22
|
#
|
|
20
23
|
# When a Monitor handshakes with a 4.4+ server, it creates an instance
|
|
21
|
-
# of PushMonitor. PushMonitor subsequently executes server-pushed
|
|
22
|
-
# (i.e. awaited & exhausted
|
|
24
|
+
# of PushMonitor. PushMonitor subsequently executes server-pushed hello
|
|
25
|
+
# (i.e. awaited & exhausted hello) to receive topology changes from the
|
|
23
26
|
# server as quickly as possible. The Monitor still monitors the server
|
|
24
27
|
# for round-trip time calculations and to perform immediate checks as
|
|
25
28
|
# requested by the application.
|
|
@@ -33,6 +36,14 @@ module Mongo
|
|
|
33
36
|
if topology_version.nil?
|
|
34
37
|
raise ArgumentError, 'Topology version must be provided but it was nil'
|
|
35
38
|
end
|
|
39
|
+
unless options[:app_metadata]
|
|
40
|
+
raise ArgumentError, 'App metadata is required'
|
|
41
|
+
end
|
|
42
|
+
unless options[:check_document]
|
|
43
|
+
raise ArgumentError, 'Check document is required'
|
|
44
|
+
end
|
|
45
|
+
@app_metadata = options[:app_metadata]
|
|
46
|
+
@check_document = options[:check_document]
|
|
36
47
|
@monitor = monitor
|
|
37
48
|
@topology_version = topology_version
|
|
38
49
|
@monitoring = monitoring
|
|
@@ -65,7 +76,7 @@ module Mongo
|
|
|
65
76
|
@lock.synchronize do
|
|
66
77
|
@stop_requested = true
|
|
67
78
|
if @connection
|
|
68
|
-
# Interrupt any in-progress exhausted
|
|
79
|
+
# Interrupt any in-progress exhausted hello reads by
|
|
69
80
|
# disconnecting the connection.
|
|
70
81
|
@connection.send(:socket).close
|
|
71
82
|
end
|
|
@@ -86,21 +97,27 @@ module Mongo
|
|
|
86
97
|
end
|
|
87
98
|
|
|
88
99
|
result = monitoring.publish_heartbeat(server, awaited: true) do
|
|
89
|
-
|
|
100
|
+
check
|
|
90
101
|
end
|
|
91
102
|
new_description = monitor.run_sdam_flow(result, awaited: true)
|
|
92
|
-
# When
|
|
103
|
+
# When hello fails due to a fail point, the response does not
|
|
93
104
|
# include topology version. In this case we need to keep our existing
|
|
94
105
|
# topology version so that we can resume monitoring.
|
|
95
106
|
# The spec does not appear to directly address this case but
|
|
96
107
|
# https://github.com/mongodb/specifications/blob/master/source/server-discovery-and-monitoring/server-monitoring.rst#streaming-ismaster
|
|
97
108
|
# says that topologyVersion should only be updated from successful
|
|
98
|
-
#
|
|
109
|
+
# hello responses.
|
|
99
110
|
if new_description.topology_version
|
|
100
111
|
@topology_version = new_description.topology_version
|
|
101
112
|
end
|
|
102
113
|
rescue Mongo::Error => exc
|
|
103
|
-
|
|
114
|
+
stop_requested = @lock.synchronize { @stop_requested }
|
|
115
|
+
if stop_requested
|
|
116
|
+
# Ignore the exception, see RUBY-2771.
|
|
117
|
+
return
|
|
118
|
+
end
|
|
119
|
+
|
|
120
|
+
msg = "Error running awaited hello on #{server.address}"
|
|
104
121
|
Utils.warn_bg_exception(msg, exc,
|
|
105
122
|
logger: options[:logger],
|
|
106
123
|
log_prefix: options[:log_prefix],
|
|
@@ -108,7 +125,7 @@ module Mongo
|
|
|
108
125
|
)
|
|
109
126
|
end
|
|
110
127
|
|
|
111
|
-
def
|
|
128
|
+
def check
|
|
112
129
|
@lock.synchronize do
|
|
113
130
|
if @connection && @connection.pid != Process.pid
|
|
114
131
|
log_warn("Detected PID change - Mongo client should have been reconnected (old pid #{@connection.pid}, new pid #{Process.pid}")
|
|
@@ -128,7 +145,7 @@ module Mongo
|
|
|
128
145
|
|
|
129
146
|
resp_msg = begin
|
|
130
147
|
unless @server_pushing
|
|
131
|
-
|
|
148
|
+
write_check_command
|
|
132
149
|
end
|
|
133
150
|
read_response
|
|
134
151
|
rescue Mongo::Error
|
|
@@ -139,17 +156,20 @@ module Mongo
|
|
|
139
156
|
raise
|
|
140
157
|
end
|
|
141
158
|
@server_pushing = resp_msg.flags.include?(:more_to_come)
|
|
142
|
-
result = resp_msg
|
|
159
|
+
result = Operation::Result.new(resp_msg)
|
|
160
|
+
result.validate!
|
|
161
|
+
result.documents.first
|
|
143
162
|
end
|
|
144
163
|
|
|
145
|
-
def
|
|
146
|
-
|
|
164
|
+
def write_check_command
|
|
165
|
+
document = @check_document.merge(
|
|
147
166
|
topologyVersion: topology_version.to_doc,
|
|
148
167
|
maxAwaitTimeMS: monitor.heartbeat_interval * 1000,
|
|
149
168
|
)
|
|
150
|
-
|
|
151
|
-
|
|
152
|
-
|
|
169
|
+
command = Protocol::Msg.new(
|
|
170
|
+
[:exhaust_allowed], {}, document.merge({'$db' => Database::ADMIN})
|
|
171
|
+
)
|
|
172
|
+
@lock.synchronize { @connection }.write_bytes(command.serialize.to_s)
|
|
153
173
|
end
|
|
154
174
|
|
|
155
175
|
def read_response
|
|
@@ -162,10 +182,11 @@ module Mongo
|
|
|
162
182
|
end
|
|
163
183
|
# We set the timeout twice: once passed into read_socket which applies
|
|
164
184
|
# to each individual read operation, and again around the entire read.
|
|
165
|
-
Timeout.timeout(timeout, Error::SocketTimeoutError, "Failed to read an awaited
|
|
185
|
+
Timeout.timeout(timeout, Error::SocketTimeoutError, "Failed to read an awaited hello response in #{timeout} seconds") do
|
|
166
186
|
@lock.synchronize { @connection }.read_response(socket_timeout: timeout)
|
|
167
187
|
end
|
|
168
188
|
end
|
|
189
|
+
|
|
169
190
|
end
|
|
170
191
|
end
|
|
171
192
|
end
|
|
@@ -1,3 +1,6 @@
|
|
|
1
|
+
# frozen_string_literal: true
|
|
2
|
+
# encoding: utf-8
|
|
3
|
+
|
|
1
4
|
# Copyright (C) 2018-2020 MongoDB Inc.
|
|
2
5
|
|
|
3
6
|
# Licensed under the Apache License, Version 2.0 (the "License");
|
|
@@ -31,7 +34,7 @@ module Mongo
|
|
|
31
34
|
attr_reader :average_round_trip_time
|
|
32
35
|
|
|
33
36
|
def measure
|
|
34
|
-
start =
|
|
37
|
+
start = Utils.monotonic_time
|
|
35
38
|
begin
|
|
36
39
|
rv = yield
|
|
37
40
|
rescue Error::SocketError, Error::SocketTimeoutError
|
|
@@ -41,9 +44,9 @@ module Mongo
|
|
|
41
44
|
rescue Error, Error::AuthError => exc
|
|
42
45
|
# For other errors, RTT is valid.
|
|
43
46
|
end
|
|
44
|
-
last_round_trip_time =
|
|
47
|
+
last_round_trip_time = Utils.monotonic_time - start
|
|
45
48
|
|
|
46
|
-
# If
|
|
49
|
+
# If hello fails, we need to return the last round trip time
|
|
47
50
|
# because it is used in the heartbeat failed SDAM event,
|
|
48
51
|
# but we must not update the round trip time recorded in the server.
|
|
49
52
|
unless exc
|
data/lib/mongo/server.rb
CHANGED
|
@@ -1,3 +1,6 @@
|
|
|
1
|
+
# frozen_string_literal: true
|
|
2
|
+
# encoding: utf-8
|
|
3
|
+
|
|
1
4
|
# Copyright (C) 2014-2020 MongoDB Inc.
|
|
2
5
|
#
|
|
3
6
|
# Licensed under the Apache License, Version 2.0 (the "License");
|
|
@@ -68,10 +71,12 @@ module Mongo
|
|
|
68
71
|
@round_trip_time_averager = RoundTripTimeAverager.new
|
|
69
72
|
@description = Description.new(address, {})
|
|
70
73
|
@last_scan = nil
|
|
74
|
+
@last_scan_monotime = nil
|
|
71
75
|
unless options[:monitoring_io] == false
|
|
72
76
|
@monitor = Monitor.new(self, event_listeners, monitoring,
|
|
73
77
|
options.merge(
|
|
74
|
-
app_metadata:
|
|
78
|
+
app_metadata: cluster.monitor_app_metadata,
|
|
79
|
+
push_monitor_app_metadata: cluster.push_monitor_app_metadata,
|
|
75
80
|
heartbeat_interval: cluster.heartbeat_interval,
|
|
76
81
|
))
|
|
77
82
|
unless _monitor == false
|
|
@@ -114,6 +119,18 @@ module Mongo
|
|
|
114
119
|
end
|
|
115
120
|
end
|
|
116
121
|
|
|
122
|
+
# @return [ Float | nil ] last_scan_monotime The monotonic time when the last server scan
|
|
123
|
+
# completed, or nil if the server has not been scanned yet.
|
|
124
|
+
# @api private
|
|
125
|
+
def last_scan_monotime
|
|
126
|
+
if description && !description.config.empty?
|
|
127
|
+
description.last_update_monotime
|
|
128
|
+
else
|
|
129
|
+
@last_scan_monotime
|
|
130
|
+
end
|
|
131
|
+
end
|
|
132
|
+
|
|
133
|
+
|
|
117
134
|
# @deprecated
|
|
118
135
|
def heartbeat_frequency
|
|
119
136
|
cluster.heartbeat_interval
|
|
@@ -172,6 +189,11 @@ module Mongo
|
|
|
172
189
|
:cluster_time,
|
|
173
190
|
:update_cluster_time
|
|
174
191
|
|
|
192
|
+
# @api private
|
|
193
|
+
def_delegators :cluster,
|
|
194
|
+
:monitor_app_metadata,
|
|
195
|
+
:push_monitor_app_metadata
|
|
196
|
+
|
|
175
197
|
def_delegators :features,
|
|
176
198
|
:check_driver_support!
|
|
177
199
|
|
|
@@ -272,19 +294,6 @@ module Mongo
|
|
|
272
294
|
@connected
|
|
273
295
|
end
|
|
274
296
|
|
|
275
|
-
# When the server is flagged for garbage collection, stop the monitor
|
|
276
|
-
# thread.
|
|
277
|
-
#
|
|
278
|
-
# @example Finalize the object.
|
|
279
|
-
# Server.finalize(monitor)
|
|
280
|
-
#
|
|
281
|
-
# @param [ Server::Monitor ] monitor The server monitor.
|
|
282
|
-
#
|
|
283
|
-
# @since 2.2.0
|
|
284
|
-
def self.finalize(monitor)
|
|
285
|
-
proc { monitor.stop! }
|
|
286
|
-
end
|
|
287
|
-
|
|
288
297
|
# Start monitoring the server.
|
|
289
298
|
#
|
|
290
299
|
# Used internally by the driver to add a server to a cluster
|
|
@@ -297,7 +306,6 @@ module Mongo
|
|
|
297
306
|
Monitoring::Event::ServerOpening.new(address, cluster.topology)
|
|
298
307
|
)
|
|
299
308
|
if options[:monitoring_io] != false
|
|
300
|
-
ObjectSpace.define_finalizer(self, self.class.finalize(monitor))
|
|
301
309
|
monitor.run!
|
|
302
310
|
end
|
|
303
311
|
end
|
|
@@ -558,6 +566,7 @@ module Mongo
|
|
|
558
566
|
# @api private
|
|
559
567
|
def update_last_scan
|
|
560
568
|
@last_scan = Time.now
|
|
569
|
+
@last_scan_monotime = Utils.monotonic_time
|
|
561
570
|
end
|
|
562
571
|
end
|
|
563
572
|
end
|
|
@@ -1,3 +1,6 @@
|
|
|
1
|
+
# frozen_string_literal: true
|
|
2
|
+
# encoding: utf-8
|
|
3
|
+
|
|
1
4
|
# Copyright (C) 2020 MongoDB Inc.
|
|
2
5
|
#
|
|
3
6
|
# Licensed under the Apache License, Version 2.0 (the "License");
|
|
@@ -181,7 +184,7 @@ module Mongo
|
|
|
181
184
|
raise Error::NoServerAvailable.new(self, cluster, msg)
|
|
182
185
|
end
|
|
183
186
|
|
|
184
|
-
deadline =
|
|
187
|
+
deadline = Utils.monotonic_time + server_selection_timeout
|
|
185
188
|
|
|
186
189
|
if session && session.pinned_server
|
|
187
190
|
if Mongo::Lint.enabled?
|
|
@@ -199,7 +202,7 @@ module Mongo
|
|
|
199
202
|
# This will no longer be the case once SRV polling is implemented.
|
|
200
203
|
|
|
201
204
|
unless server.mongos?
|
|
202
|
-
while (time_remaining = deadline -
|
|
205
|
+
while (time_remaining = deadline - Utils.monotonic_time) > 0
|
|
203
206
|
wait_for_server_selection(cluster, time_remaining)
|
|
204
207
|
end
|
|
205
208
|
|
|
@@ -252,7 +255,7 @@ module Mongo
|
|
|
252
255
|
|
|
253
256
|
cluster.scan!(false)
|
|
254
257
|
|
|
255
|
-
time_remaining = deadline -
|
|
258
|
+
time_remaining = deadline - Utils.monotonic_time
|
|
256
259
|
if time_remaining > 0
|
|
257
260
|
wait_for_server_selection(cluster, time_remaining)
|
|
258
261
|
|