forked from mirrors/gecko-dev
		
	 809beee368
			
		
	
	
		809beee368
		
	
	
	
	
		
			
			*** Bug 1682898 Migrate Performance Best Practices for Front-end Engineers MDN page to in-tree docs *** Bug 1682898 Migrate Performance Best Practices for Front-end Engineers MDN page to in-tree docs Differential Revision: https://phabricator.services.mozilla.com/D109970
		
			
				
	
	
		
			58 lines
		
	
	
	
		
			1.6 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			58 lines
		
	
	
	
		
			1.6 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
| "use strict";
 | |
| 
 | |
| /**
 | |
|  * WHOA THERE: We should never be adding new things to EXPECTED_REFLOWS.
 | |
|  * Instead of adding reflows to the list, you should be modifying your code to
 | |
|  * avoid the reflow.
 | |
|  *
 | |
|  * See https://firefox-source-docs.mozilla.org/performance/bestpractices.html
 | |
|  * for tips on how to do that.
 | |
|  */
 | |
| const EXPECTED_REFLOWS = [
 | |
|   /**
 | |
|    * Nothing here! Please don't add anything new!
 | |
|    */
 | |
| ];
 | |
| 
 | |
| /**
 | |
|  * This test ensures that there are no unexpected
 | |
|  * uninterruptible reflows when closing windows. When the
 | |
|  * window is closed, the test waits until the original window
 | |
|  * has activated.
 | |
|  */
 | |
| add_task(async function() {
 | |
|   // Ensure that this browser window starts focused. This seems to be
 | |
|   // necessary to avoid intermittent failures when running this test
 | |
|   // on repeat.
 | |
|   await new Promise(resolve => {
 | |
|     waitForFocus(resolve, window);
 | |
|   });
 | |
| 
 | |
|   let win = await BrowserTestUtils.openNewBrowserWindow();
 | |
|   await new Promise(resolve => {
 | |
|     waitForFocus(resolve, win);
 | |
|   });
 | |
| 
 | |
|   // At the time of writing, there are no reflows on window closing.
 | |
|   // Mochitest will fail if we have no assertions, so we add one here
 | |
|   // to make sure nobody adds any new ones.
 | |
|   Assert.equal(
 | |
|     EXPECTED_REFLOWS.length,
 | |
|     0,
 | |
|     "We shouldn't have added any new expected reflows for window close."
 | |
|   );
 | |
| 
 | |
|   await withPerfObserver(
 | |
|     async function() {
 | |
|       let promiseOrigBrowserFocused = TestUtils.waitForCondition(() => {
 | |
|         return Services.focus.activeWindow == window;
 | |
|       });
 | |
|       await BrowserTestUtils.closeWindow(win);
 | |
|       await promiseOrigBrowserFocused;
 | |
|     },
 | |
|     {
 | |
|       expectedReflows: EXPECTED_REFLOWS,
 | |
|     },
 | |
|     win
 | |
|   );
 | |
| });
 |