forked from mirrors/gecko-dev
		
	This was done using the following script:
37e3803c7a/processors/chromeutils-import.jsm
MozReview-Commit-ID: 1Nc3XDu0wGl
--HG--
extra : source : 12fc4dee861c812fd2bd032c63ef17af61800c70
extra : intermediate-source : 34c999fa006bffe8705cf50c54708aa21a962e62
extra : histedit_source : b2be2c5e5d226e6c347312456a6ae339c1e634b0
		
	
			
		
			
				
	
	
		
			70 lines
		
	
	
	
		
			2.5 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			70 lines
		
	
	
	
		
			2.5 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
/* Any copyright is dedicated to the Public Domain.
 | 
						|
 * http://creativecommons.org/publicdomain/zero/1.0/ */
 | 
						|
 | 
						|
"use strict";
 | 
						|
 | 
						|
ChromeUtils.import("resource://gre/modules/E10SUtils.jsm");
 | 
						|
 | 
						|
const ORIGIN = "https://example.com";
 | 
						|
const PERMISSIONS_PAGE = getRootDirectory(gTestPath).replace("chrome://mochitests/content", ORIGIN) + "permissions.html";
 | 
						|
const SUBFRAME_PAGE = getRootDirectory(gTestPath).replace("chrome://mochitests/content", ORIGIN) + "temporary_permissions_subframe.html";
 | 
						|
 | 
						|
// Test that setting temp permissions triggers a change in the identity block.
 | 
						|
add_task(async function testTempPermissionChangeEvents() {
 | 
						|
  let uri = NetUtil.newURI(ORIGIN);
 | 
						|
  let id = "geo";
 | 
						|
 | 
						|
  await BrowserTestUtils.withNewTab(uri.spec, function(browser) {
 | 
						|
    SitePermissions.set(uri, id, SitePermissions.BLOCK, SitePermissions.SCOPE_TEMPORARY, browser);
 | 
						|
 | 
						|
    Assert.deepEqual(SitePermissions.get(uri, id, browser), {
 | 
						|
      state: SitePermissions.BLOCK,
 | 
						|
      scope: SitePermissions.SCOPE_TEMPORARY,
 | 
						|
    });
 | 
						|
 | 
						|
    let geoIcon = document.querySelector(".blocked-permission-icon[data-permission-id=geo]");
 | 
						|
 | 
						|
    Assert.notEqual(geoIcon.boxObject.width, 0, "geo anchor should be visible");
 | 
						|
 | 
						|
    SitePermissions.remove(uri, id, browser);
 | 
						|
 | 
						|
    Assert.equal(geoIcon.boxObject.width, 0, "geo anchor should not be visible");
 | 
						|
  });
 | 
						|
});
 | 
						|
 | 
						|
// Test that temp blocked permissions requested by subframes (with a different URI) affect the whole page.
 | 
						|
add_task(async function testTempPermissionSubframes() {
 | 
						|
  let uri = NetUtil.newURI(ORIGIN);
 | 
						|
  let id = "geo";
 | 
						|
 | 
						|
  await BrowserTestUtils.withNewTab(SUBFRAME_PAGE, async function(browser) {
 | 
						|
    let popupshown = BrowserTestUtils.waitForEvent(PopupNotifications.panel, "popupshown");
 | 
						|
 | 
						|
    // Request a permission.
 | 
						|
    await ContentTask.spawn(browser, uri.host, function(host) {
 | 
						|
      E10SUtils.wrapHandlingUserInput(content, true, function() {
 | 
						|
        let frame = content.document.getElementById("frame");
 | 
						|
        let frameDoc = frame.contentWindow.document;
 | 
						|
 | 
						|
        // Make sure that the origin of our test page is different.
 | 
						|
        Assert.notEqual(frameDoc.location.host, host);
 | 
						|
 | 
						|
        frameDoc.getElementById("geo").click();
 | 
						|
      });
 | 
						|
    });
 | 
						|
 | 
						|
    await popupshown;
 | 
						|
 | 
						|
    let popuphidden = BrowserTestUtils.waitForEvent(PopupNotifications.panel, "popuphidden");
 | 
						|
 | 
						|
    let notification = PopupNotifications.panel.firstChild;
 | 
						|
    EventUtils.synthesizeMouseAtCenter(notification.secondaryButton, {});
 | 
						|
 | 
						|
    await popuphidden;
 | 
						|
 | 
						|
    Assert.deepEqual(SitePermissions.get(uri, id, browser), {
 | 
						|
      state: SitePermissions.BLOCK,
 | 
						|
      scope: SitePermissions.SCOPE_TEMPORARY,
 | 
						|
    });
 | 
						|
  });
 | 
						|
});
 |