aboutsummaryrefslogtreecommitdiff
path: root/tests/client
diff options
context:
space:
mode:
Diffstat (limited to 'tests/client')
-rw-r--r--tests/client/CMakeLists.txt1
-rw-r--r--tests/client/torture_proxycommand.c54
2 files changed, 55 insertions, 0 deletions
diff --git a/tests/client/CMakeLists.txt b/tests/client/CMakeLists.txt
index b92f08e6..11633863 100644
--- a/tests/client/CMakeLists.txt
+++ b/tests/client/CMakeLists.txt
@@ -2,3 +2,4 @@ project(clienttests C)
add_check_test(torture_algorithms torture_algorithms.c ${TORTURE_LIBRARY})
add_check_test(torture_auth torture_auth.c ${TORTURE_LIBRARY})
+add_check_test(torture_proxycommand torture_proxycommand.c ${TORTURE_LIBRARY})
diff --git a/tests/client/torture_proxycommand.c b/tests/client/torture_proxycommand.c
new file mode 100644
index 00000000..3ee30a74
--- /dev/null
+++ b/tests/client/torture_proxycommand.c
@@ -0,0 +1,54 @@
+#define LIBSSH_STATIC
+
+#include "torture.h"
+#include <libssh/libssh.h>
+#include "libssh/priv.h"
+ssh_session session;
+
+static void setup(void) {
+ session = ssh_new();
+}
+
+static void teardown(void) {
+ ssh_free(session);
+}
+
+START_TEST (torture_options_set_proxycommand)
+{
+ int rc;
+
+ rc = ssh_options_set(session, SSH_OPTIONS_HOST, "localhost");
+ ck_assert(rc == 0);
+
+ rc = ssh_options_set(session, SSH_OPTIONS_PROXYCOMMAND, "nc localhost 22");
+ ck_assert(rc == 0);
+ rc = ssh_connect(session);
+ ck_assert_msg(rc== SSH_OK,ssh_get_error(session));
+}
+END_TEST
+
+START_TEST (torture_options_set_proxycommand_notexist)
+{
+ int rc;
+
+ rc = ssh_options_set(session, SSH_OPTIONS_HOST, "localhost");
+ ck_assert(rc == 0);
+
+ rc = ssh_options_set(session, SSH_OPTIONS_PROXYCOMMAND, "this_command_does_not_exist");
+ ck_assert(rc == SSH_OK);
+ rc = ssh_connect(session);
+ ck_assert_msg(rc== SSH_ERROR);
+}
+END_TEST
+
+Suite *torture_make_suite(void) {
+ Suite *s = suite_create("libssh_proxycommand");
+
+ torture_create_case_fixture(s, "torture_options_set_proxycommand",
+ torture_options_set_proxycommand, setup, teardown);
+ torture_create_case_fixture(s, "torture_options_set_proxycommand_notexist",
+ torture_options_set_proxycommand_notexist, setup, teardown);
+
+
+ return s;
+}