mirror of
https://github.com/classilla/tenfourfox.git
synced 2024-10-09 01:54:55 +00:00
201 lines
6.3 KiB
HTML
201 lines
6.3 KiB
HTML
<!DOCTYPE html>
|
|
|
|
<html>
|
|
|
|
<head>
|
|
<meta charset="utf8">
|
|
<title></title>
|
|
|
|
<script type="application/javascript" src="chrome://mochikit/content/tests/SimpleTest/SimpleTest.js"></script>
|
|
<script type="application/javascript" src="chrome://mochikit/content/chrome-harness.js"></script>
|
|
<script type="application/javascript;version=1.8" src="head.js"></script>
|
|
<link rel="stylesheet" type="text/css" href="chrome://mochikit/content/tests/SimpleTest/test.css">
|
|
</head>
|
|
|
|
<body>
|
|
|
|
<script type="application/javascript;version=1.8">
|
|
window.onload = function() {
|
|
SimpleTest.waitForExplicitFinish();
|
|
|
|
let win;
|
|
|
|
SimpleTest.registerCleanupFunction(() => {
|
|
Task.spawn(function*() {
|
|
if (win) {
|
|
yield closeWebIDE(win);
|
|
}
|
|
DebuggerServer.destroy();
|
|
yield removeAllProjects();
|
|
});
|
|
});
|
|
|
|
Task.spawn(function*() {
|
|
function isPlayActive() {
|
|
return !win.document.querySelector("#cmd_play").hasAttribute("disabled");
|
|
}
|
|
|
|
function isStopActive() {
|
|
return !win.document.querySelector("#cmd_stop").hasAttribute("disabled");
|
|
}
|
|
|
|
const { DebuggerServer } = require("devtools/server/main");
|
|
|
|
if (!DebuggerServer.initialized) {
|
|
DebuggerServer.init();
|
|
DebuggerServer.addBrowserActors();
|
|
}
|
|
|
|
win = yield openWebIDE();
|
|
let docRuntime = getRuntimeDocument(win);
|
|
let docProject = getProjectDocument(win);
|
|
let winProject = getProjectWindow(win);
|
|
|
|
win.AppManager.runtimeList.usb.push({
|
|
connect: function(connection) {
|
|
is(connection, win.AppManager.connection, "connection is valid");
|
|
connection.host = null; // force connectPipe
|
|
connection.connect();
|
|
return promise.resolve();
|
|
},
|
|
|
|
get name() {
|
|
return "fakeRuntime";
|
|
}
|
|
});
|
|
|
|
win.AppManager.runtimeList.usb.push({
|
|
connect: function(connection) {
|
|
let deferred = promise.defer();
|
|
return deferred.promise;
|
|
},
|
|
|
|
get name() {
|
|
return "infiniteRuntime";
|
|
}
|
|
});
|
|
|
|
win.AppManager.runtimeList.usb.push({
|
|
connect: function(connection) {
|
|
let deferred = promise.defer();
|
|
return deferred.promise;
|
|
},
|
|
|
|
prolongedConnection: true,
|
|
|
|
get name() {
|
|
return "prolongedRuntime";
|
|
}
|
|
});
|
|
|
|
win.AppManager.update("runtime-list");
|
|
|
|
let packagedAppLocation = getTestFilePath("app");
|
|
|
|
yield winProject.projectList.importPackagedApp(packagedAppLocation);
|
|
yield waitForUpdate(win, "project-validated");
|
|
|
|
let panelNode = docRuntime.querySelector("#runtime-panel");
|
|
let items = panelNode.querySelectorAll(".runtime-panel-item-usb");
|
|
is(items.length, 3, "Found 3 runtime buttons");
|
|
|
|
let deferred = promise.defer();
|
|
win.AppManager.connection.once(
|
|
win.Connection.Events.CONNECTED,
|
|
() => deferred.resolve());
|
|
|
|
items[0].click();
|
|
|
|
ok(win.document.querySelector("window").className, "busy", "UI is busy");
|
|
yield win.UI._busyPromise;
|
|
|
|
is(Object.keys(DebuggerServer._connections).length, 1, "Connected");
|
|
|
|
yield waitForUpdate(win, "runtime-global-actors");
|
|
|
|
ok(isPlayActive(), "play button is enabled 1");
|
|
ok(!isStopActive(), "stop button is disabled 1");
|
|
let oldProject = win.AppManager.selectedProject;
|
|
win.AppManager.selectedProject = null;
|
|
|
|
yield nextTick();
|
|
|
|
ok(!isPlayActive(), "play button is disabled 2");
|
|
ok(!isStopActive(), "stop button is disabled 2");
|
|
win.AppManager._selectedProject = oldProject;
|
|
win.UI.updateCommands();
|
|
|
|
yield nextTick();
|
|
|
|
ok(isPlayActive(), "play button is enabled 3");
|
|
ok(!isStopActive(), "stop button is disabled 3");
|
|
|
|
yield win.Cmds.disconnectRuntime();
|
|
|
|
is(Object.keys(DebuggerServer._connections).length, 0, "Disconnected");
|
|
|
|
ok(win.AppManager.selectedProject, "A project is still selected");
|
|
ok(!isPlayActive(), "play button is disabled 4");
|
|
ok(!isStopActive(), "stop button is disabled 4");
|
|
|
|
docRuntime.querySelectorAll(".runtime-panel-item-other")[1].click();
|
|
|
|
yield waitForUpdate(win, "runtime-targets");
|
|
|
|
is(Object.keys(DebuggerServer._connections).length, 1, "Locally connected");
|
|
|
|
ok(win.AppManager.isMainProcessDebuggable(), "Main process available");
|
|
|
|
// Select main process
|
|
SimpleTest.executeSoon(() => {
|
|
docProject.querySelectorAll("#project-panel-runtimeapps .panel-item")[0].click();
|
|
});
|
|
|
|
yield waitForUpdate(win, "project");
|
|
|
|
// Toolbox opens automatically for main process / runtime apps
|
|
ok(win.UI.toolboxPromise, "Toolbox promise exists");
|
|
yield win.UI.toolboxPromise;
|
|
|
|
yield win.Cmds.disconnectRuntime();
|
|
|
|
Services.prefs.setIntPref("devtools.webide.busyTimeout", 100);
|
|
|
|
// Wait for error message since connection never completes
|
|
let errorDeferred = promise.defer();
|
|
win.UI.reportError = errorName => {
|
|
if (errorName === "error_operationTimeout") {
|
|
errorDeferred.resolve();
|
|
}
|
|
};
|
|
|
|
// Click the infinite runtime
|
|
items[1].click();
|
|
ok(win.document.querySelector("window").className, "busy", "UI is busy");
|
|
yield errorDeferred.promise;
|
|
|
|
// Check for unexpected error message since this is prolonged
|
|
let noErrorDeferred = promise.defer();
|
|
win.UI.reportError = errorName => {
|
|
if (errorName === "error_operationTimeout") {
|
|
noErrorDeferred.reject();
|
|
}
|
|
};
|
|
|
|
// Click the prolonged runtime
|
|
items[2].click();
|
|
ok(win.document.querySelector("window").className, "busy", "UI is busy");
|
|
|
|
setTimeout(() => {
|
|
noErrorDeferred.resolve();
|
|
}, 1000);
|
|
|
|
yield noErrorDeferred.promise;
|
|
|
|
SimpleTest.finish();
|
|
});
|
|
}
|
|
</script>
|
|
</body>
|
|
</html>
|