summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorSami Kerola2015-05-31 23:23:14 +0200
committerSami Kerola2015-06-08 22:53:37 +0200
commit8090b31e5ae03ab59101c102404f7a048b9610bc (patch)
tree0f33be51beca0dc5b2c12a955d3e9c0d3a45fb78
parentscript: move timing file opening close to use of it (diff)
downloadkernel-qcow2-util-linux-8090b31e5ae03ab59101c102404f7a048b9610bc.tar.gz
kernel-qcow2-util-linux-8090b31e5ae03ab59101c102404f7a048b9610bc.tar.xz
kernel-qcow2-util-linux-8090b31e5ae03ab59101c102404f7a048b9610bc.zip
tests: add scriptreplay test
Signed-off-by: Sami Kerola <kerolasa@iki.fi>
-rw-r--r--tests/commands.sh1
-rw-r--r--tests/expected/script/replay9
-rwxr-xr-xtests/ts/script/replay38
3 files changed, 48 insertions, 0 deletions
diff --git a/tests/commands.sh b/tests/commands.sh
index f865c0773..b5098c875 100644
--- a/tests/commands.sh
+++ b/tests/commands.sh
@@ -72,6 +72,7 @@ TS_CMD_PARTX=${TS_CMD_PARTX-"$top_builddir/partx"}
TS_CMD_RENAME=${TS_CMD_RENAME-"$top_builddir/rename"}
TS_CMD_REV=${TS_CMD_REV:-"$top_builddir/rev"}
TS_CMD_SCRIPT=${TS_CMD_SCRIPT-"$top_builddir/script"}
+TS_CMD_SCRIPTREPLAY=${TS_CMD_SCRIPTREPLAY-"$top_builddir/scriptreplay"}
TS_CMD_SETARCH=${TS_CMD_SETARCH-"$top_builddir/setarch"}
TS_CMD_SETSID=${TS_CMD_SETSID-"$top_builddir/setsid"}
TS_CMD_SWAPLABEL=${TS_CMD_SWAPLABEL:-"$top_builddir/swaplabel"}
diff --git a/tests/expected/script/replay b/tests/expected/script/replay
new file mode 100644
index 000000000..cefee3732
--- /dev/null
+++ b/tests/expected/script/replay
@@ -0,0 +1,9 @@
+record script output with timing
+Script started, file is typescript
+hello world
+all done
+Script done, file is typescript
+replay script output
+hello world
+all done
+
diff --git a/tests/ts/script/replay b/tests/ts/script/replay
new file mode 100755
index 000000000..06574c050
--- /dev/null
+++ b/tests/ts/script/replay
@@ -0,0 +1,38 @@
+#!/bin/bash
+
+# This file is part of util-linux.
+#
+# This file is free software; you can redistribute it and/or modify
+# it under the terms of the GNU General Public License as published by
+# the Free Software Foundation; either version 2 of the License, or
+# (at your option) any later version.
+#
+# This file 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 General Public License for more details.
+
+TS_TOPDIR="${0%/*}/../.."
+TS_DESC="replay"
+
+. "$TS_TOPDIR/functions.sh"
+ts_init "$*"
+
+ts_check_test_command "$TS_CMD_SCRIPT"
+ts_check_test_command "$TS_CMD_SCRIPTREPLAY"
+
+SCRIPT_FILE="$(mktemp "${TS_OUTDIR}/scXXXXXXXXXXXXX")"
+TIMING_FILE="$(mktemp "${TS_OUTDIR}/tmXXXXXXXXXXXXX")"
+
+echo "record script output with timing" >"$TS_OUTPUT"
+"$TS_CMD_SCRIPT" -c "echo hello world; sleep 0.5; echo all done" \
+ --timing="$TIMING_FILE" "$SCRIPT_FILE" >>"$TS_OUTPUT" 2>&1
+
+echo "replay script output" >>"$TS_OUTPUT"
+"$TS_CMD_SCRIPTREPLAY" "$TIMING_FILE" "$SCRIPT_FILE" 1.5 >>"$TS_OUTPUT" 2>&1
+
+sed -i "s|$SCRIPT_FILE|typescript|g; s|$TIMING_FILE|timingfile|g" "$TS_OUTPUT"
+
+rm -f "$SCRIPT_FILE" "$TIMING_FILE"
+
+ts_finalize