diff options
| author | Allan Sandfeld Jensen <allan.jensen@digia.com> | 2013-04-11 17:40:38 +0200 |
|---|---|---|
| committer | The Qt Project <gerrit-noreply@qt-project.org> | 2013-04-11 18:28:15 +0200 |
| commit | 769a561e2e4bdac702c42c1781d9d3078b498ec1 (patch) | |
| tree | 7682f4ce9b5d38a5fd2c40dd10bc3a9699187e48 | |
| parent | 64ed4a49fd2dd8211a6476687f561f971053c5b9 (diff) | |
| download | qtwebkit-769a561e2e4bdac702c42c1781d9d3078b498ec1.tar.gz | |
[Qt] window.open passes height and width parameters even if not defined in a page
https://bugs.webkit.org/show_bug.cgi?id=107705
Reviewed by Kenneth Rohde Christiansen.
Source/WebCore:
Do not override width or height of 0, as that indicates default size, and not minimum size.
Tested by tst_qwebpage.
* page/DOMWindow.cpp:
(WebCore::DOMWindow::adjustWindowRect):
Source/WebKit/efl:
Do not resize window when default size is requested.
* WebCoreSupport/ChromeClientEfl.cpp:
(WebCore::ChromeClientEfl::setWindowRect):
Source/WebKit/gtk:
Do not resize window when default size is requested.
* WebCoreSupport/ChromeClientGtk.cpp:
(WebKit::ChromeClient::setWindowRect):
Source/WebKit/qt:
Test that minimum size is applied only when the requested size is too small,
not when default is requested.
* tests/qwebpage/tst_qwebpage.cpp:
(tst_QWebPage):
(TestPage):
(TestPage::TestPage):
(TestPage::createWindow):
(TestPage::slotGeometryChangeRequested):
(tst_QWebPage::openWindowDefaultSize):
Change-Id: I4e7f9012a014918a536daac0bfca15c01cd38fab
git-svn-id: http://svn.webkit.org/repository/webkit/trunk@142755 268f45cc-cd09-0410-ab3c-d52691b4dbfc
Reviewed-by: Jocelyn Turcotte <jocelyn.turcotte@digia.com>
| -rw-r--r-- | Source/WebCore/page/DOMWindow.cpp | 7 | ||||
| -rw-r--r-- | Source/WebKit/efl/WebCoreSupport/ChromeClientEfl.cpp | 2 | ||||
| -rw-r--r-- | Source/WebKit/gtk/WebCoreSupport/ChromeClientGtk.cpp | 3 | ||||
| -rw-r--r-- | Source/WebKit/qt/tests/qwebpage/tst_qwebpage.cpp | 44 |
4 files changed, 47 insertions, 9 deletions
diff --git a/Source/WebCore/page/DOMWindow.cpp b/Source/WebCore/page/DOMWindow.cpp index 0a6bc1949..f557ba6de 100644 --- a/Source/WebCore/page/DOMWindow.cpp +++ b/Source/WebCore/page/DOMWindow.cpp @@ -341,8 +341,11 @@ FloatRect DOMWindow::adjustWindowRect(Page* page, const FloatRect& pendingChange window.setHeight(pendingChanges.height()); FloatSize minimumSize = page->chrome()->client()->minimumWindowSize(); - window.setWidth(min(max(minimumSize.width(), window.width()), screen.width())); - window.setHeight(min(max(minimumSize.height(), window.height()), screen.height())); + // Let size 0 pass through, since that indicates default size, not minimum size. + if (window.width()) + window.setWidth(min(max(minimumSize.width(), window.width()), screen.width())); + if (window.height()) + window.setHeight(min(max(minimumSize.height(), window.height()), screen.height())); // Constrain the window position within the valid screen area. window.setX(max(screen.x(), min(window.x(), screen.maxX() - window.width()))); diff --git a/Source/WebKit/efl/WebCoreSupport/ChromeClientEfl.cpp b/Source/WebKit/efl/WebCoreSupport/ChromeClientEfl.cpp index 0fe0ffab6..64ebba386 100644 --- a/Source/WebKit/efl/WebCoreSupport/ChromeClientEfl.cpp +++ b/Source/WebKit/efl/WebCoreSupport/ChromeClientEfl.cpp @@ -128,7 +128,7 @@ FloatRect ChromeClientEfl::windowRect() void ChromeClientEfl::setWindowRect(const FloatRect& rect) { - if (!ewk_view_setting_enable_auto_resize_window_get(m_view)) + if (!ewk_view_setting_enable_auto_resize_window_get(m_view) || rect.isEmpty()) return; Ecore_Evas* ee = ecore_evas_ecore_evas_get(evas_object_evas_get(m_view)); diff --git a/Source/WebKit/gtk/WebCoreSupport/ChromeClientGtk.cpp b/Source/WebKit/gtk/WebCoreSupport/ChromeClientGtk.cpp index 6152f5080..99f2b85ed 100644 --- a/Source/WebKit/gtk/WebCoreSupport/ChromeClientGtk.cpp +++ b/Source/WebKit/gtk/WebCoreSupport/ChromeClientGtk.cpp @@ -138,7 +138,8 @@ void ChromeClient::setWindowRect(const FloatRect& rect) GtkWidget* window = gtk_widget_get_toplevel(GTK_WIDGET(m_webView)); if (widgetIsOnscreenToplevelWindow(window)) { gtk_window_move(GTK_WINDOW(window), intrect.x(), intrect.y()); - gtk_window_resize(GTK_WINDOW(window), intrect.width(), intrect.height()); + if (!intrect.isEmpty()) + gtk_window_resize(GTK_WINDOW(window), intrect.width(), intrect.height()); } } diff --git a/Source/WebKit/qt/tests/qwebpage/tst_qwebpage.cpp b/Source/WebKit/qt/tests/qwebpage/tst_qwebpage.cpp index 2853d600a..aae3bbcca 100644 --- a/Source/WebKit/qt/tests/qwebpage/tst_qwebpage.cpp +++ b/Source/WebKit/qt/tests/qwebpage/tst_qwebpage.cpp @@ -186,6 +186,7 @@ private Q_SLOTS: void renderOnRepaintRequestedShouldNotRecurse(); void loadSignalsOrder_data(); void loadSignalsOrder(); + void openWindowDefaultSize(); #ifdef Q_OS_MAC void macCopyUnicodeToClipboard(); @@ -410,10 +411,13 @@ void tst_QWebPage::consoleOutput() QCOMPARE(page.lineNumbers.at(0), 1); } -class TestPage : public QWebPage -{ +class TestPage : public QWebPage { + Q_OBJECT public: - TestPage(QObject* parent = 0) : QWebPage(parent) {} + TestPage(QObject* parent = 0) : QWebPage(parent) + { + connect(this, SIGNAL(geometryChangeRequested(QRect)), this, SLOT(slotGeometryChangeRequested(QRect))); + } struct Navigation { QPointer<QWebFrame> frame; @@ -422,7 +426,8 @@ public: }; QList<Navigation> navigations; - QList<QWebPage*> createdWindows; + QList<TestPage*> createdWindows; + QRect requestedGeometry; virtual bool acceptNavigationRequest(QWebFrame* frame, const QNetworkRequest &request, NavigationType type) { Navigation n; @@ -434,10 +439,15 @@ public: } virtual QWebPage* createWindow(WebWindowType) { - QWebPage* page = new TestPage(this); + TestPage* page = new TestPage(this); createdWindows.append(page); return page; } + +private Q_SLOTS: + void slotGeometryChangeRequested(const QRect& geom) { + requestedGeometry = geom; + } }; void tst_QWebPage::popupFormSubmission() @@ -3253,5 +3263,29 @@ void tst_QWebPage::undoActionHaveCustomText() QVERIFY(typingActionText != alignActionText); } +void tst_QWebPage::openWindowDefaultSize() +{ + TestPage page; + page.settings()->setAttribute(QWebSettings::JavascriptCanOpenWindows, true); + // Open a default window. + page.mainFrame()->evaluateJavaScript("window.open()"); + // Open a too small window. + page.mainFrame()->evaluateJavaScript("window.open('', '', 'width=10,height=10')"); + + QTest::qWait(500); + // The number of popups created should be two. + QVERIFY(page.createdWindows.size() == 2); + + QRect requestedGeometry = page.createdWindows[0]->requestedGeometry; + // Check default size has been requested. + QVERIFY(requestedGeometry.width() == 0); + QVERIFY(requestedGeometry.height() == 0); + + requestedGeometry = page.createdWindows[1]->requestedGeometry; + // Check minimum size has been requested. + QVERIFY(requestedGeometry.width() == 100); + QVERIFY(requestedGeometry.height() == 100); +} + QTEST_MAIN(tst_QWebPage) #include "tst_qwebpage.moc" |
