| OLD | NEW |
| 1 // Copyright 2015 The Chromium Authors. All rights reserved. | 1 // Copyright 2015 The Chromium Authors. All rights reserved. |
| 2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
| 3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
| 4 | 4 |
| 5 #include "platform/scroll/ScrollableArea.h" | 5 #include "platform/scroll/ScrollableArea.h" |
| 6 | 6 |
| 7 #include "platform/graphics/GraphicsLayer.h" | 7 #include "platform/graphics/GraphicsLayer.h" |
| 8 #include "platform/scroll/ScrollbarTheme.h" | 8 #include "platform/scroll/ScrollbarTheme.h" |
| 9 #include "platform/scroll/ScrollbarThemeMock.h" | 9 #include "platform/scroll/ScrollbarThemeMock.h" |
| 10 #include "platform/testing/TestingPlatformSupport.h" | 10 #include "platform/testing/TestingPlatformSupport.h" |
| 11 #include "public/platform/Platform.h" | 11 #include "public/platform/Platform.h" |
| 12 #include "testing/gmock/include/gmock/gmock.h" | 12 #include "testing/gmock/include/gmock/gmock.h" |
| 13 #include "testing/gtest/include/gtest/gtest.h" | 13 #include "testing/gtest/include/gtest/gtest.h" |
| 14 | 14 |
| 15 namespace blink { | 15 namespace blink { |
| 16 | 16 |
| 17 namespace { | 17 namespace { |
| 18 | 18 |
| 19 using testing::_; |
| 19 using testing::Return; | 20 using testing::Return; |
| 20 | 21 |
| 21 class MockScrollableArea : public NoBaseWillBeGarbageCollectedFinalized<MockScro
llableArea>, public ScrollableArea { | 22 class MockScrollableArea : public NoBaseWillBeGarbageCollectedFinalized<MockScro
llableArea>, public ScrollableArea { |
| 22 WILL_BE_USING_GARBAGE_COLLECTED_MIXIN(MockScrollableArea); | 23 WILL_BE_USING_GARBAGE_COLLECTED_MIXIN(MockScrollableArea); |
| 23 public: | 24 public: |
| 24 static PassOwnPtrWillBeRawPtr<MockScrollableArea> create(const IntPoint& max
imumScrollPosition) | 25 static PassOwnPtrWillBeRawPtr<MockScrollableArea> create(const IntPoint& max
imumScrollPosition) |
| 25 { | 26 { |
| 26 return adoptPtrWillBeNoop(new MockScrollableArea(maximumScrollPosition))
; | 27 return adoptPtrWillBeNoop(new MockScrollableArea(maximumScrollPosition))
; |
| 27 } | 28 } |
| 28 | 29 |
| 29 MOCK_CONST_METHOD0(isActive, bool()); | 30 MOCK_CONST_METHOD0(isActive, bool()); |
| 30 MOCK_CONST_METHOD1(scrollSize, int(ScrollbarOrientation)); | 31 MOCK_CONST_METHOD1(scrollSize, int(ScrollbarOrientation)); |
| 31 MOCK_CONST_METHOD0(isScrollCornerVisible, bool()); | 32 MOCK_CONST_METHOD0(isScrollCornerVisible, bool()); |
| 32 MOCK_CONST_METHOD0(scrollCornerRect, IntRect()); | 33 MOCK_CONST_METHOD0(scrollCornerRect, IntRect()); |
| 34 MOCK_CONST_METHOD0(horizontalScrollbar, Scrollbar*()); |
| 35 MOCK_CONST_METHOD0(verticalScrollbar, Scrollbar*()); |
| 33 MOCK_METHOD0(scrollControlWasSetNeedsPaintInvalidation, void()); | 36 MOCK_METHOD0(scrollControlWasSetNeedsPaintInvalidation, void()); |
| 34 MOCK_CONST_METHOD0(enclosingScrollableArea, ScrollableArea*()); | 37 MOCK_CONST_METHOD0(enclosingScrollableArea, ScrollableArea*()); |
| 35 MOCK_CONST_METHOD1(visibleContentRect, IntRect(IncludeScrollbarsInRect)); | 38 MOCK_CONST_METHOD1(visibleContentRect, IntRect(IncludeScrollbarsInRect)); |
| 36 MOCK_CONST_METHOD0(contentsSize, IntSize()); | 39 MOCK_CONST_METHOD0(contentsSize, IntSize()); |
| 37 MOCK_CONST_METHOD0(scrollableAreaBoundingBox, IntRect()); | 40 MOCK_CONST_METHOD0(scrollableAreaBoundingBox, IntRect()); |
| 38 MOCK_CONST_METHOD0(layerForHorizontalScrollbar, GraphicsLayer*()); | 41 MOCK_CONST_METHOD0(layerForHorizontalScrollbar, GraphicsLayer*()); |
| 42 MOCK_CONST_METHOD0(layerForVerticalScrollbar, GraphicsLayer*()); |
| 39 | 43 |
| 40 bool userInputScrollable(ScrollbarOrientation) const override { return true;
} | 44 bool userInputScrollable(ScrollbarOrientation) const override { return true;
} |
| 41 bool scrollbarsCanBeActive () const override { return true; } | 45 bool scrollbarsCanBeActive () const override { return true; } |
| 42 bool shouldPlaceVerticalScrollbarOnLeft() const override { return false; } | 46 bool shouldPlaceVerticalScrollbarOnLeft() const override { return false; } |
| 43 void setScrollOffset(const IntPoint& offset, ScrollType) override { m_scroll
Position = offset.shrunkTo(m_maximumScrollPosition); } | 47 void setScrollOffset(const IntPoint& offset, ScrollType) override { m_scroll
Position = offset.shrunkTo(m_maximumScrollPosition); } |
| 44 IntPoint scrollPosition() const override { return m_scrollPosition; } | 48 IntPoint scrollPosition() const override { return m_scrollPosition; } |
| 45 IntPoint minimumScrollPosition() const override { return IntPoint(); } | 49 IntPoint minimumScrollPosition() const override { return IntPoint(); } |
| 46 IntPoint maximumScrollPosition() const override { return m_maximumScrollPosi
tion; } | 50 IntPoint maximumScrollPosition() const override { return m_maximumScrollPosi
tion; } |
| 47 int visibleHeight() const override { return 768; } | 51 int visibleHeight() const override { return 768; } |
| 48 int visibleWidth() const override { return 1024; } | 52 int visibleWidth() const override { return 1024; } |
| 49 bool scrollAnimatorEnabled() const override { return false; } | 53 bool scrollAnimatorEnabled() const override { return false; } |
| 50 int pageStep(ScrollbarOrientation) const override { return 0; } | 54 int pageStep(ScrollbarOrientation) const override { return 0; } |
| 51 | 55 |
| 56 using ScrollableArea::horizontalScrollbarNeedsPaintInvalidation; |
| 57 using ScrollableArea::verticalScrollbarNeedsPaintInvalidation; |
| 58 using ScrollableArea::clearNeedsPaintInvalidationForScrollControls; |
| 59 |
| 52 DEFINE_INLINE_VIRTUAL_TRACE() | 60 DEFINE_INLINE_VIRTUAL_TRACE() |
| 53 { | 61 { |
| 54 ScrollableArea::trace(visitor); | 62 ScrollableArea::trace(visitor); |
| 55 } | 63 } |
| 56 | 64 |
| 57 private: | 65 private: |
| 58 explicit MockScrollableArea(const IntPoint& maximumScrollPosition) | 66 explicit MockScrollableArea(const IntPoint& maximumScrollPosition) |
| 59 : m_maximumScrollPosition(maximumScrollPosition) { } | 67 : m_maximumScrollPosition(maximumScrollPosition) { } |
| 60 | 68 |
| 61 IntPoint m_scrollPosition; | 69 IntPoint m_scrollPosition; |
| (...skipping 31 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 93 OwnPtrWillBeRawPtr<MockScrollableArea> scrollableArea = MockScrollableArea::
create(IntPoint(0, 100)); | 101 OwnPtrWillBeRawPtr<MockScrollableArea> scrollableArea = MockScrollableArea::
create(IntPoint(0, 100)); |
| 94 scrollableArea->setScrollPosition(IntPoint(0, 10000), CompositorScroll); | 102 scrollableArea->setScrollPosition(IntPoint(0, 10000), CompositorScroll); |
| 95 EXPECT_EQ(100.0, scrollableArea->scrollAnimator().currentPosition().y()); | 103 EXPECT_EQ(100.0, scrollableArea->scrollAnimator().currentPosition().y()); |
| 96 } | 104 } |
| 97 | 105 |
| 98 namespace { | 106 namespace { |
| 99 | 107 |
| 100 class ScrollbarThemeWithMockInvalidation : public ScrollbarThemeMock { | 108 class ScrollbarThemeWithMockInvalidation : public ScrollbarThemeMock { |
| 101 public: | 109 public: |
| 102 MOCK_CONST_METHOD0(shouldRepaintAllPartsOnInvalidation, bool()); | 110 MOCK_CONST_METHOD0(shouldRepaintAllPartsOnInvalidation, bool()); |
| 111 MOCK_CONST_METHOD3(invalidateOnThumbPositionChange, ScrollbarPart(const Scro
llbarThemeClient&, float, float)); |
| 103 }; | 112 }; |
| 104 | 113 |
| 105 } // namespace | 114 } // namespace |
| 106 | 115 |
| 107 TEST_F(ScrollableAreaTest, ScrollbarTrackAndThumbRepaint) | 116 TEST_F(ScrollableAreaTest, ScrollbarTrackAndThumbRepaint) |
| 108 { | 117 { |
| 109 ScrollbarThemeWithMockInvalidation theme; | 118 ScrollbarThemeWithMockInvalidation theme; |
| 110 OwnPtrWillBeRawPtr<MockScrollableArea> scrollableArea = MockScrollableArea::
create(IntPoint(0, 100)); | 119 OwnPtrWillBeRawPtr<MockScrollableArea> scrollableArea = MockScrollableArea::
create(IntPoint(0, 100)); |
| 111 RefPtrWillBeRawPtr<Scrollbar> scrollbar = Scrollbar::createForTesting(scroll
ableArea.get(), HorizontalScrollbar, RegularScrollbar, &theme); | 120 RefPtrWillBeRawPtr<Scrollbar> scrollbar = Scrollbar::createForTesting(scroll
ableArea.get(), HorizontalScrollbar, RegularScrollbar, &theme); |
| 112 | 121 |
| 113 EXPECT_CALL(theme, shouldRepaintAllPartsOnInvalidation()).WillRepeatedly(Ret
urn(true)); | 122 EXPECT_CALL(theme, shouldRepaintAllPartsOnInvalidation()).WillRepeatedly(Ret
urn(true)); |
| 114 EXPECT_TRUE(scrollbar->trackNeedsRepaint()); | 123 EXPECT_TRUE(scrollbar->trackNeedsRepaint()); |
| 115 EXPECT_TRUE(scrollbar->thumbNeedsRepaint()); | 124 EXPECT_TRUE(scrollbar->thumbNeedsRepaint()); |
| 116 scrollbar->setNeedsPaintInvalidation(NoPart); | 125 scrollbar->setNeedsPaintInvalidation(NoPart); |
| 117 EXPECT_TRUE(scrollbar->trackNeedsRepaint()); | 126 EXPECT_TRUE(scrollbar->trackNeedsRepaint()); |
| 118 EXPECT_TRUE(scrollbar->thumbNeedsRepaint()); | 127 EXPECT_TRUE(scrollbar->thumbNeedsRepaint()); |
| 119 | 128 |
| 120 scrollbar->clearTrackNeedsRepaint(); | 129 scrollbar->clearTrackNeedsRepaint(); |
| 121 scrollbar->clearThumbNeedsRepaint(); | 130 scrollbar->clearThumbNeedsRepaint(); |
| 122 EXPECT_FALSE(scrollbar->trackNeedsRepaint()); | 131 EXPECT_FALSE(scrollbar->trackNeedsRepaint()); |
| 123 EXPECT_FALSE(scrollbar->thumbNeedsRepaint()); | 132 EXPECT_FALSE(scrollbar->thumbNeedsRepaint()); |
| 124 scrollbar->setNeedsPaintInvalidation(NoPart); | 133 scrollbar->setNeedsPaintInvalidation(ThumbPart); |
| 125 EXPECT_TRUE(scrollbar->trackNeedsRepaint()); | 134 EXPECT_TRUE(scrollbar->trackNeedsRepaint()); |
| 126 EXPECT_TRUE(scrollbar->thumbNeedsRepaint()); | 135 EXPECT_TRUE(scrollbar->thumbNeedsRepaint()); |
| 127 | 136 |
| 137 // When not all parts are repainted on invalidation, |
| 138 // setNeedsPaintInvalidation sets repaint bits only on the requested parts. |
| 128 EXPECT_CALL(theme, shouldRepaintAllPartsOnInvalidation()).WillRepeatedly(Ret
urn(false)); | 139 EXPECT_CALL(theme, shouldRepaintAllPartsOnInvalidation()).WillRepeatedly(Ret
urn(false)); |
| 129 scrollbar->clearTrackNeedsRepaint(); | 140 scrollbar->clearTrackNeedsRepaint(); |
| 130 scrollbar->clearThumbNeedsRepaint(); | 141 scrollbar->clearThumbNeedsRepaint(); |
| 131 EXPECT_FALSE(scrollbar->trackNeedsRepaint()); | 142 EXPECT_FALSE(scrollbar->trackNeedsRepaint()); |
| 132 EXPECT_FALSE(scrollbar->thumbNeedsRepaint()); | 143 EXPECT_FALSE(scrollbar->thumbNeedsRepaint()); |
| 133 scrollbar->setNeedsPaintInvalidation(NoPart); | 144 scrollbar->setNeedsPaintInvalidation(ThumbPart); |
| 134 EXPECT_FALSE(scrollbar->trackNeedsRepaint()); | 145 EXPECT_FALSE(scrollbar->trackNeedsRepaint()); |
| 135 EXPECT_FALSE(scrollbar->thumbNeedsRepaint()); | 146 EXPECT_TRUE(scrollbar->thumbNeedsRepaint()); |
| 136 | 147 |
| 137 // Forced GC in order to finalize objects depending on the mock object. | 148 // Forced GC in order to finalize objects depending on the mock object. |
| 138 Heap::collectAllGarbage(); | 149 Heap::collectAllGarbage(); |
| 139 } | 150 } |
| 140 | 151 |
| 141 class MockGraphicsLayerClient : public GraphicsLayerClient { | 152 class MockGraphicsLayerClient : public GraphicsLayerClient { |
| 142 public: | 153 public: |
| 143 IntRect computeInterestRect(const GraphicsLayer*, const IntRect&) const { re
turn IntRect(); } | 154 IntRect computeInterestRect(const GraphicsLayer*, const IntRect&) const { re
turn IntRect(); } |
| 144 void paintContents(const GraphicsLayer*, GraphicsContext&, GraphicsLayerPain
tingPhase, const IntRect&) const override { } | 155 void paintContents(const GraphicsLayer*, GraphicsContext&, GraphicsLayerPain
tingPhase, const IntRect&) const override { } |
| 145 String debugName(const GraphicsLayer*) const override { return String(); } | 156 String debugName(const GraphicsLayer*) const override { return String(); } |
| (...skipping 15 matching lines...) Expand all Loading... |
| 161 graphicsLayer.setSize(FloatSize(111, 222)); | 172 graphicsLayer.setSize(FloatSize(111, 222)); |
| 162 | 173 |
| 163 EXPECT_CALL(*scrollableArea, layerForHorizontalScrollbar()).WillRepeatedly(R
eturn(&graphicsLayer)); | 174 EXPECT_CALL(*scrollableArea, layerForHorizontalScrollbar()).WillRepeatedly(R
eturn(&graphicsLayer)); |
| 164 | 175 |
| 165 RefPtrWillBeRawPtr<Scrollbar> scrollbar = Scrollbar::create(scrollableArea.g
et(), HorizontalScrollbar, RegularScrollbar, nullptr); | 176 RefPtrWillBeRawPtr<Scrollbar> scrollbar = Scrollbar::create(scrollableArea.g
et(), HorizontalScrollbar, RegularScrollbar, nullptr); |
| 166 graphicsLayer.resetTrackedPaintInvalidations(); | 177 graphicsLayer.resetTrackedPaintInvalidations(); |
| 167 scrollbar->setNeedsPaintInvalidation(NoPart); | 178 scrollbar->setNeedsPaintInvalidation(NoPart); |
| 168 EXPECT_TRUE(graphicsLayer.hasTrackedPaintInvalidations()); | 179 EXPECT_TRUE(graphicsLayer.hasTrackedPaintInvalidations()); |
| 169 } | 180 } |
| 170 | 181 |
| 182 TEST_F(ScrollableAreaTest, InvalidatesNonCompositedScrollbarsWhenThumbMoves) |
| 183 { |
| 184 ScrollbarThemeWithMockInvalidation theme; |
| 185 OwnPtrWillBeRawPtr<MockScrollableArea> scrollableArea = MockScrollableArea::
create(IntPoint(100, 100)); |
| 186 RefPtrWillBeRawPtr<Scrollbar> horizontalScrollbar = Scrollbar::createForTest
ing(scrollableArea.get(), HorizontalScrollbar, RegularScrollbar, &theme); |
| 187 RefPtrWillBeRawPtr<Scrollbar> verticalScrollbar = Scrollbar::createForTestin
g(scrollableArea.get(), VerticalScrollbar, RegularScrollbar, &theme); |
| 188 EXPECT_CALL(*scrollableArea, horizontalScrollbar()).WillRepeatedly(Return(ho
rizontalScrollbar.get())); |
| 189 EXPECT_CALL(*scrollableArea, verticalScrollbar()).WillRepeatedly(Return(vert
icalScrollbar.get())); |
| 190 |
| 191 // Regardless of whether the theme invalidates any parts, non-composited |
| 192 // scrollbars have to be repainted if the thumb moves. |
| 193 EXPECT_CALL(*scrollableArea, layerForHorizontalScrollbar()).WillRepeatedly(R
eturn(nullptr)); |
| 194 EXPECT_CALL(*scrollableArea, layerForVerticalScrollbar()).WillRepeatedly(Ret
urn(nullptr)); |
| 195 ASSERT_FALSE(scrollableArea->hasLayerForVerticalScrollbar()); |
| 196 ASSERT_FALSE(scrollableArea->hasLayerForHorizontalScrollbar()); |
| 197 EXPECT_CALL(theme, shouldRepaintAllPartsOnInvalidation()).WillRepeatedly(Ret
urn(false)); |
| 198 EXPECT_CALL(theme, invalidateOnThumbPositionChange(_, _, _)).WillRepeatedly(
Return(NoPart)); |
| 199 |
| 200 // A scroll in each direction should only invalidate one scrollbar. |
| 201 scrollableArea->setScrollPosition(DoublePoint(0, 50), ProgrammaticScroll); |
| 202 EXPECT_FALSE(scrollableArea->horizontalScrollbarNeedsPaintInvalidation()); |
| 203 EXPECT_TRUE(scrollableArea->verticalScrollbarNeedsPaintInvalidation()); |
| 204 scrollableArea->clearNeedsPaintInvalidationForScrollControls(); |
| 205 scrollableArea->setScrollPosition(DoublePoint(50, 50), ProgrammaticScroll); |
| 206 EXPECT_TRUE(scrollableArea->horizontalScrollbarNeedsPaintInvalidation()); |
| 207 EXPECT_FALSE(scrollableArea->verticalScrollbarNeedsPaintInvalidation()); |
| 208 scrollableArea->clearNeedsPaintInvalidationForScrollControls(); |
| 209 |
| 210 // Forced GC in order to finalize objects depending on the mock object. |
| 211 Heap::collectAllGarbage(); |
| 212 } |
| 213 |
| 214 TEST_F(ScrollableAreaTest, InvalidatesCompositedScrollbarsIfPartsNeedRepaint) |
| 215 { |
| 216 ScrollbarThemeWithMockInvalidation theme; |
| 217 OwnPtrWillBeRawPtr<MockScrollableArea> scrollableArea = MockScrollableArea::
create(IntPoint(100, 100)); |
| 218 RefPtrWillBeRawPtr<Scrollbar> horizontalScrollbar = Scrollbar::createForTest
ing(scrollableArea.get(), HorizontalScrollbar, RegularScrollbar, &theme); |
| 219 horizontalScrollbar->clearTrackNeedsRepaint(); |
| 220 horizontalScrollbar->clearThumbNeedsRepaint(); |
| 221 RefPtrWillBeRawPtr<Scrollbar> verticalScrollbar = Scrollbar::createForTestin
g(scrollableArea.get(), VerticalScrollbar, RegularScrollbar, &theme); |
| 222 verticalScrollbar->clearTrackNeedsRepaint(); |
| 223 verticalScrollbar->clearThumbNeedsRepaint(); |
| 224 EXPECT_CALL(*scrollableArea, horizontalScrollbar()).WillRepeatedly(Return(ho
rizontalScrollbar.get())); |
| 225 EXPECT_CALL(*scrollableArea, verticalScrollbar()).WillRepeatedly(Return(vert
icalScrollbar.get())); |
| 226 |
| 227 // Composited scrollbars only need repainting when parts become invalid |
| 228 // (e.g. if the track changes appearance when the thumb reaches the end). |
| 229 MockGraphicsLayerClient graphicsLayerClient; |
| 230 MockGraphicsLayer layerForHorizontalScrollbar(&graphicsLayerClient); |
| 231 layerForHorizontalScrollbar.setDrawsContent(true); |
| 232 layerForHorizontalScrollbar.setSize(FloatSize(10, 10)); |
| 233 MockGraphicsLayer layerForVerticalScrollbar(&graphicsLayerClient); |
| 234 layerForVerticalScrollbar.setDrawsContent(true); |
| 235 layerForVerticalScrollbar.setSize(FloatSize(10, 10)); |
| 236 EXPECT_CALL(*scrollableArea, layerForHorizontalScrollbar()).WillRepeatedly(R
eturn(&layerForHorizontalScrollbar)); |
| 237 EXPECT_CALL(*scrollableArea, layerForVerticalScrollbar()).WillRepeatedly(Ret
urn(&layerForVerticalScrollbar)); |
| 238 ASSERT_TRUE(scrollableArea->hasLayerForHorizontalScrollbar()); |
| 239 ASSERT_TRUE(scrollableArea->hasLayerForVerticalScrollbar()); |
| 240 EXPECT_CALL(theme, shouldRepaintAllPartsOnInvalidation()).WillRepeatedly(Ret
urn(false)); |
| 241 |
| 242 // First, we'll scroll horizontally, and the theme will require repainting |
| 243 // the back button (i.e. the track). |
| 244 EXPECT_CALL(theme, invalidateOnThumbPositionChange(_, _, _)).WillOnce(Return
(BackButtonStartPart)); |
| 245 scrollableArea->setScrollPosition(DoublePoint(50, 0), ProgrammaticScroll); |
| 246 EXPECT_TRUE(layerForHorizontalScrollbar.hasTrackedPaintInvalidations()); |
| 247 EXPECT_FALSE(layerForVerticalScrollbar.hasTrackedPaintInvalidations()); |
| 248 EXPECT_TRUE(horizontalScrollbar->trackNeedsRepaint()); |
| 249 EXPECT_FALSE(horizontalScrollbar->thumbNeedsRepaint()); |
| 250 layerForHorizontalScrollbar.resetTrackedPaintInvalidations(); |
| 251 horizontalScrollbar->clearTrackNeedsRepaint(); |
| 252 |
| 253 // Next, we'll scroll vertically, but invalidate the thumb. |
| 254 EXPECT_CALL(theme, invalidateOnThumbPositionChange(_, _, _)).WillOnce(Return
(ThumbPart)); |
| 255 scrollableArea->setScrollPosition(DoublePoint(50, 50), ProgrammaticScroll); |
| 256 EXPECT_FALSE(layerForHorizontalScrollbar.hasTrackedPaintInvalidations()); |
| 257 EXPECT_TRUE(layerForVerticalScrollbar.hasTrackedPaintInvalidations()); |
| 258 EXPECT_FALSE(verticalScrollbar->trackNeedsRepaint()); |
| 259 EXPECT_TRUE(verticalScrollbar->thumbNeedsRepaint()); |
| 260 layerForVerticalScrollbar.resetTrackedPaintInvalidations(); |
| 261 verticalScrollbar->clearThumbNeedsRepaint(); |
| 262 |
| 263 // Next we'll scroll in both, but the thumb position moving requires no |
| 264 // invalidations. Nonetheless the GraphicsLayer should be invalidated, |
| 265 // because we still need to update the underlying layer (though no |
| 266 // rasterization will be required). |
| 267 EXPECT_CALL(theme, invalidateOnThumbPositionChange(_, _, _)).Times(2).WillRe
peatedly(Return(NoPart)); |
| 268 scrollableArea->setScrollPosition(DoublePoint(70, 70), ProgrammaticScroll); |
| 269 EXPECT_TRUE(layerForHorizontalScrollbar.hasTrackedPaintInvalidations()); |
| 270 EXPECT_TRUE(layerForVerticalScrollbar.hasTrackedPaintInvalidations()); |
| 271 EXPECT_FALSE(horizontalScrollbar->trackNeedsRepaint()); |
| 272 EXPECT_FALSE(horizontalScrollbar->thumbNeedsRepaint()); |
| 273 EXPECT_FALSE(verticalScrollbar->trackNeedsRepaint()); |
| 274 EXPECT_FALSE(verticalScrollbar->thumbNeedsRepaint()); |
| 275 |
| 276 // Forced GC in order to finalize objects depending on the mock object. |
| 277 Heap::collectAllGarbage(); |
| 278 } |
| 279 |
| 171 } // namespace blink | 280 } // namespace blink |
| OLD | NEW |