![Topi Miettinen](/assets/img/avatar_default.png)
Don't assume that 4MB can be allocated from stack since there could be smaller DefaultLimitSTACK= in force, so let's use malloc(). NUL terminate the huge strings by hand, also ensure termination in test_lz4_decompress_partial() and optimize the memset() for the string. Some items in /proc and /etc may not be accessible to poor unprivileged users due to e.g. SELinux, BOFH or both, so check for EACCES and EPERM. /var/tmp may be a symlink to /tmp and then path_compare() will always fail, so let's stick to /tmp like elsewhere. /tmp may be mounted with noexec option and then trying to execute scripts from there would fail. Detect and warn if seccomp is already in use, which could make seccomp test fail if the syscalls are already blocked. Unset $TMPDIR so it will not break specifier tests where %T is assumed to be /tmp and %V /var/tmp.
90 lines
3.1 KiB
C
90 lines
3.1 KiB
C
/* SPDX-License-Identifier: LGPL-2.1+ */
|
|
|
|
#include <errno.h>
|
|
#include <stdlib.h>
|
|
#include <unistd.h>
|
|
|
|
#include "sd-journal.h"
|
|
|
|
#include "macro.h"
|
|
#include "memory-util.h"
|
|
|
|
int main(int argc, char *argv[]) {
|
|
_cleanup_free_ char *huge = NULL;
|
|
|
|
#define HUGE_SIZE (4096*1024)
|
|
assert_se(huge = malloc(HUGE_SIZE));
|
|
|
|
/* 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);
|
|
|
|
memcpy(huge, "HUGE=", STRLEN("HUGE="));
|
|
memset(&huge[STRLEN("HUGE=")], 'x', HUGE_SIZE - STRLEN("HUGE=") - 1);
|
|
huge[HUGE_SIZE - 1] = '\0';
|
|
|
|
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;
|
|
}
|