Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(134)

Unified Diff: third_party/WebKit/Source/web/tests/TopControlsTest.cpp

Issue 1611693002: Revert of Don't change layout size due to top control show/hide (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Created 4 years, 11 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
Index: third_party/WebKit/Source/web/tests/TopControlsTest.cpp
diff --git a/third_party/WebKit/Source/web/tests/TopControlsTest.cpp b/third_party/WebKit/Source/web/tests/TopControlsTest.cpp
index 5ed7c95296884dff751058108392aaca81f6ffd0..c81cd278c74753bc76b7cdc33eafa6cd23ffdcee 100644
--- a/third_party/WebKit/Source/web/tests/TopControlsTest.cpp
+++ b/third_party/WebKit/Source/web/tests/TopControlsTest.cpp
@@ -29,7 +29,6 @@
*/
#include "core/frame/TopControls.h"
-#include "core/dom/ClientRect.h"
#include "core/frame/FrameHost.h"
#include "core/frame/FrameView.h"
#include "core/frame/LocalFrame.h"
@@ -38,7 +37,6 @@
#include "platform/testing/URLTestHelpers.h"
#include "public/platform/Platform.h"
#include "public/platform/WebUnitTestSupport.h"
-#include "public/web/WebElement.h"
#include "public/web/WebSettings.h"
#include "testing/gmock/include/gmock/gmock.h"
#include "testing/gtest/include/gtest/gtest.h"
@@ -59,10 +57,6 @@
registerMockedHttpURLLoad("overflow-scrolling.html");
registerMockedHttpURLLoad("iframe-scrolling.html");
registerMockedHttpURLLoad("iframe-scrolling-inner.html");
- registerMockedHttpURLLoad("percent-height.html");
- registerMockedHttpURLLoad("vh-height.html");
- registerMockedHttpURLLoad("vh-height-width-800.html");
- registerMockedHttpURLLoad("vh-height-width-800-extra-wide.html");
}
~TopControlsTest() override
@@ -118,13 +112,6 @@
webViewImpl()->handleInputEvent(generateEvent(WebInputEvent::GestureScrollEnd));
}
- PassRefPtrWillBeRawPtr<Element> getElementById(const WebString& id)
- {
- return static_cast<PassRefPtrWillBeRawPtr<Element>>(
- webViewImpl()->mainFrame()->document().getElementById(id));
- }
-
-
WebViewImpl* webViewImpl() const { return m_helper.webViewImpl(); }
LocalFrame* frame() const { return m_helper.webViewImpl()->mainFrameImpl()->frame(); }
VisualViewport& visualViewport() const { return m_helper.webViewImpl()->page()->frameHost().visualViewport(); }
@@ -557,176 +544,4 @@
EXPECT_POINT_EQ(IntPoint(0, 90), frame()->view()->scrollPosition());
}
-// Ensure that top controls do not affect the layout by showing and hiding
-// except for position: fixed elements.
-TEST_F(TopControlsTest, MAYBE(DontAffectLayoutHeight))
-{
- // Initialize with the top controls showing.
- WebViewImpl* webView = initialize("percent-height.html");
- webView->setTopControlsHeight(100.f, true);
- webView->updateTopControlsState(
- WebTopControlsBoth, WebTopControlsShown, false);
- webView->topControls().setShownRatio(1);
- webView->resize(WebSize(400, 300));
- webView->updateAllLifecyclePhases();
-
- ASSERT_EQ(100.f, webView->topControls().contentOffset());
-
- // When the top controls are showing, there's 300px for the layout height so
- // 50% should result in both the position:fixed and position: absolute divs
- // having 150px of height.
- RefPtrWillBeRawPtr<Element> absPos =
- getElementById(WebString::fromUTF8("abs"));
- RefPtrWillBeRawPtr<Element> fixedPos =
- getElementById(WebString::fromUTF8("fixed"));
- EXPECT_FLOAT_EQ(150.f, absPos->getBoundingClientRect()->height());
- EXPECT_FLOAT_EQ(150.f, fixedPos->getBoundingClientRect()->height());
-
- // The layout size on the FrameView should not include the top controls.
- EXPECT_EQ(300, frame()->view()->layoutSize(IncludeScrollbars).height());
-
- // Hide the top controls.
- verticalScroll(-100.f);
- webView->setTopControlsHeight(100.f, false);
- webView->resize(WebSize(400, 400));
- webView->updateAllLifecyclePhases();
-
- ASSERT_EQ(0.f, webView->topControls().contentOffset());
-
- // Hiding the top controls shouldn't change the height of the initial
- // containing block for non-position: fixed. Position: fixed however should
- // use the entire height of the viewport however.
- EXPECT_FLOAT_EQ(150.f, absPos->getBoundingClientRect()->height());
- EXPECT_FLOAT_EQ(200.f, fixedPos->getBoundingClientRect()->height());
-
- // The layout size should not change as a result of top controls hiding.
- EXPECT_EQ(300, frame()->view()->layoutSize(IncludeScrollbars).height());
-}
-
-// Ensure that top controls do not affect vh units.
-TEST_F(TopControlsTest, MAYBE(DontAffectVHUnits))
-{
- // Initialize with the top controls showing.
- WebViewImpl* webView = initialize("vh-height.html");
- webView->setTopControlsHeight(100.f, true);
- webView->updateTopControlsState(
- WebTopControlsBoth, WebTopControlsShown, false);
- webView->topControls().setShownRatio(1);
- webView->resize(WebSize(400, 300));
- webView->updateAllLifecyclePhases();
-
- ASSERT_EQ(100.f, webView->topControls().contentOffset());
-
- // 'vh' units should be based on the viewport when the top controls are
- // hidden.
- RefPtrWillBeRawPtr<Element> absPos =
- getElementById(WebString::fromUTF8("abs"));
- RefPtrWillBeRawPtr<Element> fixedPos =
- getElementById(WebString::fromUTF8("fixed"));
- EXPECT_FLOAT_EQ(200.f, absPos->getBoundingClientRect()->height());
- EXPECT_FLOAT_EQ(200.f, fixedPos->getBoundingClientRect()->height());
-
- // The size used for viewport units should not be reduced by the top
- // controls.
- EXPECT_EQ(400, frame()->view()->viewportSizeForViewportUnits().height());
-
- // Hide the top controls.
- verticalScroll(-100.f);
- webView->setTopControlsHeight(100.f, false);
- webView->resize(WebSize(400, 400));
- webView->updateAllLifecyclePhases();
-
- ASSERT_EQ(0.f, webView->topControls().contentOffset());
-
- // vh units should be static with respect to the top controls so neighter
- // <div> should change size are a result of the top controls hiding.
- EXPECT_FLOAT_EQ(200.f, absPos->getBoundingClientRect()->height());
- EXPECT_FLOAT_EQ(200.f, fixedPos->getBoundingClientRect()->height());
-
- // The viewport size used for vh units should not change as a result of top
- // controls hiding.
- EXPECT_EQ(400, frame()->view()->viewportSizeForViewportUnits().height());
-}
-
-// Ensure that on a legacy page (there's a non-1 minimum scale) 100vh units fill
-// the viewport, with top controls hidden, when the viewport encompasses the
-// layout width.
-TEST_F(TopControlsTest, MAYBE(DontAffectVHUnitsWithScale))
-{
- // Initialize with the top controls showing.
- WebViewImpl* webView = initialize("vh-height-width-800.html");
- webView->setTopControlsHeight(100.f, true);
- webView->updateTopControlsState(
- WebTopControlsBoth, WebTopControlsShown, false);
- webView->topControls().setShownRatio(1);
- webView->resize(WebSize(400, 300));
- webView->updateAllLifecyclePhases();
-
- ASSERT_EQ(100.f, webView->topControls().contentOffset());
-
- // Device viewport is 400px but the page is width=800 so minimum-scale
- // should be 0.5. This is also the scale at which the viewport fills the
- // layout width.
- ASSERT_EQ(0.5f, webView->minimumPageScaleFactor());
-
- // We should size vh units so that 100vh fills the viewport at min-scale so
- // we have to account for the minimum page scale factor. Since both boxes
- // are 50vh, and layout scale = 0.5, we have a vh viewport of 400 / 0.5 = 800
- // so we expect 50vh to be 400px.
- RefPtrWillBeRawPtr<Element> absPos =
- getElementById(WebString::fromUTF8("abs"));
- RefPtrWillBeRawPtr<Element> fixedPos =
- getElementById(WebString::fromUTF8("fixed"));
- EXPECT_FLOAT_EQ(400.f, absPos->getBoundingClientRect()->height());
- EXPECT_FLOAT_EQ(400.f, fixedPos->getBoundingClientRect()->height());
-
- // The size used for viewport units should not be reduced by the top
- // controls.
- EXPECT_EQ(800, frame()->view()->viewportSizeForViewportUnits().height());
-
- // Hide the top controls.
- verticalScroll(-100.f);
- webView->setTopControlsHeight(100.f, false);
- webView->resize(WebSize(400, 400));
- webView->updateAllLifecyclePhases();
-
- ASSERT_EQ(0.f, webView->topControls().contentOffset());
-
- // vh units should be static with respect to the top controls so neighter
- // <div> should change size are a result of the top controls hiding.
- EXPECT_FLOAT_EQ(400.f, absPos->getBoundingClientRect()->height());
- EXPECT_FLOAT_EQ(400.f, fixedPos->getBoundingClientRect()->height());
-
- // The viewport size used for vh units should not change as a result of top
- // controls hiding.
- EXPECT_EQ(800, frame()->view()->viewportSizeForViewportUnits().height());
-}
-
-// Ensure that on a legacy page (there's a non-1 minimum scale) whose viewport
-// at minimum-scale is larger than the layout size, 100vh units fill the
-// viewport, with top controls hidden, when the viewport is scaled such that
-// its width equals the layout width.
-TEST_F(TopControlsTest, MAYBE(DontAffectVHUnitsUseLayoutSize))
-{
- // Initialize with the top controls showing.
- WebViewImpl* webView = initialize("vh-height-width-800-extra-wide.html");
- webView->setTopControlsHeight(100.f, true);
- webView->updateTopControlsState(
- WebTopControlsBoth, WebTopControlsShown, false);
- webView->topControls().setShownRatio(1);
- webView->resize(WebSize(400, 300));
- webView->updateAllLifecyclePhases();
-
- ASSERT_EQ(100.f, webView->topControls().contentOffset());
-
- // Device viewport is 400px and page is width=800 but there's an element
- // that's 1600px wide so the minimum scale is 0.25 to encompass that.
- ASSERT_EQ(0.25f, webView->minimumPageScaleFactor());
-
- // The viewport will match the layout width at scale=0.5 so the height used
- // for vh should be (300 / 0.5) for the layout height + (100 / 0.5) for top
- // controls = 800.
- EXPECT_EQ(800, frame()->view()->viewportSizeForViewportUnits().height());
-}
-
} // namespace blink
« no previous file with comments | « third_party/WebKit/Source/web/WebViewImpl.cpp ('k') | third_party/WebKit/Source/web/tests/data/percent-height.html » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698