summaryrefslogtreecommitdiff
path: root/test
diff options
context:
space:
mode:
authorPeter Hutterer <peter.hutterer@who-t.net>2014-09-16 16:22:42 +0200
committerPeter Hutterer <peter.hutterer@who-t.net>2014-09-19 08:20:09 +1000
commit45299593c060f51c6c5e44943bb575d936ddc665 (patch)
tree196b14220df313b09561944d687ad4d7a4e47467 /test
parentb264c52a8b69dc23774c37f7628eb8f94bc8ffed (diff)
downloadlibinput-45299593c060f51c6c5e44943bb575d936ddc665.tar.gz
test: Test the topbuttons of a disabled touchpad still send events through the trackpoint
Signed-off-by: Peter Hutterer <peter.hutterer@who-t.net> Reviewed-by: Hans de Goede <hdegoede@redhat.com> Signed-off-by: Hans de Goede <hdegoede@redhat.com>
Diffstat (limited to 'test')
-rw-r--r--test/device.c58
1 files changed, 58 insertions, 0 deletions
diff --git a/test/device.c b/test/device.c
index 3f7ec4cd..33aae04e 100644
--- a/test/device.c
+++ b/test/device.c
@@ -509,6 +509,62 @@ START_TEST(device_disable_release_softbutton)
}
END_TEST
+START_TEST(device_disable_topsoftbutton)
+{
+ struct litest_device *dev = litest_current_device();
+ struct litest_device *trackpoint;
+ struct libinput *li = dev->libinput;
+ struct libinput_device *device;
+ enum libinput_config_status status;
+
+ struct libinput_event *event;
+ struct libinput_event_pointer *ptrevent;
+
+ device = dev->libinput_device;
+
+ trackpoint = litest_add_device(li, LITEST_TRACKPOINT);
+
+ status = libinput_device_config_send_events_set_mode(device,
+ LIBINPUT_CONFIG_SEND_EVENTS_DISABLED);
+ ck_assert_int_eq(status, LIBINPUT_CONFIG_STATUS_SUCCESS);
+ litest_drain_events(li);
+
+ litest_touch_down(dev, 0, 90, 10);
+ litest_button_click(dev, BTN_LEFT, true);
+ litest_button_click(dev, BTN_LEFT, false);
+ litest_touch_up(dev, 0);
+
+ litest_wait_for_event(li);
+ event = libinput_get_event(li);
+ ck_assert_int_eq(libinput_event_get_type(event),
+ LIBINPUT_EVENT_POINTER_BUTTON);
+ ck_assert_int_eq(libinput_event_get_device(event),
+ trackpoint->libinput_device);
+ ptrevent = libinput_event_get_pointer_event(event);
+ ck_assert_int_eq(libinput_event_pointer_get_button(ptrevent),
+ BTN_RIGHT);
+ ck_assert_int_eq(libinput_event_pointer_get_button_state(ptrevent),
+ LIBINPUT_BUTTON_STATE_PRESSED);
+ libinput_event_destroy(event);
+
+ event = libinput_get_event(li);
+ ck_assert_int_eq(libinput_event_get_type(event),
+ LIBINPUT_EVENT_POINTER_BUTTON);
+ ck_assert_int_eq(libinput_event_get_device(event),
+ trackpoint->libinput_device);
+ ptrevent = libinput_event_get_pointer_event(event);
+ ck_assert_int_eq(libinput_event_pointer_get_button(ptrevent),
+ BTN_RIGHT);
+ ck_assert_int_eq(libinput_event_pointer_get_button_state(ptrevent),
+ LIBINPUT_BUTTON_STATE_RELEASED);
+ libinput_event_destroy(event);
+
+ litest_assert_empty_queue(li);
+
+ litest_delete_device(trackpoint);
+}
+END_TEST
+
int main (int argc, char **argv)
{
litest_add("device:sendevents", device_sendevents_config, LITEST_ANY, LITEST_TOUCHPAD);
@@ -527,5 +583,7 @@ int main (int argc, char **argv)
litest_add("device:sendevents", device_disable_release_tap_n_drag, LITEST_TOUCHPAD, LITEST_ANY);
litest_add("device:sendevents", device_disable_release_softbutton, LITEST_CLICKPAD, LITEST_APPLE_CLICKPAD);
+ litest_add("device:sendevents", device_disable_topsoftbutton, LITEST_TOPBUTTONPAD, LITEST_ANY);
+
return litest_run(argc, argv);
}