| Index: Source/web/tests/WebFrameTest.cpp
 | 
| diff --git a/Source/web/tests/WebFrameTest.cpp b/Source/web/tests/WebFrameTest.cpp
 | 
| index 7edc8b41a7ebd47c8c690c6086676cd48ab5eacb..5fe9be24f984913db91dc7cf43fd236c58311e42 100644
 | 
| --- a/Source/web/tests/WebFrameTest.cpp
 | 
| +++ b/Source/web/tests/WebFrameTest.cpp
 | 
| @@ -998,6 +998,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;
 | 
| @@ -1031,8 +1039,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));
 | 
| @@ -1116,8 +1123,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));
 | 
|  
 | 
| @@ -1169,8 +1175,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));
 | 
| @@ -1190,8 +1195,7 @@ TEST_F(WebFrameTest, PermanentInitialPageScaleFactorOverridesPageViewportInitial
 | 
|      float enforcedPageScalePactor = 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(enforcedPageScalePactor);
 | 
|      webViewHelper.webView()->resize(WebSize(viewportWidth, viewportHeight));
 | 
|  
 | 
| @@ -1209,8 +1213,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);
 | 
| @@ -1230,8 +1233,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);
 | 
| @@ -1258,8 +1260,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");
 | 
| @@ -1326,8 +1327,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");
 | 
| @@ -1521,8 +1521,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));
 | 
| @@ -1551,8 +1550,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));
 | 
| @@ -1578,8 +1576,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);
 | 
| @@ -1602,8 +1599,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);
 | 
| @@ -1626,8 +1622,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);
 | 
| @@ -1661,8 +1656,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.
 | 
|          {
 | 
| @@ -1837,8 +1831,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());
 | 
| 
 |