summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--tests/auto/gui/kernel/qwindow/tst_foreignwindow.cpp19
-rw-r--r--tests/shared/nativewindow.h11
2 files changed, 30 insertions, 0 deletions
diff --git a/tests/auto/gui/kernel/qwindow/tst_foreignwindow.cpp b/tests/auto/gui/kernel/qwindow/tst_foreignwindow.cpp
index dc82d8b833..04c70e5fee 100644
--- a/tests/auto/gui/kernel/qwindow/tst_foreignwindow.cpp
+++ b/tests/auto/gui/kernel/qwindow/tst_foreignwindow.cpp
@@ -23,6 +23,8 @@ private slots:
void fromWinId();
void initialState();
+
+ void embedForeignWindow();
};
void tst_ForeignWindow::fromWinId()
@@ -67,5 +69,22 @@ void tst_ForeignWindow::initialState()
QCOMPARE(foreignWindow->geometry(), initialGeometry);
}
+void tst_ForeignWindow::embedForeignWindow()
+{
+ // A foreign window embedded into a Qt UI requires that the rest of Qt
+ // is to be able to treat the foreign child window as any other window
+ // that it can show, hide, stack, and move around.
+
+ QWindow parentWindow;
+
+ NativeWindow nativeWindow;
+ QVERIFY(nativeWindow);
+
+ // As a prerequisite to that, we must be able to reparent the foreign window
+ std::unique_ptr<QWindow> foreignWindow(QWindow::fromWinId(nativeWindow));
+ foreignWindow.release()->setParent(&parentWindow);
+ QCOMPARE(nativeWindow.parentWinId(), parentWindow.winId());
+}
+
#include <tst_foreignwindow.moc>
QTEST_MAIN(tst_ForeignWindow)
diff --git a/tests/shared/nativewindow.h b/tests/shared/nativewindow.h
index 6b3ffe0897..4b2aff0cdd 100644
--- a/tests/shared/nativewindow.h
+++ b/tests/shared/nativewindow.h
@@ -18,6 +18,7 @@ public:
~NativeWindow();
operator WId() const { return reinterpret_cast<WId>(m_handle); }
+ WId parentWinId() const;
void setGeometry(const QRect &rect);
QRect geometry() const;
@@ -69,6 +70,11 @@ QRect NativeWindow::geometry() const
return QRectF::fromCGRect(m_handle.frame).toRect();
}
+WId NativeWindow::parentWinId() const
+{
+ return WId(m_handle.superview);
+}
+
#elif defined(Q_OS_WIN)
NativeWindow::NativeWindow()
@@ -107,6 +113,11 @@ QRect NativeWindow::geometry() const
return {};
}
+WId NativeWindow::parentWinId() const
+{
+ return WId(GetAncestor(m_handle, GA_PARENT));
+}
+
#endif
#endif // NATIVEWINDOW_H