]> git.ipfire.org Git - thirdparty/util-linux.git/commitdiff
tests: add scriptreplay test
authorSami Kerola <kerolasa@iki.fi>
Sun, 31 May 2015 21:23:14 +0000 (22:23 +0100)
committerSami Kerola <kerolasa@iki.fi>
Mon, 8 Jun 2015 20:53:37 +0000 (21:53 +0100)
Signed-off-by: Sami Kerola <kerolasa@iki.fi>
tests/commands.sh
tests/expected/script/replay [new file with mode: 0644]
tests/ts/script/replay [new file with mode: 0755]

index f865c0773731f93afa3e0e5fcb4ab6562197bc6d..b5098c875e8208c1c2daadec204152d388ba483b 100644 (file)
@@ -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 (file)
index 0000000..cefee37
--- /dev/null
@@ -0,0 +1,9 @@
+record script output with timing
+Script started, file is typescript
+hello world\r
+all done\r
+Script done, file is typescript
+replay script output
+hello world\r
+all done\r
+
diff --git a/tests/ts/script/replay b/tests/ts/script/replay
new file mode 100755 (executable)
index 0000000..06574c0
--- /dev/null
@@ -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