forked from mirrors/gecko-dev
		
	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;
 | 
						|
    }
 | 
						|
  );
 | 
						|
}
 |