On Tue, Dec 04, 2012 at 02:22:12PM -0800, U. Artie Eoff wrote:
> From: "U. Artie Eoff" <[email protected]>
> 
> The weston-tests-env script needs to be able to handle weston
> test extension style tests as well as module style tests.

This series look good, but I don't like the python dependency or the
"give weston a moment to start" workaround here.

How about we just make the weston test module launch its test client?
Something like this:

diff --git a/tests/weston-test.c b/tests/weston-test.c
index 066650d..c957643 100644
--- a/tests/weston-test.c
+++ b/tests/weston-test.c
@@ -23,12 +23,15 @@
 #include <stdlib.h>
 #include <string.h>
 #include <assert.h>
+#include <signal.h>
+#include <unistd.h>
 #include "../src/compositor.h"
 #include "wayland-test-server-protocol.h"
 
 struct weston_test {
        struct weston_compositor *compositor;
        struct weston_layer layer;
+       struct weston_process process;
 };
 
 struct weston_test_surface {
@@ -182,10 +185,45 @@ bind_test(struct wl_client *client, void *data, uint32_t 
version, uint32_t id)
        notify_pointer_position(test, resource);
 }
 
+static void
+test_client_sigchld(struct weston_process *process, int status)
+{
+       struct weston_test *test =
+               container_of(process, struct weston_test, process);
+}
+
+static void
+idle_launch_client(void *data)
+{
+       struct weston_test *test = data;
+       pid_t pid;
+       sigset_t allsigs;
+       char *path;
+
+       path = getenv("TEST_CLIENT_PATH");
+       if (path == NULL)
+               exit(EXIT_FAILURE);
+       pid = fork();
+       if (pid == -1)
+               exit(EXIT_FAILURE);
+       if (pid == 0) {
+               sigfillset(&allsigs);
+               sigprocmask(SIG_UNBLOCK, &allsigs, NULL);
+               execl(path, path, NULL);
+               weston_log("compositor: executing '%s' failed: %m\n", path);
+               exit(EXIT_FAILURE);
+       }
+
+       test->process.pid = pid;
+       test->process.cleanup = test_client_sigchld;
+       weston_watch_process(&test->process);
+}
+
 WL_EXPORT int
 module_init(struct weston_compositor *ec)
 {
        struct weston_test *test;
+       struct wl_event_loop *loop;
 
        test = malloc(sizeof *test);
        if (test == NULL)
@@ -198,5 +236,9 @@ module_init(struct weston_compositor *ec)
        if (wl_display_add_global(ec->wl_display, &wl_test_interface,
                                  test, bind_test) == NULL)
                return -1;
+
+       loop = wl_display_get_event_loop(ec->wl_display);
+       wl_event_loop_add_idle(loop, idle_launch_client, test);
+
        return 0;
 }
diff --git a/tests/weston-tests-env b/tests/weston-tests-env
index 27b40de..a5099f2 100644
--- a/tests/weston-tests-env
+++ b/tests/weston-tests-env
@@ -1,4 +1,9 @@
 #!/bin/sh
 
-../src/weston --modules=$abs_builddir/.libs/${1/.la/.so}
-
+case $1_dir in
+       *.la|*.so)
+               ../src/weston --modules=$abs_builddir/.libs/${1/.la/.so}
+               ;;
+       *)
+               TEST_CLIENT_PATH=$1 ../src/weston 
--modules=$abs_builddir/.libs/weston-test.so
+esac


