mirror of
https://github.com/roytam1/palemoon27.git
synced 2026-05-27 13:28:42 +00:00
240cfdae23
- Bug 1195615 - Log a web console warning when a HPKP header is ignored due to a non-built in root cert. r=keeler (dcd24f0163) - Bug 1156865 - Re-enable RDP logging in debugger xpcshell tests; r=jlongster (cb82a79d32) - Bug 848502 - Add a context menu to the debugger sources panel. r=vporof (58a299ded4) - Bug 1145262 - Modularize the pane views in the debugger. r=fitzgen (64b9eca0b5) - Bug 1145262 - Modularize the toolbar views in the debugger. r=fitzgen (c827d2ed92) - Bug 1167957 - Remove spidermonkey specific JS from debugger (795b7d00fb) - Bug 1160199 - Implement TabActor.listWorkers;r=jlong (b11fef647b) - Bug 1164077 - Implement WorkerActor.attach;r=jlong (d3c0a7c820) - Bug 1164564 - Clean up the helper functions for the debugger tests;r=jlong (b5d3bbbc99) - Bug 1164564 - Define an instance of the worker loader for worker threads;r=jlong (4eac1636b3) - Bug 1164564 - Implement WorkerActor.attachThread;r=jlong (fe1ac8ba3d) - Bug 1169343 - Implement DebuggerView.Workers;r=jlong (12996e5440) - Bug 1171967 - Emit newSource events on ThreadClient instead of DebuggerClient;r=pbrosset (417dce4d13) - Bug 1171967 - Implement WorkerTarget;r=jlong (c8963b9b35) - Bug 1189587: Tighten signature of pref_HashTableLookup. r=njn (de84745d54) - Bug 1188205 - Fix more constructors in netwerk; r=mcmanus (afcf42b3f8) - namespaces (867f2a3213) - Bug 1181319 - Correctly use NS_DECL_ISUPPORTS_INHERITED instead of NS_DECL_ISUPPORTS for DataChannelChild. r=mcmanus (bbe6681ea0) - Bug 1163909 - Remove nsFtpState::mSessionStartTime, which is dead. r=mcmanus. (f7c218ed91) - Bug 1170837 - Make nsMultiMixedConv not return an error when served only a package's metadata from the cache r=honzab (afb0684b1d)
150 lines
5.2 KiB
JavaScript
150 lines
5.2 KiB
JavaScript
/* Any copyright is dedicated to the Public Domain.
|
|
http://creativecommons.org/publicdomain/zero/1.0/ */
|
|
|
|
/**
|
|
* Check setting breakpoints in source mapped sources.
|
|
*/
|
|
|
|
var gDebuggee;
|
|
var gClient;
|
|
var gThreadClient;
|
|
|
|
Components.utils.import('resource://gre/modules/devtools/SourceMap.jsm');
|
|
|
|
function run_test()
|
|
{
|
|
initTestDebuggerServer();
|
|
gDebuggee = addTestGlobal("test-source-map");
|
|
gClient = new DebuggerClient(DebuggerServer.connectPipe());
|
|
gClient.connect(function() {
|
|
attachTestTabAndResume(gClient, "test-source-map", function(aResponse, aTabClient, aThreadClient) {
|
|
gThreadClient = aThreadClient;
|
|
test_simple_source_map();
|
|
});
|
|
});
|
|
do_test_pending();
|
|
}
|
|
|
|
function testBreakpointMapping(aName, aCallback)
|
|
{
|
|
// Pause so we can set a breakpoint.
|
|
gThreadClient.addOneTimeListener("paused", function (aEvent, aPacket) {
|
|
do_check_true(!aPacket.error);
|
|
do_check_eq(aPacket.why.type, "debuggerStatement");
|
|
|
|
getSource(gThreadClient, "http://example.com/www/js/" + aName + ".js").then(source => {
|
|
source.setBreakpoint({
|
|
// Setting the breakpoint on an empty line so that it is pushed down one
|
|
// line and we can check the source mapped actualLocation later.
|
|
line: 3
|
|
}, function (aResponse) {
|
|
do_check_true(!aResponse.error);
|
|
|
|
// Actual location should come back source mapped still so that
|
|
// breakpoints are displayed in the UI correctly, etc.
|
|
do_check_eq(aResponse.actualLocation.line, 4);
|
|
do_check_eq(aResponse.actualLocation.source.url,
|
|
"http://example.com/www/js/" + aName + ".js");
|
|
|
|
// The eval will cause us to resume, then we get an unsolicited pause
|
|
// because of our breakpoint, we resume again to finish the eval, and
|
|
// finally receive our last pause which has the result of the client
|
|
// evaluation.
|
|
gThreadClient.eval(null, aName + "()", function (aResponse) {
|
|
do_check_true(!aResponse.error, "Shouldn't be an error resuming to eval");
|
|
do_check_eq(aResponse.type, "resumed");
|
|
|
|
gThreadClient.addOneTimeListener("paused", function (aEvent, aPacket) {
|
|
do_check_eq(aPacket.why.type, "breakpoint");
|
|
// Assert that we paused because of the breakpoint at the correct
|
|
// location in the code by testing that the value of `ret` is still
|
|
// undefined.
|
|
do_check_eq(aPacket.frame.environment.bindings.variables.ret.value.type,
|
|
"undefined");
|
|
|
|
gThreadClient.resume(function (aResponse) {
|
|
do_check_true(!aResponse.error);
|
|
|
|
gThreadClient.addOneTimeListener("paused", function (aEvent, aPacket) {
|
|
do_check_eq(aPacket.why.type, "clientEvaluated");
|
|
do_check_eq(aPacket.why.frameFinished.return, aName);
|
|
|
|
gThreadClient.resume(function (aResponse) {
|
|
do_check_true(!aResponse.error);
|
|
aCallback();
|
|
});
|
|
});
|
|
});
|
|
});
|
|
});
|
|
});
|
|
});
|
|
});
|
|
|
|
gDebuggee.eval("(" + function () {
|
|
debugger;
|
|
} + "());");
|
|
}
|
|
|
|
function test_simple_source_map()
|
|
{
|
|
let expectedSources = new Set([
|
|
"http://example.com/www/js/a.js",
|
|
"http://example.com/www/js/b.js",
|
|
"http://example.com/www/js/c.js"
|
|
]);
|
|
|
|
gThreadClient.addListener("newSource", function _onNewSource(aEvent, aPacket) {
|
|
expectedSources.delete(aPacket.source.url);
|
|
if (expectedSources.size > 0) {
|
|
return;
|
|
}
|
|
gThreadClient.removeListener("newSource", _onNewSource);
|
|
|
|
testBreakpointMapping("a", function () {
|
|
testBreakpointMapping("b", function () {
|
|
testBreakpointMapping("c", function () {
|
|
finishClient(gClient);
|
|
});
|
|
});
|
|
});
|
|
});
|
|
|
|
let a = new SourceNode(null, null, null, [
|
|
new SourceNode(1, 0, "a.js", "function a() {\n"),
|
|
new SourceNode(2, 0, "a.js", " var ret;\n"),
|
|
new SourceNode(3, 0, "a.js", " // Empty line\n"),
|
|
new SourceNode(4, 0, "a.js", " ret = 'a';\n"),
|
|
new SourceNode(5, 0, "a.js", " return ret;\n"),
|
|
new SourceNode(6, 0, "a.js", "}\n")
|
|
]);
|
|
let b = new SourceNode(null, null, null, [
|
|
new SourceNode(1, 0, "b.js", "function b() {\n"),
|
|
new SourceNode(2, 0, "b.js", " var ret;\n"),
|
|
new SourceNode(3, 0, "b.js", " // Empty line\n"),
|
|
new SourceNode(4, 0, "b.js", " ret = 'b';\n"),
|
|
new SourceNode(5, 0, "b.js", " return ret;\n"),
|
|
new SourceNode(6, 0, "b.js", "}\n")
|
|
]);
|
|
let c = new SourceNode(null, null, null, [
|
|
new SourceNode(1, 0, "c.js", "function c() {\n"),
|
|
new SourceNode(2, 0, "c.js", " var ret;\n"),
|
|
new SourceNode(3, 0, "c.js", " // Empty line\n"),
|
|
new SourceNode(4, 0, "c.js", " ret = 'c';\n"),
|
|
new SourceNode(5, 0, "c.js", " return ret;\n"),
|
|
new SourceNode(6, 0, "c.js", "}\n")
|
|
]);
|
|
|
|
let { code, map } = (new SourceNode(null, null, null, [
|
|
a, b, c
|
|
])).toStringWithSourceMap({
|
|
file: "http://example.com/www/js/abc.js",
|
|
sourceRoot: "http://example.com/www/js/"
|
|
});
|
|
|
|
code += "//# sourceMappingURL=data:text/json;base64," + btoa(map.toString());
|
|
|
|
Components.utils.evalInSandbox(code, gDebuggee, "1.8",
|
|
"http://example.com/www/js/abc.js", 1);
|
|
}
|