diff options
Diffstat (limited to 'tests/client')
-rw-r--r-- | tests/client/CMakeLists.txt | 1 | ||||
-rw-r--r-- | tests/client/torture_proxycommand.c | 54 |
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; +} |