From 9423a3a065c947ed5ff89da615fbd6ad7f61f60a Mon Sep 17 00:00:00 2001 From: Luka Perkov Date: Mon, 17 Mar 2014 13:53:23 +0100 Subject: [PATCH] tests: torture_connect: add test for user provided socket Signed-off-by: Luka Perkov Reviewed-by: Andreas Schneider --- tests/client/torture_connect.c | 25 +++++++++++++++++++++++++ 1 file changed, 25 insertions(+) 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 #include +#include #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();