Bug 719271 - Site-specific zoom level shouldn't apply to media documents [r=gavin]

This commit is contained in:
Matt Brubeck 2012-01-20 11:43:24 -08:00
Родитель 64fd26dafd
Коммит 7052b0f480
3 изменённых файлов: 148 добавлений и 5 удалений

Просмотреть файл

@ -232,8 +232,8 @@ var FullZoom = {
let browser = aBrowser || gBrowser.selectedBrowser; let browser = aBrowser || gBrowser.selectedBrowser;
// Image documents should always start at 1, and are not affected by prefs. // Media documents should always start at 1, and are not affected by prefs.
if (!aIsTabSwitch && browser.contentDocument instanceof ImageDocument) { if (!aIsTabSwitch && browser.contentDocument.mozSyntheticDocument) {
ZoomManager.setZoomForBrowser(browser, 1); ZoomManager.setZoomForBrowser(browser, 1);
return; return;
} }
@ -309,7 +309,7 @@ var FullZoom = {
var browser = aBrowser || (gBrowser && gBrowser.selectedBrowser); var browser = aBrowser || (gBrowser && gBrowser.selectedBrowser);
try { try {
if (browser.contentDocument instanceof ImageDocument) if (browser.contentDocument.mozSyntheticDocument)
return; return;
if (typeof aValue != "undefined") if (typeof aValue != "undefined")
@ -324,7 +324,7 @@ var FullZoom = {
_applySettingToPref: function FullZoom__applySettingToPref() { _applySettingToPref: function FullZoom__applySettingToPref() {
if (!this.siteSpecific || gInPrintPreviewMode || if (!this.siteSpecific || gInPrintPreviewMode ||
content.document instanceof ImageDocument) content.document.mozSyntheticDocument)
return; return;
var zoomLevel = ZoomManager.zoom; var zoomLevel = ZoomManager.zoom;
@ -332,7 +332,7 @@ var FullZoom = {
}, },
_removePref: function FullZoom__removePref() { _removePref: function FullZoom__removePref() {
if (!(content.document instanceof ImageDocument)) if (!(content.document.mozSyntheticDocument))
Services.contentPrefs.removePref(gBrowser.currentURI, this.name); Services.contentPrefs.removePref(gBrowser.currentURI, this.name);
}, },

Просмотреть файл

@ -174,6 +174,7 @@ _BROWSER_FILES = \
browser_bug655584.js \ browser_bug655584.js \
browser_bug664672.js \ browser_bug664672.js \
browser_bug710878.js \ browser_bug710878.js \
browser_bug719271.js \
browser_canonizeURL.js \ browser_canonizeURL.js \
browser_findbarClose.js \ browser_findbarClose.js \
browser_keywordBookmarklets.js \ browser_keywordBookmarklets.js \
@ -231,6 +232,7 @@ _BROWSER_FILES = \
discovery.html \ discovery.html \
domplate_test.js \ domplate_test.js \
moz.png \ moz.png \
video.ogg \
test_bug435035.html \ test_bug435035.html \
test_bug462673.html \ test_bug462673.html \
page_style_sample.html \ page_style_sample.html \

Просмотреть файл

@ -0,0 +1,141 @@
/* This Source Code Form is subject to the terms of the Mozilla Public
* License, v. 2.0. If a copy of the MPL was not distributed with this file,
* You can obtain one at http://mozilla.org/MPL/2.0/. */
"use strict";
const TEST_PAGE = "http://example.org/browser/browser/base/content/test/zoom_test.html";
const TEST_VIDEO = "http://example.org/browser/browser/base/content/test/video.ogg";
var gTab1, gTab2, gLevel1, gLevel2;
function test() {
waitForExplicitFinish();
gTab1 = gBrowser.addTab();
gTab2 = gBrowser.addTab();
gBrowser.selectedTab = gTab1;
load(gTab1, TEST_PAGE, function() {
load(gTab2, TEST_VIDEO, zoomTab1);
});
}
function zoomTab1() {
is(gBrowser.selectedTab, gTab1, "Tab 1 is selected");
zoomTest(gTab1, 1, "Initial zoom of tab 1 should be 1");
zoomTest(gTab2, 1, "Initial zoom of tab 2 should be 1");
FullZoom.enlarge();
gLevel1 = ZoomManager.getZoomForBrowser(gBrowser.getBrowserForTab(gTab1));
ok(gLevel1 > 1, "New zoom for tab 1 should be greater than 1");
zoomTest(gTab2, 1, "Zooming tab 1 should not affect tab 2");
gBrowser.selectedTab = gTab2;
zoomTest(gTab2, 1, "Tab 2 is still unzoomed after it is selected");
zoomTest(gTab1, gLevel1, "Tab 1 is still zoomed");
zoomTab2();
}
function zoomTab2() {
is(gBrowser.selectedTab, gTab2, "Tab 2 is selected");
FullZoom.reduce();
let gLevel2 = ZoomManager.getZoomForBrowser(gBrowser.getBrowserForTab(gTab2));
ok(gLevel2 < 1, "New zoom for tab 2 should be less than 1");
zoomTest(gTab1, gLevel1, "Zooming tab 2 should not affect tab 1");
afterZoom(function() {
zoomTest(gTab1, gLevel1, "Tab 1 should have the same zoom after it's selected");
testNavigation();
});
gBrowser.selectedTab = gTab1;
}
function testNavigation() {
load(gTab1, TEST_VIDEO, function() {
zoomTest(gTab1, 1, "Zoom should be 1 when a video was loaded");
navigate(BACK, function() {
zoomTest(gTab1, gLevel1, "Zoom should be restored when a page is loaded");
navigate(FORWARD, function() {
zoomTest(gTab1, 1, "Zoom should be 1 again when navigating back to a video");
finishTest();
});
});
});
}
var finishTestStarted = false;
function finishTest() {
ok(!finishTestStarted, "finishTest called more than once");
finishTestStarted = true;
gBrowser.selectedTab = gTab1;
FullZoom.reset();
gBrowser.removeTab(gTab1);
gBrowser.selectedTab = gTab2;
FullZoom.reset();
gBrowser.removeTab(gTab2);
finish();
}
function zoomTest(tab, val, msg) {
is(ZoomManager.getZoomForBrowser(tab.linkedBrowser), val, msg);
}
function load(tab, url, cb) {
let didLoad = false;
let didZoom = false;
tab.linkedBrowser.addEventListener("load", function onload(event) {
event.currentTarget.removeEventListener("load", onload, true);
didLoad = true;
if (didZoom)
executeSoon(cb);
}, true);
afterZoom(function() {
didZoom = true;
if (didLoad)
executeSoon(cb);
});
tab.linkedBrowser.loadURI(url);
}
const BACK = 0;
const FORWARD = 1;
function navigate(direction, cb) {
let didPs = false;
let didZoom = false;
gBrowser.addEventListener("pageshow", function onpageshow(event) {
gBrowser.removeEventListener("pageshow", onpageshow, true);
didPs = true;
if (didZoom)
executeSoon(cb);
}, true);
afterZoom(function() {
didZoom = true;
if (didPs)
executeSoon(cb);
});
if (direction == BACK)
gBrowser.goBack();
else if (direction == FORWARD)
gBrowser.goForward();
}
function afterZoom(cb) {
let oldSZFB = ZoomManager.setZoomForBrowser;
ZoomManager.setZoomForBrowser = function(browser, value) {
oldSZFB.call(ZoomManager, browser, value);
ZoomManager.setZoomForBrowser = oldSZFB;
executeSoon(cb);
};
}