diff options
-rw-r--r-- | testsuite/gdk/Makefile.am | 1 | ||||
-rw-r--r-- | testsuite/gdk/seat.c | 120 |
2 files changed, 121 insertions, 0 deletions
diff --git a/testsuite/gdk/Makefile.am b/testsuite/gdk/Makefile.am index 63b7f8b6a9..beb3cac33f 100644 --- a/testsuite/gdk/Makefile.am +++ b/testsuite/gdk/Makefile.am @@ -23,6 +23,7 @@ TEST_PROGS += \ encoding \ keysyms \ rgba \ + seat \ visual \ $(NULL) diff --git a/testsuite/gdk/seat.c b/testsuite/gdk/seat.c new file mode 100644 index 0000000000..326b70dc89 --- /dev/null +++ b/testsuite/gdk/seat.c @@ -0,0 +1,120 @@ +#include <gdk/gdk.h> + +static void +test_list_seats (void) +{ + GdkDisplay *display; + GdkSeat *seat0, *seat; + GList *list, *l; + gboolean found_default; + + display = gdk_display_get_default (); + seat0 = gdk_display_get_default_seat (display); + + g_assert_true (GDK_IS_SEAT (seat0)); + + found_default = FALSE; + list = gdk_display_list_seats (display); + for (l = list; l; l = l->next) + { + seat = l->data; + + g_assert_true (GDK_IS_SEAT (seat)); + g_assert (gdk_seat_get_display (seat) == display); + + if (seat == seat0) + found_default = TRUE; + } + g_list_free (list); + + g_assert_true (found_default); +} + +static void +test_default_seat (void) +{ + GdkDisplay *display; + GdkSeat *seat0; + GdkSeatCapabilities caps; + GdkDevice *pointer0, *keyboard0, *device; + GList *slaves, *l; + + display = gdk_display_get_default (); + seat0 = gdk_display_get_default_seat (display); + + g_assert_true (GDK_IS_SEAT (seat0)); + + caps = gdk_seat_get_capabilities (seat0); + + g_assert (caps != GDK_SEAT_CAPABILITY_NONE); + + pointer0 = gdk_seat_get_pointer (seat0); + slaves = gdk_seat_get_slaves (seat0, GDK_SEAT_CAPABILITY_POINTER); + + if ((caps & GDK_SEAT_CAPABILITY_POINTER) != 0) + { + g_assert_nonnull (pointer0); + g_assert (gdk_device_get_device_type (pointer0) == GDK_DEVICE_TYPE_MASTER); + g_assert (gdk_device_get_display (pointer0) == display); + g_assert (gdk_device_get_seat (pointer0) == seat0); + + g_assert_nonnull (slaves); + for (l = slaves; l; l = l->next) + { + device = l->data; + g_assert (gdk_device_get_device_type (device) == GDK_DEVICE_TYPE_SLAVE); + g_assert (gdk_device_get_display (device) == display); + g_assert (gdk_device_get_seat (device) == seat0); + } + g_list_free (slaves); + } + else + { + g_assert_null (pointer0); + g_assert_null (slaves); + } + + keyboard0 = gdk_seat_get_keyboard (seat0); + slaves = gdk_seat_get_slaves (seat0, GDK_SEAT_CAPABILITY_KEYBOARD); + + if ((caps & GDK_SEAT_CAPABILITY_KEYBOARD) != 0) + { + g_assert_nonnull (keyboard0); + g_assert (gdk_device_get_device_type (keyboard0) == GDK_DEVICE_TYPE_MASTER); + g_assert (gdk_device_get_display (keyboard0) == display); + g_assert (gdk_device_get_seat (keyboard0) == seat0); + g_assert (gdk_device_get_source (keyboard0) == GDK_SOURCE_KEYBOARD); + + g_assert_nonnull (slaves); + for (l = slaves; l; l = l->next) + { + device = l->data; + g_assert (gdk_device_get_device_type (device) == GDK_DEVICE_TYPE_SLAVE); + g_assert (gdk_device_get_display (device) == display); + g_assert (gdk_device_get_seat (device) == seat0); + g_assert (gdk_device_get_source (device) == GDK_SOURCE_KEYBOARD); + } + g_list_free (slaves); + } + else + { + g_assert_null (keyboard0); + g_assert_null (slaves); + } + +} + +int +main (int argc, char *argv[]) +{ + g_test_init (&argc, &argv, NULL); + + gdk_init (NULL, NULL); + + g_test_bug_base ("http://bugzilla.gnome.org/"); + + g_test_add_func ("/seat/list", test_list_seats); + g_test_add_func ("/seat/default", test_default_seat); + + return g_test_run (); +} |