mirror of
https://github.com/ManchildProductions/UXP-Fixed.git
synced 2026-05-27 21:18:52 +00:00
141 lines
4.3 KiB
JavaScript
141 lines
4.3 KiB
JavaScript
/* Any copyright is dedicated to the Public Domain.
|
|
http://creativecommons.org/publicdomain/zero/1.0/ */
|
|
|
|
"use strict";
|
|
|
|
// Tests changing viewport DPR
|
|
const TEST_URL = "data:text/html;charset=utf-8,DPR list test";
|
|
const DEFAULT_DPPX = window.devicePixelRatio;
|
|
const VIEWPORT_DPPX = DEFAULT_DPPX + 2;
|
|
const Types = require("devtools/client/responsive.html/types");
|
|
|
|
const testDevice = {
|
|
"name": "Fake Phone RDM Test",
|
|
"width": 320,
|
|
"height": 470,
|
|
"pixelRatio": 5.5,
|
|
"userAgent": "Mozilla/5.0 (Mobile; rv:39.0) Gecko/39.0 Firefox/39.0",
|
|
"touch": true,
|
|
"firefoxOS": true,
|
|
"os": "custom",
|
|
"featured": true,
|
|
};
|
|
|
|
// Add the new device to the list
|
|
addDeviceForTest(testDevice);
|
|
|
|
addRDMTask(TEST_URL, function* ({ ui, manager }) {
|
|
yield waitStartup(ui);
|
|
|
|
yield testDefaults(ui);
|
|
yield testChangingDevice(ui);
|
|
yield testResetWhenResizingViewport(ui);
|
|
yield testChangingDPR(ui);
|
|
});
|
|
|
|
function* waitStartup(ui) {
|
|
let { store } = ui.toolWindow;
|
|
|
|
// Wait until the viewport has been added and the device list has been loaded
|
|
yield waitUntilState(store, state => state.viewports.length == 1
|
|
&& state.devices.listState == Types.deviceListState.LOADED);
|
|
}
|
|
|
|
function* testDefaults(ui) {
|
|
info("Test Defaults");
|
|
|
|
yield testDevicePixelRatio(ui, window.devicePixelRatio);
|
|
testViewportDPRSelect(ui, {value: window.devicePixelRatio, disabled: false});
|
|
testViewportDeviceSelectLabel(ui, "no device selected");
|
|
}
|
|
|
|
function* testChangingDevice(ui) {
|
|
info("Test Changing Device");
|
|
|
|
let waitPixelRatioChange = onceDevicePixelRatioChange(ui);
|
|
|
|
yield selectDevice(ui, testDevice.name);
|
|
yield waitForViewportResizeTo(ui, testDevice.width, testDevice.height);
|
|
yield waitPixelRatioChange;
|
|
yield testDevicePixelRatio(ui, testDevice.pixelRatio);
|
|
testViewportDPRSelect(ui, {value: testDevice.pixelRatio, disabled: true});
|
|
testViewportDeviceSelectLabel(ui, testDevice.name);
|
|
}
|
|
|
|
function* testResetWhenResizingViewport(ui) {
|
|
info("Test reset when resizing the viewport");
|
|
|
|
let waitPixelRatioChange = onceDevicePixelRatioChange(ui);
|
|
|
|
let deviceRemoved = once(ui, "device-removed");
|
|
yield testViewportResize(ui, ".viewport-vertical-resize-handle",
|
|
[-10, -10], [testDevice.width, testDevice.height - 10], [0, -10], ui);
|
|
yield deviceRemoved;
|
|
|
|
yield waitPixelRatioChange;
|
|
yield testDevicePixelRatio(ui, window.devicePixelRatio);
|
|
|
|
testViewportDPRSelect(ui, {value: window.devicePixelRatio, disabled: false});
|
|
testViewportDeviceSelectLabel(ui, "no device selected");
|
|
}
|
|
|
|
function* testChangingDPR(ui) {
|
|
info("Test changing device pixel ratio");
|
|
|
|
let waitPixelRatioChange = onceDevicePixelRatioChange(ui);
|
|
|
|
yield selectDPR(ui, VIEWPORT_DPPX);
|
|
yield waitPixelRatioChange;
|
|
yield testDevicePixelRatio(ui, VIEWPORT_DPPX);
|
|
testViewportDPRSelect(ui, {value: VIEWPORT_DPPX, disabled: false});
|
|
testViewportDeviceSelectLabel(ui, "no device selected");
|
|
}
|
|
|
|
function testViewportDPRSelect(ui, expected) {
|
|
info("Test viewport's DPR Select");
|
|
|
|
let select = ui.toolWindow.document.querySelector("#global-dpr-selector > select");
|
|
is(select.value, expected.value,
|
|
`DPR Select value should be: ${expected.value}`);
|
|
is(select.disabled, expected.disabled,
|
|
`DPR Select should be ${expected.disabled ? "disabled" : "enabled"}.`);
|
|
}
|
|
|
|
function* testDevicePixelRatio(ui, expected) {
|
|
info("Test device pixel ratio");
|
|
|
|
let dppx = yield getViewportDevicePixelRatio(ui);
|
|
is(dppx, expected, `devicePixelRatio should be: ${expected}`);
|
|
}
|
|
|
|
function* getViewportDevicePixelRatio(ui) {
|
|
return yield ContentTask.spawn(ui.getViewportBrowser(), {}, function* () {
|
|
return content.devicePixelRatio;
|
|
});
|
|
}
|
|
|
|
function onceDevicePixelRatioChange(ui) {
|
|
return ContentTask.spawn(ui.getViewportBrowser(), {}, function* () {
|
|
info(`Listening for a pixel ratio change (current: ${content.devicePixelRatio}dppx)`);
|
|
|
|
let pixelRatio = content.devicePixelRatio;
|
|
let mql = content.matchMedia(`(resolution: ${pixelRatio}dppx)`);
|
|
|
|
return new Promise(resolve => {
|
|
const onWindowCreated = () => {
|
|
if (pixelRatio !== content.devicePixelRatio) {
|
|
resolve();
|
|
}
|
|
};
|
|
|
|
addEventListener("DOMWindowCreated", onWindowCreated, {once: true});
|
|
|
|
mql.addListener(function listener() {
|
|
mql.removeListener(listener);
|
|
removeEventListener("DOMWindowCreated", onWindowCreated, {once: true});
|
|
resolve();
|
|
});
|
|
});
|
|
});
|
|
}
|