Blame SOURCES/0087-test-replace-echo-with-socat.patch

a3e2b5
From bf7631e7c0a7d1cac2f071ce998d5c669aa5abd7 Mon Sep 17 00:00:00 2001
a3e2b5
From: Frantisek Sumsal <frantisek@sumsal.cz>
a3e2b5
Date: Tue, 29 Jan 2019 19:33:15 +0100
a3e2b5
Subject: [PATCH] test: replace echo with socat
a3e2b5
a3e2b5
The original version of the test used netcat along with a standard
a3e2b5
AF_UNIX socket, which caused issues across different netcat
a3e2b5
implementations. The AF_UNIX socket was then replaced by a FIFO with a
a3e2b5
simple echo, which, however, suffers from the same issue (some echo
a3e2b5
implementations don't check if the write() was successful).
a3e2b5
a3e2b5
Let's revert back to the AF_UNIX socket, but replace netcat with socat,
a3e2b5
which, hopefully, resolves the main issue.
a3e2b5
a3e2b5
Relevant commit: 9b45c2bf02a43e3e1b42de1ab0c3fe29c64dc5f5
a3e2b5
a3e2b5
(cherry picked from commit b35d6d828b3216d022e565820d9971cb0f7746c1)
a3e2b5
---
a3e2b5
 test/TEST-10-ISSUE-2467/test.sh | 6 +++---
a3e2b5
 1 file changed, 3 insertions(+), 3 deletions(-)
a3e2b5
a3e2b5
diff --git a/test/TEST-10-ISSUE-2467/test.sh b/test/TEST-10-ISSUE-2467/test.sh
a3e2b5
index e61f5acd3c..0e61236686 100755
a3e2b5
--- a/test/TEST-10-ISSUE-2467/test.sh
a3e2b5
+++ b/test/TEST-10-ISSUE-2467/test.sh
a3e2b5
@@ -17,7 +17,7 @@ test_setup() {
a3e2b5
         eval $(udevadm info --export --query=env --name=${LOOPDEV}p2)
a3e2b5
 
a3e2b5
         setup_basic_environment
a3e2b5
-        dracut_install true rm
a3e2b5
+        dracut_install true rm socat
a3e2b5
 
a3e2b5
         # setup the testsuite service
a3e2b5
         cat >$initdir/etc/systemd/system/testsuite.service <<'EOF'
a3e2b5
@@ -29,13 +29,13 @@ After=multi-user.target
a3e2b5
 Type=oneshot
a3e2b5
 StandardOutput=tty
a3e2b5
 StandardError=tty
a3e2b5
-ExecStart=/bin/sh -e -x -c 'rm -f /tmp/nonexistent; systemctl start test.socket; echo > /run/test.ctl; >/testok'
a3e2b5
+ExecStart=/bin/sh -e -x -c 'rm -f /tmp/nonexistent; systemctl start test.socket; printf x > test.file; socat -t20 OPEN:test.file UNIX-CONNECT:/run/test.ctl; >/testok'
a3e2b5
 TimeoutStartSec=10s
a3e2b5
 EOF
a3e2b5
 
a3e2b5
 	cat  >$initdir/etc/systemd/system/test.socket <<'EOF'
a3e2b5
 [Socket]
a3e2b5
-ListenFIFO=/run/test.ctl
a3e2b5
+ListenStream=/run/test.ctl
a3e2b5
 EOF
a3e2b5
 
a3e2b5
 	cat > $initdir/etc/systemd/system/test.service <<'EOF'