tests: add keyboard test
Signed-off-by: U. Artie Eoff <ullysses.a.eoff@intel.com>
This commit is contained in:
committed by
Kristian Høgsberg
parent
58990cae31
commit
840d5f975b
+2
-1
@@ -1,7 +1,7 @@
|
|||||||
TESTS = surface-test.la client-test.la \
|
TESTS = surface-test.la client-test.la \
|
||||||
event-test.la text-test.la \
|
event-test.la text-test.la \
|
||||||
surface-global-test.la \
|
surface-global-test.la \
|
||||||
button-test.la
|
button-test.la keyboard-test.la
|
||||||
|
|
||||||
TESTS_ENVIRONMENT = $(SHELL) $(top_srcdir)/tests/weston-test
|
TESTS_ENVIRONMENT = $(SHELL) $(top_srcdir)/tests/weston-test
|
||||||
|
|
||||||
@@ -24,6 +24,7 @@ client_test_la_SOURCES = client-test.c $(test_runner_src)
|
|||||||
event_test_la_SOURCES = event-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)
|
text_test_la_SOURCES = text-test.c $(test_runner_src)
|
||||||
button_test_la_SOURCES = button-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_SOURCES = test-client.c
|
||||||
test_client_LDADD = $(SIMPLE_CLIENT_LIBS)
|
test_client_LDADD = $(SIMPLE_CLIENT_LIBS)
|
||||||
|
|||||||
@@ -0,0 +1,124 @@
|
|||||||
|
/*
|
||||||
|
* 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.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include <stdlib.h>
|
||||||
|
#include <stdio.h>
|
||||||
|
#include <sys/socket.h>
|
||||||
|
#include <assert.h>
|
||||||
|
#include <unistd.h>
|
||||||
|
#include <string.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)
|
||||||
|
{
|
||||||
|
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;
|
||||||
|
}
|
||||||
|
|
||||||
|
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;
|
||||||
|
}
|
||||||
+31
-1
@@ -46,6 +46,7 @@ struct input {
|
|||||||
uint32_t button_mask;
|
uint32_t button_mask;
|
||||||
struct surface *pointer_focus;
|
struct surface *pointer_focus;
|
||||||
struct surface *keyboard_focus;
|
struct surface *keyboard_focus;
|
||||||
|
uint32_t last_key, last_key_state;
|
||||||
};
|
};
|
||||||
|
|
||||||
struct output {
|
struct output {
|
||||||
@@ -159,6 +160,11 @@ keyboard_handle_key(void *data, struct wl_keyboard *keyboard,
|
|||||||
uint32_t serial, uint32_t time, uint32_t key,
|
uint32_t serial, uint32_t time, uint32_t key,
|
||||||
uint32_t state)
|
uint32_t state)
|
||||||
{
|
{
|
||||||
|
struct input *input = data;
|
||||||
|
|
||||||
|
input->last_key = key;
|
||||||
|
input->last_key_state = state;
|
||||||
|
|
||||||
fprintf(stderr, "test-client: got keyboard key %u %u\n", key, state);
|
fprintf(stderr, "test-client: got keyboard key %u %u\n", key, state);
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -319,6 +325,27 @@ static const struct wl_surface_listener surface_listener = {
|
|||||||
surface_leave
|
surface_leave
|
||||||
};
|
};
|
||||||
|
|
||||||
|
static void
|
||||||
|
send_keyboard_state(int fd, struct display *display)
|
||||||
|
{
|
||||||
|
char buf[64];
|
||||||
|
int len;
|
||||||
|
int focus = display->input->keyboard_focus != NULL;
|
||||||
|
|
||||||
|
if (focus) {
|
||||||
|
assert(display->input->keyboard_focus == display->surface);
|
||||||
|
}
|
||||||
|
|
||||||
|
wl_display_flush(display->display);
|
||||||
|
|
||||||
|
len = snprintf(buf, sizeof buf, "%u %u %d\n", display->input->last_key,
|
||||||
|
display->input->last_key_state, focus);
|
||||||
|
assert(write(fd, buf, len) == len);
|
||||||
|
|
||||||
|
wl_display_roundtrip(display->display);
|
||||||
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
send_button_state(int fd, struct display *display)
|
send_button_state(int fd, struct display *display)
|
||||||
{
|
{
|
||||||
char buf[64];
|
char buf[64];
|
||||||
@@ -341,7 +368,8 @@ send_state(int fd, struct display* display)
|
|||||||
wl_fixed_t x = wl_fixed_from_int(-1);
|
wl_fixed_t x = wl_fixed_from_int(-1);
|
||||||
wl_fixed_t y = wl_fixed_from_int(-1);
|
wl_fixed_t y = wl_fixed_from_int(-1);
|
||||||
|
|
||||||
if (display->input->pointer_focus == display->surface) {
|
if (display->input->pointer_focus != NULL) {
|
||||||
|
assert(display->input->pointer_focus == display->surface);
|
||||||
x = wl_fixed_from_double(display->input->x);
|
x = wl_fixed_from_double(display->input->x);
|
||||||
y = wl_fixed_from_double(display->input->y);
|
y = wl_fixed_from_double(display->input->y);
|
||||||
}
|
}
|
||||||
@@ -423,6 +451,8 @@ int main(int argc, char *argv[])
|
|||||||
send_state(fd, display);
|
send_state(fd, display);
|
||||||
} else if (strncmp(buf, "send-button-state\n", ret) == 0) {
|
} else if (strncmp(buf, "send-button-state\n", ret) == 0) {
|
||||||
send_button_state(fd, display);
|
send_button_state(fd, display);
|
||||||
|
} else if (strncmp(buf, "send-keyboard-state\n", ret) == 0) {
|
||||||
|
send_keyboard_state(fd, display);
|
||||||
} else {
|
} else {
|
||||||
fprintf(stderr, "test-client: unknown command %.*s\n",
|
fprintf(stderr, "test-client: unknown command %.*s\n",
|
||||||
ret, buf);
|
ret, buf);
|
||||||
|
|||||||
Reference in New Issue
Block a user