mongo 1.12.5 → 2.0.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- checksums.yaml +4 -4
- checksums.yaml.gz.sig +0 -0
- data/CONTRIBUTING.md +64 -0
- data/LICENSE +1 -1
- data/README.md +21 -126
- data/Rakefile +39 -21
- data/bin/mongo_console +6 -38
- data/lib/mongo/address/ipv4.rb +85 -0
- data/lib/mongo/address/ipv6.rb +85 -0
- data/lib/mongo/address/unix.rb +76 -0
- data/lib/mongo/address.rb +111 -0
- data/lib/mongo/auth/cr/conversation.rb +119 -0
- data/lib/mongo/auth/cr.rb +44 -0
- data/lib/mongo/auth/executable.rb +52 -0
- data/lib/mongo/auth/ldap/conversation.rb +92 -0
- data/lib/mongo/auth/ldap.rb +48 -0
- data/lib/mongo/auth/roles.rb +104 -0
- data/lib/mongo/auth/scram/conversation.rb +450 -0
- data/lib/mongo/auth/scram.rb +53 -0
- data/lib/mongo/auth/user/view.rb +102 -0
- data/lib/mongo/auth/user.rb +159 -0
- data/lib/mongo/auth/x509/conversation.rb +92 -0
- data/lib/mongo/auth/x509.rb +48 -0
- data/lib/mongo/auth.rb +108 -0
- data/lib/mongo/bulk_write/bulk_writable.rb +191 -0
- data/lib/mongo/bulk_write/deletable.rb +60 -0
- data/lib/mongo/bulk_write/insertable.rb +52 -0
- data/lib/mongo/bulk_write/ordered_bulk_write.rb +48 -0
- data/lib/mongo/bulk_write/replacable.rb +57 -0
- data/lib/mongo/bulk_write/unordered_bulk_write.rb +46 -0
- data/lib/mongo/bulk_write/updatable.rb +68 -0
- data/lib/mongo/bulk_write.rb +52 -0
- data/lib/mongo/client.rb +246 -0
- data/lib/mongo/cluster/topology/replica_set.rb +160 -0
- data/lib/mongo/cluster/topology/sharded.rb +132 -0
- data/lib/mongo/cluster/topology/standalone.rb +132 -0
- data/lib/mongo/cluster/topology/unknown.rb +155 -0
- data/lib/mongo/cluster/topology.rb +60 -0
- data/lib/mongo/cluster.rb +203 -0
- data/lib/mongo/collection/view/aggregation.rb +108 -0
- data/lib/mongo/collection/view/explainable.rb +49 -0
- data/lib/mongo/collection/view/immutable.rb +43 -0
- data/lib/mongo/collection/view/iterable.rb +48 -0
- data/lib/mongo/collection/view/map_reduce.rb +191 -0
- data/lib/mongo/collection/view/readable.rb +363 -0
- data/lib/mongo/collection/view/writable.rb +185 -0
- data/lib/mongo/collection/view.rb +169 -0
- data/lib/mongo/collection.rb +130 -1101
- data/lib/mongo/cursor.rb +78 -681
- data/lib/mongo/database/view.rb +101 -0
- data/lib/mongo/database.rb +224 -0
- data/lib/mongo/error/bulk_write_error.rb +41 -0
- data/lib/mongo/error/invalid_bulk_operation.rb +36 -0
- data/lib/mongo/error/invalid_bulk_operation_type.rb +36 -0
- data/lib/mongo/error/invalid_collection_name.rb +39 -0
- data/lib/mongo/error/invalid_database_name.rb +39 -0
- data/{test/replica_set/ssl_test.rb → lib/mongo/error/invalid_document.rb} +21 -14
- data/lib/mongo/error/invalid_file.rb +38 -0
- data/lib/mongo/error/invalid_nonce.rb +46 -0
- data/lib/mongo/error/invalid_replacement_document.rb +39 -0
- data/lib/mongo/error/invalid_signature.rb +47 -0
- data/{test/functional/ssl_test.rb → lib/mongo/error/invalid_update_document.rb} +22 -12
- data/lib/mongo/error/max_bson_size.rb +40 -0
- data/lib/mongo/error/max_message_size.rb +42 -0
- data/{test/functional/db_connection_test.rb → lib/mongo/error/multi_index_drop.rb} +17 -8
- data/lib/mongo/{utils.rb → error/need_primary_server.rb} +10 -6
- data/lib/mongo/{connection.rb → error/operation_failure.rb} +10 -6
- data/lib/mongo/error/parser.rb +77 -0
- data/lib/mongo/{connection/socket.rb → error/socket_error.rb} +10 -5
- data/lib/mongo/error/socket_timeout_error.rb +23 -0
- data/lib/mongo/error/unsupported_features.rb +43 -0
- data/lib/mongo/error.rb +82 -0
- data/lib/mongo/event/listeners.rb +63 -0
- data/lib/mongo/event/primary_elected.rb +53 -0
- data/lib/mongo/event/publisher.rb +42 -0
- data/lib/mongo/event/server_added.rb +53 -0
- data/lib/mongo/event/server_removed.rb +53 -0
- data/lib/mongo/event/subscriber.rb +41 -0
- data/lib/mongo/event.rb +40 -0
- data/lib/mongo/grid/file/chunk.rb +184 -0
- data/lib/mongo/grid/file/metadata.rb +229 -0
- data/lib/mongo/grid/file.rb +106 -0
- data/lib/mongo/grid/fs.rb +149 -0
- data/lib/mongo/{gridfs.rb → grid.rb} +3 -5
- data/lib/mongo/index/view.rb +261 -0
- data/lib/mongo/index.rb +64 -0
- data/lib/mongo/loggable.rb +126 -0
- data/lib/mongo/logger.rb +132 -0
- data/lib/mongo/operation/aggregate/result.rb +88 -0
- data/lib/mongo/operation/aggregate.rb +100 -0
- data/lib/mongo/operation/command.rb +62 -0
- data/lib/mongo/operation/executable.rb +105 -0
- data/lib/mongo/operation/kill_cursors.rb +39 -0
- data/lib/mongo/operation/limited.rb +37 -0
- data/lib/mongo/operation/list_collections/result.rb +114 -0
- data/lib/mongo/operation/list_indexes/result.rb +118 -0
- data/lib/mongo/operation/map_reduce/result.rb +122 -0
- data/lib/mongo/operation/map_reduce.rb +96 -0
- data/lib/mongo/operation/read/collections_info.rb +67 -0
- data/lib/mongo/operation/read/get_more.rb +71 -0
- data/lib/mongo/operation/read/indexes.rb +68 -0
- data/lib/mongo/operation/read/list_collections.rb +75 -0
- data/lib/mongo/operation/read/list_indexes.rb +77 -0
- data/lib/mongo/operation/read/query.rb +71 -0
- data/lib/mongo/{functional.rb → operation/read.rb} +7 -7
- data/lib/mongo/operation/read_preferrable.rb +34 -0
- data/lib/mongo/operation/result.rb +259 -0
- data/lib/mongo/operation/specifiable.rb +397 -0
- data/lib/mongo/operation/write/bulk/bulk_delete/result.rb +75 -0
- data/lib/mongo/operation/write/bulk/bulk_delete.rb +144 -0
- data/lib/mongo/operation/write/bulk/bulk_insert/result.rb +68 -0
- data/lib/mongo/operation/write/bulk/bulk_insert.rb +129 -0
- data/lib/mongo/operation/write/bulk/bulk_mergable.rb +67 -0
- data/lib/mongo/operation/write/bulk/bulk_update/result.rb +162 -0
- data/lib/mongo/operation/write/bulk/bulk_update.rb +153 -0
- data/lib/mongo/operation/write/bulk/legacy_bulk_mergable.rb +83 -0
- data/lib/mongo/operation/write/bulk.rb +17 -0
- data/lib/mongo/operation/write/command/create_index.rb +50 -0
- data/lib/mongo/operation/write/command/create_user.rb +43 -0
- data/lib/mongo/operation/write/command/delete.rb +56 -0
- data/lib/mongo/operation/write/command/drop_index.rb +51 -0
- data/lib/mongo/operation/write/command/insert.rb +55 -0
- data/lib/mongo/operation/write/command/remove_user.rb +42 -0
- data/lib/mongo/operation/write/command/update.rb +60 -0
- data/lib/mongo/operation/write/command/writable.rb +61 -0
- data/lib/mongo/operation/write/command.rb +22 -0
- data/lib/mongo/operation/write/create_index.rb +89 -0
- data/lib/mongo/operation/write/create_user.rb +75 -0
- data/lib/mongo/operation/write/delete/result.rb +40 -0
- data/lib/mongo/operation/write/delete.rb +93 -0
- data/lib/mongo/operation/write/drop_index.rb +62 -0
- data/lib/mongo/{utils/thread_local_variable_manager.rb → operation/write/insert/result.rb} +15 -8
- data/lib/mongo/operation/write/insert.rb +90 -0
- data/lib/mongo/operation/write/remove_user.rb +70 -0
- data/lib/mongo/operation/write/update/result.rb +160 -0
- data/lib/mongo/operation/write/update.rb +103 -0
- data/lib/mongo/{connection/socket/socket_util.rb → operation/write.rb} +10 -24
- data/lib/mongo/operation.rb +25 -0
- data/lib/mongo/options/mapper.rb +78 -0
- data/lib/mongo/options.rb +15 -0
- data/lib/mongo/protocol/bit_vector.rb +61 -0
- data/lib/mongo/protocol/delete.rb +94 -0
- data/lib/mongo/protocol/get_more.rb +99 -0
- data/lib/mongo/protocol/insert.rb +99 -0
- data/lib/mongo/protocol/kill_cursors.rb +74 -0
- data/lib/mongo/protocol/message.rb +252 -0
- data/lib/mongo/protocol/query.rb +147 -0
- data/lib/mongo/protocol/reply.rb +72 -0
- data/lib/mongo/protocol/serializers.rb +180 -0
- data/lib/mongo/protocol/update.rb +111 -0
- data/lib/mongo/protocol.rb +15 -0
- data/lib/mongo/server/connectable.rb +110 -0
- data/lib/mongo/server/connection.rb +134 -0
- data/lib/mongo/server/connection_pool/queue.rb +182 -0
- data/lib/mongo/server/connection_pool.rb +141 -0
- data/lib/mongo/server/context.rb +66 -0
- data/lib/mongo/server/description/features.rb +85 -0
- data/lib/mongo/server/description/inspector/primary_elected.rb +58 -0
- data/lib/mongo/server/description/inspector/server_added.rb +59 -0
- data/lib/mongo/server/description/inspector/server_removed.rb +59 -0
- data/lib/mongo/server/description/inspector.rb +79 -0
- data/lib/mongo/server/description.rb +450 -0
- data/lib/mongo/server/monitor/connection.rb +89 -0
- data/lib/mongo/server/monitor.rb +176 -0
- data/lib/mongo/server.rb +163 -0
- data/lib/mongo/server_selector/nearest.rb +94 -0
- data/lib/mongo/server_selector/primary.rb +88 -0
- data/lib/mongo/server_selector/primary_preferred.rb +94 -0
- data/lib/mongo/server_selector/secondary.rb +91 -0
- data/lib/mongo/server_selector/secondary_preferred.rb +96 -0
- data/lib/mongo/server_selector/selectable.rb +209 -0
- data/lib/mongo/server_selector.rb +81 -0
- data/lib/mongo/socket/ssl.rb +130 -0
- data/lib/mongo/socket/tcp.rb +69 -0
- data/lib/mongo/socket/unix.rb +64 -0
- data/lib/mongo/socket.rb +179 -0
- data/lib/mongo/uri.rb +504 -0
- data/lib/mongo/version.rb +21 -0
- data/lib/mongo/write_concern/acknowledged.rb +52 -0
- data/lib/mongo/write_concern/normalizable.rb +51 -0
- data/lib/mongo/write_concern/unacknowledged.rb +55 -0
- data/lib/mongo/write_concern.rb +99 -0
- data/lib/mongo.rb +24 -82
- data/mongo.gemspec +17 -14
- data/spec/certificates/ca.pem +17 -0
- data/spec/certificates/client.pem +101 -0
- data/spec/certificates/crl.pem +10 -0
- data/spec/certificates/crl_client_revoked.pem +12 -0
- data/spec/certificates/password_protected.pem +51 -0
- data/spec/certificates/server.pem +34 -0
- data/spec/mongo/address/ipv4_spec.rb +74 -0
- data/spec/mongo/address/ipv6_spec.rb +74 -0
- data/spec/mongo/address/unix_spec.rb +30 -0
- data/spec/mongo/address_spec.rb +206 -0
- data/spec/mongo/auth/cr_spec.rb +59 -0
- data/spec/mongo/auth/ldap_spec.rb +40 -0
- data/spec/mongo/auth/scram/conversation_spec.rb +197 -0
- data/spec/mongo/auth/scram_spec.rb +55 -0
- data/spec/mongo/auth/user/view_spec.rb +76 -0
- data/spec/mongo/auth/user_spec.rb +190 -0
- data/spec/mongo/auth/x509_spec.rb +40 -0
- data/spec/mongo/auth_spec.rb +65 -0
- data/spec/mongo/bulk/bulk_write_spec.rb +262 -0
- data/spec/mongo/client_spec.rb +564 -0
- data/spec/mongo/cluster/topology/replica_set_spec.rb +101 -0
- data/spec/mongo/cluster/topology/sharded_spec.rb +74 -0
- data/spec/mongo/cluster/topology/standalone_spec.rb +79 -0
- data/spec/mongo/cluster/topology_spec.rb +65 -0
- data/spec/mongo/cluster_spec.rb +129 -0
- data/spec/mongo/collection/view/aggregation_spec.rb +148 -0
- data/spec/mongo/collection/view/explainable_spec.rb +32 -0
- data/spec/mongo/collection/view/map_reduce_spec.rb +242 -0
- data/spec/mongo/collection/view/readable_spec.rb +603 -0
- data/spec/mongo/collection/view/writable_spec.rb +679 -0
- data/spec/mongo/collection/view_spec.rb +530 -0
- data/spec/mongo/collection_spec.rb +362 -0
- data/spec/mongo/crud_spec.rb +42 -0
- data/spec/mongo/cursor_spec.rb +295 -0
- data/spec/mongo/database_spec.rb +302 -0
- data/spec/mongo/error/parser_spec.rb +119 -0
- data/spec/mongo/event/publisher_spec.rb +50 -0
- data/spec/mongo/event/subscriber_spec.rb +34 -0
- data/spec/mongo/grid/file/chunk_spec.rb +226 -0
- data/spec/mongo/grid/file/metadata_spec.rb +92 -0
- data/spec/mongo/grid/file_spec.rb +172 -0
- data/spec/mongo/grid/fs_spec.rb +129 -0
- data/spec/mongo/index/view_spec.rb +330 -0
- data/spec/mongo/loggable_spec.rb +62 -0
- data/spec/mongo/logger_spec.rb +97 -0
- data/spec/mongo/operation/aggregate/result_spec.rb +80 -0
- data/spec/mongo/operation/aggregate_spec.rb +127 -0
- data/spec/mongo/operation/command_spec.rb +98 -0
- data/spec/mongo/operation/kill_cursors_spec.rb +66 -0
- data/spec/mongo/operation/limited_spec.rb +50 -0
- data/spec/mongo/operation/map_reduce_spec.rb +143 -0
- data/spec/mongo/operation/read/collections_info_spec.rb +40 -0
- data/spec/mongo/operation/read/get_more_spec.rb +81 -0
- data/spec/mongo/operation/read/indexes_spec.rb +31 -0
- data/spec/mongo/operation/read/query_spec.rb +84 -0
- data/spec/mongo/operation/result_spec.rb +275 -0
- data/spec/mongo/operation/specifiable_spec.rb +53 -0
- data/spec/mongo/operation/write/bulk_delete_spec.rb +235 -0
- data/spec/mongo/operation/write/bulk_insert_spec.rb +235 -0
- data/spec/mongo/operation/write/bulk_update_spec.rb +236 -0
- data/spec/mongo/operation/write/command/delete_spec.rb +103 -0
- data/spec/mongo/operation/write/command/insert_spec.rb +103 -0
- data/spec/mongo/operation/write/command/update_spec.rb +109 -0
- data/spec/mongo/operation/write/create_index_spec.rb +63 -0
- data/spec/mongo/operation/write/create_user_spec.rb +44 -0
- data/spec/mongo/operation/write/delete_spec.rb +186 -0
- data/spec/mongo/operation/write/drop_index_spec.rb +51 -0
- data/spec/mongo/operation/write/insert_spec.rb +244 -0
- data/spec/mongo/operation/write/remove_user_spec.rb +46 -0
- data/spec/mongo/operation/write/response_spec.rb +85 -0
- data/spec/mongo/operation/write/update_spec.rb +228 -0
- data/spec/mongo/protocol/delete_spec.rb +167 -0
- data/spec/mongo/protocol/get_more_spec.rb +146 -0
- data/spec/mongo/protocol/insert_spec.rb +161 -0
- data/spec/mongo/protocol/kill_cursors_spec.rb +101 -0
- data/spec/mongo/protocol/query_spec.rb +285 -0
- data/spec/mongo/protocol/reply_spec.rb +157 -0
- data/spec/mongo/protocol/update_spec.rb +186 -0
- data/spec/mongo/server/connection_pool/queue_spec.rb +170 -0
- data/spec/mongo/server/connection_pool_spec.rb +120 -0
- data/spec/mongo/server/connection_spec.rb +312 -0
- data/spec/mongo/server/description/features_spec.rb +138 -0
- data/spec/mongo/server/description/inspector/primary_elected_spec.rb +94 -0
- data/spec/mongo/server/description/inspector/server_added_spec.rb +92 -0
- data/spec/mongo/server/description/inspector/server_removed_spec.rb +95 -0
- data/spec/mongo/server/description_spec.rb +510 -0
- data/spec/mongo/server/monitor_spec.rb +144 -0
- data/spec/mongo/server_discovery_and_monitoring_spec.rb +103 -0
- data/spec/mongo/server_selection_rtt_spec.rb +104 -0
- data/spec/mongo/server_selection_spec.rb +89 -0
- data/spec/mongo/server_selector/nearest_spec.rb +250 -0
- data/spec/mongo/server_selector/primary_preferred_spec.rb +290 -0
- data/spec/mongo/server_selector/primary_spec.rb +114 -0
- data/spec/mongo/server_selector/secondary_preferred_spec.rb +252 -0
- data/spec/mongo/server_selector/secondary_spec.rb +196 -0
- data/spec/mongo/server_selector_spec.rb +101 -0
- data/spec/mongo/server_spec.rb +131 -0
- data/spec/mongo/uri_spec.rb +517 -0
- data/spec/mongo/write_concern/acknowledged_spec.rb +44 -0
- data/spec/mongo/write_concern/unacknowledged_spec.rb +15 -0
- data/spec/spec_helper.rb +133 -0
- data/spec/support/authorization.rb +247 -0
- data/spec/support/crud/read.rb +144 -0
- data/spec/support/crud/write.rb +214 -0
- data/spec/support/crud.rb +203 -0
- data/spec/support/crud_tests/read/aggregate.yml +43 -0
- data/spec/support/crud_tests/read/count.yml +37 -0
- data/spec/support/crud_tests/read/distinct.yml +33 -0
- data/spec/support/crud_tests/read/find.yml +50 -0
- data/spec/support/crud_tests/write/deleteMany.yml +36 -0
- data/spec/support/crud_tests/write/deleteOne.yml +49 -0
- data/spec/support/crud_tests/write/findOneAndDelete.yml +54 -0
- data/spec/support/crud_tests/write/findOneAndReplace.yml +153 -0
- data/spec/support/crud_tests/write/findOneAndUpdate.yml +161 -0
- data/spec/support/crud_tests/write/insertMany.yml +24 -0
- data/spec/support/crud_tests/write/insertOne.yml +19 -0
- data/spec/support/crud_tests/write/replaceOne.yml +96 -0
- data/spec/support/crud_tests/write/updateMany.yml +83 -0
- data/spec/support/crud_tests/write/updateOne.yml +80 -0
- data/spec/support/helpers.rb +140 -0
- data/spec/support/matchers.rb +37 -0
- data/spec/support/sdam/rs/discover_arbiters.yml +41 -0
- data/spec/support/sdam/rs/discover_passives.yml +41 -0
- data/spec/support/sdam/rs/discover_primary.yml +40 -0
- data/spec/support/sdam/rs/discover_secondary.yml +41 -0
- data/spec/support/sdam/rs/discovery.yml +195 -0
- data/spec/support/sdam/rs/ghost_discovered.yml +39 -0
- data/spec/support/sdam/rs/hosts_differ_from_seeds.yml +34 -0
- data/spec/support/sdam/rs/member_reconfig.yml +68 -0
- data/spec/support/sdam/rs/member_standalone.yml +60 -0
- data/spec/support/sdam/rs/new_primary.yml +74 -0
- data/spec/support/sdam/rs/new_primary_wrong_set_name.yml +71 -0
- data/spec/support/sdam/rs/non_rs_member.yml +31 -0
- data/spec/support/sdam/rs/normalize_case.yml +49 -0
- data/spec/support/sdam/rs/primary_becomes_standalone.yml +52 -0
- data/spec/support/sdam/rs/primary_changes_set_name.yml +57 -0
- data/spec/support/sdam/rs/primary_disconnect.yml +56 -0
- data/spec/support/sdam/rs/primary_wrong_set_name.yml +27 -0
- data/spec/support/sdam/rs/response_from_removed.yml +63 -0
- data/spec/support/sdam/rs/rsother_discovered.yml +41 -0
- data/spec/support/sdam/rs/sec_not_auth.yml +49 -0
- data/spec/support/sdam/rs/secondary_wrong_set_name.yml +28 -0
- data/spec/support/sdam/rs/secondary_wrong_set_name_with_primary.yml +69 -0
- data/spec/support/sdam/rs/unexpected_mongos.yml +26 -0
- data/spec/support/sdam/rs/wrong_set_name.yml +35 -0
- data/spec/support/sdam/sharded/multiple_mongoses.yml +46 -0
- data/spec/support/sdam/sharded/non_mongos_removed.yml +41 -0
- data/spec/support/sdam/sharded/normalize_uri_case.yml +32 -0
- data/spec/support/sdam/single/direct_connection_external_ip.yml +34 -0
- data/spec/support/sdam/single/direct_connection_mongos.yml +33 -0
- data/spec/support/sdam/single/direct_connection_rsarbiter.yml +35 -0
- data/spec/support/sdam/single/direct_connection_rsprimary.yml +34 -0
- data/spec/support/sdam/single/direct_connection_rssecondary.yml +35 -0
- data/spec/support/sdam/single/direct_connection_slave.yml +32 -0
- data/spec/support/sdam/single/direct_connection_standalone.yml +32 -0
- data/spec/support/sdam/single/not_ok_response.yml +39 -0
- data/spec/support/sdam/single/standalone_removed.yml +32 -0
- data/spec/support/sdam/single/unavailable_seed.yml +28 -0
- data/spec/support/server_discovery_and_monitoring.rb +167 -0
- data/spec/support/server_selection/rtt/first_value.yml +4 -0
- data/spec/support/server_selection/rtt/first_value_zero.yml +4 -0
- data/spec/support/server_selection/rtt/value_test_1.yml +4 -0
- data/spec/support/server_selection/rtt/value_test_2.yml +4 -0
- data/spec/support/server_selection/rtt/value_test_3.yml +4 -0
- data/spec/support/server_selection/rtt/value_test_4.yml +4 -0
- data/spec/support/server_selection/rtt/value_test_5.yml +4 -0
- data/spec/support/server_selection/selection/ReplicaSetNoPrimary/read/Nearest.yml +26 -0
- data/spec/support/server_selection/selection/ReplicaSetNoPrimary/read/Nearest_non_matching.yml +21 -0
- data/spec/support/server_selection/selection/ReplicaSetNoPrimary/read/Primary.yml +21 -0
- data/spec/support/server_selection/selection/ReplicaSetNoPrimary/read/PrimaryPreferred.yml +26 -0
- data/spec/support/server_selection/selection/ReplicaSetNoPrimary/read/PrimaryPreferred_non_matching.yml +21 -0
- data/spec/support/server_selection/selection/ReplicaSetNoPrimary/read/Secondary.yml +26 -0
- data/spec/support/server_selection/selection/ReplicaSetNoPrimary/read/SecondaryPreferred.yml +26 -0
- data/spec/support/server_selection/selection/ReplicaSetNoPrimary/read/SecondaryPreferred_non_matching.yml +21 -0
- data/spec/support/server_selection/selection/ReplicaSetNoPrimary/read/Secondary_non_matching.yml +21 -0
- data/spec/support/server_selection/selection/ReplicaSetWithPrimary/read/Nearest.yml +33 -0
- data/spec/support/server_selection/selection/ReplicaSetWithPrimary/read/Nearest_non_matching.yml +26 -0
- data/spec/support/server_selection/selection/ReplicaSetWithPrimary/read/Primary.yml +29 -0
- data/spec/support/server_selection/selection/ReplicaSetWithPrimary/read/PrimaryPreferred.yml +29 -0
- data/spec/support/server_selection/selection/ReplicaSetWithPrimary/read/PrimaryPreferred_non_matching.yml +29 -0
- data/spec/support/server_selection/selection/ReplicaSetWithPrimary/read/Secondary.yml +31 -0
- data/spec/support/server_selection/selection/ReplicaSetWithPrimary/read/SecondaryPreferred.yml +31 -0
- data/spec/support/server_selection/selection/ReplicaSetWithPrimary/read/SecondaryPreferred_non_matching.yml +29 -0
- data/spec/support/server_selection/selection/ReplicaSetWithPrimary/read/Secondary_non_matching.yml +26 -0
- data/spec/support/server_selection/selection/Sharded/read/SecondaryPreferred.yml +26 -0
- data/spec/support/server_selection/selection/Single/read/SecondaryPreferred.yml +19 -0
- data/spec/support/server_selection/selection/Unknown/read/SecondaryPreferred.yml +11 -0
- data/spec/support/server_selection.rb +157 -0
- data/spec/support/server_selection_rtt.rb +41 -0
- data/spec/support/shared/bulk_write.rb +535 -0
- data/spec/support/shared/cursor.rb +38 -0
- data/spec/support/shared/operation.rb +77 -0
- data/spec/support/shared/protocol.rb +31 -0
- data/spec/support/shared/server_selector.rb +111 -0
- data/spec/support/shared/socket.rb +82 -0
- data/spec/support/travis.rb +14 -0
- data.tar.gz.sig +2 -3
- metadata +583 -186
- metadata.gz.sig +0 -0
- data/VERSION +0 -1
- data/lib/mongo/bulk_write_collection_view.rb +0 -387
- data/lib/mongo/collection_writer.rb +0 -364
- data/lib/mongo/connection/node.rb +0 -249
- data/lib/mongo/connection/pool.rb +0 -340
- data/lib/mongo/connection/pool_manager.rb +0 -320
- data/lib/mongo/connection/sharding_pool_manager.rb +0 -67
- data/lib/mongo/connection/socket/ssl_socket.rb +0 -95
- data/lib/mongo/connection/socket/tcp_socket.rb +0 -87
- data/lib/mongo/connection/socket/unix_socket.rb +0 -39
- data/lib/mongo/db.rb +0 -808
- data/lib/mongo/exception.rb +0 -145
- data/lib/mongo/functional/authentication.rb +0 -455
- data/lib/mongo/functional/logging.rb +0 -85
- data/lib/mongo/functional/read_preference.rb +0 -183
- data/lib/mongo/functional/scram.rb +0 -556
- data/lib/mongo/functional/uri_parser.rb +0 -409
- data/lib/mongo/functional/write_concern.rb +0 -66
- data/lib/mongo/gridfs/grid.rb +0 -112
- data/lib/mongo/gridfs/grid_ext.rb +0 -53
- data/lib/mongo/gridfs/grid_file_system.rb +0 -163
- data/lib/mongo/gridfs/grid_io.rb +0 -484
- data/lib/mongo/legacy.rb +0 -140
- data/lib/mongo/mongo_client.rb +0 -697
- data/lib/mongo/mongo_replica_set_client.rb +0 -535
- data/lib/mongo/mongo_sharded_client.rb +0 -159
- data/lib/mongo/networking.rb +0 -372
- data/lib/mongo/utils/conversions.rb +0 -110
- data/lib/mongo/utils/core_ext.rb +0 -70
- data/lib/mongo/utils/server_version.rb +0 -69
- data/lib/mongo/utils/support.rb +0 -80
- data/test/functional/authentication_test.rb +0 -39
- data/test/functional/bulk_api_stress_test.rb +0 -133
- data/test/functional/bulk_write_collection_view_test.rb +0 -1198
- data/test/functional/client_test.rb +0 -627
- data/test/functional/collection_test.rb +0 -2175
- data/test/functional/collection_writer_test.rb +0 -83
- data/test/functional/conversions_test.rb +0 -163
- data/test/functional/cursor_fail_test.rb +0 -57
- data/test/functional/cursor_message_test.rb +0 -56
- data/test/functional/cursor_test.rb +0 -683
- data/test/functional/db_api_test.rb +0 -835
- data/test/functional/db_test.rb +0 -348
- data/test/functional/grid_file_system_test.rb +0 -285
- data/test/functional/grid_io_test.rb +0 -252
- data/test/functional/grid_test.rb +0 -273
- data/test/functional/pool_test.rb +0 -136
- data/test/functional/safe_test.rb +0 -98
- data/test/functional/support_test.rb +0 -62
- data/test/functional/timeout_test.rb +0 -60
- data/test/functional/uri_test.rb +0 -446
- data/test/functional/write_concern_test.rb +0 -118
- data/test/helpers/general.rb +0 -50
- data/test/helpers/test_unit.rb +0 -476
- data/test/replica_set/authentication_test.rb +0 -37
- data/test/replica_set/basic_test.rb +0 -189
- data/test/replica_set/client_test.rb +0 -393
- data/test/replica_set/connection_test.rb +0 -138
- data/test/replica_set/count_test.rb +0 -66
- data/test/replica_set/cursor_test.rb +0 -220
- data/test/replica_set/insert_test.rb +0 -157
- data/test/replica_set/max_values_test.rb +0 -151
- data/test/replica_set/pinning_test.rb +0 -105
- data/test/replica_set/query_test.rb +0 -73
- data/test/replica_set/read_preference_test.rb +0 -219
- data/test/replica_set/refresh_test.rb +0 -211
- data/test/replica_set/replication_ack_test.rb +0 -95
- data/test/sharded_cluster/basic_test.rb +0 -203
- data/test/shared/authentication/basic_auth_shared.rb +0 -260
- data/test/shared/authentication/bulk_api_auth_shared.rb +0 -249
- data/test/shared/authentication/gssapi_shared.rb +0 -176
- data/test/shared/authentication/sasl_plain_shared.rb +0 -96
- data/test/shared/authentication/scram_shared.rb +0 -92
- data/test/shared/ssl_shared.rb +0 -235
- data/test/test_helper.rb +0 -61
- data/test/threading/basic_test.rb +0 -120
- data/test/tools/mongo_config.rb +0 -708
- data/test/tools/mongo_config_test.rb +0 -160
- data/test/unit/client_test.rb +0 -381
- data/test/unit/collection_test.rb +0 -166
- data/test/unit/connection_test.rb +0 -335
- data/test/unit/cursor_test.rb +0 -307
- data/test/unit/db_test.rb +0 -136
- data/test/unit/grid_test.rb +0 -76
- data/test/unit/mongo_sharded_client_test.rb +0 -48
- data/test/unit/node_test.rb +0 -93
- data/test/unit/pool_manager_test.rb +0 -111
- data/test/unit/read_pref_test.rb +0 -406
- data/test/unit/read_test.rb +0 -159
- data/test/unit/safe_test.rb +0 -158
- data/test/unit/sharding_pool_manager_test.rb +0 -84
- data/test/unit/write_concern_test.rb +0 -175
@@ -0,0 +1,397 @@
|
|
1
|
+
# Copyright (C) 2014-2015 MongoDB, Inc.
|
2
|
+
#
|
3
|
+
# Licensed under the Apache License, Version 2.0 (the "License");
|
4
|
+
# you may not use this file except in compliance with the License.
|
5
|
+
# You may obtain a copy of the License at
|
6
|
+
#
|
7
|
+
# http://www.apache.org/licenses/LICENSE-2.0
|
8
|
+
#
|
9
|
+
# Unless required by applicable law or agreed to in writing, software
|
10
|
+
# distributed under the License is distributed on an "AS IS" BASIS,
|
11
|
+
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
12
|
+
# See the License for the specific language governing permissions and
|
13
|
+
# limitations under the License.
|
14
|
+
|
15
|
+
module Mongo
|
16
|
+
module Operation
|
17
|
+
|
18
|
+
# This module contains common functionality for convenience methods getting
|
19
|
+
# various values from the spec.
|
20
|
+
#
|
21
|
+
# @since 2.0.0
|
22
|
+
module Specifiable
|
23
|
+
|
24
|
+
# The field for database name.
|
25
|
+
#
|
26
|
+
# @since 2.0.0
|
27
|
+
DB_NAME = :db_name.freeze
|
28
|
+
|
29
|
+
# The field for deletes.
|
30
|
+
#
|
31
|
+
# @since 2.0.0
|
32
|
+
DELETES = :deletes.freeze
|
33
|
+
|
34
|
+
# The field for delete.
|
35
|
+
#
|
36
|
+
# @since 2.0.0
|
37
|
+
DELETE = :delete.freeze
|
38
|
+
|
39
|
+
# The field for documents.
|
40
|
+
#
|
41
|
+
# @since 2.0.0
|
42
|
+
DOCUMENTS = :documents.freeze
|
43
|
+
|
44
|
+
# The field for collection name.
|
45
|
+
#
|
46
|
+
# @since 2.0.0
|
47
|
+
COLL_NAME = :coll_name.freeze
|
48
|
+
|
49
|
+
# The field for cursor count.
|
50
|
+
#
|
51
|
+
# @since 2.0.0
|
52
|
+
CURSOR_COUNT = :cursor_count.freeze
|
53
|
+
|
54
|
+
# The field for cursor id.
|
55
|
+
#
|
56
|
+
# @since 2.0.0
|
57
|
+
CURSOR_ID = :cursor_id.freeze
|
58
|
+
|
59
|
+
# The field for cursor ids.
|
60
|
+
#
|
61
|
+
# @since 2.0.0
|
62
|
+
CURSOR_IDS = :cursor_ids.freeze
|
63
|
+
|
64
|
+
# The field for an index.
|
65
|
+
#
|
66
|
+
# @since 2.0.0
|
67
|
+
INDEX = :index.freeze
|
68
|
+
|
69
|
+
# The field for multiple indexes.
|
70
|
+
#
|
71
|
+
# @since 2.0.0
|
72
|
+
INDEXES = :indexes.freeze
|
73
|
+
|
74
|
+
# The field for index names.
|
75
|
+
#
|
76
|
+
# @since 2.0.0
|
77
|
+
INDEX_NAME = :index_name.freeze
|
78
|
+
|
79
|
+
# The field for options.
|
80
|
+
#
|
81
|
+
# @since 2.0.0
|
82
|
+
OPTIONS = :options.freeze
|
83
|
+
|
84
|
+
# The field for a selector.
|
85
|
+
#
|
86
|
+
# @since 2.0.0
|
87
|
+
SELECTOR = :selector.freeze
|
88
|
+
|
89
|
+
# The field for number to return.
|
90
|
+
#
|
91
|
+
# @since 2.0.0
|
92
|
+
TO_RETURN = :to_return.freeze
|
93
|
+
|
94
|
+
# The field for updates.
|
95
|
+
#
|
96
|
+
# @since 2.0.0
|
97
|
+
UPDATES = :updates.freeze
|
98
|
+
|
99
|
+
# The field for update.
|
100
|
+
#
|
101
|
+
# @since 2.0.0
|
102
|
+
UPDATE = :update.freeze
|
103
|
+
|
104
|
+
# The field name for a user.
|
105
|
+
#
|
106
|
+
# @since 2.0.0
|
107
|
+
USER = :user.freeze
|
108
|
+
|
109
|
+
# The field name for user name.
|
110
|
+
#
|
111
|
+
# @since 2.0.0
|
112
|
+
USER_NAME = :user_name.freeze
|
113
|
+
|
114
|
+
# The field name for a write concern.
|
115
|
+
#
|
116
|
+
# @since 2.0.0
|
117
|
+
WRITE_CONCERN = :write_concern.freeze
|
118
|
+
|
119
|
+
# The field name for the read preference.
|
120
|
+
#
|
121
|
+
# @since 2.0.0
|
122
|
+
READ = :read.freeze
|
123
|
+
|
124
|
+
# @return [ Hash ] spec The specification for the operation.
|
125
|
+
attr_reader :spec
|
126
|
+
|
127
|
+
# Check equality of two specifiable operations.
|
128
|
+
#
|
129
|
+
# @example Are the operations equal?
|
130
|
+
# operation == other
|
131
|
+
#
|
132
|
+
# @param [ Object ] other The other operation.
|
133
|
+
#
|
134
|
+
# @return [ true, false ] Whether the objects are equal.
|
135
|
+
#
|
136
|
+
# @since 2.0.0
|
137
|
+
def ==(other)
|
138
|
+
return false unless other.is_a?(Specifiable)
|
139
|
+
spec == other.spec
|
140
|
+
end
|
141
|
+
alias_method :eql?, :==
|
142
|
+
|
143
|
+
# Get the cursor count from the spec.
|
144
|
+
#
|
145
|
+
# @example Get the cursor count.
|
146
|
+
# specifiable.cursor_count
|
147
|
+
#
|
148
|
+
# @return [ Integer ] The cursor count.
|
149
|
+
#
|
150
|
+
# @since 2.0.0
|
151
|
+
def cursor_count
|
152
|
+
spec[CURSOR_COUNT]
|
153
|
+
end
|
154
|
+
|
155
|
+
# The name of the database to which the operation should be sent.
|
156
|
+
#
|
157
|
+
# @example Get the database name.
|
158
|
+
# specifiable.db_name
|
159
|
+
#
|
160
|
+
# @return [ String ] Database name.
|
161
|
+
#
|
162
|
+
# @since 2.0.0
|
163
|
+
def db_name
|
164
|
+
spec[DB_NAME]
|
165
|
+
end
|
166
|
+
|
167
|
+
# Get the deletes from the specification.
|
168
|
+
#
|
169
|
+
# @example Get the deletes.
|
170
|
+
# specifiable.deletes
|
171
|
+
#
|
172
|
+
# @return [ Array<BSON::Document> ] The deletes.
|
173
|
+
#
|
174
|
+
# @since 2.0.0
|
175
|
+
def deletes
|
176
|
+
spec[DELETES]
|
177
|
+
end
|
178
|
+
|
179
|
+
# Get the delete document from the specification.
|
180
|
+
#
|
181
|
+
# @example Get the delete document.
|
182
|
+
# specifiable.delete
|
183
|
+
#
|
184
|
+
# @return [ Hash ] The delete document.
|
185
|
+
#
|
186
|
+
# @since 2.0.0
|
187
|
+
def delete
|
188
|
+
spec[DELETE]
|
189
|
+
end
|
190
|
+
|
191
|
+
# The documents to in the specification.
|
192
|
+
#
|
193
|
+
# @example Get the documents.
|
194
|
+
# specifiable.documents
|
195
|
+
#
|
196
|
+
# @return [ Array<BSON::Document> ] The documents.
|
197
|
+
#
|
198
|
+
# @since 2.0.0
|
199
|
+
def documents
|
200
|
+
spec[DOCUMENTS]
|
201
|
+
end
|
202
|
+
|
203
|
+
# The name of the collection to which the operation should be sent.
|
204
|
+
#
|
205
|
+
# @example Get the collection name.
|
206
|
+
# specifiable.coll_name
|
207
|
+
#
|
208
|
+
# @return [ String ] Collection name.
|
209
|
+
#
|
210
|
+
# @since 2.0.0
|
211
|
+
def coll_name
|
212
|
+
spec[COLL_NAME]
|
213
|
+
end
|
214
|
+
|
215
|
+
# The id of the cursor created on the server.
|
216
|
+
#
|
217
|
+
# @example Get the cursor id.
|
218
|
+
# specifiable.cursor_id
|
219
|
+
#
|
220
|
+
# @return [ Integer ] The cursor id.
|
221
|
+
#
|
222
|
+
# @since 2.0.0
|
223
|
+
def cursor_id
|
224
|
+
spec[CURSOR_ID]
|
225
|
+
end
|
226
|
+
|
227
|
+
# The ids of the cursors to kill from the spec.
|
228
|
+
#
|
229
|
+
# @example Get the cursor ids from the spec.
|
230
|
+
# specifiable.cursor_ids
|
231
|
+
#
|
232
|
+
# @return [ Array<Integer> ] The cursor ids.
|
233
|
+
#
|
234
|
+
# @since 2.0.0
|
235
|
+
def cursor_ids
|
236
|
+
spec[CURSOR_IDS]
|
237
|
+
end
|
238
|
+
|
239
|
+
# Get the index from the specification.
|
240
|
+
#
|
241
|
+
# @example Get the index specification.
|
242
|
+
# specifiable.index
|
243
|
+
#
|
244
|
+
# @return [ Hash ] The index specification.
|
245
|
+
#
|
246
|
+
# @since 2.0.0
|
247
|
+
def index
|
248
|
+
spec[INDEX]
|
249
|
+
end
|
250
|
+
|
251
|
+
# Get the index name from the spec.
|
252
|
+
#
|
253
|
+
# @example Get the index name.
|
254
|
+
# specifiable.index_name
|
255
|
+
#
|
256
|
+
# @return [ String ] The index name.
|
257
|
+
#
|
258
|
+
# @since 2.0.0
|
259
|
+
def index_name
|
260
|
+
spec[INDEX_NAME]
|
261
|
+
end
|
262
|
+
|
263
|
+
# Get the indexes from the specification.
|
264
|
+
#
|
265
|
+
# @example Get the index specifications.
|
266
|
+
# specifiable.indexes
|
267
|
+
#
|
268
|
+
# @return [ Hash ] The index specifications.
|
269
|
+
#
|
270
|
+
# @since 2.0.0
|
271
|
+
def indexes
|
272
|
+
spec[INDEXES]
|
273
|
+
end
|
274
|
+
|
275
|
+
# Create the new specifiable operation.
|
276
|
+
#
|
277
|
+
# @example Create the new specifiable operation.
|
278
|
+
# Specifiable.new(spec)
|
279
|
+
#
|
280
|
+
# @param [ Hash ] spec The operation specification.
|
281
|
+
#
|
282
|
+
# @see The individual operations for the values they require in their
|
283
|
+
# specs.
|
284
|
+
#
|
285
|
+
# @since 2.0.0
|
286
|
+
def initialize(spec)
|
287
|
+
@spec = spec
|
288
|
+
end
|
289
|
+
|
290
|
+
# Get the options for the operation.
|
291
|
+
#
|
292
|
+
# @example Get the options.
|
293
|
+
# specifiable.options
|
294
|
+
#
|
295
|
+
# @return [ Hash ] The options.
|
296
|
+
#
|
297
|
+
# @since 2.0.0
|
298
|
+
def options
|
299
|
+
spec[OPTIONS] || {}
|
300
|
+
end
|
301
|
+
|
302
|
+
# The selector for from the specification.
|
303
|
+
#
|
304
|
+
# @example Get a selector specification.
|
305
|
+
# specifiable.selector.
|
306
|
+
#
|
307
|
+
# @return [ Hash ] The selector spec.
|
308
|
+
#
|
309
|
+
# @since 2.0.0
|
310
|
+
def selector
|
311
|
+
spec[SELECTOR]
|
312
|
+
end
|
313
|
+
|
314
|
+
# The number of documents to request from the server.
|
315
|
+
#
|
316
|
+
# @example Get the to return value from the spec.
|
317
|
+
# specifiable.to_return
|
318
|
+
#
|
319
|
+
# @return [ Integer ] The number of documents to return.
|
320
|
+
#
|
321
|
+
# @since 2.0.0
|
322
|
+
def to_return
|
323
|
+
spec[TO_RETURN]
|
324
|
+
end
|
325
|
+
|
326
|
+
# The update documents from the spec.
|
327
|
+
#
|
328
|
+
# @example Get the update documents.
|
329
|
+
#
|
330
|
+
# @return [ Array<BSON::Document> ] The update documents.
|
331
|
+
#
|
332
|
+
# @since 2.0.0
|
333
|
+
def updates
|
334
|
+
spec[UPDATES]
|
335
|
+
end
|
336
|
+
|
337
|
+
# The update document from the spec.
|
338
|
+
#
|
339
|
+
# @example Get the update document.
|
340
|
+
#
|
341
|
+
# @return [ Hash ] The update document.
|
342
|
+
#
|
343
|
+
# @since 2.0.0
|
344
|
+
def update
|
345
|
+
spec[UPDATE]
|
346
|
+
end
|
347
|
+
|
348
|
+
# The user for user related operations.
|
349
|
+
#
|
350
|
+
# @example Get the user.
|
351
|
+
# specifiable.user
|
352
|
+
#
|
353
|
+
# @return [ Auth::User ] The user.
|
354
|
+
#
|
355
|
+
# @since 2.0.0
|
356
|
+
def user
|
357
|
+
spec[USER]
|
358
|
+
end
|
359
|
+
|
360
|
+
# The user name from the specification.
|
361
|
+
#
|
362
|
+
# @example Get the user name.
|
363
|
+
# specifiable.user_name
|
364
|
+
#
|
365
|
+
# @return [ String ] The user name.
|
366
|
+
#
|
367
|
+
# @since 2.0.
|
368
|
+
def user_name
|
369
|
+
spec[USER_NAME]
|
370
|
+
end
|
371
|
+
|
372
|
+
# The write concern to use for this operation.
|
373
|
+
#
|
374
|
+
# @example Get the write concern.
|
375
|
+
# specifiable.write_concern
|
376
|
+
#
|
377
|
+
# @return [ Mongo::WriteConcern ] The write concern.
|
378
|
+
#
|
379
|
+
# @since 2.0.0
|
380
|
+
def write_concern
|
381
|
+
@spec[WRITE_CONCERN] || WriteConcern.get(WriteConcern::DEFAULT)
|
382
|
+
end
|
383
|
+
|
384
|
+
# The read preference for this operation.
|
385
|
+
#
|
386
|
+
# @example Get the read preference.
|
387
|
+
# specifiable.read
|
388
|
+
#
|
389
|
+
# @return [ Mongo::ServerSelector ] The read preference.
|
390
|
+
#
|
391
|
+
# @since 2.0.0
|
392
|
+
def read
|
393
|
+
@spec[READ] || ServerSelector.get
|
394
|
+
end
|
395
|
+
end
|
396
|
+
end
|
397
|
+
end
|
@@ -0,0 +1,75 @@
|
|
1
|
+
# Copyright (C) 2014-2015 MongoDB, Inc.
|
2
|
+
#
|
3
|
+
# Licensed under the Apache License, Version 2.0 (the "License");
|
4
|
+
# you may not use this file except in compliance with the License.
|
5
|
+
# You may obtain a copy of the License at
|
6
|
+
#
|
7
|
+
# http://www.apache.org/licenses/LICENSE-2.0
|
8
|
+
#
|
9
|
+
# Unless required by applicable law or agreed to in writing, software
|
10
|
+
# distributed under the License is distributed on an "AS IS" BASIS,
|
11
|
+
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
12
|
+
# See the License for the specific language governing permissions and
|
13
|
+
# limitations under the License.
|
14
|
+
|
15
|
+
require 'mongo/operation/write/bulk/bulk_mergable'
|
16
|
+
require 'mongo/operation/write/bulk/legacy_bulk_mergable'
|
17
|
+
|
18
|
+
module Mongo
|
19
|
+
module Operation
|
20
|
+
module Write
|
21
|
+
class BulkDelete
|
22
|
+
|
23
|
+
# Defines custom behaviour of results when deleting.
|
24
|
+
#
|
25
|
+
# @since 2.0.0
|
26
|
+
class Result < Operation::Result
|
27
|
+
include BulkMergable
|
28
|
+
|
29
|
+
# The aggregate number of deleted docs reported in the replies.
|
30
|
+
#
|
31
|
+
# @since 2.0.0
|
32
|
+
REMOVED = 'nRemoved'.freeze
|
33
|
+
|
34
|
+
# Gets the number of documents deleted.
|
35
|
+
#
|
36
|
+
# @example Get the deleted count.
|
37
|
+
# result.n_removed
|
38
|
+
#
|
39
|
+
# @return [ Integer ] The number of documents deleted.
|
40
|
+
#
|
41
|
+
# @since 2.0.0
|
42
|
+
def n_removed
|
43
|
+
return 0 unless acknowledged?
|
44
|
+
@replies.reduce(0) do |n, reply|
|
45
|
+
n += reply.documents.first[N]
|
46
|
+
end
|
47
|
+
end
|
48
|
+
end
|
49
|
+
|
50
|
+
# Defines custom behaviour of results when deleting.
|
51
|
+
# For server versions < 2.5.5 (that don't use write commands).
|
52
|
+
#
|
53
|
+
# @since 2.0.0
|
54
|
+
class LegacyResult < Operation::Result
|
55
|
+
include LegacyBulkMergable
|
56
|
+
|
57
|
+
# Gets the number of documents deleted.
|
58
|
+
#
|
59
|
+
# @example Get the deleted count.
|
60
|
+
# result.n_removed
|
61
|
+
#
|
62
|
+
# @return [ Integer ] The number of documents deleted.
|
63
|
+
#
|
64
|
+
# @since 2.0.0
|
65
|
+
def n_removed
|
66
|
+
return 0 unless acknowledged?
|
67
|
+
@replies.reduce(0) do |n, reply|
|
68
|
+
n += reply.documents.first[N]
|
69
|
+
end
|
70
|
+
end
|
71
|
+
end
|
72
|
+
end
|
73
|
+
end
|
74
|
+
end
|
75
|
+
end
|
@@ -0,0 +1,144 @@
|
|
1
|
+
# Copyright (C) 2014-2015 MongoDB, Inc.
|
2
|
+
#
|
3
|
+
# Licensed under the Apache License, Version 2.0 (the "License");
|
4
|
+
# you may not use this file except in compliance with the License.
|
5
|
+
# You may obtain a copy of the License at
|
6
|
+
#
|
7
|
+
# http://www.apache.org/licenses/LICENSE-2.0
|
8
|
+
#
|
9
|
+
# Unless required by applicable law or agreed to in writing, software
|
10
|
+
# distributed under the License is distributed on an "AS IS" BASIS,
|
11
|
+
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
12
|
+
# See the License for the specific language governing permissions and
|
13
|
+
# limitations under the License.
|
14
|
+
|
15
|
+
require 'mongo/operation/write/bulk/bulk_delete/result'
|
16
|
+
|
17
|
+
module Mongo
|
18
|
+
module Operation
|
19
|
+
module Write
|
20
|
+
|
21
|
+
# A MongoDB bulk delete operation.
|
22
|
+
#
|
23
|
+
# @note If a server with version >= 2.5.5 is selected, a write command
|
24
|
+
# operation will be created and sent instead.
|
25
|
+
#
|
26
|
+
# @example Create the delete operation.
|
27
|
+
# Write::BulkDelete.new({
|
28
|
+
# :deletes => [{ :q => { :foo => 1 }, :limit => 1 }],
|
29
|
+
# :db_name => 'test',
|
30
|
+
# :coll_name => 'test_coll',
|
31
|
+
# :write_concern => write_concern
|
32
|
+
# })
|
33
|
+
#
|
34
|
+
# @param [ Hash ] spec The specifications for the delete.
|
35
|
+
#
|
36
|
+
# @option spec :deletes [ Array ] The delete documents.
|
37
|
+
# @option spec :db_name [ String ] The name of the database on which
|
38
|
+
# the delete should be executed.
|
39
|
+
# @option spec :coll_name [ String ] The name of the collection on which
|
40
|
+
# the delete should be executed.
|
41
|
+
# @option spec :write_concern [ Mongo::WriteConcern ] The write concern
|
42
|
+
# for this operation.
|
43
|
+
# @option spec :ordered [ true, false ] Whether the operations should be
|
44
|
+
# executed in order.
|
45
|
+
# @option spec :options [Hash] Options for the command, if it ends up being a
|
46
|
+
# write command.
|
47
|
+
#
|
48
|
+
# @since 2.0.0
|
49
|
+
class BulkDelete
|
50
|
+
include Executable
|
51
|
+
include Specifiable
|
52
|
+
|
53
|
+
# Execute the delete operation.
|
54
|
+
#
|
55
|
+
# @example Execute the operation.
|
56
|
+
# operation.execute(context)
|
57
|
+
#
|
58
|
+
# @param [ Mongo::Server::Context ] context The context for this operation.
|
59
|
+
#
|
60
|
+
# @return [ Result ] The result.
|
61
|
+
#
|
62
|
+
# @since 2.0.0
|
63
|
+
def execute(context)
|
64
|
+
if context.features.write_command_enabled?
|
65
|
+
execute_write_command(context)
|
66
|
+
else
|
67
|
+
execute_message(context)
|
68
|
+
end
|
69
|
+
end
|
70
|
+
|
71
|
+
# Set the write concern on this operation.
|
72
|
+
#
|
73
|
+
# @example Set a write concern.
|
74
|
+
# new_op = operation.write_concern(:w => 2)
|
75
|
+
#
|
76
|
+
# @param [ Hash ] wc The write concern.
|
77
|
+
#
|
78
|
+
# @since 2.0.0
|
79
|
+
def write_concern(wc = nil)
|
80
|
+
if wc
|
81
|
+
self.class.new(spec.merge(write_concern: WriteConcern.get(wc)))
|
82
|
+
else
|
83
|
+
spec[WRITE_CONCERN]
|
84
|
+
end
|
85
|
+
end
|
86
|
+
|
87
|
+
private
|
88
|
+
|
89
|
+
def execute_write_command(context)
|
90
|
+
Result.new(Command::Delete.new(spec).execute(context))
|
91
|
+
end
|
92
|
+
|
93
|
+
def execute_message(context)
|
94
|
+
replies = messages.map do |m|
|
95
|
+
context.with_connection do |connection|
|
96
|
+
result = LegacyResult.new(connection.dispatch([ m, gle ].compact))
|
97
|
+
if stop_sending?(result)
|
98
|
+
return result
|
99
|
+
else
|
100
|
+
result.reply
|
101
|
+
end
|
102
|
+
end
|
103
|
+
end
|
104
|
+
LegacyResult.new(replies.compact.empty? ? nil : replies)
|
105
|
+
end
|
106
|
+
|
107
|
+
def stop_sending?(result)
|
108
|
+
ordered? && !result.successful?
|
109
|
+
end
|
110
|
+
|
111
|
+
# @todo put this somewhere else
|
112
|
+
def ordered?
|
113
|
+
@spec.fetch(:ordered, true)
|
114
|
+
end
|
115
|
+
|
116
|
+
def gle
|
117
|
+
gle_message = ( ordered? && write_concern.get_last_error.nil? ) ?
|
118
|
+
Mongo::WriteConcern.get(:w => 1).get_last_error :
|
119
|
+
write_concern.get_last_error
|
120
|
+
if gle_message
|
121
|
+
Protocol::Query.new(
|
122
|
+
db_name,
|
123
|
+
Database::COMMAND,
|
124
|
+
gle_message,
|
125
|
+
options.merge(limit: -1)
|
126
|
+
)
|
127
|
+
end
|
128
|
+
end
|
129
|
+
|
130
|
+
def initialize_copy(original)
|
131
|
+
@spec = original.spec.dup
|
132
|
+
@spec[DELETES] = original.spec[DELETES].clone
|
133
|
+
end
|
134
|
+
|
135
|
+
def messages
|
136
|
+
deletes.collect do |del|
|
137
|
+
opts = ( del[:limit] || 0 ) <= 0 ? {} : { :flags => [ :single_remove ] }
|
138
|
+
Protocol::Delete.new(db_name, coll_name, del[:q], opts)
|
139
|
+
end
|
140
|
+
end
|
141
|
+
end
|
142
|
+
end
|
143
|
+
end
|
144
|
+
end
|
@@ -0,0 +1,68 @@
|
|
1
|
+
# Copyright (C) 2014-2015 MongoDB, Inc.
|
2
|
+
#
|
3
|
+
# Licensed under the Apache License, Version 2.0 (the "License");
|
4
|
+
# you may not use this file except in compliance with the License.
|
5
|
+
# You may obtain a copy of the License at
|
6
|
+
#
|
7
|
+
# http://www.apache.org/licenses/LICENSE-2.0
|
8
|
+
#
|
9
|
+
# Unless required by applicable law or agreed to in writing, software
|
10
|
+
# distributed under the License is distributed on an "AS IS" BASIS,
|
11
|
+
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
12
|
+
# See the License for the specific language governing permissions and
|
13
|
+
# limitations under the License.
|
14
|
+
|
15
|
+
require 'mongo/operation/write/bulk/bulk_mergable'
|
16
|
+
require 'mongo/operation/write/bulk/legacy_bulk_mergable'
|
17
|
+
|
18
|
+
module Mongo
|
19
|
+
module Operation
|
20
|
+
module Write
|
21
|
+
class BulkInsert
|
22
|
+
|
23
|
+
# Defines custom behaviour of results when inserting.
|
24
|
+
#
|
25
|
+
# @since 2.0.0
|
26
|
+
class Result < Operation::Result
|
27
|
+
include BulkMergable
|
28
|
+
|
29
|
+
# Gets the number of documents inserted.
|
30
|
+
#
|
31
|
+
# @example Get the number of documents inserted.
|
32
|
+
# result.n_inserted
|
33
|
+
#
|
34
|
+
# @return [ Integer ] The number of documents inserted.
|
35
|
+
#
|
36
|
+
# @since 2.0.0
|
37
|
+
def n_inserted
|
38
|
+
written_count
|
39
|
+
end
|
40
|
+
end
|
41
|
+
|
42
|
+
# Defines custom behaviour of results when inserting.
|
43
|
+
# For server versions < 2.5.5 (that don't use write commands).
|
44
|
+
#
|
45
|
+
# @since 2.0.0
|
46
|
+
class LegacyResult < Operation::Result
|
47
|
+
include LegacyBulkMergable
|
48
|
+
|
49
|
+
# Gets the number of documents inserted.
|
50
|
+
#
|
51
|
+
# @example Get the number of documents inserted.
|
52
|
+
# result.n_inserted
|
53
|
+
#
|
54
|
+
# @return [ Integer ] The number of documents inserted.
|
55
|
+
#
|
56
|
+
# @since 2.0.0
|
57
|
+
def n_inserted
|
58
|
+
return 0 unless acknowledged?
|
59
|
+
@replies.reduce(0) do |n, reply|
|
60
|
+
n += 1 unless reply_write_errors?(reply)
|
61
|
+
n
|
62
|
+
end
|
63
|
+
end
|
64
|
+
end
|
65
|
+
end
|
66
|
+
end
|
67
|
+
end
|
68
|
+
end
|