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

Side by Side Diff: LayoutTests/scrollingcoordinator/non-fast-scrollable-visibility-change.html

Issue 815363003: FrameView now notifies ScrollCoorinator of changes in its scrollable area set (Closed) Base URL: https://chromium.googlesource.com/chromium/blink.git@master
Patch Set: Improve test Created 5 years, 11 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
(Empty)
1 <!DOCTYPE html>
2 <style>
3 .non-fast {
4 height: 250px;
5 width: 250px;
6 display: block;
7 background-color: red;
8 overflow: scroll;
9 }
10 .non-fast > div {
11 height: 1000px;
12 width: 1000px;
13 display: block;
14 background: linear-gradient(to bottom, red, white);
15 }
16 </style>
17
18 <div id="first" class="non-fast">
19 This should be covered by the ONLY visible green overlay.
20 </div>
21 <div id="second" class="non-fast" style="margin-top:50px;">
22 This should not be visible.
23 <div></div>
24 </div>
25
26 <div id="console"></div>
27
28 <script src="../resources/js-test.js"></script>
29 <script src="resources/non-fast-scrollable-region-testing.js"></script>
30 <script>
31 window.jsTestIsAsync = true;
32 description('This test ensures that changing visibility of a non-fast ' +
33 'scrollable area correctly updates list of non-fast scrollable ' +
34 'areas. (See http://crbug.com/434982)');
35
36 onload = function() {
37 awaitCompsitingUpdate(runTest);
38 };
39
40 function runTest() {
41 var first = document.getElementById('first'),
42 second = document.getElementById('second');
43
44 nonFastScrollableRects = internals.nonFastScrollableRects(document);
45 shouldBe('nonFastScrollableRects.length', '1');
46 shouldBeEqualToString('rectToString(nonFastScrollableRects[0])',
47 '[8, 308, 250, 250]'); // second div
Rick Byers 2015/01/12 22:36:27 where is the 308 coming from? You don't want your
majidvp 2015/01/13 16:01:56 These values are not dependent on text metrics. Th
48
49 // Hide container before making it non-fast scrollable to ensure any
50 // layout occurs while it is invisible.
51 first.style.visibility = 'hidden';
52 makeNonFastScrollable(first);
53
54 // Change visibility (hidden -> visible), which should not cause any layout,
Rick Byers 2015/01/12 22:36:27 you should probably verify that no layout is neces
majidvp 2015/01/13 16:01:56 Done.
55 // and verify that non-fast scrollable areas are correctly updated.
56 awaitCompsitingUpdate(function() {
57 first.style.visibility = 'visible';
58
59 awaitCompsitingUpdate(function() {
60 nonFastScrollableRects = internals.nonFastScrollableRects(document);
61 shouldBe('nonFastScrollableRects.length', '2');
62 shouldBeEqualToString('rectToString(nonFastScrollableRects[0])',
63 '[8, 8, 250, 250]'); // first div
64 shouldBeEqualToString('rectToString(nonFastScrollableRects[1])',
65 '[8, 308, 250, 250]'); // second div
66
67 // Change visibility (visible -> hidden)
68 second.style.visibility = 'hidden';
69
70 awaitCompsitingUpdate(function() {
71 // This has no functional impact just visual
72 runNonFastScrollableRegionTest();
73
74 nonFastScrollableRects = internals.nonFastScrollableRects(document);
75 shouldBe('nonFastScrollableRects.length', '1');
76 shouldBeEqualToString('rectToString(nonFastScrollableRects[0])',
77 '[8, 8, 250, 250]'); // first div
78
79 finishJSTest();
80 });
81 });
82 });
83 }
84
85 // Makes the container non-fast scrollable area by appending a large element t o it.
86 function makeNonFastScrollable(container) {
87 var inner = document.createElement('div');
88 container.appendChild(inner);
89 }
90
91 // Waits for one RAF call to ensure compsiting update is occured and invokes t ask.
92 function awaitCompsitingUpdate(task) {
93 var loop = window.requestAnimationFrame(function() {
94 try {
95 task();
96 } finally {
97 window.cancelAnimationFrame(loop);
Rick Byers 2015/01/12 22:36:27 I don't think you need this. RAF fires exactly on
majidvp 2015/01/13 16:01:56 Done.
98 }
99 });
100 }
101
102 function rectToString(rect) {
103 return '[' + [rect.left, rect.top, rect.width, rect.height].join(', ') + ']' ;
104 }
105 </script>
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698