| /* SPDX-License-Identifier: LGPL-2.1+ */ |
| /*** |
| This file is part of systemd. |
| |
| Copyright 2011 Lennart Poettering |
| |
| systemd is free software; you can redistribute it and/or modify it |
| under the terms of the GNU Lesser General Public License as published by |
| the Free Software Foundation; either version 2.1 of the License, or |
| (at your option) any later version. |
| |
| systemd is distributed in the hope that it will be useful, but |
| WITHOUT ANY WARRANTY; without even the implied warranty of |
| MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU |
| Lesser General Public License for more details. |
| |
| You should have received a copy of the GNU Lesser General Public License |
| along with systemd; If not, see <http://www.gnu.org/licenses/>. |
| ***/ |
| |
| #include <errno.h> |
| #include <stdlib.h> |
| #include <unistd.h> |
| |
| #include "sd-journal.h" |
| |
| #include "macro.h" |
| |
| int main(int argc, char *argv[]) { |
| char huge[4096*1024]; |
| |
| /* utf-8 and non-utf-8, message-less and message-ful iovecs */ |
| struct iovec graph1[] = { |
| {(char*) "GRAPH=graph", STRLEN("GRAPH=graph")} |
| }; |
| struct iovec graph2[] = { |
| {(char*) "GRAPH=graph\n", STRLEN("GRAPH=graph\n")} |
| }; |
| struct iovec message1[] = { |
| {(char*) "MESSAGE=graph", STRLEN("MESSAGE=graph")} |
| }; |
| struct iovec message2[] = { |
| {(char*) "MESSAGE=graph\n", STRLEN("MESSAGE=graph\n")} |
| }; |
| |
| assert_se(sd_journal_print(LOG_INFO, "piepapo") == 0); |
| |
| assert_se(sd_journal_send("MESSAGE=foobar", |
| "VALUE=%i", 7, |
| NULL) == 0); |
| |
| errno = ENOENT; |
| assert_se(sd_journal_perror("Foobar") == 0); |
| |
| assert_se(sd_journal_perror("") == 0); |
| |
| memset(huge, 'x', sizeof(huge)); |
| memcpy(huge, "HUGE=", 5); |
| char_array_0(huge); |
| |
| assert_se(sd_journal_send("MESSAGE=Huge field attached", |
| huge, |
| NULL) == 0); |
| |
| assert_se(sd_journal_send("MESSAGE=uiui", |
| "VALUE=A", |
| "VALUE=B", |
| "VALUE=C", |
| "SINGLETON=1", |
| "OTHERVALUE=X", |
| "OTHERVALUE=Y", |
| "WITH_BINARY=this is a binary value \a", |
| NULL) == 0); |
| |
| syslog(LOG_NOTICE, "Hello World!"); |
| |
| assert_se(sd_journal_print(LOG_NOTICE, "Hello World") == 0); |
| |
| assert_se(sd_journal_send("MESSAGE=Hello World!", |
| "MESSAGE_ID=52fb62f99e2c49d89cfbf9d6de5e3555", |
| "PRIORITY=5", |
| "HOME=%s", getenv("HOME"), |
| "TERM=%s", getenv("TERM"), |
| "PAGE_SIZE=%li", sysconf(_SC_PAGESIZE), |
| "N_CPUS=%li", sysconf(_SC_NPROCESSORS_ONLN), |
| NULL) == 0); |
| |
| assert_se(sd_journal_sendv(graph1, 1) == 0); |
| assert_se(sd_journal_sendv(graph2, 1) == 0); |
| assert_se(sd_journal_sendv(message1, 1) == 0); |
| assert_se(sd_journal_sendv(message2, 1) == 0); |
| |
| /* test without location fields */ |
| #undef sd_journal_sendv |
| assert_se(sd_journal_sendv(graph1, 1) == 0); |
| assert_se(sd_journal_sendv(graph2, 1) == 0); |
| assert_se(sd_journal_sendv(message1, 1) == 0); |
| assert_se(sd_journal_sendv(message2, 1) == 0); |
| |
| sleep(1); |
| |
| return 0; |
| } |