summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorPeter Hutterer <peter.hutterer@who-t.net>2014-11-18 12:03:48 +1000
committerPeter Hutterer <peter.hutterer@who-t.net>2014-11-20 08:18:10 +1000
commitb1005b748109ce0bb3728ab338ade16ded4c1009 (patch)
tree478e253c189ce3179d9856807c9fa15333dbd5f1
parent805f482423b5cc11a65818ff6adfcbddad8d2228 (diff)
downloadlibinput-b1005b748109ce0bb3728ab338ade16ded4c1009.tar.gz
test: add natural scrolling tests for pointers
Signed-off-by: Peter Hutterer <peter.hutterer@who-t.net> Reviewed-by: Hans de Goede <hdegoede@redhat.com>
-rw-r--r--test/pointer.c56
1 files changed, 56 insertions, 0 deletions
diff --git a/test/pointer.c b/test/pointer.c
index 116f1856..487cd160 100644
--- a/test/pointer.c
+++ b/test/pointer.c
@@ -280,6 +280,9 @@ test_wheel_event(struct litest_device *dev, int which, int amount)
const int scroll_step = 10;
int expected = amount * scroll_step;
+ if (libinput_device_config_scroll_get_natural_scroll_enabled(dev->libinput_device))
+ expected *= -1;
+
/* mouse scroll wheels are 'upside down' */
if (which == REL_WHEEL)
amount *= -1;
@@ -325,6 +328,56 @@ START_TEST(pointer_scroll_wheel)
}
END_TEST
+START_TEST(pointer_scroll_natural_defaults)
+{
+ struct litest_device *dev = litest_current_device();
+
+ ck_assert_int_ge(libinput_device_config_scroll_has_natural_scroll(dev->libinput_device), 1);
+ ck_assert_int_eq(libinput_device_config_scroll_get_natural_scroll_enabled(dev->libinput_device), 0);
+ ck_assert_int_eq(libinput_device_config_scroll_get_default_natural_scroll_enabled(dev->libinput_device), 0);
+}
+END_TEST
+
+START_TEST(pointer_scroll_natural_enable_config)
+{
+ struct litest_device *dev = litest_current_device();
+ enum libinput_config_status status;
+
+ status = libinput_device_config_scroll_set_natural_scroll_enabled(dev->libinput_device, 1);
+ ck_assert_int_eq(status, LIBINPUT_CONFIG_STATUS_SUCCESS);
+ ck_assert_int_eq(libinput_device_config_scroll_get_natural_scroll_enabled(dev->libinput_device), 1);
+
+ status = libinput_device_config_scroll_set_natural_scroll_enabled(dev->libinput_device, 0);
+ ck_assert_int_eq(status, LIBINPUT_CONFIG_STATUS_SUCCESS);
+ ck_assert_int_eq(libinput_device_config_scroll_get_natural_scroll_enabled(dev->libinput_device), 0);
+}
+END_TEST
+
+START_TEST(pointer_scroll_natural_wheel)
+{
+ struct litest_device *dev = litest_current_device();
+ struct libinput_device *device = dev->libinput_device;
+
+ litest_drain_events(dev->libinput);
+
+ libinput_device_config_scroll_set_natural_scroll_enabled(device, 1);
+
+ test_wheel_event(dev, REL_WHEEL, -1);
+ test_wheel_event(dev, REL_WHEEL, 1);
+
+ test_wheel_event(dev, REL_WHEEL, -5);
+ test_wheel_event(dev, REL_WHEEL, 6);
+
+ if (libevdev_has_event_code(dev->evdev, EV_REL, REL_HWHEEL)) {
+ test_wheel_event(dev, REL_HWHEEL, -1);
+ test_wheel_event(dev, REL_HWHEEL, 1);
+
+ test_wheel_event(dev, REL_HWHEEL, -5);
+ test_wheel_event(dev, REL_HWHEEL, 6);
+ }
+}
+END_TEST
+
START_TEST(pointer_seat_button_count)
{
const int num_devices = 4;
@@ -603,6 +656,9 @@ int main (int argc, char **argv) {
litest_add_no_device("pointer:button_auto_release", pointer_button_auto_release);
litest_add("pointer:scroll", pointer_scroll_wheel, LITEST_WHEEL, LITEST_ANY);
litest_add("pointer:scroll", pointer_scroll_button, LITEST_RELATIVE|LITEST_BUTTON, LITEST_ANY);
+ litest_add("pointer:scroll", pointer_scroll_natural_defaults, LITEST_WHEEL, LITEST_ANY);
+ litest_add("pointer:scroll", pointer_scroll_natural_enable_config, LITEST_WHEEL, LITEST_ANY);
+ litest_add("pointer:scroll", pointer_scroll_natural_wheel, LITEST_WHEEL, LITEST_ANY);
litest_add_no_device("pointer:seat button count", pointer_seat_button_count);
litest_add("pointer:calibration", pointer_no_calibration, LITEST_ANY, LITEST_TOUCH|LITEST_SINGLE_TOUCH|LITEST_ABSOLUTE);