| Index: LayoutTests/fast/scroll-behavior/main-frame-scrollTo.html | 
| diff --git a/LayoutTests/fast/scroll-behavior/main-frame-scrollTo.html b/LayoutTests/fast/scroll-behavior/main-frame-scrollTo.html | 
| new file mode 100644 | 
| index 0000000000000000000000000000000000000000..02fb4e4b8902acd358119f69c0bd8db5a8a956e8 | 
| --- /dev/null | 
| +++ b/LayoutTests/fast/scroll-behavior/main-frame-scrollTo.html | 
| @@ -0,0 +1,65 @@ | 
| +<!DOCTYPE html> | 
| +<html> | 
| +<head> | 
| +  <style> | 
| +    #content { | 
| +      width: 7500px; | 
| +      height: 7500px; | 
| +      background-color: blue; | 
| +    } | 
| +  </style> | 
| +  <script src="../../resources/testharness.js"></script> | 
| +  <script src="../../resources/testharnessreport.js"></script> | 
| +  <script src="resources/scroll-behavior-test.js"></script> | 
| +  <script type="text/javascript"> | 
| +    function MainFrameScrollToTestCase(testData) { | 
| +      ScrollBehaviorTestCase.call(this, testData); | 
| +    } | 
| +    MainFrameScrollToTestCase.prototype = Object.create(ScrollBehaviorTestCase.prototype); | 
| +    MainFrameScrollToTestCase.constructor = MainFrameScrollToTestCase; | 
| +    MainFrameScrollToTestCase.prototype.run = function() { | 
| +      document.documentElement.style.scrollBehavior = this.css; | 
| +      if (this.js) { | 
| +        window.scrollTo(this.x, this.y, {behavior: this.js}); | 
| +      } else { | 
| +        window.scrollTo(this.x, this.y); | 
| +      } | 
| +    } | 
| + | 
| +    const testScrolls = [ | 
| +      {js: "instant", css: "instant", x: 1, y: 2}, | 
| +      {js: "instant", css: "smooth", x: 2, y: 3}, | 
| +      {js: "auto", css: "instant", x: 3, y: 4}, | 
| +      {js: "", css: "instant", x: 4, y: 5}, | 
| +      {js: "smooth", css: "instant", waitForEnd: true, x: 10, y: 15}, | 
| +      {js: "smooth", css: "smooth", waitForEnd: true, x: 20, y: 25}, | 
| +      {js: "auto", css: "smooth", waitForEnd: true, x: 30, y: 35}, | 
| +      {js: "", css: "smooth", waitForEnd: true, x: 40, y: 45}, | 
| +      {js: "smooth", css: "instant", waitForEnd: false, x: 4000, y: 4100}, | 
| +      {js: "smooth", css: "smooth", waitForEnd: false, x: 15, y: 20}, | 
| +      {js: "auto", css: "smooth", waitForEnd: false, x: 4100, y: 4000}, | 
| +      {js: "", css: "smooth", waitForEnd: false, x: 10, y: 5}, | 
| +    ]; | 
| + | 
| +    function doTest() | 
| +    { | 
| +      var testCases = []; | 
| +      for (var i = 0; i < testScrolls.length; i++) { | 
| +        testCases.push(new MainFrameScrollToTestCase(testScrolls[i])); | 
| +      } | 
| + | 
| +      var scrollBehaviorTest = new ScrollBehaviorTest(document.documentElement, | 
| +                                                      document, | 
| +                                                      testCases); | 
| +      scrollBehaviorTest.run(); | 
| +    } | 
| + | 
| +    window.addEventListener('load', doTest, false); | 
| +  </script> | 
| +</head> | 
| + | 
| +<body> | 
| +  <p>Test that calling scrollTo on the main frame works with both scroll behaviors</p> | 
| +  <div id="content"></div> | 
| +</body> | 
| +</html> | 
|  |