tests: Convert remaining module tests to not use test-runner.c
The remaining module tests don't need to fork and talk to a test client, so just convert them to regular modules and let them handle running their tests themselves. Then drop test-runner.[ch].
This commit is contained in:
parent
cbc35ae281
commit
15be01ebe6
@ -31,10 +31,8 @@ AM_CFLAGS = $(GCC_CFLAGS)
|
||||
AM_CPPFLAGS = -I$(top_srcdir)/src -DUNIT_TEST $(COMPOSITOR_CFLAGS)
|
||||
AM_LDFLAGS = -module -avoid-version -rpath $(libdir)
|
||||
|
||||
test_runner_src = test-runner.c test-runner.h
|
||||
|
||||
surface_global_test_la_SOURCES = surface-global-test.c $(test_runner_src)
|
||||
surface_test_la_SOURCES = surface-test.c $(test_runner_src)
|
||||
surface_global_test_la_SOURCES = surface-global-test.c
|
||||
surface_test_la_SOURCES = surface-test.c
|
||||
|
||||
weston_test = weston-test.la
|
||||
weston_test_la_LIBADD = $(COMPOSITOR_LIBS) \
|
||||
|
@ -22,10 +22,12 @@
|
||||
|
||||
#include <assert.h>
|
||||
|
||||
#include "test-runner.h"
|
||||
#include "../src/compositor.h"
|
||||
|
||||
TEST(surface_to_from_global)
|
||||
static void
|
||||
surface_to_from_global(void *data)
|
||||
{
|
||||
struct weston_compositor *compositor = data;
|
||||
struct weston_surface *surface;
|
||||
float x, y;
|
||||
wl_fixed_t fx, fy;
|
||||
@ -63,3 +65,15 @@ TEST(surface_to_from_global)
|
||||
|
||||
wl_display_terminate(compositor->wl_display);
|
||||
}
|
||||
|
||||
WL_EXPORT int
|
||||
module_init(struct weston_compositor *compositor)
|
||||
{
|
||||
struct wl_event_loop *loop;
|
||||
|
||||
loop = wl_display_get_event_loop(compositor->wl_display);
|
||||
|
||||
wl_event_loop_add_idle(loop, surface_to_from_global, compositor);
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
@ -25,10 +25,11 @@
|
||||
#include <assert.h>
|
||||
|
||||
#include "../src/compositor.h"
|
||||
#include "test-runner.h"
|
||||
|
||||
TEST(surface_transform)
|
||||
static void
|
||||
surface_transform(void *data)
|
||||
{
|
||||
struct weston_compositor *compositor = data;
|
||||
struct weston_surface *surface;
|
||||
float x, y;
|
||||
|
||||
@ -47,3 +48,15 @@ TEST(surface_transform)
|
||||
|
||||
wl_display_terminate(compositor->wl_display);
|
||||
}
|
||||
|
||||
WL_EXPORT int
|
||||
module_init(struct weston_compositor *compositor)
|
||||
{
|
||||
struct wl_event_loop *loop;
|
||||
|
||||
loop = wl_display_get_event_loop(compositor->wl_display);
|
||||
|
||||
wl_event_loop_add_idle(loop, surface_transform, compositor);
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
@ -1,150 +0,0 @@
|
||||
/*
|
||||
* Copyright © 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.
|
||||
*/
|
||||
|
||||
#define _GNU_SOURCE
|
||||
|
||||
#include <unistd.h>
|
||||
#include <stdio.h>
|
||||
#include <stdlib.h>
|
||||
#include <stdarg.h>
|
||||
#include <sys/types.h>
|
||||
#include <sys/wait.h>
|
||||
#include <string.h>
|
||||
#include <assert.h>
|
||||
#include <sys/socket.h>
|
||||
|
||||
#include "test-runner.h"
|
||||
|
||||
static void
|
||||
test_client_cleanup(struct weston_process *proc, int status)
|
||||
{
|
||||
struct test_client *client =
|
||||
container_of(proc, struct test_client, proc);
|
||||
|
||||
fprintf(stderr, "server: test client exited, status %d\n", status);
|
||||
|
||||
client->status = status;
|
||||
client->done = 1;
|
||||
|
||||
assert(client->status == 0);
|
||||
|
||||
if (client->terminate)
|
||||
wl_display_terminate(client->compositor->wl_display);
|
||||
}
|
||||
|
||||
static int
|
||||
test_client_data(int fd, uint32_t mask, void *data)
|
||||
{
|
||||
struct test_client *client = data;
|
||||
struct wl_event_loop *loop;
|
||||
int len;
|
||||
|
||||
len = read(client->fd, client->buf, sizeof client->buf);
|
||||
assert(len >= 0);
|
||||
fprintf(stderr, "server: got %.*s from client\n", len - 1, client->buf);
|
||||
assert(client->buf[len - 1] == '\n');
|
||||
client->buf[len - 1] = '\0';
|
||||
|
||||
loop = wl_display_get_event_loop(client->compositor->wl_display);
|
||||
wl_event_loop_add_idle(loop, (void *) client->handle, client);
|
||||
|
||||
return 1;
|
||||
}
|
||||
|
||||
struct test_client *
|
||||
test_client_launch(struct weston_compositor *compositor, const char *file_name)
|
||||
{
|
||||
struct test_client *client;
|
||||
struct wl_event_loop *loop;
|
||||
int ret, sv[2], client_fd;
|
||||
char buf[256];
|
||||
|
||||
client = malloc(sizeof *client);
|
||||
assert(client);
|
||||
ret = socketpair(AF_UNIX, SOCK_STREAM | SOCK_CLOEXEC, 0, sv);
|
||||
assert(ret == 0);
|
||||
|
||||
client_fd = dup(sv[0]);
|
||||
assert(client_fd >= 0);
|
||||
snprintf(buf, sizeof buf, "%d", client_fd);
|
||||
setenv("TEST_SOCKET", buf, 1);
|
||||
snprintf(buf, sizeof buf, "%s/%s", getenv("abs_builddir"), file_name);
|
||||
fprintf(stderr, "server: launching %s\n", buf);
|
||||
|
||||
client->terminate = 0;
|
||||
client->compositor = compositor;
|
||||
client->client = weston_client_launch(compositor,
|
||||
&client->proc, buf,
|
||||
test_client_cleanup);
|
||||
assert(client->client);
|
||||
close(sv[0]);
|
||||
client->fd = sv[1];
|
||||
|
||||
loop = wl_display_get_event_loop(compositor->wl_display);
|
||||
wl_event_loop_add_fd(loop, client->fd, WL_EVENT_READABLE,
|
||||
test_client_data, client);
|
||||
|
||||
return client;
|
||||
}
|
||||
|
||||
void
|
||||
test_client_send(struct test_client *client, const char *fmt, ...)
|
||||
{
|
||||
char buf[256];
|
||||
va_list ap;
|
||||
int len;
|
||||
|
||||
va_start(ap, fmt);
|
||||
len = vsnprintf(buf, sizeof buf, fmt, ap);
|
||||
va_end(ap);
|
||||
|
||||
fprintf(stderr, "server: sending %s", buf);
|
||||
|
||||
assert(write(client->fd, buf, len) == len);
|
||||
}
|
||||
|
||||
extern const struct test __start_test_section, __stop_test_section;
|
||||
|
||||
static void
|
||||
run_test(void *data)
|
||||
{
|
||||
struct weston_compositor *compositor = data;
|
||||
const struct test *t;
|
||||
|
||||
for (t = &__start_test_section; t < &__stop_test_section; t++)
|
||||
t->run(compositor);
|
||||
}
|
||||
|
||||
int
|
||||
module_init(struct weston_compositor *compositor);
|
||||
|
||||
WL_EXPORT int
|
||||
module_init(struct weston_compositor *compositor)
|
||||
{
|
||||
struct wl_event_loop *loop;
|
||||
|
||||
loop = wl_display_get_event_loop(compositor->wl_display);
|
||||
|
||||
wl_event_loop_add_idle(loop, run_test, compositor);
|
||||
|
||||
return 0;
|
||||
}
|
@ -1,42 +0,0 @@
|
||||
#ifndef _TEST_RUNNER_H_
|
||||
#define _TEST_RUNNER_H_
|
||||
|
||||
#ifdef NDEBUG
|
||||
#error "Tests must not be built with NDEBUG defined, they rely on assert()."
|
||||
#endif
|
||||
|
||||
#include "../src/compositor.h"
|
||||
|
||||
struct test {
|
||||
const char *name;
|
||||
void (*run)(struct weston_compositor *compositor);
|
||||
} __attribute__ ((aligned (16)));
|
||||
|
||||
#define TEST(name) \
|
||||
static void name(struct weston_compositor *compositor); \
|
||||
\
|
||||
const struct test test##name \
|
||||
__attribute__ ((section ("test_section"))) = { \
|
||||
#name, name \
|
||||
}; \
|
||||
\
|
||||
static void name(struct weston_compositor *compositor)
|
||||
|
||||
struct test_client {
|
||||
struct weston_compositor *compositor;
|
||||
struct wl_client *client;
|
||||
struct weston_process proc;
|
||||
int fd;
|
||||
int done;
|
||||
int status;
|
||||
int terminate;
|
||||
|
||||
char buf[256];
|
||||
void (*handle)(struct test_client *client);
|
||||
void *data;
|
||||
};
|
||||
|
||||
struct test_client *test_client_launch(struct weston_compositor *compositor, const char *file_name);
|
||||
void test_client_send(struct test_client *client, const char *fmt, ...);
|
||||
|
||||
#endif
|
Loading…
x
Reference in New Issue
Block a user