Files
roytam1 240cfdae23 import changes from `dev' branch of rmottola/Arctic-Fox:
- 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)
2022-04-06 09:28:39 +08:00

222 lines
5.8 KiB
JavaScript

/* Any copyright is dedicated to the Public Domain.
http://creativecommons.org/publicdomain/zero/1.0/ */
/**
* Tests that the break commands works as they should.
*/
const TAB_URL = EXAMPLE_URL + "doc_cmd-break.html";
let TAB_URL_ACTOR;
function test() {
let gPanel, gDebugger, gThreadClient, gSources;
let gLineNumber;
let expectedActorObj = {
value: null,
message: ''
};
helpers.addTabWithToolbar(TAB_URL, aOptions => {
return Task.spawn(function*() {
yield helpers.audit(aOptions, [{
setup: 'break',
check: {
input: 'break',
hints: ' add line',
markup: 'IIIII',
status: 'ERROR',
}
}]);
yield helpers.audit(aOptions, [{
setup: 'break add',
check: {
input: 'break add',
hints: ' line',
markup: 'IIIIIVIII',
status: 'ERROR'
}
}]);
yield helpers.audit(aOptions, [{
setup: 'break add line',
check: {
input: 'break add line',
hints: ' <file> <line>',
markup: 'VVVVVVVVVVVVVV',
status: 'ERROR'
}
}]);
yield helpers.audit(aOptions, [{
name: 'open toolbox',
setup: function() {
return initDebugger(gBrowser.selectedTab).then(([aTab, aDebuggee, aPanel]) => {
// Spin the event loop before causing the debuggee to pause, to allow
// this function to return first.
executeSoon(() => aDebuggee.firstCall());
return waitForSourceAndCaretAndScopes(aPanel, ".html", 1).then(() => {
gPanel = aPanel;
gDebugger = gPanel.panelWin;
gThreadClient = gPanel.panelWin.gThreadClient;
gLineNumber = '' + aOptions.window.wrappedJSObject.gLineNumber;
gSources = gDebugger.DebuggerView.Sources;
expectedActorObj.value = getSourceActor(gSources, TAB_URL);
});
});
},
post: function() {
ok(gThreadClient, "Debugger client exists.");
is(gLineNumber, 14, "gLineNumber is correct.");
},
}]);
yield helpers.audit(aOptions, [{
name: 'break add line .../doc_cmd-break.html 14',
setup: function() {
// We have to setup in a function to allow gLineNumber to be initialized.
let line = 'break add line ' + TAB_URL + ' ' + gLineNumber;
return helpers.setInput(aOptions, line);
},
check: {
hints: '',
status: 'VALID',
message: '',
args: {
file: expectedActorObj,
line: { value: 14 }
}
},
exec: {
output: 'Added breakpoint'
}
}]);
yield helpers.audit(aOptions, [{
setup: 'break add line ' + TAB_URL + ' 17',
check: {
hints: '',
status: 'VALID',
message: '',
args: {
file: expectedActorObj,
line: { value: 17 }
}
},
exec: {
output: 'Added breakpoint'
}
}]);
yield helpers.audit(aOptions, [{
setup: 'break list',
check: {
input: 'break list',
hints: '',
markup: 'VVVVVVVVVV',
status: 'VALID'
},
exec: {
output: [
/Source/, /Remove/,
/doc_cmd-break\.html:14/,
/doc_cmd-break\.html:17/
]
}
}]);
yield helpers.audit(aOptions, [{
name: 'cleanup',
setup: function() {
let deferred = promise.defer();
gThreadClient.resume(deferred.resolve);
return deferred.promise;
}
}]);
yield helpers.audit(aOptions, [{
setup: 'break del 14',
check: {
input: 'break del 14',
hints: ' -> doc_cmd-break.html:14',
markup: 'VVVVVVVVVVII',
status: 'ERROR',
args: {
breakpoint: {
status: 'INCOMPLETE',
message: 'Value required for \'breakpoint\'.'
}
}
}
}]);
yield helpers.audit(aOptions, [{
setup: 'break del doc_cmd-break.html:14',
check: {
input: 'break del doc_cmd-break.html:14',
hints: '',
markup: 'VVVVVVVVVVVVVVVVVVVVVVVVVVVVVVV',
status: 'VALID',
args: {
breakpoint: { arg: ' doc_cmd-break.html:14' },
}
},
exec: {
output: 'Breakpoint removed'
}
}]);
yield helpers.audit(aOptions, [{
setup: 'break list',
check: {
input: 'break list',
hints: '',
markup: 'VVVVVVVVVV',
status: 'VALID'
},
exec: {
output: [
/Source/, /Remove/,
/doc_cmd-break\.html:17/
]
}
}]);
yield helpers.audit(aOptions, [{
setup: 'break del doc_cmd-break.html:17',
check: {
input: 'break del doc_cmd-break.html:17',
hints: '',
markup: 'VVVVVVVVVVVVVVVVVVVVVVVVVVVVVVV',
status: 'VALID',
args: {
breakpoint: { arg: ' doc_cmd-break.html:17' },
}
},
exec: {
output: 'Breakpoint removed'
}
}]);
yield helpers.audit(aOptions, [{
setup: 'break list',
check: {
input: 'break list',
hints: '',
markup: 'VVVVVVVVVV',
status: 'VALID'
},
exec: {
output: 'No breakpoints set'
},
post: function() {
return teardown(gPanel, { noTabRemoval: true });
}
}]);
});
}).then(finish);
}