diff options
| author | Michael K. Schmidt <[email protected]> | 2014-08-22 15:34:15 -0500 | 
|---|---|---|
| committer | Michael K. Schmidt <[email protected]> | 2014-08-22 15:34:15 -0500 | 
| commit | 76b79e88aaf4d59e8cb057fe9a075cc27f0c79c8 (patch) | |
| tree | 2fafb04e8b27ff3aac332113511380bdd9c37a8b /lib/ssh/test | |
| parent | 375e6da4a0daa6592a418ecb53afa37aa186f38f (diff) | |
| download | otp-76b79e88aaf4d59e8cb057fe9a075cc27f0c79c8.tar.gz otp-76b79e88aaf4d59e8cb057fe9a075cc27f0c79c8.tar.bz2 otp-76b79e88aaf4d59e8cb057fe9a075cc27f0c79c8.zip | |
Test Other Clauses of start_shell
start_shell() is called by exec, so test those cases as well.
Also add support for passing a fun to exec.
Diffstat (limited to 'lib/ssh/test')
| -rw-r--r-- | lib/ssh/test/ssh_connection_SUITE.erl | 81 | 
1 files changed, 77 insertions, 4 deletions
| diff --git a/lib/ssh/test/ssh_connection_SUITE.erl b/lib/ssh/test/ssh_connection_SUITE.erl index 0b057f10de..c115ccee5f 100644 --- a/lib/ssh/test/ssh_connection_SUITE.erl +++ b/lib/ssh/test/ssh_connection_SUITE.erl @@ -38,7 +38,9 @@ all() ->      [       {group, openssh_payload},       interrupted_send, -     start_shell +     start_shell, +     start_shell_exec, +     start_shell_exec_fun      ].  groups() ->      [{openssh_payload, [], [simple_exec, @@ -308,7 +310,74 @@ start_shell(Config) when is_list(Config) ->      ssh:close(ConnectionRef),      ssh:stop_daemon(Pid). +%%-------------------------------------------------------------------- +start_shell_exec() -> +    [{doc, "start shell to exec command"}]. + +start_shell_exec(Config) when is_list(Config) -> +    PrivDir = ?config(priv_dir, Config), +    UserDir = filename:join(PrivDir, nopubkey), % to make sure we don't use public-key-auth +    file:make_dir(UserDir), +    SysDir = ?config(data_dir, Config), +    {Pid, Host, Port} = ssh_test_lib:daemon([{system_dir, SysDir}, +                         {user_dir, UserDir}, +                         {password, "morot"}, +                         {exec, {?MODULE,ssh_exec,[]}} ]), + +    ConnectionRef = ssh_test_lib:connect(Host, Port, [{silently_accept_hosts, true}, +                      {user, "foo"}, +                      {password, "morot"}, +                      {user_interaction, true}, +                      {user_dir, UserDir}]), + +    {ok, ChannelId0} = ssh_connection:session_channel(ConnectionRef, infinity), + +    success = ssh_connection:exec(ConnectionRef, ChannelId0, +                  "testing", infinity), +    receive +    {ssh_cm,ConnectionRef, {data, ChannelId, 0, <<"testing\r\n">>}} -> +        ok +    after 5000 -> +        ct:fail("Exec Timeout") +    end, + +    ssh:close(ConnectionRef), +    ssh:stop_daemon(Pid). + +%%-------------------------------------------------------------------- +start_shell_exec_fun() -> +    [{doc, "start shell to exec command"}]. + +start_shell_exec_fun(Config) when is_list(Config) -> +    PrivDir = ?config(priv_dir, Config), +    UserDir = filename:join(PrivDir, nopubkey), % to make sure we don't use public-key-auth +    file:make_dir(UserDir), +    SysDir = ?config(data_dir, Config), +    {Pid, Host, Port} = ssh_test_lib:daemon([{system_dir, SysDir}, +                         {user_dir, UserDir}, +                         {password, "morot"}, +                         {exec, fun ssh_exec/1}]), +    ConnectionRef = ssh_test_lib:connect(Host, Port, [{silently_accept_hosts, true}, +                      {user, "foo"}, +                      {password, "morot"}, +                      {user_interaction, true}, +                      {user_dir, UserDir}]), + +    {ok, ChannelId0} = ssh_connection:session_channel(ConnectionRef, infinity), + +    success = ssh_connection:exec(ConnectionRef, ChannelId0, +                  "testing", infinity), + +    receive +    {ssh_cm,ConnectionRef, {data, ChannelId, 0, <<"testing\r\n">>}} -> +        ok +    after 5000 -> +        ct:fail("Exec Timeout") +    end, + +    ssh:close(ConnectionRef), +    ssh:stop_daemon(Pid).  %%--------------------------------------------------------------------  %% Internal functions ------------------------------------------------  %%-------------------------------------------------------------------- @@ -347,7 +416,11 @@ collect_data(ConnectionRef, ChannelId, Acc) ->  % This is taken from the ssh example code.    start_our_shell(_User, _Peer) ->      spawn(fun() -> -          io:format("Enter command\n") -          %% Don't actually loop, just exit -      end). +            io:format("Enter command\n") +            %% Don't actually loop, just exit +          end). +ssh_exec(Cmd) -> +    spawn(fun() -> +            io:format(Cmd ++ "\n") +          end). | 
