summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorPeter Hutterer <peter.hutterer@who-t.net>2014-11-17 11:37:43 +1000
committerPeter Hutterer <peter.hutterer@who-t.net>2014-11-18 09:03:35 +1000
commitd68eb35378abad21f7f987896d80e684b3a7b306 (patch)
treecbd11ab25ff7957112a7876846bf033ef5215c36
parent318b0a5b11f5fb97d6c9562f2ff6b0263c7fbf9f (diff)
downloadlibevdev-d68eb35378abad21f7f987896d80e684b3a7b306.tar.gz
test: add missing tests for invalid calls on next_event/has_event_pending
Signed-off-by: Peter Hutterer <peter.hutterer@who-t.net>
-rw-r--r--test/test-libevdev-events.c56
1 files changed, 56 insertions, 0 deletions
diff --git a/test/test-libevdev-events.c b/test/test-libevdev-events.c
index 6ef0bf9..0f99b20 100644
--- a/test/test-libevdev-events.c
+++ b/test/test-libevdev-events.c
@@ -60,6 +60,43 @@ START_TEST(test_next_event)
}
END_TEST
+START_TEST(test_next_event_invalid_fd)
+{
+ struct uinput_device* uidev;
+ struct libevdev *dev;
+ int rc;
+ struct input_event ev;
+
+ libevdev_set_log_function(test_logfunc_ignore_error, NULL);
+
+ dev = libevdev_new();
+ rc = libevdev_next_event(dev, LIBEVDEV_READ_FLAG_NORMAL, &ev);
+ ck_assert_int_eq(rc, -EBADF);
+ libevdev_free(dev);
+
+ test_create_device(&uidev, &dev,
+ EV_REL, REL_X,
+ EV_REL, REL_Y,
+ EV_KEY, BTN_LEFT,
+ -1);
+
+ /* invalid (missing) flag */
+ rc = libevdev_next_event(dev, 0x10, &ev);
+ ck_assert_int_eq(rc, -EINVAL);
+
+ /* set an invalid fd */
+ rc = libevdev_change_fd(dev, -3);
+ ck_assert_int_eq(rc, 0);
+ rc = libevdev_next_event(dev, LIBEVDEV_READ_FLAG_NORMAL, &ev);
+ ck_assert_int_eq(rc, -EBADF);
+
+ libevdev_set_log_function(test_logfunc_abort_on_error, NULL);
+
+ libevdev_free(dev);
+ uinput_device_free(uidev);
+}
+END_TEST
+
START_TEST(test_syn_dropped_event)
{
struct uinput_device* uidev;
@@ -342,6 +379,23 @@ START_TEST(test_has_event_pending)
}
END_TEST
+START_TEST(test_has_event_pending_invalid_fd)
+{
+ struct libevdev *dev;
+ int rc;
+
+ libevdev_set_log_function(test_logfunc_ignore_error, NULL);
+
+ dev = libevdev_new();
+ rc = libevdev_has_event_pending(dev);
+ ck_assert_int_eq(rc, -EBADF);
+
+ libevdev_set_log_function(test_logfunc_abort_on_error, NULL);
+
+ libevdev_free(dev);
+}
+END_TEST
+
START_TEST(test_syn_delta_button)
{
struct uinput_device* uidev;
@@ -2066,11 +2120,13 @@ libevdev_events(void)
TCase *tc = tcase_create("event polling");
tcase_add_test(tc, test_next_event);
+ tcase_add_test(tc, test_next_event_invalid_fd);
tcase_add_test(tc, test_syn_dropped_event);
tcase_add_test(tc, test_double_syn_dropped_event);
tcase_add_test(tc, test_event_type_filtered);
tcase_add_test(tc, test_event_code_filtered);
tcase_add_test(tc, test_has_event_pending);
+ tcase_add_test(tc, test_has_event_pending_invalid_fd);
suite_add_tcase(s, tc);
tc = tcase_create("SYN_DROPPED deltas");