forked from mirrors/gecko-dev
		
	 cf83ee7bb4
			
		
	
	
		cf83ee7bb4
		
	
	
	
	
		
			
			Note that this patch also replaces legacy VK_* with KEY_*, and replaces synthesizeKey() for inputting some characters with sendString() because it's better and clearer what it does and it sets shiftKey state properly. MozReview-Commit-ID: De4enbjux3T --HG-- extra : rebase_source : 2296b84bff8e22f01eeb48cd8614fac5db11136a
		
			
				
	
	
		
			56 lines
		
	
	
	
		
			2 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			56 lines
		
	
	
	
		
			2 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
| add_task(async function() {
 | |
|   const childContent = "<div style='position: absolute; left: 2200px; background: green; width: 200px; height: 200px;'>" +
 | |
|                        "div</div><div  style='position: absolute; left: 0px; background: red; width: 200px; height: 200px;'>" +
 | |
|                        "<span id='s'>div</span></div>";
 | |
| 
 | |
|   let tab = gBrowser.selectedTab = BrowserTestUtils.addTab(gBrowser);
 | |
| 
 | |
|   await promiseTabLoadEvent(tab, "data:text/html;charset=utf-8," + escape(childContent));
 | |
|   await SimpleTest.promiseFocus(gBrowser.selectedBrowser);
 | |
| 
 | |
|   let remote = gBrowser.selectedBrowser.isRemoteBrowser;
 | |
| 
 | |
|   let findBarOpenPromise = promiseWaitForEvent(gBrowser, "findbaropen");
 | |
|   EventUtils.synthesizeKey("f", {accelKey: true});
 | |
|   await findBarOpenPromise;
 | |
| 
 | |
|   ok(gFindBarInitialized, "find bar is now initialized");
 | |
| 
 | |
|   // Finds the div in the green box.
 | |
|   let scrollPromise = remote ?
 | |
|     BrowserTestUtils.waitForContentEvent(gBrowser.selectedBrowser, "scroll") :
 | |
|     BrowserTestUtils.waitForEvent(gBrowser, "scroll");
 | |
|   EventUtils.sendString("div");
 | |
|   await scrollPromise;
 | |
| 
 | |
|   // Wait for one paint to ensure we've processed the previous key events and scrolling.
 | |
|   await ContentTask.spawn(gBrowser.selectedBrowser, null, async function() {
 | |
|     return new Promise(
 | |
|       resolve => {
 | |
|         content.requestAnimationFrame(() => {
 | |
|           setTimeout(resolve, 0);
 | |
|         });
 | |
|       }
 | |
|     );
 | |
|   });
 | |
| 
 | |
|   // Finds the div in the red box.
 | |
|   scrollPromise = remote ?
 | |
|     BrowserTestUtils.waitForContentEvent(gBrowser.selectedBrowser, "scroll") :
 | |
|     BrowserTestUtils.waitForEvent(gBrowser, "scroll");
 | |
|   EventUtils.synthesizeKey("g", {accelKey: true});
 | |
|   await scrollPromise;
 | |
| 
 | |
|   await ContentTask.spawn(gBrowser.selectedBrowser, null, async function() {
 | |
|     Assert.ok(content.document.getElementById("s").getBoundingClientRect().left >= 0,
 | |
|       "scroll should include find result");
 | |
|   });
 | |
| 
 | |
|   // clear the find bar
 | |
|   EventUtils.synthesizeKey("a", {accelKey: true});
 | |
|   EventUtils.synthesizeKey("KEY_Delete");
 | |
| 
 | |
|   gFindBar.close();
 | |
|   gBrowser.removeCurrentTab();
 | |
| });
 | |
| 
 |