diff options
Diffstat (limited to 'test/server_test.rb')
-rw-r--r-- | test/server_test.rb | 94 |
1 files changed, 55 insertions, 39 deletions
diff --git a/test/server_test.rb b/test/server_test.rb index caca334..02ba0e0 100644 --- a/test/server_test.rb +++ b/test/server_test.rb @@ -3,80 +3,96 @@ require 'net/ssh/multi/server' class ServerTest < Test::Unit::TestCase def setup - @master = mock('multi-session') + @master = stub('multi-session', :default_user => "bob") end def test_accessor_without_properties_should_access_empty_hash - assert_nil server('host', 'user')[:foo] + assert_nil server('host')[:foo] end def test_accessor_with_properties_should_access_properties - assert_equal "hello", server('host', 'user', :properties => { :foo => "hello" })[:foo] + assert_equal "hello", server('host', :properties => { :foo => "hello" })[:foo] end def test_port_should_return_22_by_default - assert_equal 22, server('host', 'user').port + assert_equal 22, server('host').port end def test_port_should_return_given_port_when_present - assert_equal 1234, server('host', 'user', :port => 1234).port + assert_equal 1234, server('host', :port => 1234).port + end + + def test_port_should_return_parsed_port_when_present + assert_equal 1234, server('host:1234', :port => 1235).port + end + + def test_user_should_return_default_user_by_default + assert_equal "bob", server('host').user + end + + def test_user_should_return_given_user_when_present + assert_equal "jim", server('host', :user => "jim").user + end + + def test_user_should_return_parsed_user_when_present + assert_equal "jim", server('jim@host', :user => "john").user end def test_equivalence_when_host_and_user_and_port_match - s1 = server('host', 'user', :port => 1234) - s2 = server('host', 'user', :port => 1234) + s1 = server('user@host:1234') + s2 = server('user@host:1234') assert s1.eql?(s2) assert_equal s1.hash, s2.hash assert s1 == s2 end def test_equivalence_when_host_mismatch - s1 = server('host1', 'user', :port => 1234) - s2 = server('host2', 'user', :port => 1234) + s1 = server('user@host1:1234') + s2 = server('user@host2:1234') assert !s1.eql?(s2) assert_not_equal s1.hash, s2.hash assert s1 != s2 end def test_equivalence_when_port_mismatch - s1 = server('host', 'user', :port => 1234) - s2 = server('host', 'user', :port => 1235) + s1 = server('user@host:1234') + s2 = server('user@host:1235') assert !s1.eql?(s2) assert_not_equal s1.hash, s2.hash assert s1 != s2 end def test_equivalence_when_user_mismatch - s1 = server('host', 'user1', :port => 1234) - s2 = server('host', 'user2', :port => 1234) + s1 = server('user1@host:1234') + s2 = server('user2@host:1234') assert !s1.eql?(s2) assert_not_equal s1.hash, s2.hash assert s1 != s2 end def test_to_s_should_include_user_and_host - assert_equal "user@host", server('host', 'user').to_s + assert_equal "user@host", server('user@host').to_s end def test_to_s_should_include_user_and_host_and_port_when_port_is_given - assert_equal "user@host:1234", server('host', 'user', :port => 1234).to_s + assert_equal "user@host:1234", server('user@host:1234').to_s end def test_gateway_should_be_nil_by_default - assert_nil server('host', 'user').gateway + assert_nil server('host').gateway end def test_gateway_should_be_set_with_the_via_value gateway = mock('gateway') - assert_equal gateway, server('host', 'user', :via => gateway).gateway + assert_equal gateway, server('host', :via => gateway).gateway end def test_session_with_default_argument_should_not_instantiate_session - assert_nil server('host', 'user').session + assert_nil server('host').session end def test_session_with_true_argument_should_instantiate_and_cache_session - srv = server('host', 'user', :port => 1234) + srv = server('host') session = expect_connection_to(srv) assert_equal session, srv.session(true) assert_equal session, srv.session(true) @@ -84,23 +100,23 @@ class ServerTest < Test::Unit::TestCase end def test_session_that_cannot_authenticate_adds_host_to_exception_message - srv = server('host', 'user') - Net::SSH.expects(:start).with('host', 'user', {}).raises(Net::SSH::AuthenticationFailed.new('user')) + srv = server('host') + Net::SSH.expects(:start).with('host', 'bob', {}).raises(Net::SSH::AuthenticationFailed.new('bob')) begin srv.new_session flunk rescue Net::SSH::AuthenticationFailed => e - assert_equal "user@host", e.message + assert_equal "bob@host", e.message end end def test_close_channels_when_session_is_not_open_should_not_do_anything - assert_nothing_raised { server('host', 'user').close_channels } + assert_nothing_raised { server('host').close_channels } end def test_close_channels_when_session_is_open_should_iterate_over_open_channels_and_close_them - srv = server('host', 'user') + srv = server('host') session = expect_connection_to(srv) c1 = mock('channel', :close => nil) c2 = mock('channel', :close => nil) @@ -111,11 +127,11 @@ class ServerTest < Test::Unit::TestCase end def test_close_when_session_is_not_open_should_not_do_anything - assert_nothing_raised { server('host', 'user').close } + assert_nothing_raised { server('host').close } end def test_close_when_session_is_open_should_close_session - srv = server('host', 'user') + srv = server('host') session = expect_connection_to(srv) session.expects(:close) @master.expects(:server_closed).with(srv) @@ -124,11 +140,11 @@ class ServerTest < Test::Unit::TestCase end def test_busy_should_be_false_when_session_is_not_open - assert !server('host', 'user').busy? + assert !server('host').busy? end def test_busy_should_be_false_when_session_is_not_busy - srv = server('host', 'user') + srv = server('host') session = expect_connection_to(srv) session.expects(:busy?).returns(false) srv.session(true) @@ -136,7 +152,7 @@ class ServerTest < Test::Unit::TestCase end def test_busy_should_be_true_when_session_is_busy - srv = server('host', 'user') + srv = server('host') session = expect_connection_to(srv) session.expects(:busy?).returns(true) srv.session(true) @@ -144,11 +160,11 @@ class ServerTest < Test::Unit::TestCase end def test_preprocess_should_be_nil_when_session_is_not_open - assert_nil server('host', 'user').preprocess + assert_nil server('host').preprocess end def test_preprocess_should_return_result_of_session_preprocess - srv = server('host', 'user') + srv = server('host') session = expect_connection_to(srv) session.expects(:preprocess).returns(:result) srv.session(true) @@ -156,11 +172,11 @@ class ServerTest < Test::Unit::TestCase end def test_readers_should_return_empty_array_when_session_is_not_open - assert_equal [], server('host', 'user').readers + assert_equal [], server('host').readers end def test_readers_should_return_all_listeners_when_session_is_open - srv = server('host', 'user') + srv = server('host') session = expect_connection_to(srv) session.expects(:listeners).returns(1 => 2, 3 => 4, 5 => 6, 7 => 8) srv.session(true) @@ -168,11 +184,11 @@ class ServerTest < Test::Unit::TestCase end def test_writers_should_return_empty_array_when_session_is_not_open - assert_equal [], server('host', 'user').writers + assert_equal [], server('host').writers end def test_writers_should_return_all_listeners_that_are_pending_writes_when_session_is_open - srv = server('host', 'user') + srv = server('host') session = expect_connection_to(srv) listeners = { writer(:ready) => 1, writer(:reader) => 2, writer(:reader) => 3, writer(:idle) => 4, writer(:ready) => 5 } @@ -182,11 +198,11 @@ class ServerTest < Test::Unit::TestCase end def test_postprocess_should_return_true_when_session_is_not_open - assert_equal true, server('host', 'user').postprocess([], []) + assert_equal true, server('host').postprocess([], []) end def test_postprocess_should_call_session_postprocess_with_ios_belonging_to_session - srv = server('host', 'user') + srv = server('host') session = expect_connection_to(srv) session.expects(:listeners).returns(1 => 2, 3 => 4, 5 => 6, 7 => 8) session.expects(:postprocess).with([1,3], [7]).returns(:result) @@ -196,8 +212,8 @@ class ServerTest < Test::Unit::TestCase private - def server(host, user, options={}) - Net::SSH::Multi::Server.new(@master, host, user, options) + def server(host, options={}) + Net::SSH::Multi::Server.new(@master, host, options) end def expect_connection_to(server) |