| 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());
|
|
|