summaryrefslogtreecommitdiffstats
path: root/devtools/client/debugger/test/mochitest/browser_dbg-sourcemaps3.js
blob: 86ab35129a4abef4114b497f577f93e2e2ab4af1 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
/* 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/>. */

"use strict";

// Tests loading sourcemapped sources, setting breakpoints, and
// inspecting restored scopes.
requestLongerTimeout(2);

// This source map does not have source contents, so it's fetched separately
add_task(async function () {
  await pushPref("devtools.debugger.map-scopes-enabled", true);
  // NOTE: the CORS call makes the test run times inconsistent
  const dbg = await initDebugger(
    "doc-sourcemaps3.html",
    "bundle.js",
    "sorted.js",
    "test.js"
  );

  ok(true, "Original sources exist");
  const sortedSrc = findSource(dbg, "sorted.js");

  await selectSource(dbg, sortedSrc);

  // Test that breakpoint is not off by a line.
  await addBreakpoint(dbg, sortedSrc, 9, 5);
  is(dbg.selectors.getBreakpointCount(), 1, "One breakpoint exists");
  ok(
    dbg.selectors.getBreakpoint(
      createLocation({ source: sortedSrc, line: 9, column: 4 })
    ),
    "Breakpoint has correct line"
  );

  invokeInTab("test");

  await waitForPaused(dbg);
  assertPausedAtSourceAndLine(dbg, sortedSrc.id, 9, 5);

  is(getScopeNodeLabel(dbg, 1), "Block");
  is(getScopeNodeLabel(dbg, 2), "na");
  is(getScopeNodeLabel(dbg, 3), "nb");

  is(getScopeNodeLabel(dbg, 4), "Function Body");

  await toggleScopeNode(dbg, 4);

  is(getScopeNodeLabel(dbg, 5), "ma");
  is(getScopeNodeLabel(dbg, 6), "mb");

  await toggleScopeNode(dbg, 7);

  is(getScopeNodeLabel(dbg, 8), "a");
  is(getScopeNodeLabel(dbg, 9), "b");

  is(getScopeNodeLabel(dbg, 10), "Module");

  await toggleScopeNode(dbg, 10);

  is(getScopeNodeLabel(dbg, 11), "binaryLookup:o(n, e, r)");
  is(getScopeNodeLabel(dbg, 12), "comparer:t(n, e)");
  is(getScopeNodeLabel(dbg, 13), "fancySort");

  const frameLabels = [
    ...findAllElementsWithSelector(dbg, ".pane.frames .frame .title"),
  ].map(el => el.textContent);
  // The frame display named are mapped to the original source.
  // For example "fancySort" method is named "u" in the generated source.
  Assert.deepEqual(frameLabels, [
    "comparer",
    "binaryLookup",
    "fancySort",
    "fancySort",
    "originalTestName",
  ]);

  info(
    "Verify that original function names are displayed in frames on source selection"
  );
  await selectSource(dbg, "test.js");

  const frameLabelsAfterUpdate = [
    ...findAllElementsWithSelector(dbg, ".pane.frames .frame .title"),
  ].map(el => el.textContent);
  Assert.deepEqual(frameLabelsAfterUpdate, [
    "comparer",
    "binaryLookup",
    "fancySort",
    "fancySort",
    "originalTestName", // <== this frame was updated
  ]);
});