D7net
Home
Console
Upload
information
Create File
Create Folder
About
Tools
:
/
opt
/
td-agent
/
embedded
/
lib
/
ruby
/
gems
/
2.1.0
/
gems
/
mongo-2.2.7
/
spec
/
mongo
/
Filename :
server_selection_spec.rb
back
Copy
require 'spec_helper' describe 'Server Selection' do include Mongo::ServerSelection::Read SERVER_SELECTION_TESTS.each do |file| spec = Mongo::ServerSelection::Read::Spec.new(file) context(spec.description) do let(:topology) do spec.type.new({}) end let(:monitoring) do Mongo::Monitoring.new end let(:listeners) do Mongo::Event::Listeners.new end let(:cluster) do double('cluster').tap do |c| allow(c).to receive(:topology).and_return(topology) allow(c).to receive(:single?).and_return(topology.single?) allow(c).to receive(:sharded?).and_return(topology.sharded?) allow(c).to receive(:replica_set?).and_return(topology.replica_set?) end end let(:candidate_servers) do spec.candidate_servers.collect do |server| address = Mongo::Address.new(server['address']) Mongo::Server.new(address, double('cluster'), monitoring, listeners, TEST_OPTIONS).tap do |s| allow(s).to receive(:average_round_trip_time).and_return(server['avg_rtt_ms']) allow(s).to receive(:tags).and_return(server['tags']) allow(s).to receive(:secondary?).and_return(server['type'] == 'RSSecondary') allow(s).to receive(:primary?).and_return(server['type'] == 'RSPrimary') allow(s).to receive(:connectable?).and_return(true) end end end let(:in_latency_window) do spec.in_latency_window.collect do |server| address = Mongo::Address.new(server['address']) Mongo::Server.new(address, double('cluster'), monitoring, listeners, TEST_OPTIONS).tap do |s| allow(s).to receive(:average_round_trip_time).and_return(server['avg_rtt_ms']) allow(s).to receive(:tags).and_return(server['tags']) allow(s).to receive(:connectable?).and_return(true) end end end let(:server_selector) do Mongo::ServerSelector.get(:mode => spec.read_preference['mode'], :tag_sets => spec.read_preference['tag_sets'], :server_selection_timeout => 1) end before do allow(cluster).to receive(:servers).and_return(candidate_servers) allow(cluster).to receive(:scan!).and_return(true) end context 'Valid read preference and matching server available', if: spec.server_available? do it 'Finds all suitable servers in the latency window', if: spec.replica_set? do expect(server_selector.send(:select, cluster.servers)).to eq(in_latency_window) end it 'Finds the most suitable server in the latency window' do expect(in_latency_window).to include(server_selector.select_server(cluster)) end end context 'No matching server available', if: !spec.server_available? do it 'Raises exception' do expect do server_selector.select_server(cluster) end.to raise_exception(Mongo::Error::NoServerAvailable) end end end end end