summaryrefslogtreecommitdiffstats
path: root/devtools/client/debugger/test/mochitest/browser_dbg-sourcemaps.js
diff options
context:
space:
mode:
Diffstat (limited to 'devtools/client/debugger/test/mochitest/browser_dbg-sourcemaps.js')
-rw-r--r--devtools/client/debugger/test/mochitest/browser_dbg-sourcemaps.js102
1 files changed, 102 insertions, 0 deletions
diff --git a/devtools/client/debugger/test/mochitest/browser_dbg-sourcemaps.js b/devtools/client/debugger/test/mochitest/browser_dbg-sourcemaps.js
new file mode 100644
index 0000000000..ef3fe4dcbb
--- /dev/null
+++ b/devtools/client/debugger/test/mochitest/browser_dbg-sourcemaps.js
@@ -0,0 +1,102 @@
+/* This Source Code Form is subject to the terms of the Mozilla Public
+ * License, v. 2.0. If a copy of the MPL was not distributed with this
+ * file, You can obtain one at <http://mozilla.org/MPL/2.0/>. */
+
+// Tests loading sourcemapped sources, setting breakpoints, and
+// stepping in them.
+
+"use strict";
+
+requestLongerTimeout(2);
+
+add_task(async function() {
+ // NOTE: the CORS call makes the test run times inconsistent
+ const dbg = await initDebugger(
+ "doc-sourcemaps.html",
+ "entry.js",
+ "output.js",
+ "times2.js",
+ "opts.js"
+ );
+ const {
+ selectors: { getBreakpointCount },
+ } = dbg;
+
+ // Check that the original sources appear in the source tree
+ info("Before opening the page directory, no source are displayed");
+ await waitForSourcesInSourceTree(dbg, [], { noExpand: true });
+ await clickElement(dbg, "sourceDirectoryLabel", 4);
+ info(
+ "After opening the page directory, only all original sources (entry, output, time2, opts). (bundle is still hidden)"
+ );
+ await waitForSourcesInSourceTree(
+ dbg,
+ ["entry.js", "output.js", "times2.js", "opts.js"],
+ { noExpand: true }
+ );
+ info("Expand the page folder and assert that the bundle appears");
+ await clickElement(dbg, "sourceDirectoryLabel", 3);
+ await clickElement(dbg, "sourceDirectoryLabel", 4);
+ await waitForSourcesInSourceTree(
+ dbg,
+ ["entry.js", "output.js", "times2.js", "opts.js", "bundle.js"],
+ { noExpand: true }
+ );
+
+ await selectSource(dbg, "bundle.js");
+
+ await clickGutter(dbg, 70);
+ await waitForBreakpointCount(dbg, 1);
+ await assertBreakpoint(dbg, 70);
+
+ await clickGutter(dbg, 70);
+ await waitForBreakpointCount(dbg, 0);
+
+ const entrySrc = findSource(dbg, "entry.js");
+
+ await selectSource(dbg, entrySrc);
+ ok(
+ getCM(dbg)
+ .getValue()
+ .includes("window.keepMeAlive"),
+ "Original source text loaded correctly"
+ );
+
+ // Test breaking on a breakpoint
+ await addBreakpoint(dbg, "entry.js", 15);
+ is(getBreakpointCount(), 1, "One breakpoint exists");
+ assertBreakpointExists(dbg, entrySrc, 15);
+
+ invokeInTab("keepMeAlive");
+ await waitForPaused(dbg);
+ assertPausedAtSourceAndLine(dbg, entrySrc.id, 15);
+
+ await stepIn(dbg);
+ assertPausedAtSourceAndLine(dbg, findSource(dbg, "times2.js").id, 2);
+
+ await dbg.actions.jumpToMappedSelectedLocation(getContext(dbg));
+ await stepOver(dbg);
+ assertPausedAtSourceAndLine(dbg, findSource(dbg, "times2.js").id, 3);
+
+ await dbg.actions.jumpToMappedSelectedLocation(getContext(dbg));
+ await stepOut(dbg);
+ assertPausedAtSourceAndLine(dbg, entrySrc.id, 16);
+});
+
+function assertBreakpointExists(dbg, source, line) {
+ const {
+ selectors: { getBreakpoint },
+ } = dbg;
+
+ ok(
+ getBreakpoint({ sourceId: source.id, line }),
+ "Breakpoint has correct line"
+ );
+}
+
+async function waitForBreakpointCount(dbg, count) {
+ const {
+ selectors: { getBreakpointCount },
+ } = dbg;
+ await waitForState(dbg, state => getBreakpointCount() == count);
+}