[PATCH weston 7/9] tests: Convert keyboard-test to new test interface
U. Artie Eoff
ullysses.a.eoff at intel.com
Tue Dec 4 14:22:13 PST 2012
From: "U. Artie Eoff" <ullysses.a.eoff at intel.com>
Signed-off-by: U. Artie Eoff <ullysses.a.eoff at intel.com>
---
tests/.gitignore | 1 +
tests/Makefile.am | 31 +++++++++--
tests/keyboard-test.c | 139 +++++++++++++++-----------------------------------
3 files changed, 68 insertions(+), 103 deletions(-)
diff --git a/tests/.gitignore b/tests/.gitignore
index 26bf83d..ffc8b9d 100644
--- a/tests/.gitignore
+++ b/tests/.gitignore
@@ -5,3 +5,4 @@ test-text-client
wayland-test-client-protocol.h
wayland-test-protocol.c
wayland-test-server-protocol.h
+keyboard-test
diff --git a/tests/Makefile.am b/tests/Makefile.am
index 3cceef2..5f5dcf5 100644
--- a/tests/Makefile.am
+++ b/tests/Makefile.am
@@ -1,7 +1,12 @@
-TESTS = surface-test.la client-test.la \
+TESTS = $(module_tests) $(weston_tests)
+
+module_tests = surface-test.la client-test.la \
event-test.la text-test.la \
surface-global-test.la \
- button-test.la keyboard-test.la
+ button-test.la
+
+weston_tests = \
+ keyboard-test
TESTS_ENVIRONMENT = $(PYTHON) $(top_srcdir)/tests/weston-tests-env
@@ -15,11 +20,12 @@ noinst_PROGRAMS = \
matrix-test
check_LTLIBRARIES = \
- $(TESTS)
+ $(module_tests)
check_PROGRAMS = \
test-client \
- test-text-client
+ test-text-client \
+ $(weston_tests)
AM_CFLAGS = $(GCC_CFLAGS)
AM_CPPFLAGS = -I$(top_srcdir)/src -DUNIT_TEST $(COMPOSITOR_CFLAGS)
@@ -33,7 +39,6 @@ client_test_la_SOURCES = client-test.c $(test_runner_src)
event_test_la_SOURCES = event-test.c $(test_runner_src)
text_test_la_SOURCES = text-test.c $(test_runner_src)
button_test_la_SOURCES = button-test.c $(test_runner_src)
-keyboard_test_la_SOURCES = keyboard-test.c $(test_runner_src)
test_client_SOURCES = test-client.c
test_client_LDADD = $(SIMPLE_CLIENT_LIBS)
@@ -50,6 +55,22 @@ weston_test_la_SOURCES = \
wayland-test-protocol.c \
wayland-test-server-protocol.h
+weston_test_runner_src = \
+ weston-test-runner.c \
+ weston-test-runner.h
+weston_test_client_src = \
+ weston-test-client-helper.c \
+ weston-test-client-helper.h \
+ wayland-test-protocol.c \
+ wayland-test-client-protocol.h \
+ $(weston_test_runner_src)
+weston_test_client_libs = \
+ $(SIMPLE_CLIENT_LIBS) \
+ ../shared/libshared.la
+
+keyboard_test_SOURCES = keyboard-test.c $(weston_test_client_src)
+keyboard_test_LDADD = $(weston_test_client_libs)
+
matrix_test_SOURCES = \
matrix-test.c \
$(top_srcdir)/src/matrix.c \
diff --git a/tests/keyboard-test.c b/tests/keyboard-test.c
index ef450b5..353dde2 100644
--- a/tests/keyboard-test.c
+++ b/tests/keyboard-test.c
@@ -20,105 +20,48 @@
* CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
*/
-#include <stdlib.h>
-#include <stdio.h>
-#include <sys/socket.h>
-#include <assert.h>
-#include <unistd.h>
-#include <string.h>
+#include "weston-test-client-helper.h"
-#include "test-runner.h"
-
-struct context {
- struct weston_seat *seat;
- struct weston_surface *surface;
- uint32_t expect_key;
- uint32_t expect_key_state;
- int expect_focus;
-};
-
-static void
-handle_keyboard_state(struct test_client *client)
+TEST(simple_keyboard_test)
{
- struct context *context = client->data;
- uint32_t key, key_state;
- int focus;
-
- assert(sscanf(client->buf, "%u %u %d", &key, &key_state, &focus));
-
- assert(key == context->expect_key);
- assert(key_state == context->expect_key_state);
- assert(focus == context->expect_focus);
-
- if (key_state == WL_KEYBOARD_KEY_STATE_PRESSED) {
- context->expect_key_state = WL_KEYBOARD_KEY_STATE_RELEASED;
- notify_key(context->seat, 100, context->expect_key,
- context->expect_key_state,
- STATE_UPDATE_AUTOMATIC);
- } else if (focus) {
- context->expect_focus = 0;
- notify_keyboard_focus_out(context->seat);
- } else if (context->expect_key < 10) {
- context->expect_key++;
- context->expect_focus = 1;
- context->expect_key_state = WL_KEYBOARD_KEY_STATE_PRESSED;
- notify_keyboard_focus_in(context->seat,
- &context->seat->keyboard.keys,
- STATE_UPDATE_AUTOMATIC);
- notify_key(context->seat, 100, context->expect_key,
- context->expect_key_state,
- STATE_UPDATE_AUTOMATIC);
- } else {
- test_client_send(client, "bye\n");
- return;
+ struct client *client;
+ struct surface *expect_focus = NULL;
+ struct keyboard *keyboard;
+ uint32_t expect_key = 0;
+ uint32_t expect_state = 0;
+
+ client = client_create(10, 10, 1, 1);
+ assert(client);
+
+ keyboard = client->input->keyboard;
+
+ while(1) {
+ assert(keyboard->key == expect_key);
+ assert(keyboard->state == expect_state);
+ assert(keyboard->focus == expect_focus);
+
+ if (keyboard->state == WL_KEYBOARD_KEY_STATE_PRESSED) {
+ expect_state = WL_KEYBOARD_KEY_STATE_RELEASED;
+ wl_test_send_key(client->test->wl_test, expect_key,
+ expect_state);
+ yield(client);
+ } else if (keyboard->focus) {
+ expect_focus = NULL;
+ wl_test_activate_surface(client->test->wl_test,
+ NULL);
+ yield(client);
+ } else if (expect_key < 10) {
+ expect_key++;
+ expect_focus = client->surface;
+ expect_state = WL_KEYBOARD_KEY_STATE_PRESSED;
+ wl_test_activate_surface(client->test->wl_test,
+ expect_focus->wl_surface);
+ yield(client);
+ wl_test_send_key(client->test->wl_test, expect_key,
+ expect_state);
+ yield(client);
+ } else {
+ break;
+ }
}
-
- test_client_send(client, "send-keyboard-state\n");
-}
-
-static void
-handle_surface(struct test_client *client)
-{
- uint32_t id;
- struct context *context = client->data;
- struct wl_resource *resource;
- struct wl_list *seat_list;
-
- assert(sscanf(client->buf, "surface %u", &id) == 1);
- fprintf(stderr, "server: got surface id %u\n", id);
- resource = wl_client_get_object(client->client, id);
- assert(resource);
- assert(strcmp(resource->object.interface->name, "wl_surface") == 0);
-
- context->surface = (struct weston_surface *) resource;
- weston_surface_set_color(context->surface, 0.0, 0.0, 0.0, 1.0);
- weston_surface_configure(context->surface, 100, 100, 100, 100);
- weston_surface_update_transform(context->surface);
- weston_surface_damage(context->surface);
-
- seat_list = &client->compositor->seat_list;
- assert(wl_list_length(seat_list) == 1);
- context->seat = container_of(seat_list->next, struct weston_seat, link);
-
- context->seat->keyboard.focus = context->surface;
- notify_keyboard_focus_out(context->seat);
-
- test_client_send(client, "send-keyboard-state\n");
- client->handle = handle_keyboard_state;
-}
-
-TEST(keyboard_test)
-{
- struct context *context;
- struct test_client *client;
-
- client = test_client_launch(compositor, "test-client");
- client->terminate = 1;
-
- test_client_send(client, "create-surface\n");
- client->handle = handle_surface;
-
- context = calloc(1, sizeof *context);
- assert(context);
- client->data = context;
}
--
1.7.11.7
More information about the wayland-devel
mailing list