summaryrefslogtreecommitdiffstats
path: root/tests/unittests
diff options
context:
space:
mode:
authorAris Adamantiadis <aris@0xbadc0de.be>2011-02-12 15:06:15 +0100
committerAndreas Schneider <asn@cryptomilk.org>2011-02-12 19:21:42 +0100
commit5158877b72bef1e4dca86ee1d1c1d364d3bc7285 (patch)
tree74c5f599b841bacc8136d8bd1a8c5eb0c0c987b8 /tests/unittests
parenta785ba3c4d42b0470d4c758b92bc55911f6e228b (diff)
downloadlibssh-5158877b72bef1e4dca86ee1d1c1d364d3bc7285.tar.gz
libssh-5158877b72bef1e4dca86ee1d1c1d364d3bc7285.tar.xz
libssh-5158877b72bef1e4dca86ee1d1c1d364d3bc7285.zip
Connect: Test the new isipaddr() function
(cherry picked from commit 7acc2fa607d8242372f84266f90a25bd7000e587)
Diffstat (limited to 'tests/unittests')
-rw-r--r--tests/unittests/CMakeLists.txt1
-rw-r--r--tests/unittests/torture_isipaddr.c39
2 files changed, 40 insertions, 0 deletions
diff --git a/tests/unittests/CMakeLists.txt b/tests/unittests/CMakeLists.txt
index 6dc68911..55144042 100644
--- a/tests/unittests/CMakeLists.txt
+++ b/tests/unittests/CMakeLists.txt
@@ -6,6 +6,7 @@ add_cmockery_test(torture_init torture_init.c ${TORTURE_LIBRARY})
add_cmockery_test(torture_list torture_list.c ${TORTURE_LIBRARY})
add_cmockery_test(torture_misc torture_misc.c ${TORTURE_LIBRARY})
add_cmockery_test(torture_options torture_options.c ${TORTURE_LIBRARY})
+add_cmockery_test(torture_isipaddr torture_isipaddr.c ${TORTURE_LIBRARY})
if (UNIX AND NOT WIN32)
# requires ssh-keygen
add_cmockery_test(torture_keyfiles torture_keyfiles.c ${TORTURE_LIBRARY})
diff --git a/tests/unittests/torture_isipaddr.c b/tests/unittests/torture_isipaddr.c
new file mode 100644
index 00000000..57427000
--- /dev/null
+++ b/tests/unittests/torture_isipaddr.c
@@ -0,0 +1,39 @@
+#define LIBSSH_STATIC
+
+#include "torture.h"
+
+#include "connect.c"
+
+/*
+ * Test the behavior of isipaddr()
+ */
+static void torture_isipaddr(void **state) {
+ (void)state;
+ assert_int_equal(isipaddr("127.0.0.1"),1);
+ assert_int_equal(isipaddr("0.0.0.0"),1);
+ assert_int_equal(isipaddr("1.1.1.1"),1);
+ assert_int_equal(isipaddr("255.255.255.255"),1);
+ assert_int_equal(isipaddr("128.128.128.128"),1);
+ assert_int_equal(isipaddr("1.10.100.1"),1);
+ assert_int_equal(isipaddr("0.1.10.100"),1);
+
+ assert_int_equal(isipaddr("0.0.0.0.0"),0);
+ assert_int_equal(isipaddr("0.0.0.0.a"),0);
+ assert_int_equal(isipaddr("a.0.0.0"),0);
+ assert_int_equal(isipaddr("0a.0.0.0.0"),0);
+ assert_int_equal(isipaddr(""),0);
+ assert_int_equal(isipaddr("0.0.0."),0);
+ assert_int_equal(isipaddr("0.0.0"),0);
+}
+
+int torture_run_tests(void) {
+ int rc;
+ const UnitTest tests[] = {
+ unit_test(torture_isipaddr)
+ };
+
+ ssh_init();
+ rc=run_tests(tests);
+ ssh_finalize();
+ return rc;
+}