diff options
author | Peter Hutterer <peter.hutterer@who-t.net> | 2014-11-17 11:37:43 +1000 |
---|---|---|
committer | Peter Hutterer <peter.hutterer@who-t.net> | 2014-11-18 09:03:35 +1000 |
commit | d68eb35378abad21f7f987896d80e684b3a7b306 (patch) | |
tree | cbd11ab25ff7957112a7876846bf033ef5215c36 | |
parent | 318b0a5b11f5fb97d6c9562f2ff6b0263c7fbf9f (diff) | |
download | libevdev-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.c | 56 |
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"); |