summaryrefslogtreecommitdiff
path: root/tests/check_public.c
diff options
context:
space:
mode:
Diffstat (limited to 'tests/check_public.c')
-rw-r--r--tests/check_public.c129
1 files changed, 129 insertions, 0 deletions
diff --git a/tests/check_public.c b/tests/check_public.c
new file mode 100644
index 0000000..9a32ba9
--- /dev/null
+++ b/tests/check_public.c
@@ -0,0 +1,129 @@
+#include <check.h>
+#include <string.h>
+#include <stdlib.h>
+#include "check_suites.h"
+#include "xcb.h"
+
+/* XCBParseDisplay tests {{{ */
+
+static void parse_display_pass(const char *name, const char *host, const int display, const int screen)
+{
+ int success;
+ char *got_host;
+ int got_display, got_screen;
+
+ got_host = (char *) -1;
+ got_display = got_screen = -42;
+ mark_point();
+ success = XCBParseDisplay(name, &got_host, &got_display, &got_screen);
+ fail_unless(success, "unexpected parse failure for '%s'", name);
+ fail_unless(strcmp(host, got_host) == 0, "parse produced unexpected hostname '%s' for '%s': expected '%s'", got_host, name, host);
+ fail_unless(display == got_display, "parse produced unexpected display '%d' for '%s': expected '%d'", got_display, name, display);
+ fail_unless(screen == got_screen, "parse produced unexpected screen '%d' for '%s': expected '%d'", got_screen, name, screen);
+
+ got_host = (char *) -1;
+ got_display = got_screen = -42;
+ mark_point();
+ success = XCBParseDisplay(name, &got_host, &got_display, 0);
+ fail_unless(success, "unexpected screenless parse failure for '%s'", name);
+ fail_unless(strcmp(host, got_host) == 0, "screenless parse produced unexpected hostname '%s' for '%s': expected '%s'", got_host, name, host);
+ fail_unless(display == got_display, "screenless parse produced unexpected display '%d' for '%s': expected '%d'", got_display, name, display);
+}
+
+static void parse_display_fail(const char *name)
+{
+ int success;
+ char *got_host;
+ int got_display, got_screen;
+
+ got_host = (char *) -1;
+ got_display = got_screen = -42;
+ mark_point();
+ success = XCBParseDisplay(name, &got_host, &got_display, &got_screen);
+ fail_unless(!success, "unexpected parse success for '%s'", name);
+ fail_unless(got_host == (char *) -1, "host changed on failure for '%s': got %p", got_host);
+ fail_unless(got_display == -42, "display changed on failure for '%s': got %d", got_display);
+ fail_unless(got_screen == -42, "screen changed on failure for '%s': got %d", got_screen);
+
+ got_host = (char *) -1;
+ got_display = got_screen = -42;
+ mark_point();
+ success = XCBParseDisplay(name, &got_host, &got_display, 0);
+ fail_unless(!success, "unexpected screenless parse success for '%s'", name);
+ fail_unless(got_host == (char *) -1, "host changed on failure for '%s': got %p", got_host);
+ fail_unless(got_display == -42, "display changed on failure for '%s': got %d", got_display);
+}
+
+START_TEST(parse_display_unix)
+{
+ parse_display_pass(":0", "", 0, 0);
+ parse_display_pass(":1", "", 1, 0);
+ parse_display_pass(":0.1", "", 0, 1);
+}
+END_TEST
+
+START_TEST(parse_display_ip)
+{
+ parse_display_pass("x.org:0", "x.org", 0, 0);
+ parse_display_pass("expo:0", "expo", 0, 0);
+ parse_display_pass("bigmachine:1", "bigmachine", 1, 0);
+ parse_display_pass("hydra:0.1", "hydra", 0, 1);
+}
+END_TEST
+
+START_TEST(parse_display_ipv4)
+{
+ parse_display_pass("198.112.45.11:0", "198.112.45.11", 0, 0);
+ parse_display_pass("198.112.45.11:0.1", "198.112.45.11", 0, 1);
+}
+END_TEST
+
+START_TEST(parse_display_ipv6)
+{
+ parse_display_pass("::1:0", "::1", 0, 0);
+ parse_display_pass("::1:0.1", "::1", 0, 1);
+ parse_display_pass("2002:83fc:d052::1:0", "2002:83fc:d052::1", 0, 0);
+ parse_display_pass("2002:83fc:d052::1:0.1", "2002:83fc:d052::1", 0, 1);
+}
+END_TEST
+
+START_TEST(parse_display_decnet)
+{
+ parse_display_pass("myws::0", "myws:", 0, 0);
+ parse_display_pass("big::1", "big:", 1, 0);
+ parse_display_pass("hydra::0.1", "hydra:", 0, 1);
+}
+END_TEST
+
+START_TEST(parse_display_negative)
+{
+ parse_display_fail(0);
+ parse_display_fail("");
+ parse_display_fail(":");
+ parse_display_fail("::");
+ parse_display_fail(":.");
+ parse_display_fail(":a");
+ parse_display_fail(":a.");
+ parse_display_fail(":0.");
+ parse_display_fail(":0.a");
+ parse_display_fail(":0.0.");
+
+ parse_display_fail("localhost");
+ parse_display_fail("localhost:");
+}
+END_TEST
+
+/* }}} */
+
+Suite *public_suite(void)
+{
+ Suite *s = suite_create("Public API");
+ putenv("DISPLAY");
+ suite_add_test(s, parse_display_unix, "XCBParseDisplay unix");
+ suite_add_test(s, parse_display_ip, "XCBParseDisplay ip");
+ suite_add_test(s, parse_display_ipv4, "XCBParseDisplay ipv4");
+ suite_add_test(s, parse_display_ipv6, "XCBParseDisplay ipv6");
+ suite_add_test(s, parse_display_decnet, "XCBParseDisplay decnet");
+ suite_add_test(s, parse_display_negative, "XCBParseDisplay negative");
+ return s;
+}