aboutsummaryrefslogtreecommitdiff
path: root/tests/unittests/torture_proxycommand.c
diff options
context:
space:
mode:
Diffstat (limited to 'tests/unittests/torture_proxycommand.c')
-rw-r--r--tests/unittests/torture_proxycommand.c61
1 files changed, 61 insertions, 0 deletions
diff --git a/tests/unittests/torture_proxycommand.c b/tests/unittests/torture_proxycommand.c
new file mode 100644
index 00000000..d289019b
--- /dev/null
+++ b/tests/unittests/torture_proxycommand.c
@@ -0,0 +1,61 @@
+#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
+
+static Suite *torture_make_suite(void) {
+ Suite *s = suite_create("libssh_keyfiles");
+
+ torture_create_case_fixture(s, "torture_options_set_proxycommand",
+ torture_options_set_proxycommand, setup, teardown);
+
+ return s;
+}
+
+int main(int argc, char **argv) {
+ Suite *s = NULL;
+ SRunner *sr = NULL;
+ struct argument_s arguments;
+ int nf;
+
+ ZERO_STRUCT(arguments);
+
+ torture_cmdline_parse(argc, argv, &arguments);
+
+ s = torture_make_suite();
+
+ sr = srunner_create(s);
+ if (arguments.nofork) {
+ srunner_set_fork_status(sr, CK_NOFORK);
+ }
+ srunner_run_all(sr, CK_VERBOSE);
+ nf = srunner_ntests_failed(sr);
+ srunner_free(sr);
+
+ return (nf == 0) ? EXIT_SUCCESS : EXIT_FAILURE;
+}
+