2010-12-23 07:59:19 -08:00
|
|
|
/* Any copyright is dedicated to the Public Domain.
|
|
|
|
* http://creativecommons.org/publicdomain/zero/1.0/ */
|
|
|
|
|
|
|
|
// Tests that source URLs in the Web Console can be clicked to display the
|
|
|
|
// standard View Source window.
|
|
|
|
|
2012-01-17 06:04:23 -08:00
|
|
|
const TEST_URI = "http://example.com/browser/browser/devtools/webconsole/test/test-error.html";
|
2010-12-23 07:59:19 -08:00
|
|
|
|
2013-09-18 12:47:42 -07:00
|
|
|
let containsValue;
|
|
|
|
let Sources;
|
|
|
|
let containsValueInvoked = false;
|
|
|
|
|
2010-12-23 07:59:19 -08:00
|
|
|
function test() {
|
|
|
|
addTab(TEST_URI);
|
2012-05-10 08:01:37 -07:00
|
|
|
browser.addEventListener("load", function onLoad() {
|
|
|
|
browser.removeEventListener("load", onLoad, true);
|
2013-09-10 11:37:48 -07:00
|
|
|
openConsole(null, testViewSource);
|
2012-05-10 08:01:37 -07:00
|
|
|
}, true);
|
2010-12-23 07:59:19 -08:00
|
|
|
}
|
|
|
|
|
2012-05-10 08:01:37 -07:00
|
|
|
function testViewSource(hud) {
|
2013-09-18 12:47:42 -07:00
|
|
|
info("console opened");
|
|
|
|
|
2010-12-23 07:59:19 -08:00
|
|
|
let button = content.document.querySelector("button");
|
|
|
|
ok(button, "we have the button on the page");
|
|
|
|
|
2012-05-10 08:01:37 -07:00
|
|
|
expectUncaughtException();
|
2013-09-10 11:37:48 -07:00
|
|
|
EventUtils.sendMouseEvent({ type: "click" }, button, content);
|
|
|
|
|
2013-09-18 12:47:42 -07:00
|
|
|
openDebugger().then(({panelWin: { DebuggerView }}) => {
|
|
|
|
info("debugger openeed");
|
|
|
|
Sources = DebuggerView.Sources;
|
|
|
|
openConsole(null, (hud) => {
|
|
|
|
info("console opened again");
|
|
|
|
|
|
|
|
waitForMessages({
|
|
|
|
webconsole: hud,
|
|
|
|
messages: [{
|
|
|
|
text: "fooBazBaz is not defined",
|
|
|
|
category: CATEGORY_JS,
|
|
|
|
severity: SEVERITY_ERROR,
|
|
|
|
}],
|
|
|
|
}).then(onMessage);
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
function onMessage([result]) {
|
2013-09-10 11:37:48 -07:00
|
|
|
let msg = [...result.matched][0];
|
|
|
|
ok(msg, "error message");
|
|
|
|
let locationNode = msg.querySelector(".location");
|
|
|
|
ok(locationNode, "location node");
|
|
|
|
|
|
|
|
Services.ww.registerNotification(observer);
|
|
|
|
|
2013-09-18 12:47:42 -07:00
|
|
|
containsValue = Sources.containsValue;
|
|
|
|
Sources.containsValue = () => {
|
|
|
|
containsValueInvoked = true;
|
|
|
|
return false;
|
|
|
|
};
|
|
|
|
|
2013-09-10 11:37:48 -07:00
|
|
|
EventUtils.sendMouseEvent({ type: "click" }, locationNode);
|
2013-09-18 12:47:42 -07:00
|
|
|
}
|
2010-12-23 07:59:19 -08:00
|
|
|
}
|
|
|
|
|
|
|
|
let observer = {
|
|
|
|
observe: function(aSubject, aTopic, aData) {
|
|
|
|
if (aTopic != "domwindowopened") {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
ok(true, "the view source window was opened in response to clicking " +
|
|
|
|
"the location node");
|
|
|
|
|
|
|
|
// executeSoon() is necessary to avoid crashing Firefox. See bug 611543.
|
|
|
|
executeSoon(function() {
|
|
|
|
aSubject.close();
|
2013-09-18 12:47:42 -07:00
|
|
|
ok(containsValueInvoked, "custom containsValue() was invoked");
|
|
|
|
Sources.containsValue = containsValue;
|
|
|
|
Sources = containsValue = null;
|
2010-12-23 07:59:19 -08:00
|
|
|
finishTest();
|
|
|
|
});
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
2012-05-10 08:01:37 -07:00
|
|
|
registerCleanupFunction(function() {
|
|
|
|
Services.ww.unregisterNotification(observer);
|
|
|
|
});
|