forked from mirrors/gecko-dev
		
	 6cd960cfb3
			
		
	
	
		6cd960cfb3
		
	
	
	
	
		
			
			A new `BrowsingContext` field has been added to track the active browser window for the `:-moz-window-inactive` pseudoclass. This field takes the place of `nsPIDOMWindowOuter::mIsActive`. With this change `:-moz-window-inactive` is now fission compatible. Differential Revision: https://phabricator.services.mozilla.com/D86422
		
			
				
	
	
		
			113 lines
		
	
	
	
		
			4.7 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			113 lines
		
	
	
	
		
			4.7 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
| /*
 | |
|  * This test checks that window activation state is set properly with multiple tabs.
 | |
|  */
 | |
| 
 | |
| /* eslint-env mozilla/frame-script */
 | |
| 
 | |
| const testPageChrome =
 | |
|   getRootDirectory(gTestPath) + "file_window_activation.html";
 | |
| const testPageHttp = testPageChrome.replace(
 | |
|   "chrome://mochitests/content",
 | |
|   "http://example.com"
 | |
| );
 | |
| const testPageWindow =
 | |
|   getRootDirectory(gTestPath) + "file_window_activation2.html";
 | |
| 
 | |
| add_task(async function reallyRunTests() {
 | |
|   let chromeTab1 = await BrowserTestUtils.openNewForegroundTab(
 | |
|     gBrowser,
 | |
|     testPageChrome
 | |
|   );
 | |
|   let chromeBrowser1 = chromeTab1.linkedBrowser;
 | |
| 
 | |
|   // This can't use openNewForegroundTab because if we focus chromeTab2 now, we
 | |
|   // won't send a focus event during test 6, further down in this file.
 | |
|   let chromeTab2 = BrowserTestUtils.addTab(gBrowser, testPageChrome);
 | |
|   let chromeBrowser2 = chromeTab2.linkedBrowser;
 | |
|   await BrowserTestUtils.browserLoaded(chromeBrowser2);
 | |
| 
 | |
|   let httpTab = BrowserTestUtils.addTab(gBrowser, testPageHttp);
 | |
|   let httpBrowser = httpTab.linkedBrowser;
 | |
|   await BrowserTestUtils.browserLoaded(httpBrowser);
 | |
| 
 | |
|   function failTest() {
 | |
|     ok(false, "Test received unexpected activate/deactivate event");
 | |
|   }
 | |
| 
 | |
|   // chrome:// url tabs should not receive "activate" or "deactivate" events
 | |
|   // as they should be sent to the top-level window in the parent process.
 | |
|   for (let b of [chromeBrowser1, chromeBrowser2]) {
 | |
|     BrowserTestUtils.waitForContentEvent(b, "activate", true).then(failTest);
 | |
|     BrowserTestUtils.waitForContentEvent(b, "deactivate", true).then(failTest);
 | |
|   }
 | |
| 
 | |
|   gURLBar.focus();
 | |
| 
 | |
|   gBrowser.selectedTab = chromeTab1;
 | |
| 
 | |
|   // The test performs four checks, using -moz-window-inactive on three child
 | |
|   // tabs (2 loading chrome:// urls and one loading an http:// url).
 | |
|   // First, the initial state should be transparent. The second check is done
 | |
|   // while another window is focused. The third check is done after that window
 | |
|   // is closed and the main window focused again. The fourth check is done after
 | |
|   // switching to the second tab.
 | |
| 
 | |
|   // Step 1 - check the initial state
 | |
|   let colorChromeBrowser1 = await getBackgroundColor(chromeBrowser1, true);
 | |
|   let colorChromeBrowser2 = await getBackgroundColor(chromeBrowser2, true);
 | |
|   let colorHttpBrowser = await getBackgroundColor(httpBrowser, true);
 | |
|   is(colorChromeBrowser1, "rgba(0, 0, 0, 0)", "first tab initial");
 | |
|   is(colorChromeBrowser2, "rgba(0, 0, 0, 0)", "second tab initial");
 | |
|   is(colorHttpBrowser, "rgba(0, 0, 0, 0)", "third tab initial");
 | |
| 
 | |
|   // Step 2 - open and focus another window
 | |
|   let otherWindow = window.open(testPageWindow, "", "chrome");
 | |
|   await SimpleTest.promiseFocus(otherWindow);
 | |
|   colorChromeBrowser1 = await getBackgroundColor(chromeBrowser1, false);
 | |
|   colorChromeBrowser2 = await getBackgroundColor(chromeBrowser2, false);
 | |
|   colorHttpBrowser = await getBackgroundColor(httpBrowser, false);
 | |
|   is(colorChromeBrowser1, "rgb(255, 0, 0)", "first tab lowered");
 | |
|   is(colorChromeBrowser2, "rgb(255, 0, 0)", "second tab lowered");
 | |
|   is(colorHttpBrowser, "rgb(255, 0, 0)", "third tab lowered");
 | |
| 
 | |
|   // Step 3 - close the other window again
 | |
|   otherWindow.close();
 | |
|   colorChromeBrowser1 = await getBackgroundColor(chromeBrowser1, true);
 | |
|   colorChromeBrowser2 = await getBackgroundColor(chromeBrowser2, true);
 | |
|   colorHttpBrowser = await getBackgroundColor(httpBrowser, true);
 | |
|   is(colorChromeBrowser1, "rgba(0, 0, 0, 0)", "first tab raised");
 | |
|   is(colorChromeBrowser2, "rgba(0, 0, 0, 0)", "second tab raised");
 | |
|   is(colorHttpBrowser, "rgba(0, 0, 0, 0)", "third tab raised");
 | |
| 
 | |
|   // Step 4 - switch to the second tab
 | |
|   gBrowser.selectedTab = chromeTab2;
 | |
|   colorChromeBrowser1 = await getBackgroundColor(chromeBrowser1, true);
 | |
|   colorChromeBrowser2 = await getBackgroundColor(chromeBrowser2, true);
 | |
|   colorHttpBrowser = await getBackgroundColor(httpBrowser, true);
 | |
|   is(colorChromeBrowser1, "rgba(0, 0, 0, 0)", "first tab after tab switch");
 | |
|   is(colorChromeBrowser2, "rgba(0, 0, 0, 0)", "second tab after tab switch");
 | |
|   is(colorHttpBrowser, "rgba(0, 0, 0, 0)", "third tab after tab switch");
 | |
| 
 | |
|   BrowserTestUtils.removeTab(chromeTab1);
 | |
|   BrowserTestUtils.removeTab(chromeTab2);
 | |
|   BrowserTestUtils.removeTab(httpTab);
 | |
|   otherWindow = null;
 | |
| });
 | |
| 
 | |
| function getBackgroundColor(browser, expectedActive) {
 | |
|   return SpecialPowers.spawn(
 | |
|     browser,
 | |
|     [!expectedActive],
 | |
|     async hasPseudoClass => {
 | |
|       let area = content.document.getElementById("area");
 | |
|       await ContentTaskUtils.waitForCondition(() => {
 | |
|         return area;
 | |
|       }, "Page has loaded");
 | |
|       await ContentTaskUtils.waitForCondition(() => {
 | |
|         return area.matches(":-moz-window-inactive") == hasPseudoClass;
 | |
|       }, `Window is considered ${hasPseudoClass ? "inactive" : "active"}`);
 | |
| 
 | |
|       return content.getComputedStyle(area).backgroundColor;
 | |
|     }
 | |
|   );
 | |
| }
 |