chiark / gitweb /
bus: beautify bus_message_dump() output a bit
[elogind.git] / src / libsystemd-bus / test-bus-kernel.c
1 /*-*- Mode: C; c-basic-offset: 8; indent-tabs-mode: nil -*-*/
2
3 /***
4   This file is part of systemd.
5
6   Copyright 2013 Lennart Poettering
7
8   systemd is free software; you can redistribute it and/or modify it
9   under the terms of the GNU Lesser General Public License as published by
10   the Free Software Foundation; either version 2.1 of the License, or
11   (at your option) any later version.
12
13   systemd is distributed in the hope that it will be useful, but
14   WITHOUT ANY WARRANTY; without even the implied warranty of
15   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
16   Lesser General Public License for more details.
17
18   You should have received a copy of the GNU Lesser General Public License
19   along with systemd; If not, see <http://www.gnu.org/licenses/>.
20 ***/
21
22 #include <fcntl.h>
23
24 #include "util.h"
25 #include "log.h"
26
27 #include "sd-bus.h"
28 #include "bus-message.h"
29 #include "bus-error.h"
30 #include "bus-kernel.h"
31 #include "bus-util.h"
32 #include "bus-dump.h"
33
34 int main(int argc, char *argv[]) {
35         _cleanup_close_ int bus_ref = -1;
36         _cleanup_free_ char *bus_name = NULL, *address = NULL;
37         _cleanup_bus_message_unref_ sd_bus_message *m = NULL;
38         const char *ua = NULL, *ub = NULL, *the_string = NULL;
39         sd_bus *a, *b;
40         int r, pipe_fds[2];
41
42         log_set_max_level(LOG_DEBUG);
43
44         bus_ref = bus_kernel_create("deine-mutter", &bus_name);
45         if (bus_ref == -ENOENT)
46                 return EXIT_TEST_SKIP;
47
48         assert_se(bus_ref >= 0);
49
50         address = strappend("kernel:path=", bus_name);
51         assert_se(address);
52
53         r = sd_bus_new(&a);
54         assert_se(r >= 0);
55
56         r = sd_bus_new(&b);
57         assert_se(r >= 0);
58
59         r = sd_bus_set_address(a, address);
60         assert_se(r >= 0);
61
62         r = sd_bus_set_address(b, address);
63         assert_se(r >= 0);
64
65         assert_se(sd_bus_negotiate_attach_comm(a, 1) >= 0);
66         assert_se(sd_bus_negotiate_attach_exe(a, 1) >= 0);
67         assert_se(sd_bus_negotiate_attach_cmdline(a, 1) >= 0);
68         assert_se(sd_bus_negotiate_attach_cgroup(a, 1) >= 0);
69         assert_se(sd_bus_negotiate_attach_caps(a, 1) >= 0);
70         assert_se(sd_bus_negotiate_attach_selinux_context(a, 1) >= 0);
71         assert_se(sd_bus_negotiate_attach_audit(a, 1) >= 0);
72
73         assert_se(sd_bus_negotiate_attach_comm(b, 1) >= 0);
74         assert_se(sd_bus_negotiate_attach_exe(b, 1) >= 0);
75         assert_se(sd_bus_negotiate_attach_cmdline(b, 1) >= 0);
76         assert_se(sd_bus_negotiate_attach_cgroup(b, 1) >= 0);
77         assert_se(sd_bus_negotiate_attach_caps(b, 1) >= 0);
78         assert_se(sd_bus_negotiate_attach_selinux_context(b, 1) >= 0);
79         assert_se(sd_bus_negotiate_attach_audit(b, 1) >= 0);
80
81         r = sd_bus_start(a);
82         assert_se(r >= 0);
83
84         r = sd_bus_start(b);
85         assert_se(r >= 0);
86
87         r = sd_bus_get_unique_name(a, &ua);
88         assert_se(r >= 0);
89
90         printf("unique a: %s\n", ua);
91
92         r = sd_bus_get_unique_name(b, &ub);
93         assert_se(r >= 0);
94
95         printf("unique b: %s\n", ub);
96
97         r = sd_bus_add_match(b, "interface='waldo.com',member='Piep'", NULL, NULL);
98         assert_se(r >= 0);
99
100         r = sd_bus_emit_signal(a, "/foo/bar/waldo", "waldo.com", "Piep", "sss", "I am a string", "/this/is/a/path", "and.this.a.domain.name");
101         assert_se(r >= 0);
102
103         r = sd_bus_process(b, &m);
104         assert_se(r > 0);
105         assert_se(m);
106
107         bus_message_dump(m, stdout, true);
108         assert_se(sd_bus_message_rewind(m, true) >= 0);
109
110         r = sd_bus_message_read(m, "s", &the_string);
111         assert_se(r >= 0);
112         assert_se(streq(the_string, "I am a string"));
113
114         sd_bus_message_unref(m);
115         m = NULL;
116
117         r = sd_bus_request_name(a, "net.x0pointer.foobar", 0);
118         assert_se(r >= 0);
119
120         r = sd_bus_message_new_method_call(b, "net.x0pointer.foobar", "/a/path", "an.inter.face", "AMethod", &m);
121         assert_se(r >= 0);
122
123         assert_se(pipe2(pipe_fds, O_CLOEXEC) >= 0);
124
125         assert_se(write(pipe_fds[1], "x", 1) == 1);
126
127         close_nointr_nofail(pipe_fds[1]);
128         pipe_fds[1] = -1;
129
130         r = sd_bus_message_append(m, "h", pipe_fds[0]);
131         assert_se(r >= 0);
132
133         close_nointr_nofail(pipe_fds[0]);
134         pipe_fds[0] = -1;
135
136         r = sd_bus_send(b, m, NULL);
137         assert_se(r >= 0);
138
139         for (;;) {
140                 sd_bus_message_unref(m);
141                 m = NULL;
142                 r = sd_bus_process(a, &m);
143                 assert_se(r > 0);
144                 assert_se(m);
145
146                 bus_message_dump(m, stdout, true);
147                 assert_se(sd_bus_message_rewind(m, true) >= 0);
148
149                 if (sd_bus_message_is_method_call(m, "an.inter.face", "AMethod")) {
150                         int fd;
151                         char x;
152
153                         r = sd_bus_message_read(m, "h", &fd);
154                         assert_se(r >= 0);
155
156                         assert_se(read(fd, &x, 1) == 1);
157                         assert_se(x == 'x');
158                         break;
159                 }
160         }
161
162         r = sd_bus_release_name(a, "net.x0pointer.foobar");
163         assert_se(r >= 0);
164
165         r = sd_bus_release_name(a, "net.x0pointer.foobar");
166         assert_se(r == -ESRCH);
167
168         sd_bus_unref(a);
169         sd_bus_unref(b);
170
171         return 0;
172 }