OLD | NEW |
1 // Copyright 2014 The Chromium Authors. All rights reserved. | 1 // Copyright 2014 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 "config.h" | 5 #include "config.h" |
6 #include "platform/graphics/paint/DisplayItemList.h" | 6 #include "platform/graphics/paint/PaintController.h" |
7 | 7 |
8 #include "platform/RuntimeEnabledFeatures.h" | 8 #include "platform/RuntimeEnabledFeatures.h" |
9 #include "platform/graphics/GraphicsContext.h" | 9 #include "platform/graphics/GraphicsContext.h" |
10 #include "platform/graphics/paint/CachedDisplayItem.h" | 10 #include "platform/graphics/paint/CachedDisplayItem.h" |
11 #include "platform/graphics/paint/ClipPathRecorder.h" | 11 #include "platform/graphics/paint/ClipPathRecorder.h" |
12 #include "platform/graphics/paint/ClipRecorder.h" | 12 #include "platform/graphics/paint/ClipRecorder.h" |
13 #include "platform/graphics/paint/DrawingDisplayItem.h" | 13 #include "platform/graphics/paint/DrawingDisplayItem.h" |
14 #include "platform/graphics/paint/DrawingRecorder.h" | 14 #include "platform/graphics/paint/DrawingRecorder.h" |
15 #include "platform/graphics/paint/SubsequenceRecorder.h" | 15 #include "platform/graphics/paint/SubsequenceRecorder.h" |
16 #include <gtest/gtest.h> | 16 #include <gtest/gtest.h> |
17 | 17 |
18 namespace blink { | 18 namespace blink { |
19 | 19 |
20 class DisplayItemListTest : public ::testing::Test { | 20 class PaintControllerTest : public ::testing::Test { |
21 public: | 21 public: |
22 DisplayItemListTest() | 22 PaintControllerTest() |
23 : m_displayItemList(DisplayItemList::create()) | 23 : m_paintController(PaintController::create()) |
24 , m_originalSlimmingPaintSubsequenceCachingEnabled(RuntimeEnabledFeature
s::slimmingPaintSubsequenceCachingEnabled()) | 24 , m_originalSlimmingPaintSubsequenceCachingEnabled(RuntimeEnabledFeature
s::slimmingPaintSubsequenceCachingEnabled()) |
25 , m_originalSlimmingPaintV2Enabled(RuntimeEnabledFeatures::slimmingPaint
V2Enabled()) { } | 25 , m_originalSlimmingPaintV2Enabled(RuntimeEnabledFeatures::slimmingPaint
V2Enabled()) { } |
26 | 26 |
27 protected: | 27 protected: |
28 DisplayItemList& displayItemList() { return *m_displayItemList; } | 28 PaintController& paintController() { return *m_paintController; } |
29 | 29 |
30 private: | 30 private: |
31 void TearDown() override | 31 void TearDown() override |
32 { | 32 { |
33 RuntimeEnabledFeatures::setSlimmingPaintSubsequenceCachingEnabled(m_orig
inalSlimmingPaintSubsequenceCachingEnabled); | 33 RuntimeEnabledFeatures::setSlimmingPaintSubsequenceCachingEnabled(m_orig
inalSlimmingPaintSubsequenceCachingEnabled); |
34 RuntimeEnabledFeatures::setSlimmingPaintV2Enabled(m_originalSlimmingPain
tV2Enabled); | 34 RuntimeEnabledFeatures::setSlimmingPaintV2Enabled(m_originalSlimmingPain
tV2Enabled); |
35 } | 35 } |
36 | 36 |
37 OwnPtr<DisplayItemList> m_displayItemList; | 37 OwnPtr<PaintController> m_paintController; |
38 bool m_originalSlimmingPaintSubsequenceCachingEnabled; | 38 bool m_originalSlimmingPaintSubsequenceCachingEnabled; |
39 bool m_originalSlimmingPaintV2Enabled; | 39 bool m_originalSlimmingPaintV2Enabled; |
40 }; | 40 }; |
41 | 41 |
42 const DisplayItem::Type foregroundDrawingType = static_cast<DisplayItem::Type>(D
isplayItem::DrawingPaintPhaseFirst + 4); | 42 const DisplayItem::Type foregroundDrawingType = static_cast<DisplayItem::Type>(D
isplayItem::DrawingPaintPhaseFirst + 4); |
43 const DisplayItem::Type backgroundDrawingType = DisplayItem::DrawingPaintPhaseFi
rst; | 43 const DisplayItem::Type backgroundDrawingType = DisplayItem::DrawingPaintPhaseFi
rst; |
44 const DisplayItem::Type clipType = DisplayItem::ClipFirst; | 44 const DisplayItem::Type clipType = DisplayItem::ClipFirst; |
45 const DisplayItem::Type subsequenceType = DisplayItem::SubsequenceNormalFlowAndP
ositiveZOrder; | 45 const DisplayItem::Type subsequenceType = DisplayItem::SubsequenceNormalFlowAndP
ositiveZOrder; |
46 const DisplayItem::Type endSubsequenceType = DisplayItem::subsequenceTypeToEndSu
bsequenceType(subsequenceType); | 46 const DisplayItem::Type endSubsequenceType = DisplayItem::subsequenceTypeToEndSu
bsequenceType(subsequenceType); |
47 const DisplayItem::Type cachedSubsequenceType = DisplayItem::subsequenceTypeToCa
chedSubsequenceType(subsequenceType); | 47 const DisplayItem::Type cachedSubsequenceType = DisplayItem::subsequenceTypeToCa
chedSubsequenceType(subsequenceType); |
(...skipping 48 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
96 IntRect rect(0, 0, 10, 10); | 96 IntRect rect(0, 0, 10, 10); |
97 context.drawRect(rect); | 97 context.drawRect(rect); |
98 } | 98 } |
99 | 99 |
100 void drawClippedRect(GraphicsContext& context, const TestDisplayItemClient& clie
nt, DisplayItem::Type clipType, DisplayItem::Type drawingType, const FloatRect&
bound) | 100 void drawClippedRect(GraphicsContext& context, const TestDisplayItemClient& clie
nt, DisplayItem::Type clipType, DisplayItem::Type drawingType, const FloatRect&
bound) |
101 { | 101 { |
102 ClipRecorder clipRecorder(context, client, clipType, LayoutRect(1, 1, 9, 9))
; | 102 ClipRecorder clipRecorder(context, client, clipType, LayoutRect(1, 1, 9, 9))
; |
103 drawRect(context, client, drawingType, bound); | 103 drawRect(context, client, drawingType, bound); |
104 } | 104 } |
105 | 105 |
106 TEST_F(DisplayItemListTest, NestedRecorders) | 106 TEST_F(PaintControllerTest, NestedRecorders) |
107 { | 107 { |
108 GraphicsContext context(&displayItemList()); | 108 GraphicsContext context(&paintController()); |
109 | 109 |
110 TestDisplayItemClient client("client"); | 110 TestDisplayItemClient client("client"); |
111 | 111 |
112 drawClippedRect(context, client, clipType, backgroundDrawingType, FloatRect(
100, 100, 200, 200)); | 112 drawClippedRect(context, client, clipType, backgroundDrawingType, FloatRect(
100, 100, 200, 200)); |
113 displayItemList().commitNewDisplayItems(); | 113 paintController().commitNewDisplayItems(); |
114 | 114 |
115 EXPECT_DISPLAY_LIST(displayItemList().displayItems(), 3, | 115 EXPECT_DISPLAY_LIST(paintController().displayItems(), 3, |
116 TestDisplayItem(client, clipType), | 116 TestDisplayItem(client, clipType), |
117 TestDisplayItem(client, backgroundDrawingType), | 117 TestDisplayItem(client, backgroundDrawingType), |
118 TestDisplayItem(client, DisplayItem::clipTypeToEndClipType(clipType))); | 118 TestDisplayItem(client, DisplayItem::clipTypeToEndClipType(clipType))); |
119 } | 119 } |
120 | 120 |
121 TEST_F(DisplayItemListTest, UpdateBasic) | 121 TEST_F(PaintControllerTest, UpdateBasic) |
122 { | 122 { |
123 TestDisplayItemClient first("first"); | 123 TestDisplayItemClient first("first"); |
124 TestDisplayItemClient second("second"); | 124 TestDisplayItemClient second("second"); |
125 GraphicsContext context(&displayItemList()); | 125 GraphicsContext context(&paintController()); |
126 | 126 |
127 drawRect(context, first, backgroundDrawingType, FloatRect(100, 100, 300, 300
)); | 127 drawRect(context, first, backgroundDrawingType, FloatRect(100, 100, 300, 300
)); |
128 drawRect(context, second, backgroundDrawingType, FloatRect(100, 100, 200, 20
0)); | 128 drawRect(context, second, backgroundDrawingType, FloatRect(100, 100, 200, 20
0)); |
129 drawRect(context, first, foregroundDrawingType, FloatRect(100, 100, 300, 300
)); | 129 drawRect(context, first, foregroundDrawingType, FloatRect(100, 100, 300, 300
)); |
130 displayItemList().commitNewDisplayItems(); | 130 paintController().commitNewDisplayItems(); |
131 | 131 |
132 EXPECT_DISPLAY_LIST(displayItemList().displayItems(), 3, | 132 EXPECT_DISPLAY_LIST(paintController().displayItems(), 3, |
133 TestDisplayItem(first, backgroundDrawingType), | 133 TestDisplayItem(first, backgroundDrawingType), |
134 TestDisplayItem(second, backgroundDrawingType), | 134 TestDisplayItem(second, backgroundDrawingType), |
135 TestDisplayItem(first, foregroundDrawingType)); | 135 TestDisplayItem(first, foregroundDrawingType)); |
136 | 136 |
137 displayItemList().invalidate(second, PaintInvalidationFull, IntRect(), IntRe
ct()); | 137 paintController().invalidate(second, PaintInvalidationFull, IntRect(), IntRe
ct()); |
138 drawRect(context, first, backgroundDrawingType, FloatRect(100, 100, 300, 300
)); | 138 drawRect(context, first, backgroundDrawingType, FloatRect(100, 100, 300, 300
)); |
139 drawRect(context, first, foregroundDrawingType, FloatRect(100, 100, 300, 300
)); | 139 drawRect(context, first, foregroundDrawingType, FloatRect(100, 100, 300, 300
)); |
140 displayItemList().commitNewDisplayItems(); | 140 paintController().commitNewDisplayItems(); |
141 | 141 |
142 EXPECT_DISPLAY_LIST(displayItemList().displayItems(), 2, | 142 EXPECT_DISPLAY_LIST(paintController().displayItems(), 2, |
143 TestDisplayItem(first, backgroundDrawingType), | 143 TestDisplayItem(first, backgroundDrawingType), |
144 TestDisplayItem(first, foregroundDrawingType)); | 144 TestDisplayItem(first, foregroundDrawingType)); |
145 } | 145 } |
146 | 146 |
147 TEST_F(DisplayItemListTest, UpdateSwapOrder) | 147 TEST_F(PaintControllerTest, UpdateSwapOrder) |
148 { | 148 { |
149 TestDisplayItemClient first("first"); | 149 TestDisplayItemClient first("first"); |
150 TestDisplayItemClient second("second"); | 150 TestDisplayItemClient second("second"); |
151 TestDisplayItemClient unaffected("unaffected"); | 151 TestDisplayItemClient unaffected("unaffected"); |
152 GraphicsContext context(&displayItemList()); | 152 GraphicsContext context(&paintController()); |
153 | 153 |
154 drawRect(context, first, backgroundDrawingType, FloatRect(100, 100, 100, 100
)); | 154 drawRect(context, first, backgroundDrawingType, FloatRect(100, 100, 100, 100
)); |
155 drawRect(context, second, backgroundDrawingType, FloatRect(100, 100, 50, 200
)); | 155 drawRect(context, second, backgroundDrawingType, FloatRect(100, 100, 50, 200
)); |
156 drawRect(context, unaffected, backgroundDrawingType, FloatRect(300, 300, 10,
10)); | 156 drawRect(context, unaffected, backgroundDrawingType, FloatRect(300, 300, 10,
10)); |
157 displayItemList().commitNewDisplayItems(); | 157 paintController().commitNewDisplayItems(); |
158 | 158 |
159 EXPECT_DISPLAY_LIST(displayItemList().displayItems(), 3, | 159 EXPECT_DISPLAY_LIST(paintController().displayItems(), 3, |
160 TestDisplayItem(first, backgroundDrawingType), | 160 TestDisplayItem(first, backgroundDrawingType), |
161 TestDisplayItem(second, backgroundDrawingType), | 161 TestDisplayItem(second, backgroundDrawingType), |
162 TestDisplayItem(unaffected, backgroundDrawingType)); | 162 TestDisplayItem(unaffected, backgroundDrawingType)); |
163 | 163 |
164 displayItemList().invalidate(second, PaintInvalidationFull, IntRect(), IntRe
ct()); | 164 paintController().invalidate(second, PaintInvalidationFull, IntRect(), IntRe
ct()); |
165 drawRect(context, second, backgroundDrawingType, FloatRect(100, 100, 50, 200
)); | 165 drawRect(context, second, backgroundDrawingType, FloatRect(100, 100, 50, 200
)); |
166 drawRect(context, first, backgroundDrawingType, FloatRect(100, 100, 100, 100
)); | 166 drawRect(context, first, backgroundDrawingType, FloatRect(100, 100, 100, 100
)); |
167 drawRect(context, unaffected, backgroundDrawingType, FloatRect(300, 300, 10,
10)); | 167 drawRect(context, unaffected, backgroundDrawingType, FloatRect(300, 300, 10,
10)); |
168 displayItemList().commitNewDisplayItems(); | 168 paintController().commitNewDisplayItems(); |
169 | 169 |
170 EXPECT_DISPLAY_LIST(displayItemList().displayItems(), 3, | 170 EXPECT_DISPLAY_LIST(paintController().displayItems(), 3, |
171 TestDisplayItem(second, backgroundDrawingType), | 171 TestDisplayItem(second, backgroundDrawingType), |
172 TestDisplayItem(first, backgroundDrawingType), | 172 TestDisplayItem(first, backgroundDrawingType), |
173 TestDisplayItem(unaffected, backgroundDrawingType)); | 173 TestDisplayItem(unaffected, backgroundDrawingType)); |
174 } | 174 } |
175 | 175 |
176 TEST_F(DisplayItemListTest, UpdateNewItemInMiddle) | 176 TEST_F(PaintControllerTest, UpdateNewItemInMiddle) |
177 { | 177 { |
178 TestDisplayItemClient first("first"); | 178 TestDisplayItemClient first("first"); |
179 TestDisplayItemClient second("second"); | 179 TestDisplayItemClient second("second"); |
180 TestDisplayItemClient third("third"); | 180 TestDisplayItemClient third("third"); |
181 GraphicsContext context(&displayItemList()); | 181 GraphicsContext context(&paintController()); |
182 | 182 |
183 drawRect(context, first, backgroundDrawingType, FloatRect(100, 100, 100, 100
)); | 183 drawRect(context, first, backgroundDrawingType, FloatRect(100, 100, 100, 100
)); |
184 drawRect(context, second, backgroundDrawingType, FloatRect(100, 100, 50, 200
)); | 184 drawRect(context, second, backgroundDrawingType, FloatRect(100, 100, 50, 200
)); |
185 displayItemList().commitNewDisplayItems(); | 185 paintController().commitNewDisplayItems(); |
186 | 186 |
187 EXPECT_DISPLAY_LIST(displayItemList().displayItems(), 2, | 187 EXPECT_DISPLAY_LIST(paintController().displayItems(), 2, |
188 TestDisplayItem(first, backgroundDrawingType), | 188 TestDisplayItem(first, backgroundDrawingType), |
189 TestDisplayItem(second, backgroundDrawingType)); | 189 TestDisplayItem(second, backgroundDrawingType)); |
190 | 190 |
191 drawRect(context, first, backgroundDrawingType, FloatRect(100, 100, 100, 100
)); | 191 drawRect(context, first, backgroundDrawingType, FloatRect(100, 100, 100, 100
)); |
192 drawRect(context, third, backgroundDrawingType, FloatRect(125, 100, 200, 50)
); | 192 drawRect(context, third, backgroundDrawingType, FloatRect(125, 100, 200, 50)
); |
193 drawRect(context, second, backgroundDrawingType, FloatRect(100, 100, 50, 200
)); | 193 drawRect(context, second, backgroundDrawingType, FloatRect(100, 100, 50, 200
)); |
194 displayItemList().commitNewDisplayItems(); | 194 paintController().commitNewDisplayItems(); |
195 | 195 |
196 EXPECT_DISPLAY_LIST(displayItemList().displayItems(), 3, | 196 EXPECT_DISPLAY_LIST(paintController().displayItems(), 3, |
197 TestDisplayItem(first, backgroundDrawingType), | 197 TestDisplayItem(first, backgroundDrawingType), |
198 TestDisplayItem(third, backgroundDrawingType), | 198 TestDisplayItem(third, backgroundDrawingType), |
199 TestDisplayItem(second, backgroundDrawingType)); | 199 TestDisplayItem(second, backgroundDrawingType)); |
200 } | 200 } |
201 | 201 |
202 TEST_F(DisplayItemListTest, UpdateInvalidationWithPhases) | 202 TEST_F(PaintControllerTest, UpdateInvalidationWithPhases) |
203 { | 203 { |
204 TestDisplayItemClient first("first"); | 204 TestDisplayItemClient first("first"); |
205 TestDisplayItemClient second("second"); | 205 TestDisplayItemClient second("second"); |
206 TestDisplayItemClient third("third"); | 206 TestDisplayItemClient third("third"); |
207 GraphicsContext context(&displayItemList()); | 207 GraphicsContext context(&paintController()); |
208 | 208 |
209 drawRect(context, first, backgroundDrawingType, FloatRect(100, 100, 100, 100
)); | 209 drawRect(context, first, backgroundDrawingType, FloatRect(100, 100, 100, 100
)); |
210 drawRect(context, second, backgroundDrawingType, FloatRect(100, 100, 50, 200
)); | 210 drawRect(context, second, backgroundDrawingType, FloatRect(100, 100, 50, 200
)); |
211 drawRect(context, third, backgroundDrawingType, FloatRect(300, 100, 50, 50))
; | 211 drawRect(context, third, backgroundDrawingType, FloatRect(300, 100, 50, 50))
; |
212 drawRect(context, first, foregroundDrawingType, FloatRect(100, 100, 100, 100
)); | 212 drawRect(context, first, foregroundDrawingType, FloatRect(100, 100, 100, 100
)); |
213 drawRect(context, second, foregroundDrawingType, FloatRect(100, 100, 50, 200
)); | 213 drawRect(context, second, foregroundDrawingType, FloatRect(100, 100, 50, 200
)); |
214 drawRect(context, third, foregroundDrawingType, FloatRect(300, 100, 50, 50))
; | 214 drawRect(context, third, foregroundDrawingType, FloatRect(300, 100, 50, 50))
; |
215 displayItemList().commitNewDisplayItems(); | 215 paintController().commitNewDisplayItems(); |
216 | 216 |
217 EXPECT_DISPLAY_LIST(displayItemList().displayItems(), 6, | 217 EXPECT_DISPLAY_LIST(paintController().displayItems(), 6, |
218 TestDisplayItem(first, backgroundDrawingType), | 218 TestDisplayItem(first, backgroundDrawingType), |
219 TestDisplayItem(second, backgroundDrawingType), | 219 TestDisplayItem(second, backgroundDrawingType), |
220 TestDisplayItem(third, backgroundDrawingType), | 220 TestDisplayItem(third, backgroundDrawingType), |
221 TestDisplayItem(first, foregroundDrawingType), | 221 TestDisplayItem(first, foregroundDrawingType), |
222 TestDisplayItem(second, foregroundDrawingType), | 222 TestDisplayItem(second, foregroundDrawingType), |
223 TestDisplayItem(third, foregroundDrawingType)); | 223 TestDisplayItem(third, foregroundDrawingType)); |
224 | 224 |
225 displayItemList().invalidate(second, PaintInvalidationFull, IntRect(), IntRe
ct()); | 225 paintController().invalidate(second, PaintInvalidationFull, IntRect(), IntRe
ct()); |
226 drawRect(context, first, backgroundDrawingType, FloatRect(100, 100, 100, 100
)); | 226 drawRect(context, first, backgroundDrawingType, FloatRect(100, 100, 100, 100
)); |
227 drawRect(context, second, backgroundDrawingType, FloatRect(100, 100, 50, 200
)); | 227 drawRect(context, second, backgroundDrawingType, FloatRect(100, 100, 50, 200
)); |
228 drawRect(context, third, backgroundDrawingType, FloatRect(300, 100, 50, 50))
; | 228 drawRect(context, third, backgroundDrawingType, FloatRect(300, 100, 50, 50))
; |
229 drawRect(context, first, foregroundDrawingType, FloatRect(100, 100, 100, 100
)); | 229 drawRect(context, first, foregroundDrawingType, FloatRect(100, 100, 100, 100
)); |
230 drawRect(context, second, foregroundDrawingType, FloatRect(100, 100, 50, 200
)); | 230 drawRect(context, second, foregroundDrawingType, FloatRect(100, 100, 50, 200
)); |
231 drawRect(context, third, foregroundDrawingType, FloatRect(300, 100, 50, 50))
; | 231 drawRect(context, third, foregroundDrawingType, FloatRect(300, 100, 50, 50))
; |
232 displayItemList().commitNewDisplayItems(); | 232 paintController().commitNewDisplayItems(); |
233 | 233 |
234 EXPECT_DISPLAY_LIST(displayItemList().displayItems(), 6, | 234 EXPECT_DISPLAY_LIST(paintController().displayItems(), 6, |
235 TestDisplayItem(first, backgroundDrawingType), | 235 TestDisplayItem(first, backgroundDrawingType), |
236 TestDisplayItem(second, backgroundDrawingType), | 236 TestDisplayItem(second, backgroundDrawingType), |
237 TestDisplayItem(third, backgroundDrawingType), | 237 TestDisplayItem(third, backgroundDrawingType), |
238 TestDisplayItem(first, foregroundDrawingType), | 238 TestDisplayItem(first, foregroundDrawingType), |
239 TestDisplayItem(second, foregroundDrawingType), | 239 TestDisplayItem(second, foregroundDrawingType), |
240 TestDisplayItem(third, foregroundDrawingType)); | 240 TestDisplayItem(third, foregroundDrawingType)); |
241 } | 241 } |
242 | 242 |
243 TEST_F(DisplayItemListTest, UpdateAddFirstOverlap) | 243 TEST_F(PaintControllerTest, UpdateAddFirstOverlap) |
244 { | 244 { |
245 TestDisplayItemClient first("first"); | 245 TestDisplayItemClient first("first"); |
246 TestDisplayItemClient second("second"); | 246 TestDisplayItemClient second("second"); |
247 GraphicsContext context(&displayItemList()); | 247 GraphicsContext context(&paintController()); |
248 | 248 |
249 drawRect(context, second, backgroundDrawingType, FloatRect(200, 200, 50, 50)
); | 249 drawRect(context, second, backgroundDrawingType, FloatRect(200, 200, 50, 50)
); |
250 drawRect(context, second, foregroundDrawingType, FloatRect(200, 200, 50, 50)
); | 250 drawRect(context, second, foregroundDrawingType, FloatRect(200, 200, 50, 50)
); |
251 displayItemList().commitNewDisplayItems(); | 251 paintController().commitNewDisplayItems(); |
252 | 252 |
253 EXPECT_DISPLAY_LIST(displayItemList().displayItems(), 2, | 253 EXPECT_DISPLAY_LIST(paintController().displayItems(), 2, |
254 TestDisplayItem(second, backgroundDrawingType), | 254 TestDisplayItem(second, backgroundDrawingType), |
255 TestDisplayItem(second, foregroundDrawingType)); | 255 TestDisplayItem(second, foregroundDrawingType)); |
256 | 256 |
257 displayItemList().invalidate(first, PaintInvalidationFull, IntRect(), IntRec
t()); | 257 paintController().invalidate(first, PaintInvalidationFull, IntRect(), IntRec
t()); |
258 displayItemList().invalidate(second, PaintInvalidationFull, IntRect(), IntRe
ct()); | 258 paintController().invalidate(second, PaintInvalidationFull, IntRect(), IntRe
ct()); |
259 drawRect(context, first, backgroundDrawingType, FloatRect(100, 100, 150, 150
)); | 259 drawRect(context, first, backgroundDrawingType, FloatRect(100, 100, 150, 150
)); |
260 drawRect(context, first, foregroundDrawingType, FloatRect(100, 100, 150, 150
)); | 260 drawRect(context, first, foregroundDrawingType, FloatRect(100, 100, 150, 150
)); |
261 drawRect(context, second, backgroundDrawingType, FloatRect(200, 200, 50, 50)
); | 261 drawRect(context, second, backgroundDrawingType, FloatRect(200, 200, 50, 50)
); |
262 drawRect(context, second, foregroundDrawingType, FloatRect(200, 200, 50, 50)
); | 262 drawRect(context, second, foregroundDrawingType, FloatRect(200, 200, 50, 50)
); |
263 displayItemList().commitNewDisplayItems(); | 263 paintController().commitNewDisplayItems(); |
264 | 264 |
265 EXPECT_DISPLAY_LIST(displayItemList().displayItems(), 4, | 265 EXPECT_DISPLAY_LIST(paintController().displayItems(), 4, |
266 TestDisplayItem(first, backgroundDrawingType), | 266 TestDisplayItem(first, backgroundDrawingType), |
267 TestDisplayItem(first, foregroundDrawingType), | 267 TestDisplayItem(first, foregroundDrawingType), |
268 TestDisplayItem(second, backgroundDrawingType), | 268 TestDisplayItem(second, backgroundDrawingType), |
269 TestDisplayItem(second, foregroundDrawingType)); | 269 TestDisplayItem(second, foregroundDrawingType)); |
270 | 270 |
271 displayItemList().invalidate(first, PaintInvalidationFull, IntRect(), IntRec
t()); | 271 paintController().invalidate(first, PaintInvalidationFull, IntRect(), IntRec
t()); |
272 drawRect(context, second, backgroundDrawingType, FloatRect(200, 200, 50, 50)
); | 272 drawRect(context, second, backgroundDrawingType, FloatRect(200, 200, 50, 50)
); |
273 drawRect(context, second, foregroundDrawingType, FloatRect(200, 200, 50, 50)
); | 273 drawRect(context, second, foregroundDrawingType, FloatRect(200, 200, 50, 50)
); |
274 displayItemList().commitNewDisplayItems(); | 274 paintController().commitNewDisplayItems(); |
275 | 275 |
276 EXPECT_DISPLAY_LIST(displayItemList().displayItems(), 2, | 276 EXPECT_DISPLAY_LIST(paintController().displayItems(), 2, |
277 TestDisplayItem(second, backgroundDrawingType), | 277 TestDisplayItem(second, backgroundDrawingType), |
278 TestDisplayItem(second, foregroundDrawingType)); | 278 TestDisplayItem(second, foregroundDrawingType)); |
279 } | 279 } |
280 | 280 |
281 TEST_F(DisplayItemListTest, UpdateAddLastOverlap) | 281 TEST_F(PaintControllerTest, UpdateAddLastOverlap) |
282 { | 282 { |
283 TestDisplayItemClient first("first"); | 283 TestDisplayItemClient first("first"); |
284 TestDisplayItemClient second("second"); | 284 TestDisplayItemClient second("second"); |
285 GraphicsContext context(&displayItemList()); | 285 GraphicsContext context(&paintController()); |
286 | 286 |
287 drawRect(context, first, backgroundDrawingType, FloatRect(100, 100, 150, 150
)); | 287 drawRect(context, first, backgroundDrawingType, FloatRect(100, 100, 150, 150
)); |
288 drawRect(context, first, foregroundDrawingType, FloatRect(100, 100, 150, 150
)); | 288 drawRect(context, first, foregroundDrawingType, FloatRect(100, 100, 150, 150
)); |
289 displayItemList().commitNewDisplayItems(); | 289 paintController().commitNewDisplayItems(); |
290 | 290 |
291 EXPECT_DISPLAY_LIST(displayItemList().displayItems(), 2, | 291 EXPECT_DISPLAY_LIST(paintController().displayItems(), 2, |
292 TestDisplayItem(first, backgroundDrawingType), | 292 TestDisplayItem(first, backgroundDrawingType), |
293 TestDisplayItem(first, foregroundDrawingType)); | 293 TestDisplayItem(first, foregroundDrawingType)); |
294 | 294 |
295 displayItemList().invalidate(first, PaintInvalidationFull, IntRect(), IntRec
t()); | 295 paintController().invalidate(first, PaintInvalidationFull, IntRect(), IntRec
t()); |
296 displayItemList().invalidate(second, PaintInvalidationFull, IntRect(), IntRe
ct()); | 296 paintController().invalidate(second, PaintInvalidationFull, IntRect(), IntRe
ct()); |
297 drawRect(context, first, backgroundDrawingType, FloatRect(100, 100, 150, 150
)); | 297 drawRect(context, first, backgroundDrawingType, FloatRect(100, 100, 150, 150
)); |
298 drawRect(context, first, foregroundDrawingType, FloatRect(100, 100, 150, 150
)); | 298 drawRect(context, first, foregroundDrawingType, FloatRect(100, 100, 150, 150
)); |
299 drawRect(context, second, backgroundDrawingType, FloatRect(200, 200, 50, 50)
); | 299 drawRect(context, second, backgroundDrawingType, FloatRect(200, 200, 50, 50)
); |
300 drawRect(context, second, foregroundDrawingType, FloatRect(200, 200, 50, 50)
); | 300 drawRect(context, second, foregroundDrawingType, FloatRect(200, 200, 50, 50)
); |
301 displayItemList().commitNewDisplayItems(); | 301 paintController().commitNewDisplayItems(); |
302 | 302 |
303 EXPECT_DISPLAY_LIST(displayItemList().displayItems(), 4, | 303 EXPECT_DISPLAY_LIST(paintController().displayItems(), 4, |
304 TestDisplayItem(first, backgroundDrawingType), | 304 TestDisplayItem(first, backgroundDrawingType), |
305 TestDisplayItem(first, foregroundDrawingType), | 305 TestDisplayItem(first, foregroundDrawingType), |
306 TestDisplayItem(second, backgroundDrawingType), | 306 TestDisplayItem(second, backgroundDrawingType), |
307 TestDisplayItem(second, foregroundDrawingType)); | 307 TestDisplayItem(second, foregroundDrawingType)); |
308 | 308 |
309 displayItemList().invalidate(first, PaintInvalidationFull, IntRect(), IntRec
t()); | 309 paintController().invalidate(first, PaintInvalidationFull, IntRect(), IntRec
t()); |
310 displayItemList().invalidate(second, PaintInvalidationFull, IntRect(), IntRe
ct()); | 310 paintController().invalidate(second, PaintInvalidationFull, IntRect(), IntRe
ct()); |
311 drawRect(context, first, backgroundDrawingType, FloatRect(100, 100, 150, 150
)); | 311 drawRect(context, first, backgroundDrawingType, FloatRect(100, 100, 150, 150
)); |
312 drawRect(context, first, foregroundDrawingType, FloatRect(100, 100, 150, 150
)); | 312 drawRect(context, first, foregroundDrawingType, FloatRect(100, 100, 150, 150
)); |
313 displayItemList().commitNewDisplayItems(); | 313 paintController().commitNewDisplayItems(); |
314 | 314 |
315 EXPECT_DISPLAY_LIST(displayItemList().displayItems(), 2, | 315 EXPECT_DISPLAY_LIST(paintController().displayItems(), 2, |
316 TestDisplayItem(first, backgroundDrawingType), | 316 TestDisplayItem(first, backgroundDrawingType), |
317 TestDisplayItem(first, foregroundDrawingType)); | 317 TestDisplayItem(first, foregroundDrawingType)); |
318 } | 318 } |
319 | 319 |
320 TEST_F(DisplayItemListTest, UpdateClip) | 320 TEST_F(PaintControllerTest, UpdateClip) |
321 { | 321 { |
322 TestDisplayItemClient first("first"); | 322 TestDisplayItemClient first("first"); |
323 TestDisplayItemClient second("second"); | 323 TestDisplayItemClient second("second"); |
324 GraphicsContext context(&displayItemList()); | 324 GraphicsContext context(&paintController()); |
325 | 325 |
326 { | 326 { |
327 ClipRecorder clipRecorder(context, first, clipType, LayoutRect(1, 1, 2,
2)); | 327 ClipRecorder clipRecorder(context, first, clipType, LayoutRect(1, 1, 2,
2)); |
328 drawRect(context, first, backgroundDrawingType, FloatRect(100, 100, 150,
150)); | 328 drawRect(context, first, backgroundDrawingType, FloatRect(100, 100, 150,
150)); |
329 drawRect(context, second, backgroundDrawingType, FloatRect(100, 100, 150
, 150)); | 329 drawRect(context, second, backgroundDrawingType, FloatRect(100, 100, 150
, 150)); |
330 } | 330 } |
331 displayItemList().commitNewDisplayItems(); | 331 paintController().commitNewDisplayItems(); |
332 | 332 |
333 EXPECT_DISPLAY_LIST(displayItemList().displayItems(), 4, | 333 EXPECT_DISPLAY_LIST(paintController().displayItems(), 4, |
334 TestDisplayItem(first, clipType), | 334 TestDisplayItem(first, clipType), |
335 TestDisplayItem(first, backgroundDrawingType), | 335 TestDisplayItem(first, backgroundDrawingType), |
336 TestDisplayItem(second, backgroundDrawingType), | 336 TestDisplayItem(second, backgroundDrawingType), |
337 TestDisplayItem(first, DisplayItem::clipTypeToEndClipType(clipType))); | 337 TestDisplayItem(first, DisplayItem::clipTypeToEndClipType(clipType))); |
338 | 338 |
339 displayItemList().invalidate(first, PaintInvalidationFull, IntRect(), IntRec
t()); | 339 paintController().invalidate(first, PaintInvalidationFull, IntRect(), IntRec
t()); |
340 drawRect(context, first, backgroundDrawingType, FloatRect(100, 100, 150, 150
)); | 340 drawRect(context, first, backgroundDrawingType, FloatRect(100, 100, 150, 150
)); |
341 drawRect(context, second, backgroundDrawingType, FloatRect(100, 100, 150, 15
0)); | 341 drawRect(context, second, backgroundDrawingType, FloatRect(100, 100, 150, 15
0)); |
342 displayItemList().commitNewDisplayItems(); | 342 paintController().commitNewDisplayItems(); |
343 | 343 |
344 EXPECT_DISPLAY_LIST(displayItemList().displayItems(), 2, | 344 EXPECT_DISPLAY_LIST(paintController().displayItems(), 2, |
345 TestDisplayItem(first, backgroundDrawingType), | 345 TestDisplayItem(first, backgroundDrawingType), |
346 TestDisplayItem(second, backgroundDrawingType)); | 346 TestDisplayItem(second, backgroundDrawingType)); |
347 | 347 |
348 displayItemList().invalidate(second, PaintInvalidationFull, IntRect(), IntRe
ct()); | 348 paintController().invalidate(second, PaintInvalidationFull, IntRect(), IntRe
ct()); |
349 drawRect(context, first, backgroundDrawingType, FloatRect(100, 100, 150, 150
)); | 349 drawRect(context, first, backgroundDrawingType, FloatRect(100, 100, 150, 150
)); |
350 { | 350 { |
351 ClipRecorder clipRecorder(context, second, clipType, LayoutRect(1, 1, 2,
2)); | 351 ClipRecorder clipRecorder(context, second, clipType, LayoutRect(1, 1, 2,
2)); |
352 drawRect(context, second, backgroundDrawingType, FloatRect(100, 100, 150
, 150)); | 352 drawRect(context, second, backgroundDrawingType, FloatRect(100, 100, 150
, 150)); |
353 } | 353 } |
354 displayItemList().commitNewDisplayItems(); | 354 paintController().commitNewDisplayItems(); |
355 | 355 |
356 EXPECT_DISPLAY_LIST(displayItemList().displayItems(), 4, | 356 EXPECT_DISPLAY_LIST(paintController().displayItems(), 4, |
357 TestDisplayItem(first, backgroundDrawingType), | 357 TestDisplayItem(first, backgroundDrawingType), |
358 TestDisplayItem(second, clipType), | 358 TestDisplayItem(second, clipType), |
359 TestDisplayItem(second, backgroundDrawingType), | 359 TestDisplayItem(second, backgroundDrawingType), |
360 TestDisplayItem(second, DisplayItem::clipTypeToEndClipType(clipType))); | 360 TestDisplayItem(second, DisplayItem::clipTypeToEndClipType(clipType))); |
361 } | 361 } |
362 | 362 |
363 TEST_F(DisplayItemListTest, CachedDisplayItems) | 363 TEST_F(PaintControllerTest, CachedDisplayItems) |
364 { | 364 { |
365 TestDisplayItemClient first("first"); | 365 TestDisplayItemClient first("first"); |
366 TestDisplayItemClient second("second"); | 366 TestDisplayItemClient second("second"); |
367 GraphicsContext context(&displayItemList()); | 367 GraphicsContext context(&paintController()); |
368 | 368 |
369 drawRect(context, first, backgroundDrawingType, FloatRect(100, 100, 150, 150
)); | 369 drawRect(context, first, backgroundDrawingType, FloatRect(100, 100, 150, 150
)); |
370 drawRect(context, second, backgroundDrawingType, FloatRect(100, 100, 150, 15
0)); | 370 drawRect(context, second, backgroundDrawingType, FloatRect(100, 100, 150, 15
0)); |
371 displayItemList().commitNewDisplayItems(); | 371 paintController().commitNewDisplayItems(); |
372 | 372 |
373 EXPECT_DISPLAY_LIST(displayItemList().displayItems(), 2, | 373 EXPECT_DISPLAY_LIST(paintController().displayItems(), 2, |
374 TestDisplayItem(first, backgroundDrawingType), | 374 TestDisplayItem(first, backgroundDrawingType), |
375 TestDisplayItem(second, backgroundDrawingType)); | 375 TestDisplayItem(second, backgroundDrawingType)); |
376 EXPECT_TRUE(displayItemList().clientCacheIsValid(first.displayItemClient()))
; | 376 EXPECT_TRUE(paintController().clientCacheIsValid(first.displayItemClient()))
; |
377 EXPECT_TRUE(displayItemList().clientCacheIsValid(second.displayItemClient())
); | 377 EXPECT_TRUE(paintController().clientCacheIsValid(second.displayItemClient())
); |
378 const SkPicture* firstPicture = static_cast<const DrawingDisplayItem&>(displ
ayItemList().displayItems()[0]).picture(); | 378 const SkPicture* firstPicture = static_cast<const DrawingDisplayItem&>(paint
Controller().displayItems()[0]).picture(); |
379 const SkPicture* secondPicture = static_cast<const DrawingDisplayItem&>(disp
layItemList().displayItems()[1]).picture(); | 379 const SkPicture* secondPicture = static_cast<const DrawingDisplayItem&>(pain
tController().displayItems()[1]).picture(); |
380 | 380 |
381 displayItemList().invalidate(first, PaintInvalidationFull, IntRect(), IntRec
t()); | 381 paintController().invalidate(first, PaintInvalidationFull, IntRect(), IntRec
t()); |
382 EXPECT_FALSE(displayItemList().clientCacheIsValid(first.displayItemClient())
); | 382 EXPECT_FALSE(paintController().clientCacheIsValid(first.displayItemClient())
); |
383 EXPECT_TRUE(displayItemList().clientCacheIsValid(second.displayItemClient())
); | 383 EXPECT_TRUE(paintController().clientCacheIsValid(second.displayItemClient())
); |
384 | 384 |
385 drawRect(context, first, backgroundDrawingType, FloatRect(100, 100, 150, 150
)); | 385 drawRect(context, first, backgroundDrawingType, FloatRect(100, 100, 150, 150
)); |
386 drawRect(context, second, backgroundDrawingType, FloatRect(100, 100, 150, 15
0)); | 386 drawRect(context, second, backgroundDrawingType, FloatRect(100, 100, 150, 15
0)); |
387 displayItemList().commitNewDisplayItems(); | 387 paintController().commitNewDisplayItems(); |
388 | 388 |
389 EXPECT_DISPLAY_LIST(displayItemList().displayItems(), 2, | 389 EXPECT_DISPLAY_LIST(paintController().displayItems(), 2, |
390 TestDisplayItem(first, backgroundDrawingType), | 390 TestDisplayItem(first, backgroundDrawingType), |
391 TestDisplayItem(second, backgroundDrawingType)); | 391 TestDisplayItem(second, backgroundDrawingType)); |
392 // The first display item should be updated. | 392 // The first display item should be updated. |
393 EXPECT_NE(firstPicture, static_cast<const DrawingDisplayItem&>(displayItemLi
st().displayItems()[0]).picture()); | 393 EXPECT_NE(firstPicture, static_cast<const DrawingDisplayItem&>(paintControll
er().displayItems()[0]).picture()); |
394 // The second display item should be cached. | 394 // The second display item should be cached. |
395 EXPECT_EQ(secondPicture, static_cast<const DrawingDisplayItem&>(displayItemL
ist().displayItems()[1]).picture()); | 395 EXPECT_EQ(secondPicture, static_cast<const DrawingDisplayItem&>(paintControl
ler().displayItems()[1]).picture()); |
396 EXPECT_TRUE(displayItemList().clientCacheIsValid(first.displayItemClient()))
; | 396 EXPECT_TRUE(paintController().clientCacheIsValid(first.displayItemClient()))
; |
397 EXPECT_TRUE(displayItemList().clientCacheIsValid(second.displayItemClient())
); | 397 EXPECT_TRUE(paintController().clientCacheIsValid(second.displayItemClient())
); |
398 | 398 |
399 displayItemList().invalidateAll(); | 399 paintController().invalidateAll(); |
400 EXPECT_FALSE(displayItemList().clientCacheIsValid(first.displayItemClient())
); | 400 EXPECT_FALSE(paintController().clientCacheIsValid(first.displayItemClient())
); |
401 EXPECT_FALSE(displayItemList().clientCacheIsValid(second.displayItemClient()
)); | 401 EXPECT_FALSE(paintController().clientCacheIsValid(second.displayItemClient()
)); |
402 } | 402 } |
403 | 403 |
404 TEST_F(DisplayItemListTest, ComplexUpdateSwapOrder) | 404 TEST_F(PaintControllerTest, ComplexUpdateSwapOrder) |
405 { | 405 { |
406 TestDisplayItemClient container1("container1"); | 406 TestDisplayItemClient container1("container1"); |
407 TestDisplayItemClient content1("content1"); | 407 TestDisplayItemClient content1("content1"); |
408 TestDisplayItemClient container2("container2"); | 408 TestDisplayItemClient container2("container2"); |
409 TestDisplayItemClient content2("content2"); | 409 TestDisplayItemClient content2("content2"); |
410 GraphicsContext context(&displayItemList()); | 410 GraphicsContext context(&paintController()); |
411 | 411 |
412 drawRect(context, container1, backgroundDrawingType, FloatRect(100, 100, 100
, 100)); | 412 drawRect(context, container1, backgroundDrawingType, FloatRect(100, 100, 100
, 100)); |
413 drawRect(context, content1, backgroundDrawingType, FloatRect(100, 100, 50, 2
00)); | 413 drawRect(context, content1, backgroundDrawingType, FloatRect(100, 100, 50, 2
00)); |
414 drawRect(context, content1, foregroundDrawingType, FloatRect(100, 100, 50, 2
00)); | 414 drawRect(context, content1, foregroundDrawingType, FloatRect(100, 100, 50, 2
00)); |
415 drawRect(context, container1, foregroundDrawingType, FloatRect(100, 100, 100
, 100)); | 415 drawRect(context, container1, foregroundDrawingType, FloatRect(100, 100, 100
, 100)); |
416 drawRect(context, container2, backgroundDrawingType, FloatRect(100, 200, 100
, 100)); | 416 drawRect(context, container2, backgroundDrawingType, FloatRect(100, 200, 100
, 100)); |
417 drawRect(context, content2, backgroundDrawingType, FloatRect(100, 200, 50, 2
00)); | 417 drawRect(context, content2, backgroundDrawingType, FloatRect(100, 200, 50, 2
00)); |
418 drawRect(context, content2, foregroundDrawingType, FloatRect(100, 200, 50, 2
00)); | 418 drawRect(context, content2, foregroundDrawingType, FloatRect(100, 200, 50, 2
00)); |
419 drawRect(context, container2, foregroundDrawingType, FloatRect(100, 200, 100
, 100)); | 419 drawRect(context, container2, foregroundDrawingType, FloatRect(100, 200, 100
, 100)); |
420 displayItemList().commitNewDisplayItems(); | 420 paintController().commitNewDisplayItems(); |
421 | 421 |
422 EXPECT_DISPLAY_LIST(displayItemList().displayItems(), 8, | 422 EXPECT_DISPLAY_LIST(paintController().displayItems(), 8, |
423 TestDisplayItem(container1, backgroundDrawingType), | 423 TestDisplayItem(container1, backgroundDrawingType), |
424 TestDisplayItem(content1, backgroundDrawingType), | 424 TestDisplayItem(content1, backgroundDrawingType), |
425 TestDisplayItem(content1, foregroundDrawingType), | 425 TestDisplayItem(content1, foregroundDrawingType), |
426 TestDisplayItem(container1, foregroundDrawingType), | 426 TestDisplayItem(container1, foregroundDrawingType), |
427 TestDisplayItem(container2, backgroundDrawingType), | 427 TestDisplayItem(container2, backgroundDrawingType), |
428 TestDisplayItem(content2, backgroundDrawingType), | 428 TestDisplayItem(content2, backgroundDrawingType), |
429 TestDisplayItem(content2, foregroundDrawingType), | 429 TestDisplayItem(content2, foregroundDrawingType), |
430 TestDisplayItem(container2, foregroundDrawingType)); | 430 TestDisplayItem(container2, foregroundDrawingType)); |
431 | 431 |
432 // Simulate the situation when container1 e.g. gets a z-index that is now gr
eater than container2. | 432 // Simulate the situation when container1 e.g. gets a z-index that is now gr
eater than container2. |
433 displayItemList().invalidate(container1, PaintInvalidationFull, IntRect(), I
ntRect()); | 433 paintController().invalidate(container1, PaintInvalidationFull, IntRect(), I
ntRect()); |
434 drawRect(context, container2, backgroundDrawingType, FloatRect(100, 200, 100
, 100)); | 434 drawRect(context, container2, backgroundDrawingType, FloatRect(100, 200, 100
, 100)); |
435 drawRect(context, content2, backgroundDrawingType, FloatRect(100, 200, 50, 2
00)); | 435 drawRect(context, content2, backgroundDrawingType, FloatRect(100, 200, 50, 2
00)); |
436 drawRect(context, content2, foregroundDrawingType, FloatRect(100, 200, 50, 2
00)); | 436 drawRect(context, content2, foregroundDrawingType, FloatRect(100, 200, 50, 2
00)); |
437 drawRect(context, container2, foregroundDrawingType, FloatRect(100, 200, 100
, 100)); | 437 drawRect(context, container2, foregroundDrawingType, FloatRect(100, 200, 100
, 100)); |
438 drawRect(context, container1, backgroundDrawingType, FloatRect(100, 100, 100
, 100)); | 438 drawRect(context, container1, backgroundDrawingType, FloatRect(100, 100, 100
, 100)); |
439 drawRect(context, content1, backgroundDrawingType, FloatRect(100, 100, 50, 2
00)); | 439 drawRect(context, content1, backgroundDrawingType, FloatRect(100, 100, 50, 2
00)); |
440 drawRect(context, content1, foregroundDrawingType, FloatRect(100, 100, 50, 2
00)); | 440 drawRect(context, content1, foregroundDrawingType, FloatRect(100, 100, 50, 2
00)); |
441 drawRect(context, container1, foregroundDrawingType, FloatRect(100, 100, 100
, 100)); | 441 drawRect(context, container1, foregroundDrawingType, FloatRect(100, 100, 100
, 100)); |
442 displayItemList().commitNewDisplayItems(); | 442 paintController().commitNewDisplayItems(); |
443 | 443 |
444 EXPECT_DISPLAY_LIST(displayItemList().displayItems(), 8, | 444 EXPECT_DISPLAY_LIST(paintController().displayItems(), 8, |
445 TestDisplayItem(container2, backgroundDrawingType), | 445 TestDisplayItem(container2, backgroundDrawingType), |
446 TestDisplayItem(content2, backgroundDrawingType), | 446 TestDisplayItem(content2, backgroundDrawingType), |
447 TestDisplayItem(content2, foregroundDrawingType), | 447 TestDisplayItem(content2, foregroundDrawingType), |
448 TestDisplayItem(container2, foregroundDrawingType), | 448 TestDisplayItem(container2, foregroundDrawingType), |
449 TestDisplayItem(container1, backgroundDrawingType), | 449 TestDisplayItem(container1, backgroundDrawingType), |
450 TestDisplayItem(content1, backgroundDrawingType), | 450 TestDisplayItem(content1, backgroundDrawingType), |
451 TestDisplayItem(content1, foregroundDrawingType), | 451 TestDisplayItem(content1, foregroundDrawingType), |
452 TestDisplayItem(container1, foregroundDrawingType)); | 452 TestDisplayItem(container1, foregroundDrawingType)); |
453 } | 453 } |
454 | 454 |
455 TEST_F(DisplayItemListTest, CachedSubsequenceSwapOrder) | 455 TEST_F(PaintControllerTest, CachedSubsequenceSwapOrder) |
456 { | 456 { |
457 RuntimeEnabledFeatures::setSlimmingPaintSubsequenceCachingEnabled(true); | 457 RuntimeEnabledFeatures::setSlimmingPaintSubsequenceCachingEnabled(true); |
458 | 458 |
459 TestDisplayItemClient container1("container1"); | 459 TestDisplayItemClient container1("container1"); |
460 TestDisplayItemClient content1("content1"); | 460 TestDisplayItemClient content1("content1"); |
461 TestDisplayItemClient container2("container2"); | 461 TestDisplayItemClient container2("container2"); |
462 TestDisplayItemClient content2("content2"); | 462 TestDisplayItemClient content2("content2"); |
463 GraphicsContext context(&displayItemList()); | 463 GraphicsContext context(&paintController()); |
464 | 464 |
465 { | 465 { |
466 SubsequenceRecorder r(context, container1, subsequenceType); | 466 SubsequenceRecorder r(context, container1, subsequenceType); |
467 drawRect(context, container1, backgroundDrawingType, FloatRect(100, 100,
100, 100)); | 467 drawRect(context, container1, backgroundDrawingType, FloatRect(100, 100,
100, 100)); |
468 drawRect(context, content1, backgroundDrawingType, FloatRect(100, 100, 5
0, 200)); | 468 drawRect(context, content1, backgroundDrawingType, FloatRect(100, 100, 5
0, 200)); |
469 drawRect(context, content1, foregroundDrawingType, FloatRect(100, 100, 5
0, 200)); | 469 drawRect(context, content1, foregroundDrawingType, FloatRect(100, 100, 5
0, 200)); |
470 drawRect(context, container1, foregroundDrawingType, FloatRect(100, 100,
100, 100)); | 470 drawRect(context, container1, foregroundDrawingType, FloatRect(100, 100,
100, 100)); |
471 } | 471 } |
472 { | 472 { |
473 SubsequenceRecorder r(context, container2, subsequenceType); | 473 SubsequenceRecorder r(context, container2, subsequenceType); |
474 drawRect(context, container2, backgroundDrawingType, FloatRect(100, 200,
100, 100)); | 474 drawRect(context, container2, backgroundDrawingType, FloatRect(100, 200,
100, 100)); |
475 drawRect(context, content2, backgroundDrawingType, FloatRect(100, 200, 5
0, 200)); | 475 drawRect(context, content2, backgroundDrawingType, FloatRect(100, 200, 5
0, 200)); |
476 drawRect(context, content2, foregroundDrawingType, FloatRect(100, 200, 5
0, 200)); | 476 drawRect(context, content2, foregroundDrawingType, FloatRect(100, 200, 5
0, 200)); |
477 drawRect(context, container2, foregroundDrawingType, FloatRect(100, 200,
100, 100)); | 477 drawRect(context, container2, foregroundDrawingType, FloatRect(100, 200,
100, 100)); |
478 } | 478 } |
479 displayItemList().commitNewDisplayItems(); | 479 paintController().commitNewDisplayItems(); |
480 | 480 |
481 EXPECT_DISPLAY_LIST(displayItemList().displayItems(), 12, | 481 EXPECT_DISPLAY_LIST(paintController().displayItems(), 12, |
482 TestDisplayItem(container1, subsequenceType), | 482 TestDisplayItem(container1, subsequenceType), |
483 TestDisplayItem(container1, backgroundDrawingType), | 483 TestDisplayItem(container1, backgroundDrawingType), |
484 TestDisplayItem(content1, backgroundDrawingType), | 484 TestDisplayItem(content1, backgroundDrawingType), |
485 TestDisplayItem(content1, foregroundDrawingType), | 485 TestDisplayItem(content1, foregroundDrawingType), |
486 TestDisplayItem(container1, foregroundDrawingType), | 486 TestDisplayItem(container1, foregroundDrawingType), |
487 TestDisplayItem(container1, endSubsequenceType), | 487 TestDisplayItem(container1, endSubsequenceType), |
488 | 488 |
489 TestDisplayItem(container2, subsequenceType), | 489 TestDisplayItem(container2, subsequenceType), |
490 TestDisplayItem(container2, backgroundDrawingType), | 490 TestDisplayItem(container2, backgroundDrawingType), |
491 TestDisplayItem(content2, backgroundDrawingType), | 491 TestDisplayItem(content2, backgroundDrawingType), |
492 TestDisplayItem(content2, foregroundDrawingType), | 492 TestDisplayItem(content2, foregroundDrawingType), |
493 TestDisplayItem(container2, foregroundDrawingType), | 493 TestDisplayItem(container2, foregroundDrawingType), |
494 TestDisplayItem(container2, endSubsequenceType)); | 494 TestDisplayItem(container2, endSubsequenceType)); |
495 | 495 |
496 // Simulate the situation when container1 e.g. gets a z-index that is now gr
eater than container2. | 496 // Simulate the situation when container1 e.g. gets a z-index that is now gr
eater than container2. |
497 EXPECT_TRUE(SubsequenceRecorder::useCachedSubsequenceIfPossible(context, con
tainer2, subsequenceType)); | 497 EXPECT_TRUE(SubsequenceRecorder::useCachedSubsequenceIfPossible(context, con
tainer2, subsequenceType)); |
498 EXPECT_TRUE(SubsequenceRecorder::useCachedSubsequenceIfPossible(context, con
tainer1, subsequenceType)); | 498 EXPECT_TRUE(SubsequenceRecorder::useCachedSubsequenceIfPossible(context, con
tainer1, subsequenceType)); |
499 | 499 |
500 EXPECT_DISPLAY_LIST(displayItemList().newDisplayItems(), 2, | 500 EXPECT_DISPLAY_LIST(paintController().newDisplayItems(), 2, |
501 TestDisplayItem(container2, cachedSubsequenceType), | 501 TestDisplayItem(container2, cachedSubsequenceType), |
502 TestDisplayItem(container1, cachedSubsequenceType)); | 502 TestDisplayItem(container1, cachedSubsequenceType)); |
503 | 503 |
504 displayItemList().commitNewDisplayItems(); | 504 paintController().commitNewDisplayItems(); |
505 | 505 |
506 EXPECT_DISPLAY_LIST(displayItemList().displayItems(), 12, | 506 EXPECT_DISPLAY_LIST(paintController().displayItems(), 12, |
507 TestDisplayItem(container2, subsequenceType), | 507 TestDisplayItem(container2, subsequenceType), |
508 TestDisplayItem(container2, backgroundDrawingType), | 508 TestDisplayItem(container2, backgroundDrawingType), |
509 TestDisplayItem(content2, backgroundDrawingType), | 509 TestDisplayItem(content2, backgroundDrawingType), |
510 TestDisplayItem(content2, foregroundDrawingType), | 510 TestDisplayItem(content2, foregroundDrawingType), |
511 TestDisplayItem(container2, foregroundDrawingType), | 511 TestDisplayItem(container2, foregroundDrawingType), |
512 TestDisplayItem(container2, endSubsequenceType), | 512 TestDisplayItem(container2, endSubsequenceType), |
513 | 513 |
514 TestDisplayItem(container1, subsequenceType), | 514 TestDisplayItem(container1, subsequenceType), |
515 TestDisplayItem(container1, backgroundDrawingType), | 515 TestDisplayItem(container1, backgroundDrawingType), |
516 TestDisplayItem(content1, backgroundDrawingType), | 516 TestDisplayItem(content1, backgroundDrawingType), |
517 TestDisplayItem(content1, foregroundDrawingType), | 517 TestDisplayItem(content1, foregroundDrawingType), |
518 TestDisplayItem(container1, foregroundDrawingType), | 518 TestDisplayItem(container1, foregroundDrawingType), |
519 TestDisplayItem(container1, endSubsequenceType)); | 519 TestDisplayItem(container1, endSubsequenceType)); |
520 } | 520 } |
521 | 521 |
522 TEST_F(DisplayItemListTest, OutOfOrderNoCrash) | 522 TEST_F(PaintControllerTest, OutOfOrderNoCrash) |
523 { | 523 { |
524 TestDisplayItemClient client("client"); | 524 TestDisplayItemClient client("client"); |
525 GraphicsContext context(&displayItemList()); | 525 GraphicsContext context(&paintController()); |
526 | 526 |
527 const DisplayItem::Type type1 = DisplayItem::DrawingFirst; | 527 const DisplayItem::Type type1 = DisplayItem::DrawingFirst; |
528 const DisplayItem::Type type2 = static_cast<DisplayItem::Type>(DisplayItem::
DrawingFirst + 1); | 528 const DisplayItem::Type type2 = static_cast<DisplayItem::Type>(DisplayItem::
DrawingFirst + 1); |
529 const DisplayItem::Type type3 = static_cast<DisplayItem::Type>(DisplayItem::
DrawingFirst + 2); | 529 const DisplayItem::Type type3 = static_cast<DisplayItem::Type>(DisplayItem::
DrawingFirst + 2); |
530 const DisplayItem::Type type4 = static_cast<DisplayItem::Type>(DisplayItem::
DrawingFirst + 3); | 530 const DisplayItem::Type type4 = static_cast<DisplayItem::Type>(DisplayItem::
DrawingFirst + 3); |
531 | 531 |
532 drawRect(context, client, type1, FloatRect(100, 100, 100, 100)); | 532 drawRect(context, client, type1, FloatRect(100, 100, 100, 100)); |
533 drawRect(context, client, type2, FloatRect(100, 100, 50, 200)); | 533 drawRect(context, client, type2, FloatRect(100, 100, 50, 200)); |
534 drawRect(context, client, type3, FloatRect(100, 100, 50, 200)); | 534 drawRect(context, client, type3, FloatRect(100, 100, 50, 200)); |
535 drawRect(context, client, type4, FloatRect(100, 100, 100, 100)); | 535 drawRect(context, client, type4, FloatRect(100, 100, 100, 100)); |
536 | 536 |
537 displayItemList().commitNewDisplayItems(); | 537 paintController().commitNewDisplayItems(); |
538 | 538 |
539 drawRect(context, client, type2, FloatRect(100, 100, 50, 200)); | 539 drawRect(context, client, type2, FloatRect(100, 100, 50, 200)); |
540 drawRect(context, client, type3, FloatRect(100, 100, 50, 200)); | 540 drawRect(context, client, type3, FloatRect(100, 100, 50, 200)); |
541 drawRect(context, client, type1, FloatRect(100, 100, 100, 100)); | 541 drawRect(context, client, type1, FloatRect(100, 100, 100, 100)); |
542 drawRect(context, client, type4, FloatRect(100, 100, 100, 100)); | 542 drawRect(context, client, type4, FloatRect(100, 100, 100, 100)); |
543 | 543 |
544 displayItemList().commitNewDisplayItems(); | 544 paintController().commitNewDisplayItems(); |
545 } | 545 } |
546 | 546 |
547 TEST_F(DisplayItemListTest, CachedNestedSubsequenceUpdate) | 547 TEST_F(PaintControllerTest, CachedNestedSubsequenceUpdate) |
548 { | 548 { |
549 RuntimeEnabledFeatures::setSlimmingPaintSubsequenceCachingEnabled(true); | 549 RuntimeEnabledFeatures::setSlimmingPaintSubsequenceCachingEnabled(true); |
550 | 550 |
551 TestDisplayItemClient container1("container1"); | 551 TestDisplayItemClient container1("container1"); |
552 TestDisplayItemClient content1("content1"); | 552 TestDisplayItemClient content1("content1"); |
553 TestDisplayItemClient container2("container2"); | 553 TestDisplayItemClient container2("container2"); |
554 TestDisplayItemClient content2("content2"); | 554 TestDisplayItemClient content2("content2"); |
555 GraphicsContext context(&displayItemList()); | 555 GraphicsContext context(&paintController()); |
556 | 556 |
557 { | 557 { |
558 SubsequenceRecorder r(context, container1, subsequenceType); | 558 SubsequenceRecorder r(context, container1, subsequenceType); |
559 drawRect(context, container1, backgroundDrawingType, FloatRect(100, 100,
100, 100)); | 559 drawRect(context, container1, backgroundDrawingType, FloatRect(100, 100,
100, 100)); |
560 { | 560 { |
561 SubsequenceRecorder r(context, content1, subsequenceType); | 561 SubsequenceRecorder r(context, content1, subsequenceType); |
562 drawRect(context, content1, backgroundDrawingType, FloatRect(100, 10
0, 50, 200)); | 562 drawRect(context, content1, backgroundDrawingType, FloatRect(100, 10
0, 50, 200)); |
563 drawRect(context, content1, foregroundDrawingType, FloatRect(100, 10
0, 50, 200)); | 563 drawRect(context, content1, foregroundDrawingType, FloatRect(100, 10
0, 50, 200)); |
564 } | 564 } |
565 drawRect(context, container1, foregroundDrawingType, FloatRect(100, 100,
100, 100)); | 565 drawRect(context, container1, foregroundDrawingType, FloatRect(100, 100,
100, 100)); |
566 } | 566 } |
567 { | 567 { |
568 SubsequenceRecorder r(context, container2, subsequenceType); | 568 SubsequenceRecorder r(context, container2, subsequenceType); |
569 drawRect(context, container2, backgroundDrawingType, FloatRect(100, 200,
100, 100)); | 569 drawRect(context, container2, backgroundDrawingType, FloatRect(100, 200,
100, 100)); |
570 { | 570 { |
571 SubsequenceRecorder r(context, content2, subsequenceType); | 571 SubsequenceRecorder r(context, content2, subsequenceType); |
572 drawRect(context, content2, backgroundDrawingType, FloatRect(100, 20
0, 50, 200)); | 572 drawRect(context, content2, backgroundDrawingType, FloatRect(100, 20
0, 50, 200)); |
573 } | 573 } |
574 } | 574 } |
575 displayItemList().commitNewDisplayItems(); | 575 paintController().commitNewDisplayItems(); |
576 | 576 |
577 EXPECT_DISPLAY_LIST(displayItemList().displayItems(), 14, | 577 EXPECT_DISPLAY_LIST(paintController().displayItems(), 14, |
578 TestDisplayItem(container1, subsequenceType), | 578 TestDisplayItem(container1, subsequenceType), |
579 TestDisplayItem(container1, backgroundDrawingType), | 579 TestDisplayItem(container1, backgroundDrawingType), |
580 TestDisplayItem(content1, subsequenceType), | 580 TestDisplayItem(content1, subsequenceType), |
581 TestDisplayItem(content1, backgroundDrawingType), | 581 TestDisplayItem(content1, backgroundDrawingType), |
582 TestDisplayItem(content1, foregroundDrawingType), | 582 TestDisplayItem(content1, foregroundDrawingType), |
583 TestDisplayItem(content1, endSubsequenceType), | 583 TestDisplayItem(content1, endSubsequenceType), |
584 TestDisplayItem(container1, foregroundDrawingType), | 584 TestDisplayItem(container1, foregroundDrawingType), |
585 TestDisplayItem(container1, endSubsequenceType), | 585 TestDisplayItem(container1, endSubsequenceType), |
586 | 586 |
587 TestDisplayItem(container2, subsequenceType), | 587 TestDisplayItem(container2, subsequenceType), |
588 TestDisplayItem(container2, backgroundDrawingType), | 588 TestDisplayItem(container2, backgroundDrawingType), |
589 TestDisplayItem(content2, subsequenceType), | 589 TestDisplayItem(content2, subsequenceType), |
590 TestDisplayItem(content2, backgroundDrawingType), | 590 TestDisplayItem(content2, backgroundDrawingType), |
591 TestDisplayItem(content2, endSubsequenceType), | 591 TestDisplayItem(content2, endSubsequenceType), |
592 TestDisplayItem(container2, endSubsequenceType)); | 592 TestDisplayItem(container2, endSubsequenceType)); |
593 | 593 |
594 // Invalidate container1 but not content1. | 594 // Invalidate container1 but not content1. |
595 displayItemList().invalidate(container1, PaintInvalidationFull, IntRect(), I
ntRect()); | 595 paintController().invalidate(container1, PaintInvalidationFull, IntRect(), I
ntRect()); |
596 | 596 |
597 // Container2 itself now becomes empty (but still has the 'content2' child), | 597 // Container2 itself now becomes empty (but still has the 'content2' child), |
598 // and chooses not to output subsequence info. | 598 // and chooses not to output subsequence info. |
599 | 599 |
600 displayItemList().invalidate(container2, PaintInvalidationFull, IntRect(), I
ntRect()); | 600 paintController().invalidate(container2, PaintInvalidationFull, IntRect(), I
ntRect()); |
601 displayItemList().invalidate(content2, PaintInvalidationFull, IntRect(), Int
Rect()); | 601 paintController().invalidate(content2, PaintInvalidationFull, IntRect(), Int
Rect()); |
602 EXPECT_FALSE(SubsequenceRecorder::useCachedSubsequenceIfPossible(context, co
ntainer2, subsequenceType)); | 602 EXPECT_FALSE(SubsequenceRecorder::useCachedSubsequenceIfPossible(context, co
ntainer2, subsequenceType)); |
603 EXPECT_FALSE(SubsequenceRecorder::useCachedSubsequenceIfPossible(context, co
ntent2, subsequenceType)); | 603 EXPECT_FALSE(SubsequenceRecorder::useCachedSubsequenceIfPossible(context, co
ntent2, subsequenceType)); |
604 // Content2 now outputs foreground only. | 604 // Content2 now outputs foreground only. |
605 { | 605 { |
606 SubsequenceRecorder r(context, content2, subsequenceType); | 606 SubsequenceRecorder r(context, content2, subsequenceType); |
607 drawRect(context, content2, foregroundDrawingType, FloatRect(100, 200, 5
0, 200)); | 607 drawRect(context, content2, foregroundDrawingType, FloatRect(100, 200, 5
0, 200)); |
608 } | 608 } |
609 // Repaint container1 with foreground only. | 609 // Repaint container1 with foreground only. |
610 { | 610 { |
611 EXPECT_FALSE(SubsequenceRecorder::useCachedSubsequenceIfPossible(context
, container1, subsequenceType)); | 611 EXPECT_FALSE(SubsequenceRecorder::useCachedSubsequenceIfPossible(context
, container1, subsequenceType)); |
612 SubsequenceRecorder r(context, container1, subsequenceType); | 612 SubsequenceRecorder r(context, container1, subsequenceType); |
613 // Use cached subsequence of content1. | 613 // Use cached subsequence of content1. |
614 EXPECT_TRUE(SubsequenceRecorder::useCachedSubsequenceIfPossible(context,
content1, subsequenceType)); | 614 EXPECT_TRUE(SubsequenceRecorder::useCachedSubsequenceIfPossible(context,
content1, subsequenceType)); |
615 drawRect(context, container1, foregroundDrawingType, FloatRect(100, 100,
100, 100)); | 615 drawRect(context, container1, foregroundDrawingType, FloatRect(100, 100,
100, 100)); |
616 } | 616 } |
617 EXPECT_DISPLAY_LIST(displayItemList().newDisplayItems(), 7, | 617 EXPECT_DISPLAY_LIST(paintController().newDisplayItems(), 7, |
618 TestDisplayItem(content2, subsequenceType), | 618 TestDisplayItem(content2, subsequenceType), |
619 TestDisplayItem(content2, foregroundDrawingType), | 619 TestDisplayItem(content2, foregroundDrawingType), |
620 TestDisplayItem(content2, endSubsequenceType), | 620 TestDisplayItem(content2, endSubsequenceType), |
621 TestDisplayItem(container1, subsequenceType), | 621 TestDisplayItem(container1, subsequenceType), |
622 TestDisplayItem(content1, cachedSubsequenceType), | 622 TestDisplayItem(content1, cachedSubsequenceType), |
623 TestDisplayItem(container1, foregroundDrawingType), | 623 TestDisplayItem(container1, foregroundDrawingType), |
624 TestDisplayItem(container1, endSubsequenceType)); | 624 TestDisplayItem(container1, endSubsequenceType)); |
625 | 625 |
626 displayItemList().commitNewDisplayItems(); | 626 paintController().commitNewDisplayItems(); |
627 | 627 |
628 EXPECT_DISPLAY_LIST(displayItemList().displayItems(), 10, | 628 EXPECT_DISPLAY_LIST(paintController().displayItems(), 10, |
629 TestDisplayItem(content2, subsequenceType), | 629 TestDisplayItem(content2, subsequenceType), |
630 TestDisplayItem(content2, foregroundDrawingType), | 630 TestDisplayItem(content2, foregroundDrawingType), |
631 TestDisplayItem(content2, endSubsequenceType), | 631 TestDisplayItem(content2, endSubsequenceType), |
632 | 632 |
633 TestDisplayItem(container1, subsequenceType), | 633 TestDisplayItem(container1, subsequenceType), |
634 TestDisplayItem(content1, subsequenceType), | 634 TestDisplayItem(content1, subsequenceType), |
635 TestDisplayItem(content1, backgroundDrawingType), | 635 TestDisplayItem(content1, backgroundDrawingType), |
636 TestDisplayItem(content1, foregroundDrawingType), | 636 TestDisplayItem(content1, foregroundDrawingType), |
637 TestDisplayItem(content1, endSubsequenceType), | 637 TestDisplayItem(content1, endSubsequenceType), |
638 TestDisplayItem(container1, foregroundDrawingType), | 638 TestDisplayItem(container1, foregroundDrawingType), |
639 TestDisplayItem(container1, endSubsequenceType)); | 639 TestDisplayItem(container1, endSubsequenceType)); |
640 } | 640 } |
641 | 641 |
642 TEST_F(DisplayItemListTest, Scope) | 642 TEST_F(PaintControllerTest, Scope) |
643 { | 643 { |
644 TestDisplayItemClient multicol("multicol"); | 644 TestDisplayItemClient multicol("multicol"); |
645 TestDisplayItemClient content("content"); | 645 TestDisplayItemClient content("content"); |
646 GraphicsContext context(&displayItemList()); | 646 GraphicsContext context(&paintController()); |
647 | 647 |
648 FloatRect rect1(100, 100, 50, 50); | 648 FloatRect rect1(100, 100, 50, 50); |
649 FloatRect rect2(150, 100, 50, 50); | 649 FloatRect rect2(150, 100, 50, 50); |
650 FloatRect rect3(200, 100, 50, 50); | 650 FloatRect rect3(200, 100, 50, 50); |
651 | 651 |
652 drawRect(context, multicol, backgroundDrawingType, FloatRect(100, 200, 100,
100)); | 652 drawRect(context, multicol, backgroundDrawingType, FloatRect(100, 200, 100,
100)); |
653 | 653 |
654 displayItemList().beginScope(); | 654 paintController().beginScope(); |
655 drawRect(context, content, foregroundDrawingType, rect1); | 655 drawRect(context, content, foregroundDrawingType, rect1); |
656 displayItemList().endScope(); | 656 paintController().endScope(); |
657 | 657 |
658 displayItemList().beginScope(); | 658 paintController().beginScope(); |
659 drawRect(context, content, foregroundDrawingType, rect2); | 659 drawRect(context, content, foregroundDrawingType, rect2); |
660 displayItemList().endScope(); | 660 paintController().endScope(); |
661 displayItemList().commitNewDisplayItems(); | 661 paintController().commitNewDisplayItems(); |
662 | 662 |
663 EXPECT_DISPLAY_LIST(displayItemList().displayItems(), 3, | 663 EXPECT_DISPLAY_LIST(paintController().displayItems(), 3, |
664 TestDisplayItem(multicol, backgroundDrawingType), | 664 TestDisplayItem(multicol, backgroundDrawingType), |
665 TestDisplayItem(content, foregroundDrawingType), | 665 TestDisplayItem(content, foregroundDrawingType), |
666 TestDisplayItem(content, foregroundDrawingType)); | 666 TestDisplayItem(content, foregroundDrawingType)); |
667 RefPtr<const SkPicture> picture1 = static_cast<const DrawingDisplayItem&>(di
splayItemList().displayItems()[1]).picture(); | 667 RefPtr<const SkPicture> picture1 = static_cast<const DrawingDisplayItem&>(pa
intController().displayItems()[1]).picture(); |
668 RefPtr<const SkPicture> picture2 = static_cast<const DrawingDisplayItem&>(di
splayItemList().displayItems()[2]).picture(); | 668 RefPtr<const SkPicture> picture2 = static_cast<const DrawingDisplayItem&>(pa
intController().displayItems()[2]).picture(); |
669 EXPECT_NE(picture1, picture2); | 669 EXPECT_NE(picture1, picture2); |
670 | 670 |
671 // Draw again with nothing invalidated. | 671 // Draw again with nothing invalidated. |
672 EXPECT_TRUE(displayItemList().clientCacheIsValid(multicol.displayItemClient(
))); | 672 EXPECT_TRUE(paintController().clientCacheIsValid(multicol.displayItemClient(
))); |
673 drawRect(context, multicol, backgroundDrawingType, FloatRect(100, 200, 100,
100)); | 673 drawRect(context, multicol, backgroundDrawingType, FloatRect(100, 200, 100,
100)); |
674 displayItemList().beginScope(); | 674 paintController().beginScope(); |
675 drawRect(context, content, foregroundDrawingType, rect1); | 675 drawRect(context, content, foregroundDrawingType, rect1); |
676 displayItemList().endScope(); | 676 paintController().endScope(); |
677 | 677 |
678 displayItemList().beginScope(); | 678 paintController().beginScope(); |
679 drawRect(context, content, foregroundDrawingType, rect2); | 679 drawRect(context, content, foregroundDrawingType, rect2); |
680 displayItemList().endScope(); | 680 paintController().endScope(); |
681 | 681 |
682 EXPECT_DISPLAY_LIST(displayItemList().newDisplayItems(), 3, | 682 EXPECT_DISPLAY_LIST(paintController().newDisplayItems(), 3, |
683 TestDisplayItem(multicol, DisplayItem::drawingTypeToCachedDrawingType(ba
ckgroundDrawingType)), | 683 TestDisplayItem(multicol, DisplayItem::drawingTypeToCachedDrawingType(ba
ckgroundDrawingType)), |
684 TestDisplayItem(content, foregroundDrawingType), | 684 TestDisplayItem(content, foregroundDrawingType), |
685 TestDisplayItem(content, foregroundDrawingType)); | 685 TestDisplayItem(content, foregroundDrawingType)); |
686 | 686 |
687 displayItemList().commitNewDisplayItems(); | 687 paintController().commitNewDisplayItems(); |
688 | 688 |
689 EXPECT_DISPLAY_LIST(displayItemList().displayItems(), 3, | 689 EXPECT_DISPLAY_LIST(paintController().displayItems(), 3, |
690 TestDisplayItem(multicol, backgroundDrawingType), | 690 TestDisplayItem(multicol, backgroundDrawingType), |
691 TestDisplayItem(content, foregroundDrawingType), | 691 TestDisplayItem(content, foregroundDrawingType), |
692 TestDisplayItem(content, foregroundDrawingType)); | 692 TestDisplayItem(content, foregroundDrawingType)); |
693 EXPECT_NE(picture1, static_cast<const DrawingDisplayItem&>(displayItemList()
.displayItems()[1]).picture()); | 693 EXPECT_NE(picture1, static_cast<const DrawingDisplayItem&>(paintController()
.displayItems()[1]).picture()); |
694 EXPECT_NE(picture2, static_cast<const DrawingDisplayItem&>(displayItemList()
.displayItems()[2]).picture()); | 694 EXPECT_NE(picture2, static_cast<const DrawingDisplayItem&>(paintController()
.displayItems()[2]).picture()); |
695 | 695 |
696 // Now the multicol becomes 3 columns and repaints. | 696 // Now the multicol becomes 3 columns and repaints. |
697 displayItemList().invalidate(multicol, PaintInvalidationFull, IntRect(), Int
Rect()); | 697 paintController().invalidate(multicol, PaintInvalidationFull, IntRect(), Int
Rect()); |
698 drawRect(context, multicol, backgroundDrawingType, FloatRect(100, 100, 100,
100)); | 698 drawRect(context, multicol, backgroundDrawingType, FloatRect(100, 100, 100,
100)); |
699 | 699 |
700 displayItemList().beginScope(); | 700 paintController().beginScope(); |
701 drawRect(context, content, foregroundDrawingType, rect1); | 701 drawRect(context, content, foregroundDrawingType, rect1); |
702 displayItemList().endScope(); | 702 paintController().endScope(); |
703 | 703 |
704 displayItemList().beginScope(); | 704 paintController().beginScope(); |
705 drawRect(context, content, foregroundDrawingType, rect2); | 705 drawRect(context, content, foregroundDrawingType, rect2); |
706 displayItemList().endScope(); | 706 paintController().endScope(); |
707 | 707 |
708 displayItemList().beginScope(); | 708 paintController().beginScope(); |
709 drawRect(context, content, foregroundDrawingType, rect3); | 709 drawRect(context, content, foregroundDrawingType, rect3); |
710 displayItemList().endScope(); | 710 paintController().endScope(); |
711 | 711 |
712 // We should repaint everything on invalidation of the scope container. | 712 // We should repaint everything on invalidation of the scope container. |
713 EXPECT_DISPLAY_LIST(displayItemList().newDisplayItems(), 4, | 713 EXPECT_DISPLAY_LIST(paintController().newDisplayItems(), 4, |
714 TestDisplayItem(multicol, backgroundDrawingType), | 714 TestDisplayItem(multicol, backgroundDrawingType), |
715 TestDisplayItem(content, foregroundDrawingType), | 715 TestDisplayItem(content, foregroundDrawingType), |
716 TestDisplayItem(content, foregroundDrawingType), | 716 TestDisplayItem(content, foregroundDrawingType), |
717 TestDisplayItem(content, foregroundDrawingType)); | 717 TestDisplayItem(content, foregroundDrawingType)); |
718 EXPECT_NE(picture1, static_cast<const DrawingDisplayItem&>(displayItemList()
.newDisplayItems()[1]).picture()); | 718 EXPECT_NE(picture1, static_cast<const DrawingDisplayItem&>(paintController()
.newDisplayItems()[1]).picture()); |
719 EXPECT_NE(picture2, static_cast<const DrawingDisplayItem&>(displayItemList()
.newDisplayItems()[2]).picture()); | 719 EXPECT_NE(picture2, static_cast<const DrawingDisplayItem&>(paintController()
.newDisplayItems()[2]).picture()); |
720 | 720 |
721 displayItemList().commitNewDisplayItems(); | 721 paintController().commitNewDisplayItems(); |
722 } | 722 } |
723 | 723 |
724 TEST_F(DisplayItemListTest, OptimizeNoopPairs) | 724 TEST_F(PaintControllerTest, OptimizeNoopPairs) |
725 { | 725 { |
726 TestDisplayItemClient first("first"); | 726 TestDisplayItemClient first("first"); |
727 TestDisplayItemClient second("second"); | 727 TestDisplayItemClient second("second"); |
728 TestDisplayItemClient third("third"); | 728 TestDisplayItemClient third("third"); |
729 | 729 |
730 GraphicsContext context(&displayItemList()); | 730 GraphicsContext context(&paintController()); |
731 drawRect(context, first, backgroundDrawingType, FloatRect(0, 0, 100, 100)); | 731 drawRect(context, first, backgroundDrawingType, FloatRect(0, 0, 100, 100)); |
732 { | 732 { |
733 ClipPathRecorder clipRecorder(context, second, Path()); | 733 ClipPathRecorder clipRecorder(context, second, Path()); |
734 drawRect(context, second, backgroundDrawingType, FloatRect(0, 0, 100, 10
0)); | 734 drawRect(context, second, backgroundDrawingType, FloatRect(0, 0, 100, 10
0)); |
735 } | 735 } |
736 drawRect(context, third, backgroundDrawingType, FloatRect(0, 0, 100, 100)); | 736 drawRect(context, third, backgroundDrawingType, FloatRect(0, 0, 100, 100)); |
737 | 737 |
738 displayItemList().commitNewDisplayItems(); | 738 paintController().commitNewDisplayItems(); |
739 EXPECT_DISPLAY_LIST(displayItemList().displayItems(), 5, | 739 EXPECT_DISPLAY_LIST(paintController().displayItems(), 5, |
740 TestDisplayItem(first, backgroundDrawingType), | 740 TestDisplayItem(first, backgroundDrawingType), |
741 TestDisplayItem(second, DisplayItem::BeginClipPath), | 741 TestDisplayItem(second, DisplayItem::BeginClipPath), |
742 TestDisplayItem(second, backgroundDrawingType), | 742 TestDisplayItem(second, backgroundDrawingType), |
743 TestDisplayItem(second, DisplayItem::EndClipPath), | 743 TestDisplayItem(second, DisplayItem::EndClipPath), |
744 TestDisplayItem(third, backgroundDrawingType)); | 744 TestDisplayItem(third, backgroundDrawingType)); |
745 | 745 |
746 displayItemList().invalidate(second, PaintInvalidationFull, IntRect(), IntRe
ct()); | 746 paintController().invalidate(second, PaintInvalidationFull, IntRect(), IntRe
ct()); |
747 drawRect(context, first, backgroundDrawingType, FloatRect(0, 0, 100, 100)); | 747 drawRect(context, first, backgroundDrawingType, FloatRect(0, 0, 100, 100)); |
748 { | 748 { |
749 ClipRecorder clipRecorder(context, second, clipType, LayoutRect(1, 1, 2,
2)); | 749 ClipRecorder clipRecorder(context, second, clipType, LayoutRect(1, 1, 2,
2)); |
750 // Do not draw anything for second. | 750 // Do not draw anything for second. |
751 } | 751 } |
752 drawRect(context, third, backgroundDrawingType, FloatRect(0, 0, 100, 100)); | 752 drawRect(context, third, backgroundDrawingType, FloatRect(0, 0, 100, 100)); |
753 displayItemList().commitNewDisplayItems(); | 753 paintController().commitNewDisplayItems(); |
754 | 754 |
755 // Empty clips should have been optimized out. | 755 // Empty clips should have been optimized out. |
756 EXPECT_DISPLAY_LIST(displayItemList().displayItems(), 2, | 756 EXPECT_DISPLAY_LIST(paintController().displayItems(), 2, |
757 TestDisplayItem(first, backgroundDrawingType), | 757 TestDisplayItem(first, backgroundDrawingType), |
758 TestDisplayItem(third, backgroundDrawingType)); | 758 TestDisplayItem(third, backgroundDrawingType)); |
759 | 759 |
760 displayItemList().invalidate(second, PaintInvalidationFull, IntRect(), IntRe
ct()); | 760 paintController().invalidate(second, PaintInvalidationFull, IntRect(), IntRe
ct()); |
761 drawRect(context, first, backgroundDrawingType, FloatRect(0, 0, 100, 100)); | 761 drawRect(context, first, backgroundDrawingType, FloatRect(0, 0, 100, 100)); |
762 { | 762 { |
763 ClipRecorder clipRecorder(context, second, clipType, LayoutRect(1, 1, 2,
2)); | 763 ClipRecorder clipRecorder(context, second, clipType, LayoutRect(1, 1, 2,
2)); |
764 { | 764 { |
765 ClipPathRecorder clipPathRecorder(context, second, Path()); | 765 ClipPathRecorder clipPathRecorder(context, second, Path()); |
766 // Do not draw anything for second. | 766 // Do not draw anything for second. |
767 } | 767 } |
768 } | 768 } |
769 drawRect(context, third, backgroundDrawingType, FloatRect(0, 0, 100, 100)); | 769 drawRect(context, third, backgroundDrawingType, FloatRect(0, 0, 100, 100)); |
770 displayItemList().commitNewDisplayItems(); | 770 paintController().commitNewDisplayItems(); |
771 | 771 |
772 // Empty clips should have been optimized out. | 772 // Empty clips should have been optimized out. |
773 EXPECT_DISPLAY_LIST(displayItemList().displayItems(), 2, | 773 EXPECT_DISPLAY_LIST(paintController().displayItems(), 2, |
774 TestDisplayItem(first, backgroundDrawingType), | 774 TestDisplayItem(first, backgroundDrawingType), |
775 TestDisplayItem(third, backgroundDrawingType)); | 775 TestDisplayItem(third, backgroundDrawingType)); |
776 } | 776 } |
777 | 777 |
778 TEST_F(DisplayItemListTest, SmallDisplayItemListHasOnePaintChunk) | 778 TEST_F(PaintControllerTest, SmallPaintControllerHasOnePaintChunk) |
779 { | 779 { |
780 RuntimeEnabledFeatures::setSlimmingPaintV2Enabled(true); | 780 RuntimeEnabledFeatures::setSlimmingPaintV2Enabled(true); |
781 TestDisplayItemClient client("test client"); | 781 TestDisplayItemClient client("test client"); |
782 | 782 |
783 GraphicsContext context(&displayItemList()); | 783 GraphicsContext context(&paintController()); |
784 drawRect(context, client, backgroundDrawingType, FloatRect(0, 0, 100, 100)); | 784 drawRect(context, client, backgroundDrawingType, FloatRect(0, 0, 100, 100)); |
785 | 785 |
786 displayItemList().commitNewDisplayItems(); | 786 paintController().commitNewDisplayItems(); |
787 const auto& paintChunks = displayItemList().paintChunks(); | 787 const auto& paintChunks = paintController().paintChunks(); |
788 ASSERT_EQ(1u, paintChunks.size()); | 788 ASSERT_EQ(1u, paintChunks.size()); |
789 EXPECT_EQ(0u, paintChunks[0].beginIndex); | 789 EXPECT_EQ(0u, paintChunks[0].beginIndex); |
790 EXPECT_EQ(1u, paintChunks[0].endIndex); | 790 EXPECT_EQ(1u, paintChunks[0].endIndex); |
791 } | 791 } |
792 | 792 |
793 } // namespace blink | 793 } // namespace blink |
OLD | NEW |