]> git.ipfire.org Git - thirdparty/systemd.git/blame - src/journal/test-journal-send.c
Merge pull request #8417 from brauner/2018-03-09/add_bind_mount_fallback_to_private_d...
[thirdparty/systemd.git] / src / journal / test-journal-send.c
CommitLineData
53e1b683 1/* SPDX-License-Identifier: LGPL-2.1+ */
b070e7f3
LP
2/***
3 This file is part of systemd.
4
5 Copyright 2011 Lennart Poettering
b070e7f3
LP
6***/
7
d94819c8 8#include <errno.h>
7fb4d896
LP
9#include <stdlib.h>
10#include <unistd.h>
b070e7f3 11
3ffd4af2
LP
12#include "sd-journal.h"
13
d94819c8 14#include "macro.h"
cbdca852 15
b070e7f3 16int main(int argc, char *argv[]) {
1dfa7e79
LP
17 char huge[4096*1024];
18
85049096
ZJS
19 /* utf-8 and non-utf-8, message-less and message-ful iovecs */
20 struct iovec graph1[] = {
fbd0b64f 21 {(char*) "GRAPH=graph", STRLEN("GRAPH=graph")}
85049096
ZJS
22 };
23 struct iovec graph2[] = {
fbd0b64f 24 {(char*) "GRAPH=graph\n", STRLEN("GRAPH=graph\n")}
85049096
ZJS
25 };
26 struct iovec message1[] = {
fbd0b64f 27 {(char*) "MESSAGE=graph", STRLEN("MESSAGE=graph")}
85049096
ZJS
28 };
29 struct iovec message2[] = {
fbd0b64f 30 {(char*) "MESSAGE=graph\n", STRLEN("MESSAGE=graph\n")}
85049096
ZJS
31 };
32
33 assert_se(sd_journal_print(LOG_INFO, "piepapo") == 0);
34
35 assert_se(sd_journal_send("MESSAGE=foobar",
36 "VALUE=%i", 7,
37 NULL) == 0);
b070e7f3 38
18c7ed18 39 errno = ENOENT;
85049096 40 assert_se(sd_journal_perror("Foobar") == 0);
18c7ed18 41
85049096 42 assert_se(sd_journal_perror("") == 0);
18c7ed18 43
1dfa7e79
LP
44 memset(huge, 'x', sizeof(huge));
45 memcpy(huge, "HUGE=", 5);
46 char_array_0(huge);
47
85049096
ZJS
48 assert_se(sd_journal_send("MESSAGE=Huge field attached",
49 huge,
50 NULL) == 0);
1dfa7e79 51
85049096
ZJS
52 assert_se(sd_journal_send("MESSAGE=uiui",
53 "VALUE=A",
54 "VALUE=B",
55 "VALUE=C",
56 "SINGLETON=1",
57 "OTHERVALUE=X",
58 "OTHERVALUE=Y",
59 "WITH_BINARY=this is a binary value \a",
60 NULL) == 0);
d99ae53a 61
7fb4d896
LP
62 syslog(LOG_NOTICE, "Hello World!");
63
85049096
ZJS
64 assert_se(sd_journal_print(LOG_NOTICE, "Hello World") == 0);
65
66 assert_se(sd_journal_send("MESSAGE=Hello World!",
67 "MESSAGE_ID=52fb62f99e2c49d89cfbf9d6de5e3555",
68 "PRIORITY=5",
69 "HOME=%s", getenv("HOME"),
70 "TERM=%s", getenv("TERM"),
71 "PAGE_SIZE=%li", sysconf(_SC_PAGESIZE),
72 "N_CPUS=%li", sysconf(_SC_NPROCESSORS_ONLN),
73 NULL) == 0);
74
75 assert_se(sd_journal_sendv(graph1, 1) == 0);
76 assert_se(sd_journal_sendv(graph2, 1) == 0);
77 assert_se(sd_journal_sendv(message1, 1) == 0);
78 assert_se(sd_journal_sendv(message2, 1) == 0);
79
80 /* test without location fields */
81#undef sd_journal_sendv
82 assert_se(sd_journal_sendv(graph1, 1) == 0);
83 assert_se(sd_journal_sendv(graph2, 1) == 0);
84 assert_se(sd_journal_sendv(message1, 1) == 0);
85 assert_se(sd_journal_sendv(message2, 1) == 0);
7fb4d896 86
037ee337 87 sleep(1);
7fb4d896 88
b070e7f3
LP
89 return 0;
90}