mirror of
https://gitlab.winehq.org/wine/wine-gecko.git
synced 2024-09-13 09:24:08 -07:00
Bug 958176 - Split console: Escape should close console sidebar (when visible) without closing split console. r=msucan
This commit is contained in:
parent
94b8202afa
commit
de83a2f3ac
@ -258,6 +258,7 @@ run-if = os == "mac"
|
||||
[browser_webconsole_property_provider.js]
|
||||
[browser_webconsole_scratchpad_panel_link.js]
|
||||
[browser_webconsole_split.js]
|
||||
[browser_webconsole_split_escape_key.js]
|
||||
[browser_webconsole_view_source.js]
|
||||
[browser_webconsole_reflow.js]
|
||||
[browser_webconsole_log_file_filter.js]
|
||||
|
@ -222,7 +222,7 @@ function test()
|
||||
|
||||
checkToolboxUI();
|
||||
|
||||
testDestroy();
|
||||
toolbox.switchHost(Toolbox.HostType.BOTTOM).then(testDestroy);
|
||||
}
|
||||
|
||||
function checkHostType(hostType)
|
||||
|
@ -0,0 +1,171 @@
|
||||
/*
|
||||
* Any copyright is dedicated to the Public Domain.
|
||||
* http://creativecommons.org/publicdomain/zero/1.0/
|
||||
*/
|
||||
|
||||
function test() {
|
||||
info("Test various cases where the escape key should hide the split console.");
|
||||
|
||||
let toolbox;
|
||||
let hud;
|
||||
let jsterm;
|
||||
let hudMessages;
|
||||
let variablesView;
|
||||
|
||||
Task.spawn(runner).then(finish);
|
||||
|
||||
function* runner() {
|
||||
let {tab} = yield loadTab("data:text/html;charset=utf-8,<p>Web Console test for splitting");
|
||||
let target = TargetFactory.forTab(tab);
|
||||
toolbox = yield gDevTools.showToolbox(target, "inspector");
|
||||
|
||||
yield testCreateSplitConsoleAfterEscape();
|
||||
|
||||
yield showAutoCompletePopoup();
|
||||
|
||||
yield testHideAutoCompletePopupAfterEscape();
|
||||
|
||||
yield executeJS();
|
||||
yield clickMessageAndShowVariablesView();
|
||||
jsterm.inputNode.focus();
|
||||
|
||||
yield testHideVariablesViewAfterEscape();
|
||||
|
||||
yield clickMessageAndShowVariablesView();
|
||||
yield startPropertyEditor();
|
||||
|
||||
yield testCancelPropertyEditorAfterEscape();
|
||||
yield testHideVariablesViewAfterEscape();
|
||||
yield testHideSplitConsoleAfterEscape();
|
||||
}
|
||||
|
||||
function testCreateSplitConsoleAfterEscape() {
|
||||
let result = toolbox.once("webconsole-ready", () => {
|
||||
hud = toolbox.getPanel("webconsole").hud;
|
||||
jsterm = hud.jsterm;
|
||||
ok(toolbox.splitConsole, "Split console is created.");
|
||||
});
|
||||
|
||||
let contentWindow = toolbox.frame.contentWindow;
|
||||
contentWindow.focus();
|
||||
EventUtils.sendKey("ESCAPE", contentWindow);
|
||||
|
||||
return result;
|
||||
}
|
||||
|
||||
function testShowSplitConsoleAfterEscape() {
|
||||
let result = toolbox.once("split-console", () => {
|
||||
ok(toolbox.splitConsole, "Split console is shown.");
|
||||
});
|
||||
EventUtils.sendKey("ESCAPE", toolbox.frame.contentWindow);
|
||||
|
||||
return result;
|
||||
}
|
||||
|
||||
function testHideSplitConsoleAfterEscape() {
|
||||
let result = toolbox.once("split-console", () => {
|
||||
ok(!toolbox.splitConsole, "Split console is hidden.");
|
||||
});
|
||||
EventUtils.sendKey("ESCAPE", toolbox.frame.contentWindow);
|
||||
|
||||
return result;
|
||||
}
|
||||
|
||||
function testHideVariablesViewAfterEscape() {
|
||||
let result = jsterm.once("sidebar-closed", () => {
|
||||
ok(!hud.ui.jsterm.sidebar,
|
||||
"Variables view is hidden.");
|
||||
ok(toolbox.splitConsole,
|
||||
"Split console is open after hiding the variables view.");
|
||||
});
|
||||
EventUtils.sendKey("ESCAPE", toolbox.frame.contentWindow);
|
||||
|
||||
return result;
|
||||
}
|
||||
|
||||
function testHideAutoCompletePopupAfterEscape() {
|
||||
let deferred = promise.defer();
|
||||
let popup = jsterm.autocompletePopup;
|
||||
|
||||
popup._panel.addEventListener("popuphidden", function popupHidden() {
|
||||
popup._panel.removeEventListener("popuphidden", popupHidden, false);
|
||||
ok(!popup.isOpen,
|
||||
"Auto complete popup is hidden.");
|
||||
ok(toolbox.splitConsole,
|
||||
"Split console is open after hiding the autocomplete popup.");
|
||||
|
||||
deferred.resolve();
|
||||
}, false);
|
||||
|
||||
EventUtils.sendKey("ESCAPE", toolbox.frame.contentWindow);
|
||||
|
||||
return deferred.promise;
|
||||
}
|
||||
|
||||
function testCancelPropertyEditorAfterEscape() {
|
||||
EventUtils.sendKey("ESCAPE", variablesView.window);
|
||||
ok(hud.ui.jsterm.sidebar,
|
||||
"Variables view is open after canceling property editor.");
|
||||
ok(toolbox.splitConsole,
|
||||
"Split console is open after editing.");
|
||||
}
|
||||
|
||||
function executeJS() {
|
||||
jsterm.execute("var foo = { bar: \"baz\" }; foo;");
|
||||
hudMessages = yield waitForMessages({
|
||||
webconsole: hud,
|
||||
messages: [{
|
||||
text: "Object { bar: \"baz\" }",
|
||||
category: CATEGORY_OUTPUT,
|
||||
objects: true
|
||||
}],
|
||||
});
|
||||
}
|
||||
|
||||
function clickMessageAndShowVariablesView() {
|
||||
let result = jsterm.once("variablesview-fetched", (event, vview) => {
|
||||
variablesView = vview;
|
||||
});
|
||||
|
||||
let clickable = hudMessages[0].clickableElements[0];
|
||||
EventUtils.synthesizeMouse(clickable, 2, 2, {}, hud.iframeWindow);
|
||||
|
||||
return result;
|
||||
}
|
||||
|
||||
function startPropertyEditor() {
|
||||
let results = yield findVariableViewProperties(variablesView, [
|
||||
{name: "bar", value: "baz"}
|
||||
], {webconsole: hud});
|
||||
results[0].matchedProp.focus();
|
||||
EventUtils.synthesizeKey("VK_RETURN", variablesView.window);
|
||||
}
|
||||
|
||||
function showAutoCompletePopoup() {
|
||||
let deferred = promise.defer();
|
||||
let popupPanel = jsterm.autocompletePopup._panel;
|
||||
|
||||
popupPanel.addEventListener("popupshown", function popupShown() {
|
||||
popupPanel.removeEventListener("popupshown", popupShown, false);
|
||||
deferred.resolve();
|
||||
}, false);
|
||||
|
||||
jsterm.inputNode.focus();
|
||||
jsterm.setInputValue("document.location.");
|
||||
EventUtils.sendKey("TAB", hud.iframeWindow);
|
||||
|
||||
return deferred.promise;
|
||||
}
|
||||
|
||||
function finish() {
|
||||
toolbox.destroy().then(() => {
|
||||
toolbox = null;
|
||||
hud = null;
|
||||
jsterm = null;
|
||||
hudMessages = null;
|
||||
variablesView = null;
|
||||
|
||||
finishTest();
|
||||
});
|
||||
}
|
||||
}
|
@ -3489,6 +3489,7 @@ JSTerm.prototype = {
|
||||
|
||||
this._sidebarDestroy();
|
||||
this.inputNode.focus();
|
||||
aEvent.stopPropagation();
|
||||
},
|
||||
|
||||
/**
|
||||
@ -3922,10 +3923,12 @@ JSTerm.prototype = {
|
||||
if (this.autocompletePopup.isOpen) {
|
||||
this.clearCompletion();
|
||||
aEvent.preventDefault();
|
||||
aEvent.stopPropagation();
|
||||
}
|
||||
else if (this.sidebar) {
|
||||
this._sidebarDestroy();
|
||||
aEvent.preventDefault();
|
||||
aEvent.stopPropagation();
|
||||
}
|
||||
break;
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user