aboutsummaryrefslogtreecommitdiffstats
path: root/src/libstrongswan/tests/test_utils.c
diff options
context:
space:
mode:
authorTobias Brunner <tobias@strongswan.org>2013-08-06 17:27:15 +0200
committerAndreas Steffen <andreas.steffen@strongswan.org>2013-08-24 16:22:51 +0200
commit32a145fdbd657eb886bee15ccd7fbef7bbea7801 (patch)
tree8c4a2998332c02851098d4a3434c04e3b478939c /src/libstrongswan/tests/test_utils.c
parent49032d15be34cdb0ba9f233e837e3949ee14067c (diff)
downloadstrongswan-32a145fdbd657eb886bee15ccd7fbef7bbea7801.tar.bz2
strongswan-32a145fdbd657eb886bee15ccd7fbef7bbea7801.tar.xz
utils: Add case-insensitive version of strpfx()
Diffstat (limited to 'src/libstrongswan/tests/test_utils.c')
-rw-r--r--src/libstrongswan/tests/test_utils.c36
1 files changed, 36 insertions, 0 deletions
diff --git a/src/libstrongswan/tests/test_utils.c b/src/libstrongswan/tests/test_utils.c
index d9f1726ff..6ab60a6fd 100644
--- a/src/libstrongswan/tests/test_utils.c
+++ b/src/libstrongswan/tests/test_utils.c
@@ -188,6 +188,38 @@ START_TEST(test_round)
END_TEST
/*******************************************************************************
+ * strpfx
+ */
+
+static struct {
+ char *str;
+ char *pfx;
+ bool prefix;
+ bool case_prefix;
+} strpfx_data[] = {
+ {"", "", TRUE, TRUE},
+ {"abc", "", TRUE, TRUE},
+ {"abc", "a", TRUE, TRUE},
+ {"abc", "ab", TRUE, TRUE},
+ {"abc", "abc", TRUE, TRUE},
+ {"abc", "abcd", FALSE, FALSE},
+ {"abc", "AB", FALSE, TRUE},
+ {"ABC", "ab", FALSE, TRUE},
+ {" abc", "abc", FALSE, FALSE},
+};
+
+START_TEST(test_strpfx)
+{
+ bool prefix;
+
+ prefix = strpfx(strpfx_data[_i].str, strpfx_data[_i].pfx);
+ ck_assert(prefix == strpfx_data[_i].prefix);
+ prefix = strcasepfx(strpfx_data[_i].str, strpfx_data[_i].pfx);
+ ck_assert(prefix == strpfx_data[_i].case_prefix);
+}
+END_TEST
+
+/*******************************************************************************
* memxor
*/
@@ -442,6 +474,10 @@ Suite *utils_suite_create()
tcase_add_test(tc, test_round);
suite_add_tcase(s, tc);
+ tc = tcase_create("string helper");
+ tcase_add_loop_test(tc, test_strpfx, 0, countof(strpfx_data));
+ suite_add_tcase(s, tc);
+
tc = tcase_create("memxor");
tcase_add_test(tc, test_memxor);
tcase_add_test(tc, test_memxor_aligned);