1
1
mirror of https://github.com/systemd/systemd-stable.git synced 2025-01-11 05:17:44 +03:00

sd-event: add a simple test for checking the timeout parameter of sd_event_wait()

Related to: #18973
This commit is contained in:
Lennart Poettering 2021-03-12 17:54:12 +01:00
parent 495787b56c
commit c14e57ba6b

View File

@ -13,6 +13,7 @@
#include "parse-util.h" #include "parse-util.h"
#include "path-util.h" #include "path-util.h"
#include "process-util.h" #include "process-util.h"
#include "random-util.h"
#include "rm-rf.h" #include "rm-rf.h"
#include "signal-util.h" #include "signal-util.h"
#include "stdio-util.h" #include "stdio-util.h"
@ -693,9 +694,30 @@ static void test_ratelimit(void) {
assert_se(count == 20); assert_se(count == 20);
} }
static void test_simple_timeout(void) {
_cleanup_(sd_event_unrefp) sd_event *e = NULL;
usec_t f, t, some_time;
some_time = random_u64_range(2 * USEC_PER_SEC);
assert_se(sd_event_default(&e) >= 0);
assert_se(sd_event_prepare(e) == 0);
f = now(CLOCK_MONOTONIC);
assert_se(sd_event_wait(e, some_time) >= 0);
t = now(CLOCK_MONOTONIC);
/* The event loop may sleep longer than the specified time (timer accuracy, scheduling latencies, …),
* but never shorter. Let's check that. */
assert_se(t >= usec_add(f, some_time));
}
int main(int argc, char *argv[]) { int main(int argc, char *argv[]) {
test_setup_logging(LOG_DEBUG); test_setup_logging(LOG_DEBUG);
test_simple_timeout();
test_basic(true); /* test with pidfd */ test_basic(true); /* test with pidfd */
test_basic(false); /* test without pidfd */ test_basic(false); /* test without pidfd */