chiark / gitweb /
608052be1159ce5be7854a8b3b33d53473e6bc68
[elogind.git] / src / test / test-bus-util.c
1 /* SPDX-License-Identifier: LGPL-2.1+ */
2
3 //#include "bus-util.h"
4 //#include "log.h"
5
6 static void test_name_async(unsigned n_messages) {
7         _cleanup_(sd_bus_flush_close_unrefp) sd_bus *bus = NULL;
8         int r;
9         unsigned i;
10
11         log_info("/* %s (%u) */", __func__, n_messages);
12
13         r = bus_open_system_watch_bind_with_description(&bus, "test-bus");
14         if (r < 0) {
15                 log_error_errno(r, "Failed to connect to bus: %m");
16                 return;
17         }
18
19         r = bus_request_name_async_may_reload_dbus(bus, NULL, "org.freedesktop.elogind.test-bus-util", 0, NULL);
20         if (r < 0) {
21                 log_error_errno(r, "Failed to request name: %m");
22                 return;
23         }
24
25         for (i = 0; i < n_messages; i++) {
26                 r = sd_bus_process(bus, NULL);
27                 log_debug("stage %u: sd_bus_process returned %d", i, r);
28                 if (r < 0) {
29                         log_notice_errno(r, "Processing failed: %m");
30                         return;
31                 }
32
33                 if (r > 0 && i + 1 < n_messages)
34                         (void) sd_bus_wait(bus, USEC_PER_SEC / 3);
35         }
36 }
37
38 int main(int argc, char **argv) {
39         log_set_max_level(LOG_DEBUG);
40         log_parse_environment();
41         log_open();
42
43         test_name_async(0);
44         test_name_async(20);
45
46         return 0;
47 }