2011-08-24 22:34:00 +00:00
|
|
|
$:.unshift(File.join(File.dirname(__FILE__), '..', 'lib'))
|
|
|
|
require './test/replica_sets/rs_test_helper'
|
|
|
|
require 'benchmark'
|
|
|
|
|
|
|
|
class ReplicaSetRefreshTest < Test::Unit::TestCase
|
2011-11-03 15:17:36 +00:00
|
|
|
include ReplicaSetTest
|
2011-08-24 22:34:00 +00:00
|
|
|
|
2011-09-13 21:50:01 +00:00
|
|
|
def setup
|
|
|
|
@conn = nil
|
|
|
|
end
|
|
|
|
|
2011-08-24 22:34:00 +00:00
|
|
|
def teardown
|
2011-11-03 15:17:36 +00:00
|
|
|
self.rs.restart_killed_nodes
|
2011-08-25 15:27:58 +00:00
|
|
|
@conn.close if @conn
|
2011-08-24 22:34:00 +00:00
|
|
|
end
|
|
|
|
|
2011-08-31 20:05:21 +00:00
|
|
|
def test_connect_speed
|
|
|
|
Benchmark.bm do |x|
|
|
|
|
x.report("Connect") do
|
|
|
|
10.times do
|
2011-11-18 20:47:06 +00:00
|
|
|
ReplSetConnection.new([self.rs.host, self.rs.ports[0]],
|
|
|
|
[self.rs.host, self.rs.ports[1]],
|
|
|
|
[self.rs.host, self.rs.ports[2]],
|
|
|
|
:refresh_mode => false)
|
2011-08-31 20:05:21 +00:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2011-11-18 20:47:06 +00:00
|
|
|
@con = ReplSetConnection.new([self.rs.host, self.rs.ports[0]],
|
|
|
|
[self.rs.host, self.rs.ports[1]],
|
|
|
|
[self.rs.host, self.rs.ports[2]],
|
|
|
|
:refresh_mode => false)
|
2011-08-31 20:05:21 +00:00
|
|
|
|
|
|
|
x.report("manager") do
|
|
|
|
man = Mongo::PoolManager.new(@con, @con.seeds)
|
|
|
|
10.times do
|
|
|
|
man.connect
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2011-08-24 22:34:00 +00:00
|
|
|
def test_connect_and_manual_refresh_with_secondaries_down
|
2011-11-03 15:17:36 +00:00
|
|
|
self.rs.kill_all_secondaries
|
2011-08-24 22:34:00 +00:00
|
|
|
|
|
|
|
rescue_connection_failure do
|
2011-11-18 20:47:06 +00:00
|
|
|
@conn = ReplSetConnection.new([self.rs.host, self.rs.ports[0]],
|
|
|
|
[self.rs.host, self.rs.ports[1]],
|
|
|
|
[self.rs.host, self.rs.ports[2]],
|
|
|
|
:refresh_mode => false)
|
2011-08-24 22:34:00 +00:00
|
|
|
end
|
|
|
|
|
|
|
|
assert_equal [], @conn.secondaries
|
|
|
|
assert @conn.connected?
|
|
|
|
assert_equal @conn.read_pool, @conn.primary_pool
|
|
|
|
|
|
|
|
# Refresh with no change to set
|
|
|
|
@conn.refresh
|
|
|
|
assert_equal [], @conn.secondaries
|
|
|
|
assert @conn.connected?
|
|
|
|
assert_equal @conn.read_pool, @conn.primary_pool
|
|
|
|
|
2011-11-03 15:17:36 +00:00
|
|
|
self.rs.restart_killed_nodes
|
2011-08-24 22:34:00 +00:00
|
|
|
assert_equal [], @conn.secondaries
|
|
|
|
assert @conn.connected?
|
|
|
|
assert_equal @conn.read_pool, @conn.primary_pool
|
|
|
|
|
|
|
|
# Refresh with everything up
|
|
|
|
@conn.refresh
|
|
|
|
assert @conn.read_pool
|
|
|
|
assert @conn.secondaries.length > 0
|
|
|
|
end
|
|
|
|
|
|
|
|
def test_automated_refresh_with_secondaries_down
|
2011-11-03 15:17:36 +00:00
|
|
|
self.rs.kill_all_secondaries
|
2011-08-24 22:34:00 +00:00
|
|
|
|
|
|
|
rescue_connection_failure do
|
2011-11-18 20:47:06 +00:00
|
|
|
@conn = ReplSetConnection.new([self.rs.host, self.rs.ports[0]],
|
|
|
|
[self.rs.host, self.rs.ports[1]],
|
|
|
|
[self.rs.host, self.rs.ports[2]],
|
|
|
|
:refresh_interval => 2,
|
|
|
|
:refresh_mode => :sync)
|
2011-08-24 22:34:00 +00:00
|
|
|
end
|
|
|
|
|
|
|
|
assert_equal [], @conn.secondaries
|
|
|
|
assert @conn.connected?
|
|
|
|
assert_equal @conn.read_pool, @conn.primary_pool
|
2011-11-18 20:47:06 +00:00
|
|
|
old_refresh_version = @conn.refresh_version
|
2011-08-24 22:34:00 +00:00
|
|
|
|
2011-11-03 15:17:36 +00:00
|
|
|
self.rs.restart_killed_nodes
|
2011-10-14 13:52:11 +00:00
|
|
|
sleep(4)
|
2011-11-18 20:47:06 +00:00
|
|
|
@conn['foo']['bar'].find_one
|
|
|
|
@conn['foo']['bar'].insert({:a => 1})
|
|
|
|
puts "Old: #{old_refresh_version} New: #{@conn.refresh_version}"
|
|
|
|
|
|
|
|
assert @conn.refresh_version > old_refresh_version,
|
|
|
|
"Refresh version hasn't changed."
|
|
|
|
assert @conn.secondaries.length > 0,
|
|
|
|
"No secondaries have been added."
|
|
|
|
assert @conn.read_pool != @conn.primary_pool,
|
|
|
|
"Read pool and primary pool are identical."
|
2011-08-24 22:34:00 +00:00
|
|
|
end
|
|
|
|
|
|
|
|
def test_automated_refresh_with_removed_node
|
2011-11-18 20:47:06 +00:00
|
|
|
@conn = ReplSetConnection.new([self.rs.host, self.rs.ports[0]],
|
|
|
|
[self.rs.host, self.rs.ports[1]],
|
|
|
|
[self.rs.host, self.rs.ports[2]],
|
|
|
|
:refresh_interval => 2,
|
|
|
|
:refresh_mode => :sync)
|
2011-08-24 22:34:00 +00:00
|
|
|
|
2011-11-18 20:47:06 +00:00
|
|
|
num_secondaries = @conn.secondary_pools.length
|
|
|
|
old_refresh_version = @conn.refresh_version
|
2011-08-25 22:52:20 +00:00
|
|
|
|
2011-11-03 15:17:36 +00:00
|
|
|
n = self.rs.remove_secondary_node
|
2011-08-31 15:46:33 +00:00
|
|
|
sleep(4)
|
2011-11-18 20:47:06 +00:00
|
|
|
@conn['foo']['bar'].find_one
|
|
|
|
puts "Old: #{old_refresh_version} New: #{@conn.refresh_version}"
|
2011-08-25 22:52:20 +00:00
|
|
|
|
2011-11-18 20:47:06 +00:00
|
|
|
assert @conn.refresh_version > old_refresh_version,
|
|
|
|
"Refresh version hasn't changed."
|
|
|
|
assert_equal num_secondaries - 1, @conn.secondaries.length
|
|
|
|
assert_equal num_secondaries - 1, @conn.secondary_pools.length
|
2011-08-31 20:05:21 +00:00
|
|
|
|
2011-11-03 15:17:36 +00:00
|
|
|
self.rs.add_node(n)
|
2011-08-24 22:34:00 +00:00
|
|
|
end
|
2011-08-25 22:52:20 +00:00
|
|
|
|
2011-08-31 20:05:21 +00:00
|
|
|
def test_adding_and_removing_nodes
|
2011-11-04 20:53:28 +00:00
|
|
|
@conn = ReplSetConnection.new([self.rs.host, self.rs.ports[0]],
|
|
|
|
[self.rs.host, self.rs.ports[1]],
|
|
|
|
[self.rs.host, self.rs.ports[2]],
|
2011-11-18 20:47:06 +00:00
|
|
|
:refresh_interval => 2, :refresh_mode => :sync)
|
2011-08-31 20:05:21 +00:00
|
|
|
|
2011-11-03 15:17:36 +00:00
|
|
|
self.rs.add_node
|
2011-10-14 13:52:11 +00:00
|
|
|
sleep(4)
|
2011-11-18 20:47:06 +00:00
|
|
|
@conn['foo']['bar'].find_one
|
2011-08-31 20:05:21 +00:00
|
|
|
|
2011-11-04 20:53:28 +00:00
|
|
|
@conn2 = ReplSetConnection.new([self.rs.host, self.rs.ports[0]],
|
|
|
|
[self.rs.host, self.rs.ports[1]],
|
|
|
|
[self.rs.host, self.rs.ports[2]],
|
2011-11-18 20:47:06 +00:00
|
|
|
:refresh_interval => 2, :refresh_mode => :sync)
|
2011-08-31 20:05:21 +00:00
|
|
|
|
2011-11-18 20:47:06 +00:00
|
|
|
assert @conn2.secondaries.sort == @conn.secondaries.sort,
|
|
|
|
"Second connection secondaries not equal to first."
|
2011-08-31 20:05:21 +00:00
|
|
|
assert_equal 3, @conn.secondary_pools.length
|
|
|
|
assert_equal 3, @conn.secondaries.length
|
|
|
|
|
2011-10-14 13:52:11 +00:00
|
|
|
config = @conn['admin'].command({:ismaster => 1})
|
|
|
|
|
2011-11-03 15:17:36 +00:00
|
|
|
self.rs.remove_secondary_node
|
2011-08-31 20:05:21 +00:00
|
|
|
sleep(4)
|
2011-10-14 13:52:11 +00:00
|
|
|
config = @conn['admin'].command({:ismaster => 1})
|
|
|
|
|
2011-08-31 20:05:21 +00:00
|
|
|
assert_equal 2, @conn.secondary_pools.length
|
|
|
|
assert_equal 2, @conn.secondaries.length
|
|
|
|
end
|
2011-08-24 22:34:00 +00:00
|
|
|
end
|