diff mbox

[v3,04/13] docker: Add test runner

Message ID 1457086720-30391-5-git-send-email-famz@redhat.com (mailing list archive)
State New, archived
Headers show

Commit Message

Fam Zheng March 4, 2016, 10:18 a.m. UTC
It's better to have a launcher for all tests, to make it easier to
initialize and manage the environment.

If "DEBUG=1"  a shell prompt will show up before the test runs.

Signed-off-by: Fam Zheng <famz@redhat.com>
---
 tests/docker/run | 58 ++++++++++++++++++++++++++++++++++++++++++++++++++++++++
 1 file changed, 58 insertions(+)
 create mode 100755 tests/docker/run

Comments

Alex Bennée March 11, 2016, 4:05 p.m. UTC | #1
Fam Zheng <famz@redhat.com> writes:

> It's better to have a launcher for all tests, to make it easier to
> initialize and manage the environment.
>
> If "DEBUG=1"  a shell prompt will show up before the test runs.
>
> Signed-off-by: Fam Zheng <famz@redhat.com>

Reviewed-by: Alex Bennée <alex.bennee@linaro.org>

> ---
>  tests/docker/run | 58 ++++++++++++++++++++++++++++++++++++++++++++++++++++++++
>  1 file changed, 58 insertions(+)
>  create mode 100755 tests/docker/run
>
> diff --git a/tests/docker/run b/tests/docker/run
> new file mode 100755
> index 0000000..ec3d119
> --- /dev/null
> +++ b/tests/docker/run
> @@ -0,0 +1,58 @@
> +#!/bin/bash -e
> +#
> +# Docker test runner
> +#
> +# Copyright (c) 2016 Red Hat Inc.
> +#
> +# Authors:
> +#  Fam Zheng <famz@redhat.com>
> +#
> +# This work is licensed under the terms of the GNU GPL, version 2
> +# or (at your option) any later version. See the COPYING file in
> +# the top-level directory.
> +
> +# Prepare the environment
> +. /etc/profile || true
> +export PATH=/usr/lib/ccache:$PATH
> +
> +if test -n "$J"; then
> +    export MAKEFLAGS="$MAKEFLAGS -j$J"
> +fi
> +
> +# We are in the container so the whole file system belong to us
> +export TEST_DIR=/tmp/qemu-test
> +mkdir -p $TEST_DIR/{src,build,install}
> +
> +# Extract the source tarballs
> +tar -C $TEST_DIR/src -xzf qemu.tgz
> +for p in dtc pixman; do
> +    if test -f $p.tgz; then
> +        tar -C $TEST_DIR/src/$p -xzf $p.tgz
> +        export FEATURES="$FEATURES $p"
> +    fi
> +done
> +
> +export QEMU_SRC="$TEST_DIR/src"
> +
> +cd "$QEMU_SRC/tests/docker"
> +
> +CMD="$QEMU_SRC/tests/docker/$@"
> +
> +if test -n "$DEBUG"; then
> +    echo "* Prepared to run command:"
> +    echo "  $CMD"
> +    echo "* Hit Ctrl-D to continue, or type 'exit 1' to abort"
> +    echo
> +    $SHELL
> +fi
> +
> +if "$CMD"; then
> +    exit 0
> +elif test -n "$DEBUG"; then
> +    echo "* Command failed:"
> +    echo "  $CMD"
> +    echo "* Hit Ctrl-D to exit"
> +    echo
> +    # Force error after shell exits
> +    $SHELL && exit 1
> +fi


--
Alex Bennée
diff mbox

Patch

diff --git a/tests/docker/run b/tests/docker/run
new file mode 100755
index 0000000..ec3d119
--- /dev/null
+++ b/tests/docker/run
@@ -0,0 +1,58 @@ 
+#!/bin/bash -e
+#
+# Docker test runner
+#
+# Copyright (c) 2016 Red Hat Inc.
+#
+# Authors:
+#  Fam Zheng <famz@redhat.com>
+#
+# This work is licensed under the terms of the GNU GPL, version 2
+# or (at your option) any later version. See the COPYING file in
+# the top-level directory.
+
+# Prepare the environment
+. /etc/profile || true
+export PATH=/usr/lib/ccache:$PATH
+
+if test -n "$J"; then
+    export MAKEFLAGS="$MAKEFLAGS -j$J"
+fi
+
+# We are in the container so the whole file system belong to us
+export TEST_DIR=/tmp/qemu-test
+mkdir -p $TEST_DIR/{src,build,install}
+
+# Extract the source tarballs
+tar -C $TEST_DIR/src -xzf qemu.tgz
+for p in dtc pixman; do
+    if test -f $p.tgz; then
+        tar -C $TEST_DIR/src/$p -xzf $p.tgz
+        export FEATURES="$FEATURES $p"
+    fi
+done
+
+export QEMU_SRC="$TEST_DIR/src"
+
+cd "$QEMU_SRC/tests/docker"
+
+CMD="$QEMU_SRC/tests/docker/$@"
+
+if test -n "$DEBUG"; then
+    echo "* Prepared to run command:"
+    echo "  $CMD"
+    echo "* Hit Ctrl-D to continue, or type 'exit 1' to abort"
+    echo
+    $SHELL
+fi
+
+if "$CMD"; then
+    exit 0
+elif test -n "$DEBUG"; then
+    echo "* Command failed:"
+    echo "  $CMD"
+    echo "* Hit Ctrl-D to exit"
+    echo
+    # Force error after shell exits
+    $SHELL && exit 1
+fi