summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorPeter Hutterer <peter.hutterer@who-t.net>2013-07-01 10:08:26 +1000
committerPeter Hutterer <peter.hutterer@who-t.net>2013-07-01 10:10:25 +1000
commit3ad61372c8e2169e2ed0cdcb6df07538ae5fa99b (patch)
tree914c05e321f00e47901aec3310ed2ec6231bbc4c
parent2ae4dc003a0ac4c9a6cf78ac020e1e45b9c8516b (diff)
downloadlibevdev-3ad61372c8e2169e2ed0cdcb6df07538ae5fa99b.tar.gz
test: add test for filtered event delivery
Signed-off-by: Peter Hutterer <peter.hutterer@who-t.net>
-rw-r--r--test/test-libevdev-events.c80
1 files changed, 79 insertions, 1 deletions
diff --git a/test/test-libevdev-events.c b/test/test-libevdev-events.c
index 6270e6b..e3ccb6a 100644
--- a/test/test-libevdev-events.c
+++ b/test/test-libevdev-events.c
@@ -122,6 +122,83 @@ START_TEST(test_syn_event)
}
END_TEST
+START_TEST(test_event_type_filtered)
+{
+ struct uinput_device* uidev;
+ struct libevdev *dev;
+ int rc;
+ struct input_event ev;
+
+ rc = test_create_device(&uidev, &dev,
+ EV_REL, REL_X,
+ EV_REL, REL_Y,
+ EV_KEY, BTN_LEFT,
+ -1);
+ ck_assert_msg(rc == 0, "Failed to create device: %s", strerror(-rc));
+
+ libevdev_disable_event_type(dev, EV_REL);
+
+ rc = libevdev_next_event(dev, LIBEVDEV_READ_NORMAL, &ev);
+ ck_assert_int_eq(rc, -EAGAIN);
+
+ uinput_device_event(uidev, EV_REL, REL_X, 1);
+ uinput_device_event(uidev, EV_KEY, REL_Y, 1);
+ uinput_device_event(uidev, EV_SYN, SYN_REPORT, 0);
+ rc = libevdev_next_event(dev, LIBEVDEV_READ_NORMAL, &ev);
+ ck_assert_int_eq(rc, 0);
+ ck_assert_int_eq(ev.type, EV_SYN);
+ ck_assert_int_eq(ev.code, SYN_REPORT);
+
+ rc = libevdev_next_event(dev, LIBEVDEV_READ_NORMAL, &ev);
+ ck_assert_int_eq(rc, -EAGAIN);
+
+ libevdev_free(dev);
+ uinput_device_free(uidev);
+
+}
+END_TEST
+START_TEST(test_event_code_filtered)
+{
+ struct uinput_device* uidev;
+ struct libevdev *dev;
+ int rc;
+ struct input_event ev;
+
+ rc = test_create_device(&uidev, &dev,
+ EV_REL, REL_X,
+ EV_REL, REL_Y,
+ EV_KEY, BTN_LEFT,
+ -1);
+ ck_assert_msg(rc == 0, "Failed to create device: %s", strerror(-rc));
+
+ libevdev_disable_event_code(dev, EV_REL, REL_X);
+
+ rc = libevdev_next_event(dev, LIBEVDEV_READ_NORMAL, &ev);
+ ck_assert_int_eq(rc, -EAGAIN);
+
+ uinput_device_event(uidev, EV_REL, REL_X, 1);
+ uinput_device_event(uidev, EV_REL, REL_Y, 1);
+ uinput_device_event(uidev, EV_SYN, SYN_REPORT, 0);
+ rc = libevdev_next_event(dev, LIBEVDEV_READ_NORMAL, &ev);
+ ck_assert_int_eq(rc, 0);
+ ck_assert_int_eq(ev.type, EV_REL);
+ ck_assert_int_eq(ev.code, REL_Y);
+ ck_assert_int_eq(ev.value, 1);
+
+ rc = libevdev_next_event(dev, LIBEVDEV_READ_NORMAL, &ev);
+ ck_assert_int_eq(rc, 0);
+ ck_assert_int_eq(ev.type, EV_SYN);
+ ck_assert_int_eq(ev.code, SYN_REPORT);
+
+ rc = libevdev_next_event(dev, LIBEVDEV_READ_NORMAL, &ev);
+ ck_assert_int_eq(rc, -EAGAIN);
+
+ libevdev_free(dev);
+ uinput_device_free(uidev);
+
+}
+END_TEST
+
START_TEST(test_syn_delta_button)
{
struct uinput_device* uidev;
@@ -181,13 +258,14 @@ libevdev_events(void)
TCase *tc = tcase_create("event polling");
tcase_add_test(tc, test_next_event);
tcase_add_test(tc, test_syn_event);
+ tcase_add_test(tc, test_event_type_filtered);
+ tcase_add_test(tc, test_event_code_filtered);
suite_add_tcase(s, tc);
tc = tcase_create("SYN_DROPPED deltas");
tcase_add_test(tc, test_syn_delta_button);
suite_add_tcase(s, tc);
-
return s;
}