tests: Convert keyboard-test to new test extension
This adds a weston-test-runner for the weston test extension and
some weston test client helper methods.
Converted keyboard-test to use the new test interface, runner,
and helper methods.
Fixes https://bugs.freedesktop.org/show_bug.cgi?id=56822
Signed-off-by: U. Artie Eoff <ullysses.a.eoff@intel.com>
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;
+ struct client *client;
+ struct surface *expect_focus = NULL;
+ struct keyboard *keyboard;
+ uint32_t expect_key = 0;
+ uint32_t expect_state = 0;
- 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);
+ client = client_create(10, 10, 1, 1);
+ assert(client);
- 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;
+ 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;
}