OLD | NEW |
1 <script src="../../../resources/testharness.js"></script> | 1 <script src="../../../resources/testharness.js"></script> |
2 <script src="../../../resources/testharnessreport.js"></script> | 2 <script src="../../../resources/testharnessreport.js"></script> |
3 <style> | 3 <style> |
| 4 html { |
| 5 -webkit-writing-mode: vertical-rl; |
| 6 } |
4 body { | 7 body { |
5 margin: 0px; | 8 margin: 0px; |
6 height: 2000px; | 9 height: 2000px; |
7 width: 2000px; | 10 width: 2000px; |
8 } | 11 } |
9 #changer { | 12 #changer { |
10 background-color: #FF7F7F; | 13 background-color: #FF7F7F; |
11 height: 10px; | 14 width: 0px; |
12 } | 15 } |
13 #anchor { | 16 #anchor { |
14 height: 1500px; | 17 width: 1500px; |
15 background-color: #84BE6A; | 18 background-color: #84BE6A; |
16 } | 19 } |
17 </style> | 20 </style> |
18 | 21 |
19 <div id="changer"></div> | 22 <div id="changer"></div> |
20 <div id="anchor"></div> | 23 <div id="anchor"></div> |
21 | 24 |
22 <script> | 25 <script> |
23 var asyncTest = async_test("Verify smooth scroll interaction with scroll anchr
oing"); | 26 var asyncTest = async_test("Verify smooth scroll interaction with scroll anchr
oing on page with vertical-lr writing mode"); |
24 | 27 |
25 // The element that will change in height. | 28 // The element that will change in height. |
26 var ch; | 29 var ch; |
27 | |
28 // Initital scroll position. | |
29 var initialX = 0; | |
30 var initialY = 10; | |
31 // Amount to smooth scroll by. | 30 // Amount to smooth scroll by. |
32 var userScrollX = 51; | 31 var userScrollX = -205; |
33 var userScrollY = 205; | 32 var userScrollY = 51; |
34 // Amount to change the height of the element above the viewport. | 33 // Amount to change the height of the element above the viewport. |
35 var changerY = 100; | 34 var changerX = 100; |
36 // End position: height of ch + userScroll. | 35 // End position: height of ch + userScroll. |
37 var endX = 51; | 36 var endX = -305; |
38 var endY = 305; | 37 var endY = 51; |
39 | 38 |
40 function scrollListener() { | 39 function scrollListener() { |
41 if (window.scrollX == endX && window.scrollY == endY) { | 40 if (window.scrollX == endX && window.scrollY == endY) { |
42 asyncTest.done(); | 41 asyncTest.done(); |
43 return; | 42 return; |
44 } | 43 } |
45 | 44 |
46 if (ch.style.height != "100") | 45 if (ch.style.width != "100") |
47 ch.style.height = changerY; | 46 ch.style.width = changerX; |
48 } | 47 } |
49 | 48 |
50 window.onload = function() { | 49 window.onload = function() { |
51 assert_false(!window.internals, 'This test requires internals'); | 50 assert_false(!window.internals, 'This test requires internals'); |
52 internals.runtimeFlags.scrollAnchoringEnabled = true; | 51 internals.runtimeFlags.scrollAnchoringEnabled = true; |
53 // Turn on smooth scrolling. | 52 // Turn on smooth scrolling. |
54 internals.settings.setScrollAnimatorEnabled(true); | 53 internals.settings.setScrollAnimatorEnabled(true); |
55 | 54 |
56 ch = document.getElementById("changer"); | 55 ch = document.getElementById("changer"); |
57 document.getElementById('anchor').scrollIntoView(); | |
58 | 56 |
59 // Smooth scroll. | 57 // Smooth scroll. |
60 eventSender.mouseMoveTo(100, 100); | 58 eventSender.mouseMoveTo(100, 100); |
61 eventSender.continuousMouseScrollBy(-userScrollX, -userScrollY); | 59 eventSender.continuousMouseScrollBy(-userScrollX, -userScrollY); |
62 | 60 |
63 asyncTest.step(function() { | |
64 assert_equals(window.scrollX, initialX); | |
65 assert_equals(window.scrollY, initialY); | |
66 }); | |
67 | |
68 document.addEventListener("scroll", scrollListener); | 61 document.addEventListener("scroll", scrollListener); |
69 } | 62 } |
70 </script> | 63 </script> |
OLD | NEW |