summaryrefslogtreecommitdiffstats
path: root/tests/auto/compositor/compositor
diff options
context:
space:
mode:
Diffstat (limited to 'tests/auto/compositor/compositor')
-rw-r--r--tests/auto/compositor/compositor/tst_compositor.cpp48
1 files changed, 48 insertions, 0 deletions
diff --git a/tests/auto/compositor/compositor/tst_compositor.cpp b/tests/auto/compositor/compositor/tst_compositor.cpp
index 6f00b6e61..c51c13bd6 100644
--- a/tests/auto/compositor/compositor/tst_compositor.cpp
+++ b/tests/auto/compositor/compositor/tst_compositor.cpp
@@ -39,6 +39,7 @@
#include <QtGui/QScreen>
#include <QtWaylandCompositor/QWaylandXdgShellV5>
+#include <QtWaylandCompositor/private/qwaylandxdgshellv6_p.h>
#include <QtWaylandCompositor/QWaylandIviApplication>
#include <QtWaylandCompositor/QWaylandIviSurface>
#include <QtWaylandCompositor/QWaylandSurface>
@@ -78,6 +79,9 @@ private slots:
void emitsErrorOnSameIviId();
void sendsIviConfigure();
void destroysIviSurfaces();
+
+ void convertsXdgEdgesToQtEdges();
+ void xdgShellV6Positioner();
};
void tst_WaylandCompositor::init() {
@@ -835,5 +839,49 @@ void tst_WaylandCompositor::destroysIviSurfaces()
QTRY_VERIFY(destroySpy.count() == 1);
}
+void tst_WaylandCompositor::convertsXdgEdgesToQtEdges()
+{
+ const uint wlLeft = ZXDG_POSITIONER_V6_ANCHOR_LEFT;
+ QCOMPARE(QWaylandXdgShellV6Private::convertToEdges(wlLeft), Qt::LeftEdge);
+
+ const uint wlRight = ZXDG_POSITIONER_V6_ANCHOR_RIGHT;
+ QCOMPARE(QWaylandXdgShellV6Private::convertToEdges(wlRight), Qt::RightEdge);
+
+ const uint wlTop = ZXDG_POSITIONER_V6_ANCHOR_TOP;
+ QCOMPARE(QWaylandXdgShellV6Private::convertToEdges(wlTop), Qt::TopEdge);
+
+ const uint wlBottom = ZXDG_POSITIONER_V6_ANCHOR_BOTTOM;
+ QCOMPARE(QWaylandXdgShellV6Private::convertToEdges(wlBottom), Qt::BottomEdge);
+
+ QCOMPARE(QWaylandXdgShellV6Private::convertToEdges(wlBottom | wlLeft), Qt::Edges(Qt::BottomEdge | Qt::LeftEdge));
+ QCOMPARE(QWaylandXdgShellV6Private::convertToEdges(wlTop | wlRight), Qt::Edges(Qt::TopEdge | Qt::RightEdge));
+}
+
+void tst_WaylandCompositor::xdgShellV6Positioner()
+{
+ QWaylandXdgPositionerV6Data p;
+ QVERIFY(!p.isComplete());
+
+ p.size = QSize(100, 50);
+ p.anchorRect = QRect(QPoint(1, 2), QSize(800, 600));
+ QVERIFY(p.isComplete());
+
+ p.anchorEdges = Qt::TopEdge | Qt::LeftEdge;
+ p.gravityEdges = Qt::BottomEdge | Qt::RightEdge;
+ QCOMPARE(p.unconstrainedPosition(), QPoint(1, 2));
+
+ p.anchorEdges = Qt::RightEdge;
+ QCOMPARE(p.unconstrainedPosition(), QPoint(1 + 800, 2 + 600 / 2));
+
+ p.gravityEdges = Qt::BottomEdge;
+ QCOMPARE(p.unconstrainedPosition(), QPoint(1 + 800 - 100 / 2, 2 + 600 / 2));
+
+ p.gravityEdges = Qt::TopEdge;
+ QCOMPARE(p.unconstrainedPosition(), QPoint(1 + 800 - 100 / 2, 2 + 600 / 2 - 50));
+
+ p.offset = QPoint(4, 8);
+ QCOMPARE(p.unconstrainedPosition(), QPoint(1 + 800 - 100 / 2 + 4, 2 + 600 / 2 - 50 + 8));
+}
+
#include <tst_compositor.moc>
QTEST_MAIN(tst_WaylandCompositor);