4 #include "check_suites.h"
8 /* xcb_parse_display tests {{{ */
10 typedef enum test_type_t {
11 TEST_ARGUMENT, TEST_ENVIRONMENT, TEST_END
13 static const char *const test_string[] = { "", "via $DISPLAY " };
15 static void parse_display_pass(const char *name, const char *host, const int display, const int screen)
19 int got_display, got_screen;
20 const char *argument = 0;
21 test_type_t test_type;
23 for(test_type = TEST_ARGUMENT; test_type != TEST_END; test_type++)
25 if(test_type == TEST_ARGUMENT)
30 else if(test_type == TEST_ENVIRONMENT)
33 setenv("DISPLAY", name, 1);
36 got_host = (char *) -1;
37 got_display = got_screen = -42;
39 success = xcb_parse_display(argument, &got_host, &got_display, &got_screen);
40 fail_unless(success, "unexpected parse failure %sfor '%s'", test_string[test_type], name);
41 fail_unless(strcmp(host, got_host) == 0, "parse %sproduced unexpected hostname '%s' for '%s': expected '%s'", test_string[test_type], got_host, name, host);
42 fail_unless(display == got_display, "parse %sproduced unexpected display '%d' for '%s': expected '%d'", test_string[test_type], got_display, name, display);
43 fail_unless(screen == got_screen, "parse %sproduced unexpected screen '%d' for '%s': expected '%d'", test_string[test_type], got_screen, name, screen);
45 got_host = (char *) -1;
46 got_display = got_screen = -42;
48 success = xcb_parse_display(argument, &got_host, &got_display, 0);
49 fail_unless(success, "unexpected screenless parse failure %sfor '%s'", test_string[test_type], name);
50 fail_unless(strcmp(host, got_host) == 0, "screenless parse %sproduced unexpected hostname '%s' for '%s': expected '%s'", test_string[test_type], got_host, name, host);
51 fail_unless(display == got_display, "screenless parse %sproduced unexpected display '%d' for '%s': expected '%d'", test_string[test_type], got_display, name, display);
56 static void parse_display_fail(const char *name)
60 int got_display, got_screen;
61 const char *argument = 0;
62 test_type_t test_type;
64 for(test_type = TEST_ARGUMENT; test_type != TEST_END; test_type++)
66 if(test_type == TEST_ARGUMENT)
71 else if(test_type == TEST_ENVIRONMENT)
74 setenv("DISPLAY", name, 1);
77 got_host = (char *) -1;
78 got_display = got_screen = -42;
80 success = xcb_parse_display(argument, &got_host, &got_display, &got_screen);
81 fail_unless(!success, "unexpected parse success %sfor '%s'", test_string[test_type], name);
82 fail_unless(got_host == (char *) -1, "host changed on parse failure %sfor '%s': got %p", test_string[test_type], name, got_host);
83 fail_unless(got_display == -42, "display changed on parse failure %sfor '%s': got %d", test_string[test_type], name, got_display);
84 fail_unless(got_screen == -42, "screen changed on parse failure %sfor '%s': got %d", test_string[test_type], name, got_screen);
86 got_host = (char *) -1;
87 got_display = got_screen = -42;
89 success = xcb_parse_display(argument, &got_host, &got_display, 0);
90 fail_unless(!success, "unexpected screenless parse success %sfor '%s'", test_string[test_type], name);
91 fail_unless(got_host == (char *) -1, "host changed on parse failure %sfor '%s': got %p", test_string[test_type], name, got_host);
92 fail_unless(got_display == -42, "display changed on parse failure %sfor '%s': got %d", test_string[test_type], name, got_display);
97 START_TEST(parse_display_unix)
99 parse_display_pass(":0", "", 0, 0);
100 parse_display_pass(":1", "", 1, 0);
101 parse_display_pass(":0.1", "", 0, 1);
105 START_TEST(parse_display_ip)
107 parse_display_pass("x.org:0", "x.org", 0, 0);
108 parse_display_pass("expo:0", "expo", 0, 0);
109 parse_display_pass("bigmachine:1", "bigmachine", 1, 0);
110 parse_display_pass("hydra:0.1", "hydra", 0, 1);
114 START_TEST(parse_display_ipv4)
116 parse_display_pass("198.112.45.11:0", "198.112.45.11", 0, 0);
117 parse_display_pass("198.112.45.11:0.1", "198.112.45.11", 0, 1);
121 START_TEST(parse_display_ipv6)
123 parse_display_pass(":::0", "::", 0, 0);
124 parse_display_pass("1:::0", "1::", 0, 0);
125 parse_display_pass("::1:0", "::1", 0, 0);
126 parse_display_pass("::1:0.1", "::1", 0, 1);
127 parse_display_pass("::127.0.0.1:0", "::127.0.0.1", 0, 0);
128 parse_display_pass("::ffff:127.0.0.1:0", "::ffff:127.0.0.1", 0, 0);
129 parse_display_pass("2002:83fc:d052::1:0", "2002:83fc:d052::1", 0, 0);
130 parse_display_pass("2002:83fc:d052::1:0.1", "2002:83fc:d052::1", 0, 1);
131 parse_display_pass("[::]:0", "[::]", 0, 0);
132 parse_display_pass("[1::]:0", "[1::]", 0, 0);
133 parse_display_pass("[::1]:0", "[::1]", 0, 0);
134 parse_display_pass("[::1]:0.1", "[::1]", 0, 1);
135 parse_display_pass("[::127.0.0.1]:0", "[::127.0.0.1]", 0, 0);
136 parse_display_pass("[::ffff:127.0.0.1]:0", "[::ffff:127.0.0.1]", 0, 0);
137 parse_display_pass("[2002:83fc:d052::1]:0", "[2002:83fc:d052::1]", 0, 0);
138 parse_display_pass("[2002:83fc:d052::1]:0.1", "[2002:83fc:d052::1]", 0, 1);
142 START_TEST(parse_display_decnet)
144 parse_display_pass("myws::0", "myws:", 0, 0);
145 parse_display_pass("big::1", "big:", 1, 0);
146 parse_display_pass("hydra::0.1", "hydra:", 0, 1);
150 START_TEST(parse_display_negative)
152 parse_display_fail(0);
153 parse_display_fail("");
154 parse_display_fail(":");
155 parse_display_fail("::");
156 parse_display_fail(":::");
157 parse_display_fail(":.");
158 parse_display_fail(":a");
159 parse_display_fail(":a.");
160 parse_display_fail(":0.");
161 parse_display_fail(":.a");
162 parse_display_fail(":.0");
163 parse_display_fail(":0.a");
164 parse_display_fail(":0.0.");
166 parse_display_fail("127.0.0.1");
167 parse_display_fail("127.0.0.1:");
168 parse_display_fail("127.0.0.1::");
169 parse_display_fail("::127.0.0.1");
170 parse_display_fail("::127.0.0.1:");
171 parse_display_fail("::127.0.0.1::");
172 parse_display_fail("::ffff:127.0.0.1");
173 parse_display_fail("::ffff:127.0.0.1:");
174 parse_display_fail("::ffff:127.0.0.1::");
175 parse_display_fail("localhost");
176 parse_display_fail("localhost:");
177 parse_display_fail("localhost::");
183 static void popcount_eq(uint32_t bits, int count)
185 fail_unless(xcb_popcount(bits) == count, "unexpected popcount(%08x) != %d", bits, count);
193 for (mask = 0xffffffff, count = 32; count >= 0; mask >>= 1, --count) {
194 popcount_eq(mask, count);
196 for (mask = 0x80000000; mask; mask >>= 1) {
197 popcount_eq(mask, 1);
199 for (mask = 0x80000000; mask > 1; mask >>= 1) {
200 popcount_eq(mask | 1, 2);
205 Suite *public_suite(void)
207 Suite *s = suite_create("Public API");
209 suite_add_test(s, parse_display_unix, "xcb_parse_display unix");
210 suite_add_test(s, parse_display_ip, "xcb_parse_display ip");
211 suite_add_test(s, parse_display_ipv4, "xcb_parse_display ipv4");
212 suite_add_test(s, parse_display_ipv6, "xcb_parse_display ipv6");
213 suite_add_test(s, parse_display_decnet, "xcb_parse_display decnet");
214 suite_add_test(s, parse_display_negative, "xcb_parse_display negative");
215 suite_add_test(s, popcount, "xcb_popcount");