aboutsummaryrefslogtreecommitdiff
path: root/src/test/test_protover.c
diff options
context:
space:
mode:
authorNick Mathewson <nickm@torproject.org>2016-08-23 13:47:14 -0400
committerNick Mathewson <nickm@torproject.org>2016-09-26 10:56:49 -0700
commit0697e413efa32b71d080353e5151beee117fca04 (patch)
tree3bd71be4bdbc115db04272ef4b7977d8692f2bbc /src/test/test_protover.c
parentc1be8f9d574dace9941c532ce5d612c315bc74c7 (diff)
downloadtor-0697e413efa32b71d080353e5151beee117fca04.tar.gz
tor-0697e413efa32b71d080353e5151beee117fca04.zip
Unit tests for protover_all_supported
Diffstat (limited to 'src/test/test_protover.c')
-rw-r--r--src/test/test_protover.c39
1 files changed, 39 insertions, 0 deletions
diff --git a/src/test/test_protover.c b/src/test/test_protover.c
index 2c72282a5c..651d2fd52d 100644
--- a/src/test/test_protover.c
+++ b/src/test/test_protover.c
@@ -110,6 +110,44 @@ test_protover_vote(void *arg)
smartlist_free(lst);
}
+static void
+test_protover_all_supported(void *arg)
+{
+ (void)arg;
+ char *msg = NULL;
+
+ tt_assert(protover_all_supported(NULL, &msg));
+ tt_assert(msg == NULL);
+
+ tt_assert(protover_all_supported("", &msg));
+ tt_assert(msg == NULL);
+
+ // Some things that we do support
+ tt_assert(protover_all_supported("Link=3-4", &msg));
+ tt_assert(msg == NULL);
+ tt_assert(protover_all_supported("Link=3-4 Desc=2", &msg));
+ tt_assert(msg == NULL);
+
+ // Some things we don't support
+ tt_assert(! protover_all_supported("Wombat=9", &msg));
+ tt_str_op(msg, OP_EQ, "Wombat=9");
+ tor_free(msg);
+ tt_assert(! protover_all_supported("Link=999", &msg));
+ tt_str_op(msg, OP_EQ, "Link=999");
+ tor_free(msg);
+
+ // Mix of things we support and things we don't
+ tt_assert(! protover_all_supported("Link=3-4 Wombat=9", &msg));
+ tt_str_op(msg, OP_EQ, "Wombat=9");
+ tor_free(msg);
+ tt_assert(! protover_all_supported("Link=3-999", &msg));
+ tt_str_op(msg, OP_EQ, "Link=3-999");
+ tor_free(msg);
+
+ done:
+ tor_free(msg);
+}
+
#define PV_TEST(name, flags) \
{ #name, test_protover_ ##name, (flags), NULL, NULL }
@@ -117,6 +155,7 @@ test_protover_vote(void *arg)
struct testcase_t protover_tests[] = {
PV_TEST(parse, 0),
PV_TEST(vote, 0),
+ PV_TEST(all_supported, 0),
END_OF_TESTCASES
};