summaryrefslogtreecommitdiffstats
path: root/test/TEST-04-JOURNAL
diff options
context:
space:
mode:
authorLorenz Bauer <lmb@cloudflare.com>2019-11-04 17:35:46 +0100
committerZbigniew Jędrzejewski-Szmek <zbyszek@in.waw.pl>2019-11-05 10:41:03 +0100
commit09d0b46ab61bebafe5bdc1be95ee153dfb13d6bc (patch)
treeb288dc511429779f576be81e80929bd0a9960622 /test/TEST-04-JOURNAL
parenthwdb: add XKB_FIXED_MODEL to the keyboard hwdb (diff)
downloadsystemd-09d0b46ab61bebafe5bdc1be95ee153dfb13d6bc.tar.xz
systemd-09d0b46ab61bebafe5bdc1be95ee153dfb13d6bc.zip
journal: refresh cached credentials of stdout streams
journald assumes that getsockopt(SO_PEERCRED) correctly identifies the process on the remote end of the socket. However, this is incorrect according to man 7 socket: The returned credentials are those that were in effect at the time of the call to connect(2) or socketpair(2). This becomes a problem when a new process inherits the stdout stream from a parent. First, log messages from the child process will be attributed to the parent. Second, the struct ucred used by journald becomes invalid as soon as the parent exits. Further sendmsg calls then fail with ENOENT. Logs for the child process then vanish from the journal. Fix this by using recvmsg on the stdout stream, and refreshing the cached struct ucred if SCM_CREDENTIALS indicate a new process. Fixes #13708
Diffstat (limited to 'test/TEST-04-JOURNAL')
-rwxr-xr-xtest/TEST-04-JOURNAL/test-journal.sh16
1 files changed, 16 insertions, 0 deletions
diff --git a/test/TEST-04-JOURNAL/test-journal.sh b/test/TEST-04-JOURNAL/test-journal.sh
index 4e539aa151..de27eb0064 100755
--- a/test/TEST-04-JOURNAL/test-journal.sh
+++ b/test/TEST-04-JOURNAL/test-journal.sh
@@ -74,6 +74,22 @@ cmp /expected /output
{ journalctl -ball -b -m 2>&1 || :; } | head -1 > /output
cmp /expected /output
+# https://github.com/systemd/systemd/issues/13708
+ID=$(systemd-id128 new)
+systemd-cat -t "$ID" bash -c 'echo parent; (echo child) & wait' &
+PID=$!
+wait %%
+journalctl --sync
+# We can drop this grep when https://github.com/systemd/systemd/issues/13937
+# has a fix.
+journalctl -b -o export -t "$ID" --output-fields=_PID | grep '^_PID=' >/output
+[[ `grep -c . /output` -eq 2 ]]
+grep -q "^_PID=$PID" /output
+grep -vq "^_PID=$PID" /output
+
+# Add new tests before here, the journald restarts below
+# may make tests flappy.
+
# Don't lose streams on restart
systemctl start forever-print-hola
sleep 3