Index: Source/web/tests/WebFrameTest.cpp |
diff --git a/Source/web/tests/WebFrameTest.cpp b/Source/web/tests/WebFrameTest.cpp |
index a308f78579bc9d135c01d7b8c267e2aee32e7790..27ec3aa8a236785bfa831cc52eec6a3630d22911 100644 |
--- a/Source/web/tests/WebFrameTest.cpp |
+++ b/Source/web/tests/WebFrameTest.cpp |
@@ -1028,6 +1028,14 @@ TEST_F(WebFrameTest, SetLoadWithOverviewModeToFalseAndNoWideViewport) |
EXPECT_EQ(1.0f, webViewHelper.webView()->pageScaleFactor()); |
} |
+// Viewport settings need to be set before the page gets loaded |
+static void enableViewportSettings(WebSettings* settings) |
+{ |
+ settings->setViewportMetaEnabled(true); |
+ settings->setViewportEnabled(true); |
+ settings->setMainFrameResizesAreOrientationChanges(true); |
+} |
+ |
TEST_F(WebFrameTest, NoWideViewportIgnoresPageViewportWidth) |
{ |
UseMockScrollbarSettings mockScrollbarSettings; |
@@ -1061,8 +1069,7 @@ TEST_F(WebFrameTest, NoWideViewportIgnoresPageViewportWidthButAccountsScale) |
int viewportHeight = 480; |
FrameTestHelpers::WebViewHelper webViewHelper; |
- webViewHelper.initializeAndLoad(m_baseURL + "viewport-wide-2x-initial-scale.html", true, 0, &client); |
- webViewHelper.webView()->settings()->setViewportEnabled(true); |
+ webViewHelper.initializeAndLoad(m_baseURL + "viewport-wide-2x-initial-scale.html", true, 0, &client, enableViewportSettings); |
webViewHelper.webView()->settings()->setWideViewportQuirkEnabled(true); |
webViewHelper.webView()->settings()->setUseWideViewport(false); |
webViewHelper.webView()->resize(WebSize(viewportWidth, viewportHeight)); |
@@ -1146,8 +1153,7 @@ TEST_F(WebFrameTest, PageViewportInitialScaleOverridesLoadWithOverviewMode) |
int viewportHeight = 480; |
FrameTestHelpers::WebViewHelper webViewHelper; |
- webViewHelper.initializeAndLoad(m_baseURL + "viewport-wide-2x-initial-scale.html", true, 0, &client); |
- webViewHelper.webView()->settings()->setViewportEnabled(true); |
+ webViewHelper.initializeAndLoad(m_baseURL + "viewport-wide-2x-initial-scale.html", true, 0, &client, enableViewportSettings); |
webViewHelper.webView()->settings()->setLoadWithOverviewMode(false); |
webViewHelper.webView()->resize(WebSize(viewportWidth, viewportHeight)); |
@@ -1199,8 +1205,7 @@ TEST_F(WebFrameTest, PermanentInitialPageScaleFactorOverridesLoadWithOverviewMod |
float enforcedPageScalePactor = 0.5f; |
FrameTestHelpers::WebViewHelper webViewHelper; |
- webViewHelper.initializeAndLoad(m_baseURL + "viewport-auto-initial-scale.html", true, 0, &client); |
- webViewHelper.webView()->settings()->setViewportEnabled(true); |
+ webViewHelper.initializeAndLoad(m_baseURL + "viewport-auto-initial-scale.html", true, 0, &client, enableViewportSettings); |
webViewHelper.webView()->settings()->setLoadWithOverviewMode(false); |
webViewHelper.webView()->setInitialPageScaleOverride(enforcedPageScalePactor); |
webViewHelper.webView()->resize(WebSize(viewportWidth, viewportHeight)); |
@@ -1220,8 +1225,7 @@ TEST_F(WebFrameTest, PermanentInitialPageScaleFactorOverridesPageViewportInitial |
float enforcedPageScaleFactor = 0.5f; |
FrameTestHelpers::WebViewHelper webViewHelper; |
- webViewHelper.initializeAndLoad(m_baseURL + "viewport-wide-2x-initial-scale.html", true, 0, &client); |
- webViewHelper.webView()->settings()->setViewportEnabled(true); |
+ webViewHelper.initializeAndLoad(m_baseURL + "viewport-wide-2x-initial-scale.html", true, 0, &client, enableViewportSettings); |
webViewHelper.webView()->setInitialPageScaleOverride(enforcedPageScaleFactor); |
webViewHelper.webView()->resize(WebSize(viewportWidth, viewportHeight)); |
@@ -1239,8 +1243,7 @@ TEST_F(WebFrameTest, WideViewportInitialScaleDoesNotExpandFixedLayoutWidth) |
int viewportHeight = 480; |
FrameTestHelpers::WebViewHelper webViewHelper; |
- webViewHelper.initializeAndLoad(m_baseURL + "viewport-device-0.5x-initial-scale.html", true, 0, &client); |
- webViewHelper.webView()->settings()->setViewportEnabled(true); |
+ webViewHelper.initializeAndLoad(m_baseURL + "viewport-device-0.5x-initial-scale.html", true, 0, &client, enableViewportSettings); |
webViewHelper.webView()->settings()->setWideViewportQuirkEnabled(true); |
webViewHelper.webView()->settings()->setUseWideViewport(true); |
webViewHelper.webView()->settings()->setViewportMetaLayoutSizeQuirk(true); |
@@ -1266,8 +1269,7 @@ TEST_F(WebFrameTest, WideViewportAndWideContentWithInitialScale) |
int viewportHeight = 800; |
FrameTestHelpers::WebViewHelper webViewHelper; |
- webViewHelper.initializeAndLoad("about:blank", true, 0, &client); |
- webViewHelper.webView()->settings()->setViewportEnabled(true); |
+ webViewHelper.initializeAndLoad("about:blank", true, 0, &client, enableViewportSettings); |
webViewHelper.webView()->settings()->setWideViewportQuirkEnabled(true); |
webViewHelper.webView()->settings()->setUseWideViewport(true); |
webViewHelper.webView()->settings()->setViewportMetaLayoutSizeQuirk(true); |
@@ -1294,8 +1296,7 @@ TEST_F(WebFrameTest, ZeroValuesQuirk) |
int viewportHeight = 480; |
FrameTestHelpers::WebViewHelper webViewHelper; |
- webViewHelper.initialize(true, 0, &client); |
- webViewHelper.webView()->settings()->setViewportEnabled(true); |
+ webViewHelper.initialize(true, 0, &client, enableViewportSettings); |
webViewHelper.webView()->settings()->setViewportMetaZeroValuesQuirk(true); |
webViewHelper.webView()->settings()->setWideViewportQuirkEnabled(true); |
FrameTestHelpers::loadFrame(webViewHelper.webView()->mainFrame(), m_baseURL + "viewport-zero-values.html"); |
@@ -1362,8 +1363,7 @@ TEST_F(WebFrameTest, NonZeroValuesNoQuirk) |
float expectedPageScaleFactor = 0.5f; |
FrameTestHelpers::WebViewHelper webViewHelper; |
- webViewHelper.initialize(true, 0, &client); |
- webViewHelper.webView()->settings()->setViewportEnabled(true); |
+ webViewHelper.initialize(true, 0, &client, enableViewportSettings); |
webViewHelper.webView()->settings()->setViewportMetaZeroValuesQuirk(true); |
webViewHelper.webView()->settings()->setWideViewportQuirkEnabled(true); |
FrameTestHelpers::loadFrame(webViewHelper.webView()->mainFrame(), m_baseURL + "viewport-nonzero-values.html"); |
@@ -1540,8 +1540,7 @@ TEST_F(WebFrameTest, targetDensityDpiHigh) |
client.m_screenInfo.deviceScaleFactor = deviceScaleFactor; |
FrameTestHelpers::WebViewHelper webViewHelper; |
- webViewHelper.initializeAndLoad(m_baseURL + "viewport-target-densitydpi-high.html", true, 0, &client); |
- webViewHelper.webView()->settings()->setViewportEnabled(true); |
+ webViewHelper.initializeAndLoad(m_baseURL + "viewport-target-densitydpi-high.html", true, 0, &client, enableViewportSettings); |
webViewHelper.webView()->settings()->setWideViewportQuirkEnabled(true); |
webViewHelper.webView()->settings()->setSupportDeprecatedTargetDensityDPI(true); |
webViewHelper.webView()->resize(WebSize(viewportWidth, viewportHeight)); |
@@ -1570,8 +1569,7 @@ TEST_F(WebFrameTest, targetDensityDpiDevice) |
client.m_screenInfo.deviceScaleFactor = deviceScaleFactors[i]; |
FrameTestHelpers::WebViewHelper webViewHelper; |
- webViewHelper.initializeAndLoad(m_baseURL + "viewport-target-densitydpi-device.html", true, 0, &client); |
- webViewHelper.webView()->settings()->setViewportEnabled(true); |
+ webViewHelper.initializeAndLoad(m_baseURL + "viewport-target-densitydpi-device.html", true, 0, &client, enableViewportSettings); |
webViewHelper.webView()->settings()->setWideViewportQuirkEnabled(true); |
webViewHelper.webView()->settings()->setSupportDeprecatedTargetDensityDPI(true); |
webViewHelper.webView()->resize(WebSize(viewportWidth, viewportHeight)); |
@@ -1597,8 +1595,7 @@ TEST_F(WebFrameTest, targetDensityDpiDeviceAndFixedWidth) |
client.m_screenInfo.deviceScaleFactor = deviceScaleFactors[i]; |
FrameTestHelpers::WebViewHelper webViewHelper; |
- webViewHelper.initializeAndLoad(m_baseURL + "viewport-target-densitydpi-device-and-fixed-width.html", true, 0, &client); |
- webViewHelper.webView()->settings()->setViewportEnabled(true); |
+ webViewHelper.initializeAndLoad(m_baseURL + "viewport-target-densitydpi-device-and-fixed-width.html", true, 0, &client, enableViewportSettings); |
webViewHelper.webView()->settings()->setWideViewportQuirkEnabled(true); |
webViewHelper.webView()->settings()->setSupportDeprecatedTargetDensityDPI(true); |
webViewHelper.webView()->settings()->setUseWideViewport(true); |
@@ -1621,8 +1618,7 @@ TEST_F(WebFrameTest, NoWideViewportAndScaleLessThanOne) |
int viewportHeight = 480; |
FrameTestHelpers::WebViewHelper webViewHelper; |
- webViewHelper.initializeAndLoad(m_baseURL + "viewport-initial-scale-less-than-1.html", true, 0, &client); |
- webViewHelper.webView()->settings()->setViewportEnabled(true); |
+ webViewHelper.initializeAndLoad(m_baseURL + "viewport-initial-scale-less-than-1.html", true, 0, &client, enableViewportSettings); |
webViewHelper.webView()->settings()->setSupportDeprecatedTargetDensityDPI(true); |
webViewHelper.webView()->settings()->setWideViewportQuirkEnabled(true); |
webViewHelper.webView()->settings()->setUseWideViewport(false); |
@@ -1645,8 +1641,7 @@ TEST_F(WebFrameTest, NoWideViewportAndScaleLessThanOneWithDeviceWidth) |
int viewportHeight = 480; |
FrameTestHelpers::WebViewHelper webViewHelper; |
- webViewHelper.initializeAndLoad(m_baseURL + "viewport-initial-scale-less-than-1-device-width.html", true, 0, &client); |
- webViewHelper.webView()->settings()->setViewportEnabled(true); |
+ webViewHelper.initializeAndLoad(m_baseURL + "viewport-initial-scale-less-than-1-device-width.html", true, 0, &client, enableViewportSettings); |
webViewHelper.webView()->settings()->setSupportDeprecatedTargetDensityDPI(true); |
webViewHelper.webView()->settings()->setWideViewportQuirkEnabled(true); |
webViewHelper.webView()->settings()->setUseWideViewport(false); |
@@ -1680,8 +1675,7 @@ protected: |
const float aspectRatio = static_cast<float>(viewportSize.width) / viewportSize.height; |
FrameTestHelpers::WebViewHelper webViewHelper; |
- webViewHelper.initializeAndLoad(m_baseURL + url, true); |
- webViewHelper.webView()->settings()->setViewportEnabled(true); |
+ webViewHelper.initializeAndLoad(m_baseURL + url, true, 0, 0, enableViewportSettings); |
// Origin scrollOffsets preserved under resize. |
{ |
@@ -1856,8 +1850,7 @@ TEST_F(WebFrameTest, CanOverrideScaleLimits) |
int viewportHeight = 480; |
FrameTestHelpers::WebViewHelper webViewHelper; |
- webViewHelper.initializeAndLoad(m_baseURL + "no_scale_for_you.html", true, 0, &client); |
- webViewHelper.webView()->settings()->setViewportEnabled(true); |
+ webViewHelper.initializeAndLoad(m_baseURL + "no_scale_for_you.html", true, 0, &client, enableViewportSettings); |
webViewHelper.webView()->resize(WebSize(viewportWidth, viewportHeight)); |
EXPECT_EQ(2.0f, webViewHelper.webView()->minimumPageScaleFactor()); |