]> git.ipfire.org Git - thirdparty/systemd.git/blob - src/journal/test-journal-init.c
a6e7a82982747b091f45d68b8256bc69827b998f
[thirdparty/systemd.git] / src / journal / test-journal-init.c
1 /* SPDX-License-Identifier: LGPL-2.1+ */
2 /***
3 Copyright 2013 Zbigniew Jędrzejewski-Szmek
4 ***/
5
6 #include "sd-journal.h"
7
8 #include "log.h"
9 #include "parse-util.h"
10 #include "rm-rf.h"
11 #include "util.h"
12
13 int main(int argc, char *argv[]) {
14 sd_journal *j;
15 int r, i, I = 100;
16 char t[] = "/tmp/journal-stream-XXXXXX";
17
18 log_set_max_level(LOG_DEBUG);
19
20 if (argc >= 2) {
21 r = safe_atoi(argv[1], &I);
22 if (r < 0)
23 log_info("Could not parse loop count argument. Using default.");
24 }
25
26 log_info("Running %d loops", I);
27
28 assert_se(mkdtemp(t));
29
30 for (i = 0; i < I; i++) {
31 r = sd_journal_open(&j, SD_JOURNAL_LOCAL_ONLY);
32 assert_se(r == 0);
33
34 sd_journal_close(j);
35
36 r = sd_journal_open_directory(&j, t, 0);
37 assert_se(r == 0);
38
39 sd_journal_close(j);
40
41 j = NULL;
42 r = sd_journal_open_directory(&j, t, SD_JOURNAL_LOCAL_ONLY);
43 assert_se(r == -EINVAL);
44 assert_se(j == NULL);
45 }
46
47 assert_se(rm_rf(t, REMOVE_ROOT|REMOVE_PHYSICAL) >= 0);
48
49 return 0;
50 }