diff options
author | Luca Boccassi <bluca@debian.org> | 2023-07-25 13:16:05 +0200 |
---|---|---|
committer | Luca Boccassi <bluca@debian.org> | 2023-07-28 17:43:13 +0200 |
commit | 791a84ad51c0e41a6498ea5b9a1e4d0777f8c955 (patch) | |
tree | 436fbf1bf28279122edbef4bf7a27d22357264ca /src/test/test-execute.c | |
parent | Merge pull request #28551 from mrc0mmand/unit-cleanup-set (diff) | |
download | systemd-791a84ad51c0e41a6498ea5b9a1e4d0777f8c955.tar.xz systemd-791a84ad51c0e41a6498ea5b9a1e4d0777f8c955.zip |
test-execute: measure and log time elapsed while running tests
In order to get a good approximation of latencies when starting
services, timestamp before/after running the test cases and print
the difference. This allows to measure while ignoring the setup/shutdown
time for the test harness.
Diffstat (limited to 'src/test/test-execute.c')
-rw-r--r-- | src/test/test-execute.c | 12 |
1 files changed, 12 insertions, 0 deletions
diff --git a/src/test/test-execute.c b/src/test/test-execute.c index 4d2eefc1b3..b7ae9a7870 100644 --- a/src/test/test-execute.c +++ b/src/test/test-execute.c @@ -1176,6 +1176,7 @@ static void run_tests(RuntimeScope scope, char **patterns) { _cleanup_(rm_rf_physical_and_freep) char *runtime_dir = NULL; _cleanup_free_ char *unit_paths = NULL; _cleanup_(manager_freep) Manager *m = NULL; + usec_t start, finish; int r; static const test_entry tests[] = { @@ -1264,11 +1265,22 @@ static void run_tests(RuntimeScope scope, char **patterns) { //manager_override_log_target(m, LOG_TARGET_AUTO); //manager_override_log_level(m, LOG_DEBUG); + /* Measure and print the time that it takes to run tests, excluding startup of the manager object, + * to try and measure latency of spawning services */ + start = now(CLOCK_MONOTONIC); + for (const test_entry *test = tests; test->f; test++) if (strv_fnmatch_or_empty(patterns, test->name, FNM_NOESCAPE)) test->f(m); else log_info("Skipping %s because it does not match any pattern.", test->name); + + finish = now(CLOCK_MONOTONIC); + + log_info("%s manager + unshare=%s test runtime: %s", + scope == RUNTIME_SCOPE_SYSTEM ? "system" : "user", + yes_no(can_unshare), + FORMAT_TIMESPAN(finish - start, USEC_PER_MSEC)); } static int prepare_ns(const char *process_name) { |