diff options
author | Luka Perkov <luka.perkov@sartura.hr> | 2014-03-17 13:53:23 +0100 |
---|---|---|
committer | Andreas Schneider <asn@cryptomilk.org> | 2014-03-27 10:14:35 +0100 |
commit | 9423a3a065c947ed5ff89da615fbd6ad7f61f60a (patch) | |
tree | 333dce5833b1fe2c3b8f24f6ef9a678e5626db63 /tests | |
parent | 0c5d4954a78714c35e18fef9ef1010b3f53ee094 (diff) | |
download | libssh-9423a3a065c947ed5ff89da615fbd6ad7f61f60a.tar.gz libssh-9423a3a065c947ed5ff89da615fbd6ad7f61f60a.tar.xz libssh-9423a3a065c947ed5ff89da615fbd6ad7f61f60a.zip |
tests: torture_connect: add test for user provided socket
Signed-off-by: Luka Perkov <luka.perkov@sartura.hr>
Reviewed-by: Andreas Schneider <asn@cryptomilk.org>
Diffstat (limited to 'tests')
-rw-r--r-- | tests/client/torture_connect.c | 25 |
1 files changed, 25 insertions, 0 deletions
diff --git a/tests/client/torture_connect.c b/tests/client/torture_connect.c index a364055d..f61afc91 100644 --- a/tests/client/torture_connect.c +++ b/tests/client/torture_connect.c @@ -24,6 +24,7 @@ #include "torture.h" #include <libssh/libssh.h> #include <sys/time.h> +#include <arpa/inet.h> #define HOST "localhost" /* Should work until Apnic decides to assign it :) */ @@ -113,6 +114,29 @@ static void torture_connect_failure(void **state) { ssh_disconnect(session); } +static void torture_connect_socket(void **state) { + ssh_session session = *state; + + int rc; + int sock_fd = 0; + struct sockaddr_in server_addr; + + sock_fd = socket(AF_INET, SOCK_STREAM, 0); + assert_true(sock_fd > 0); + + server_addr.sin_family = AF_INET; + server_addr.sin_port = htons(22); + server_addr.sin_addr.s_addr = inet_addr("127.0.0.1"); + + rc = connect(sock_fd, &server_addr, sizeof(server_addr)); + assert_true(rc == 0); + + ssh_options_set(session, SSH_OPTIONS_FD, &sock_fd); + + rc = ssh_connect(session); + assert_true(rc == SSH_OK); +} + int torture_run_tests(void) { int rc; const UnitTest tests[] = { @@ -120,6 +144,7 @@ int torture_run_tests(void) { unit_test_setup_teardown(torture_connect_double, setup, teardown), unit_test_setup_teardown(torture_connect_failure, setup, teardown), unit_test_setup_teardown(torture_connect_timeout, setup, teardown), + unit_test_setup_teardown(torture_connect_socket, setup, teardown), }; ssh_init(); |