test: add test for clock id setting on an invalid device
authorPeter Hutterer <peter.hutterer@who-t.net>
Mon, 17 Nov 2014 02:06:46 +0000 (12:06 +1000)
committerPeter Hutterer <peter.hutterer@who-t.net>
Mon, 17 Nov 2014 23:05:14 +0000 (09:05 +1000)
Signed-off-by: Peter Hutterer <peter.hutterer@who-t.net>
test/test-libevdev-init.c

index 06b924ef154ce37a2d593905da2695be584c1802..62f539f703b5c8cddd013924f621463692a63261 100644 (file)
@@ -498,6 +498,38 @@ START_TEST(test_set_clock_id)
 }
 END_TEST
 
+START_TEST(test_set_clock_id_invalid_fd)
+{
+       struct uinput_device* uidev;
+       struct libevdev *dev;
+       int rc;
+
+       libevdev_set_log_function(test_logfunc_ignore_error, NULL);
+
+       dev = libevdev_new();
+       rc = libevdev_set_clock_id(dev, CLOCK_MONOTONIC);
+       ck_assert_int_eq(rc, -EBADF);
+       libevdev_free(dev);
+
+       test_create_device(&uidev, &dev,
+                          EV_SYN, SYN_REPORT,
+                          EV_REL, REL_X,
+                          EV_REL, REL_Y,
+                          EV_REL, REL_WHEEL,
+                          EV_KEY, BTN_LEFT,
+                          EV_KEY, BTN_MIDDLE,
+                          EV_KEY, BTN_RIGHT,
+                          -1);
+       libevdev_change_fd(dev, -2);
+       rc = libevdev_set_clock_id(dev, CLOCK_MONOTONIC);
+       ck_assert_int_eq(rc, -EBADF);
+
+       uinput_device_free(uidev);
+       libevdev_free(dev);
+}
+END_TEST
+
+
 START_TEST(test_clock_id_events)
 {
        struct uinput_device* uidev;
@@ -598,6 +630,7 @@ libevdev_init_test(void)
 
        tc = tcase_create("clock id");
        tcase_add_test(tc, test_set_clock_id);
+       tcase_add_test(tc, test_set_clock_id_invalid_fd);
        tcase_add_test(tc, test_clock_id_events);
        suite_add_tcase(s, tc);