aboutsummaryrefslogtreecommitdiff
path: root/tests
diff options
context:
space:
mode:
authorLuka Perkov <luka.perkov@sartura.hr>2014-03-17 13:53:23 +0100
committerAndreas Schneider <asn@cryptomilk.org>2014-03-27 10:14:35 +0100
commit9423a3a065c947ed5ff89da615fbd6ad7f61f60a (patch)
tree333dce5833b1fe2c3b8f24f6ef9a678e5626db63 /tests
parent0c5d4954a78714c35e18fef9ef1010b3f53ee094 (diff)
downloadlibssh-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.c25
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();