> Signed-off-by: U. Artie Eoff <[email protected]>
> ---
>  tests/Makefile.am      |   2 +-
>  tests/weston-tests-env | 123 
> ++++++++++++++++++++++++++++++++++++++++++++++++-
>  2 files changed, 122 insertions(+), 3 deletions(-)
>  mode change 100644 => 100755 tests/weston-tests-env
> 
> diff --git a/tests/Makefile.am b/tests/Makefile.am
> index ad27f7e..3cceef2 100644
> --- a/tests/Makefile.am
> +++ b/tests/Makefile.am
> @@ -3,7 +3,7 @@ TESTS = surface-test.la client-test.la        \
>       surface-global-test.la          \
>       button-test.la keyboard-test.la
>  
> -TESTS_ENVIRONMENT = $(SHELL) $(top_srcdir)/tests/weston-tests-env
> +TESTS_ENVIRONMENT = $(PYTHON) $(top_srcdir)/tests/weston-tests-env
>  
>  export abs_builddir
>  
> diff --git a/tests/weston-tests-env b/tests/weston-tests-env
> old mode 100644
> new mode 100755
> index 27b40de..9de90ca
> --- a/tests/weston-tests-env
> +++ b/tests/weston-tests-env
> @@ -1,4 +1,123 @@
> -#!/bin/sh
> +#!/usr/bin/env python
> +#
> +#* Copyright (c) 2012 Intel Corporation
> +#*
> +#* Permission to use, copy, modify, distribute, and sell this software and
> +#* its documentation for any purpose is hereby granted without fee, provided
> +#* that the above copyright notice appear in all copies and that both that
> +#* copyright notice and this permission notice appear in supporting
> +#* documentation, and that the name of the copyright holders not be used in
> +#* advertising or publicity pertaining to distribution of the software
> +#* without specific, written prior permission.  The copyright holders make
> +#* no representations about the suitability of this software for any
> +#* purpose.  It is provided "as is" without express or implied warranty.
> +#*
> +#* THE COPYRIGHT HOLDERS DISCLAIM ALL WARRANTIES WITH REGARD TO THIS
> +#* SOFTWARE, INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY AND
> +#* FITNESS, IN NO EVENT SHALL THE COPYRIGHT HOLDERS BE LIABLE FOR ANY
> +#* SPECIAL, INDIRECT OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER
> +#* RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF
> +#* CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF OR IN
> +#* CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
> +#
> +# Python Version 2.6 or later is required
>  
> -../src/weston --modules=$abs_builddir/.libs/${1/.la/.so}
> +import os, sys, time
> +import subprocess, signal
> +from threading import RLock, Thread
>  
> +def synchronized_write(message):
> +### Make writing to sys.stderr threadsafe
> +     synchronized_write.lock.acquire()
> +     try:
> +             sys.stderr.write(message)
> +             sys.stderr.flush()
> +     finally:
> +             synchronized_write.lock.release()
> +synchronized_write.lock = RLock()
> +
> +def endproc(proc):
> +     proc.terminate()
> +
> +     result = proc.poll()
> +     if result is None:
> +             time.sleep(1) # Give proc more time to terminate.
> +     else:
> +             return
> +
> +     result = proc.poll()
> +     if result is None:
> +             proc.kill() # Sorry proc, you're taking too long! Bye!
> +     else:
> +             return
> +
> +     result = proc.poll()
> +     if result is None:
> +             time.sleep(1) # Give system a moment to finalize kill
> +
> +def readproc(proc):
> +### Does not return until EOF is reached in proc.stdout
> +     line = proc.stdout.readline()
> +     while line:
> +             synchronized_write(line)
> +             line = proc.stdout.readline()
> +
> +def startproc(command):
> +     proc = subprocess.Popen(
> +             command,
> +             stdout  = subprocess.PIPE,
> +             stderr  = subprocess.STDOUT,
> +             bufsize = 1,
> +             shell   = True,
> +             env     = os.environ,
> +     )
> +     return proc
> +
> +def run_module_test(basepath, name):
> +     command = "%s/../src/weston --modules=%s/.libs/%s.so" \
> +             % (basepath, basepath, name)
> +     test = startproc(command)
> +     Thread(target = lambda: readproc(test)).start()
> +     test.wait()
> +     if test.returncode != 0:
> +             r = "fail"
> +     else:
> +             r = "pass"
> +
> +     synchronized_write('test "%s":\texit status %d, %s.\n' \
> +             % (os.path.basename(name), abs(test.returncode), r))
> +
> +     return test.returncode
> +
> +def run_weston_test(basepath, name):
> +     command = "%s/../src/weston --modules=%s/.libs/weston-test.so" \
> +             % (basepath, basepath)
> +     weston = startproc(command)
> +     Thread(target = lambda: readproc(weston)).start()
> +     time.sleep(1) # give weston a moment to start
> +
> +     command = "%s/%s" % (basepath, name)
> +     test = startproc(command)
> +     Thread(target = lambda: readproc(test)).start()
> +     test.wait()
> +
> +     endproc(weston)
> +
> +     if weston.returncode not in [0, signal.SIGTERM,]:
> +             return weston.returncode or -128
> +     return test.returncode
> +
> +def main():
> +     assert len(sys.argv) == 2
> +     assert "abs_builddir" in os.environ.keys()
> +
> +     abs_builddir = os.environ["abs_builddir"]
> +     name, ext = os.path.splitext(sys.argv[1])
> +
> +     if ext in ['.la', '.so',]:
> +             return run_module_test(abs_builddir, name)
> +
> +     return run_weston_test(abs_builddir, name)
> +
> +if "__main__" == __name__:
> +     sys.exit(main())
> -- 
> 1.7.11.7
> 
> _______________________________________________
> wayland-devel mailing list
> [email protected]
> http://lists.freedesktop.org/mailman/listinfo/wayland-devel
_______________________________________________
wayland-devel mailing list
[email protected]
http://lists.freedesktop.org/mailman/listinfo/wayland-devel

Reply via email to