chiark
/
gitweb
/
~ianmdlvl
/
elogind.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
bus: don't rely on static IDs in tests
[elogind.git]
/
src
/
libsystemd
/
sd-bus
/
test-bus-zero-copy.c
diff --git
a/src/libsystemd/sd-bus/test-bus-zero-copy.c
b/src/libsystemd/sd-bus/test-bus-zero-copy.c
index 2cc671b16d16932be0d316cb8f91ac2a622f4f27..4ea9f9fc3530ae895846a910f7f7aa577ee888de 100644
(file)
--- a/
src/libsystemd/sd-bus/test-bus-zero-copy.c
+++ b/
src/libsystemd/sd-bus/test-bus-zero-copy.c
@@
-39,6
+39,7
@@
int main(int argc, char *argv[]) {
_cleanup_free_ char *name = NULL, *bus_name = NULL, *address = NULL;
int main(int argc, char *argv[]) {
_cleanup_free_ char *name = NULL, *bus_name = NULL, *address = NULL;
+ const char *unique;
uint8_t *p;
sd_bus *a, *b;
int r, bus_ref;
uint8_t *p;
sd_bus *a, *b;
int r, bus_ref;
@@
-48,6
+49,7
@@
int main(int argc, char *argv[]) {
uint32_t u32;
size_t i, l;
char *s;
uint32_t u32;
size_t i, l;
char *s;
+ _cleanup_close_ int sfd = -1;
log_set_max_level(LOG_DEBUG);
log_set_max_level(LOG_DEBUG);
@@
-80,7
+82,10
@@
int main(int argc, char *argv[]) {
r = sd_bus_start(b);
assert_se(r >= 0);
r = sd_bus_start(b);
assert_se(r >= 0);
- r = sd_bus_message_new_method_call(b, &m, ":1.1", "/a/path", "an.inter.face", "AMethod");
+ r = sd_bus_get_unique_name(a, &unique);
+ assert_se(r >= 0);
+
+ r = sd_bus_message_new_method_call(b, &m, unique, "/a/path", "an.inter.face", "AMethod");
assert_se(r >= 0);
r = sd_bus_message_open_container(m, 'r', "aysay");
assert_se(r >= 0);
r = sd_bus_message_open_container(m, 'r', "aysay");
@@
-107,7
+112,7
@@
int main(int argc, char *argv[]) {
assert_se(r >= 0);
assert_se(sz == STRING_SIZE);
assert_se(r >= 0);
assert_se(sz == STRING_SIZE);
- r = sd_bus_message_append_string_memfd(m, f);
+ r = sd_bus_message_append_string_memfd(m, f
, 0, (uint64_t) -1
);
assert_se(r >= 0);
close(f);
assert_se(r >= 0);
close(f);
@@
-124,7
+129,7
@@
int main(int argc, char *argv[]) {
assert_se(r >= 0);
assert_se(sz == SECOND_ARRAY);
assert_se(r >= 0);
assert_se(sz == SECOND_ARRAY);
- r = sd_bus_message_append_array_memfd(m, 'y', f);
+ r = sd_bus_message_append_array_memfd(m, 'y', f
, 0, (uint64_t) -1
);
assert_se(r >= 0);
close(f);
assert_se(r >= 0);
close(f);
@@
-135,6
+140,11
@@
int main(int argc, char *argv[]) {
r = sd_bus_message_append(m, "u", 4711);
assert_se(r >= 0);
r = sd_bus_message_append(m, "u", 4711);
assert_se(r >= 0);
+ assert_se((sfd = memfd_new_and_map(NULL, 6, (void**) &p)) >= 0);
+ memcpy(p, "abcd\0", 6);
+ munmap(p, 6);
+ assert_se(sd_bus_message_append_string_memfd(m, sfd, 1, 4) >= 0);
+
r = bus_message_seal(m, 55, 99*USEC_PER_SEC);
assert_se(r >= 0);
r = bus_message_seal(m, 55, 99*USEC_PER_SEC);
assert_se(r >= 0);
@@
-188,6
+198,10
@@
int main(int argc, char *argv[]) {
assert_se(r > 0);
assert_se(u32 == 4711);
assert_se(r > 0);
assert_se(u32 == 4711);
+ r = sd_bus_message_read(m, "s", &s);
+ assert_se(r > 0);
+ assert_se(streq_ptr(s, "bcd"));
+
sd_bus_message_unref(m);
sd_bus_unref(a);
sd_bus_message_unref(m);
sd_bus_unref(a);