From 73edf04050b70093ad3dbf664dbdaa42ddf0bfda Mon Sep 17 00:00:00 2001 From: Johan Klokkhammer Helsing Date: Tue, 25 Sep 2018 16:28:10 +0200 Subject: Compositor: Add test for wl_surface::set_input_region Change-Id: I9b110647c054c897fa2a6d6fc6f392c981845f09 Reviewed-by: Paul Olav Tvete --- .../auto/compositor/compositor/tst_compositor.cpp | 35 ++++++++++++++++++++++ 1 file changed, 35 insertions(+) (limited to 'tests/auto') diff --git a/tests/auto/compositor/compositor/tst_compositor.cpp b/tests/auto/compositor/compositor/tst_compositor.cpp index e3c4daccc..abad9b0d6 100644 --- a/tests/auto/compositor/compositor/tst_compositor.cpp +++ b/tests/auto/compositor/compositor/tst_compositor.cpp @@ -67,6 +67,7 @@ private slots: void seatCreation(); void seatKeyboardFocus(); void seatMouseFocus(); + void inputRegion(); void singleClient(); void multipleClients(); void geometry(); @@ -650,6 +651,40 @@ void tst_WaylandCompositor::seatMouseFocus() delete view; } +void tst_WaylandCompositor::inputRegion() +{ + TestCompositor compositor(true); + compositor.create(); + + // Create client after all the seats have been set up as the mock client + // does not dynamically listen to new seats + MockClient client; + wl_surface *surface = client.createSurface(); + + // We need to attach a buffer, since QWaylandSurface::inputRegionContains will will return + // false for coordinates outside the buffer (so don't let it be 0x0). + QSize size(16, 16); + ShmBuffer buffer(size, client.shm); + wl_surface_attach(surface, buffer.handle, 0, 0); + wl_surface_damage(surface, 0, 0, size.width(), size.height()); + wl_surface_commit(surface); + + // Set the input region + wl_region *region = wl_compositor_create_region(client.compositor); + wl_region_add(region, 1, 2, 3, 4); + wl_surface_set_input_region(surface, region); + wl_surface_commit(surface); + + QTRY_COMPARE(compositor.surfaces.size(), 1); + QWaylandSurface *waylandSurface = compositor.surfaces.at(0); + + QVERIFY(waylandSurface->inputRegionContains(QPoint(1, 2))); + QVERIFY(waylandSurface->inputRegionContains(QPoint(3, 5))); + QVERIFY(!waylandSurface->inputRegionContains(QPoint(0, 0))); + QVERIFY(!waylandSurface->inputRegionContains(QPoint(1, 6))); + QVERIFY(!waylandSurface->inputRegionContains(QPoint(4, 2))); +} + class XdgTestCompositor: public TestCompositor { Q_OBJECT public: -- cgit v1.2.3