diff options
author | Lennart Poettering <lennart@poettering.net> | 2018-10-19 22:05:50 +0200 |
---|---|---|
committer | GitHub <noreply@github.com> | 2018-10-19 22:05:50 +0200 |
commit | 347a19343c7975fc4c2d627150fce4b4e75f91ac (patch) | |
tree | 663903047a523ed47529c8ee9d0ac01f2d1d79c8 | |
parent | tree-wide: some automatic coccinelle fixes (#10463) (diff) | |
parent | test: add tests for sd_device_monitor (diff) | |
download | systemd-347a19343c7975fc4c2d627150fce4b4e75f91ac.tar.xz systemd-347a19343c7975fc4c2d627150fce4b4e75f91ac.zip |
Merge pull request #10462 from yuwata/test-sd-device-monitor
Add tests for sd_device_monitor and small cleanups
-rw-r--r-- | src/libsystemd/sd-device/device-monitor.c | 4 | ||||
-rw-r--r-- | src/libsystemd/sd-device/test-sd-device-monitor.c | 131 | ||||
-rw-r--r-- | src/test/meson.build | 5 |
3 files changed, 138 insertions, 2 deletions
diff --git a/src/libsystemd/sd-device/device-monitor.c b/src/libsystemd/sd-device/device-monitor.c index 866c7a3be7..5a604fecfa 100644 --- a/src/libsystemd/sd-device/device-monitor.c +++ b/src/libsystemd/sd-device/device-monitor.c @@ -525,7 +525,7 @@ int device_monitor_send_device( return log_debug_errno(r, "Failed to get device subsystem: %m"); nlh.filter_subsystem_hash = htobe32(string_hash32(val)); - if (sd_device_get_devtype(device, &val) >= 0 && val) + if (sd_device_get_devtype(device, &val) >= 0) nlh.filter_devtype_hash = htobe32(string_hash32(val)); /* add tag bloom filter */ @@ -560,7 +560,7 @@ int device_monitor_send_device( log_debug("Passed device to netlink monitor"); return 0; } else - return log_debug_errno(errno, "Failed to send device to netlink monitor"); + return log_debug_errno(errno, "Failed to send device to netlink monitor: %m"); } log_debug("Passed %zi byte device to netlink monitor", count); diff --git a/src/libsystemd/sd-device/test-sd-device-monitor.c b/src/libsystemd/sd-device/test-sd-device-monitor.c new file mode 100644 index 0000000000..56cf1af434 --- /dev/null +++ b/src/libsystemd/sd-device/test-sd-device-monitor.c @@ -0,0 +1,131 @@ +/* SPDX-License-Identifier: LGPL-2.1+ */ + +#include <stdbool.h> +#include <unistd.h> + +#include "sd-device.h" +#include "sd-event.h" + +#include "device-monitor-private.h" +#include "device-private.h" +#include "device-util.h" +#include "macro.h" +#include "string-util.h" +#include "tests.h" +#include "util.h" +#include "virt.h" + +static int monitor_handler(sd_device_monitor *m, sd_device *d, void *userdata) { + const char *s, *syspath = userdata; + + assert_se(sd_device_get_syspath(d, &s) >= 0); + assert_se(streq(s, syspath)); + + return sd_event_exit(sd_device_monitor_get_event(m), 0); +} + +static int test_loopback(bool subsystem_filter, bool tag_filter, bool use_bpf) { + _cleanup_(sd_device_monitor_unrefp) sd_device_monitor *monitor_server = NULL, *monitor_client = NULL; + _cleanup_(sd_device_unrefp) sd_device *loopback = NULL; + const char *syspath, *subsystem, *tag; + int r; + + log_info("/* %s(subsystem_filter=%s, tag_filter=%s, use_bpf=%s) */", __func__, + true_false(subsystem_filter), true_false(tag_filter), true_false(use_bpf)); + + assert_se(sd_device_new_from_syspath(&loopback, "/sys/class/net/lo") >= 0); + assert_se(sd_device_get_syspath(loopback, &syspath) >= 0); + assert_se(device_add_property(loopback, "ACTION", "add") >= 0); + assert_se(device_add_property(loopback, "SEQNUM", "10") >= 0); + + assert_se(device_monitor_new_full(&monitor_server, MONITOR_GROUP_NONE, -1) >= 0); + assert_se(sd_device_monitor_start(monitor_server, NULL, NULL, NULL) >= 0); + + assert_se(device_monitor_new_full(&monitor_client, MONITOR_GROUP_NONE, -1) >= 0); + assert_se(device_monitor_allow_unicast_sender(monitor_client, monitor_server) >= 0); + assert_se(sd_device_monitor_start(monitor_client, monitor_handler, (void *) syspath, "loopback-monitor") >= 0); + + if (subsystem_filter) { + assert_se(sd_device_get_subsystem(loopback, &subsystem) >= 0); + assert_se(sd_device_monitor_filter_add_match_subsystem_devtype(monitor_client, subsystem, NULL) >= 0); + } + + if (tag_filter) + FOREACH_DEVICE_TAG(loopback, tag) + assert_se(sd_device_monitor_filter_add_match_tag(monitor_client, tag) >= 0); + + if ((subsystem_filter || tag_filter) && use_bpf) + assert_se(sd_device_monitor_filter_update(monitor_client) >= 0); + + r = device_monitor_send_device(monitor_server, monitor_client, loopback); + if (r < 0) + return log_error_errno(r, "Failed to send loopback device: %m"); + + assert_se(sd_event_loop(sd_device_monitor_get_event(monitor_client)) == 0); + + return 0; +} + +static void test_subsystem_filter(void) { + _cleanup_(sd_device_monitor_unrefp) sd_device_monitor *monitor_server = NULL, *monitor_client = NULL; + _cleanup_(sd_device_enumerator_unrefp) sd_device_enumerator *e = NULL; + _cleanup_(sd_device_unrefp) sd_device *loopback = NULL; + const char *syspath, *subsystem, *p, *s; + sd_device *d; + + log_info("/* %s */", __func__); + + assert_se(sd_device_new_from_syspath(&loopback, "/sys/class/net/lo") >= 0); + assert_se(sd_device_get_syspath(loopback, &syspath) >= 0); + assert_se(sd_device_get_subsystem(loopback, &subsystem) >= 0); + assert_se(device_add_property(loopback, "ACTION", "add") >= 0); + assert_se(device_add_property(loopback, "SEQNUM", "10") >= 0); + + assert_se(device_monitor_new_full(&monitor_server, MONITOR_GROUP_NONE, -1) >= 0); + assert_se(sd_device_monitor_start(monitor_server, NULL, NULL, NULL) >= 0); + + assert_se(device_monitor_new_full(&monitor_client, MONITOR_GROUP_NONE, -1) >= 0); + assert_se(device_monitor_allow_unicast_sender(monitor_client, monitor_server) >= 0); + assert_se(sd_device_monitor_filter_add_match_subsystem_devtype(monitor_client, subsystem, NULL) >= 0); + assert_se(sd_device_monitor_start(monitor_client, monitor_handler, (void *) syspath, "subsystem-filter") >= 0); + + assert_se(sd_device_enumerator_new(&e) >= 0); + assert_se(sd_device_enumerator_add_match_subsystem(e, subsystem, false) >= 0); + FOREACH_DEVICE(e, d) { + assert_se(sd_device_get_syspath(d, &p) >= 0); + assert_se(sd_device_get_subsystem(d, &s) >= 0); + + log_info("Sending device subsystem:%s syspath:%s", s, p); + assert_se(device_monitor_send_device(monitor_server, monitor_client, d) >= 0); + } + + log_info("Sending device subsystem:%s syspath:%s", subsystem, syspath); + assert_se(device_monitor_send_device(monitor_server, monitor_client, loopback) >= 0); + assert_se(sd_event_loop(sd_device_monitor_get_event(monitor_client)) == 0); +} + +int main(int argc, char *argv[]) { + int r; + + test_setup_logging(LOG_INFO); + + if (getuid() != 0) + return log_tests_skipped("not root"); + + r = test_loopback(false, false, false); + if (r < 0) { + assert_se(r == -EPERM && detect_container() > 0); + return log_tests_skipped("Running in container? Skipping remaining tests"); + } + + assert_se(test_loopback( true, false, false) >= 0); + assert_se(test_loopback(false, true, false) >= 0); + assert_se(test_loopback( true, true, false) >= 0); + assert_se(test_loopback( true, false, true) >= 0); + assert_se(test_loopback(false, true, true) >= 0); + assert_se(test_loopback( true, true, true) >= 0); + + test_subsystem_filter(); + + return 0; +} diff --git a/src/test/meson.build b/src/test/meson.build index a1770213a8..cf060c3bd1 100644 --- a/src/test/meson.build +++ b/src/test/meson.build @@ -909,6 +909,11 @@ tests += [ libshared_static, libudev], [threads]], + + [['src/libsystemd/sd-device/test-sd-device-monitor.c'], + [], + []], + ] if cxx.found() |