From: Peter Hutterer Date: Mon, 17 Nov 2014 01:37:43 +0000 (+1000) Subject: test: add missing tests for invalid calls on next_event/has_event_pending X-Git-Tag: libevdev-1.3.2~8 X-Git-Url: http://review.tizen.org/git/?a=commitdiff_plain;h=d68eb35378abad21f7f987896d80e684b3a7b306;p=platform%2Fupstream%2Flibevdev.git test: add missing tests for invalid calls on next_event/has_event_pending Signed-off-by: Peter Hutterer --- 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");