summaryrefslogtreecommitdiff
path: root/tests/test-sigpipe.sh
diff options
context:
space:
mode:
authorLorry Tar Creator <lorry-tar-importer@baserock.org>2013-09-22 07:04:10 +0000
committer <>2015-02-02 12:02:31 +0000
commit23c11479b3ad787adc7a651ee0c4347839e47723 (patch)
tree3aa9e1125da84f7e3bd764bbff577c42a766508b /tests/test-sigpipe.sh
downloadm4-tarball-23c11479b3ad787adc7a651ee0c4347839e47723.tar.gz
Imported from /home/lorry/working-area/delta_m4-tarball/m4-1.4.17.tar.xz.HEADm4-1.4.17master
Diffstat (limited to 'tests/test-sigpipe.sh')
-rwxr-xr-xtests/test-sigpipe.sh31
1 files changed, 31 insertions, 0 deletions
diff --git a/tests/test-sigpipe.sh b/tests/test-sigpipe.sh
new file mode 100755
index 0000000..bc2baf2
--- /dev/null
+++ b/tests/test-sigpipe.sh
@@ -0,0 +1,31 @@
+#!/bin/sh
+
+tmpfiles=""
+trap 'rm -fr $tmpfiles' 1 2 3 15
+
+# Test signal's default behaviour.
+tmpfiles="$tmpfiles t-sigpipeA.tmp"
+./test-sigpipe${EXEEXT} A 2> t-sigpipeA.tmp | head -1 > /dev/null
+if test -s t-sigpipeA.tmp; then
+ LC_ALL=C tr -d '\r' < t-sigpipeA.tmp
+ rm -fr $tmpfiles; exit 1
+fi
+
+# Test signal's ignored behaviour.
+tmpfiles="$tmpfiles t-sigpipeB.tmp"
+./test-sigpipe${EXEEXT} B 2> t-sigpipeB.tmp | head -1 > /dev/null
+if test -s t-sigpipeB.tmp; then
+ LC_ALL=C tr -d '\r' < t-sigpipeB.tmp
+ rm -fr $tmpfiles; exit 1
+fi
+
+# Test signal's behaviour when a handler is installed.
+tmpfiles="$tmpfiles t-sigpipeC.tmp"
+./test-sigpipe${EXEEXT} B 2> t-sigpipeC.tmp | head -1 > /dev/null
+if test -s t-sigpipeC.tmp; then
+ LC_ALL=C tr -d '\r' < t-sigpipeC.tmp
+ rm -fr $tmpfiles; exit 1
+fi
+
+rm -fr $tmpfiles
+exit 0