RE: [PATCH] tests: add button test
Ignore this patch... resubmitting as a series to address coding conventions. U. Artie -Original Message- From: Eoff, Ullysses A Sent: Wednesday, September 26, 2012 3:09 PM To: wayland-devel@lists.freedesktop.org Cc: Eoff, Ullysses A Subject: [PATCH] tests: add button test From: U. Artie Eoff ullysses.a.e...@intel.com Signed-off-by: U. Artie Eoff ullysses.a.e...@intel.com --- tests/Makefile.am | 4 +- tests/button-test.c | 136 tests/test-client.c | 18 ++- 3 files changed, 156 insertions(+), 2 deletions(-) create mode 100644 tests/button-test.c diff --git a/tests/Makefile.am b/tests/Makefile.am index 60c73a1..fcf6674 100644 --- a/tests/Makefile.am +++ b/tests/Makefile.am @@ -1,6 +1,7 @@ TESTS = surface-test.la client-test.la\ event-test.la text-test.la \ - surface-global-test.la + surface-global-test.la \ + button-test.la TESTS_ENVIRONMENT = $(SHELL) $(top_srcdir)/tests/weston-test @@ -22,6 +23,7 @@ surface_test_la_SOURCES = surface-test.c $(test_runner_src) 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) test_client_SOURCES = test-client.c test_client_LDADD = $(SIMPLE_CLIENT_LIBS) diff --git a/tests/button-test.c b/tests/button-test.c new file mode 100644 index 000..437291a --- /dev/null +++ b/tests/button-test.c @@ -0,0 +1,136 @@ +/* + * 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 linux/input.h + +#include test-runner.h + +struct context { + struct weston_layer *layer; + struct weston_seat *seat; + struct weston_surface *surface; +}; + +static void +handle_button_up(struct test_client *); + +static void +handle_button_down(struct test_client *client) +{ + struct context *context = client-data; + uint32_t mask; + + assert(sscanf(client-buf, %u, mask) == 1); + + assert(mask == 1); + + notify_button(context-seat, 100, BTN_LEFT, + WL_POINTER_BUTTON_STATE_RELEASED); + + test_client_send(client, send-button-state\n); + client-handle = handle_button_up; +} + +static void +handle_button_up(struct test_client *client) +{ + struct context *context = client-data; + static int once = 0; + uint32_t mask; + + assert(sscanf(client-buf, %u, mask) == 1); + + assert(mask == 0); + + if (!once++) { + notify_button(context-seat, 100, BTN_LEFT, + WL_POINTER_BUTTON_STATE_PRESSED); + + test_client_send(client, send-button-state\n); + client-handle = handle_button_down; + } else { + test_client_send(client, bye\n); + client-handle = NULL; + } +} + +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); + + context-layer = malloc(sizeof *context-layer); + assert(context-layer); + weston_layer_init(context-layer, client-compositor- cursor_layer.link); + wl_list_insert(context-layer-surface_list, context-surface
[PATCH] tests: add button test
From: U. Artie Eoff ullysses.a.e...@intel.com Signed-off-by: U. Artie Eoff ullysses.a.e...@intel.com --- tests/Makefile.am | 4 +- tests/button-test.c | 136 tests/test-client.c | 18 ++- 3 files changed, 156 insertions(+), 2 deletions(-) create mode 100644 tests/button-test.c diff --git a/tests/Makefile.am b/tests/Makefile.am index 60c73a1..fcf6674 100644 --- a/tests/Makefile.am +++ b/tests/Makefile.am @@ -1,6 +1,7 @@ TESTS = surface-test.la client-test.la \ event-test.la text-test.la \ - surface-global-test.la + surface-global-test.la \ + button-test.la TESTS_ENVIRONMENT = $(SHELL) $(top_srcdir)/tests/weston-test @@ -22,6 +23,7 @@ surface_test_la_SOURCES = surface-test.c $(test_runner_src) 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) test_client_SOURCES = test-client.c test_client_LDADD = $(SIMPLE_CLIENT_LIBS) diff --git a/tests/button-test.c b/tests/button-test.c new file mode 100644 index 000..437291a --- /dev/null +++ b/tests/button-test.c @@ -0,0 +1,136 @@ +/* + * 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 linux/input.h + +#include test-runner.h + +struct context { + struct weston_layer *layer; + struct weston_seat *seat; + struct weston_surface *surface; +}; + +static void +handle_button_up(struct test_client *); + +static void +handle_button_down(struct test_client *client) +{ + struct context *context = client-data; + uint32_t mask; + + assert(sscanf(client-buf, %u, mask) == 1); + + assert(mask == 1); + + notify_button(context-seat, 100, BTN_LEFT, + WL_POINTER_BUTTON_STATE_RELEASED); + + test_client_send(client, send-button-state\n); + client-handle = handle_button_up; +} + +static void +handle_button_up(struct test_client *client) +{ + struct context *context = client-data; + static int once = 0; + uint32_t mask; + + assert(sscanf(client-buf, %u, mask) == 1); + + assert(mask == 0); + + if (!once++) { + notify_button(context-seat, 100, BTN_LEFT, + WL_POINTER_BUTTON_STATE_PRESSED); + + test_client_send(client, send-button-state\n); + client-handle = handle_button_down; + } else { + test_client_send(client, bye\n); + client-handle = NULL; + } +} + +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); + + context-layer = malloc(sizeof *context-layer); + assert(context-layer); + weston_layer_init(context-layer, client-compositor-cursor_layer.link); + wl_list_insert(context-layer-surface_list, context-surface-layer_link); + + seat_list = client-compositor-seat_list; + assert(wl_list_length(seat_list) == 1); + context-seat = container_of(seat_list-next, struct weston_seat, link); + + client-compositor-focus = 1; /*