File: test_nsScriptErrorWithStack.html

package info (click to toggle)
firefox 147.0.3-1
  • links: PTS, VCS
  • area: main
  • in suites: sid
  • size: 4,683,320 kB
  • sloc: cpp: 7,607,359; javascript: 6,533,295; ansic: 3,775,223; python: 1,415,500; xml: 634,561; asm: 438,949; java: 186,241; sh: 62,752; makefile: 18,079; objc: 13,092; perl: 12,808; yacc: 4,583; cs: 3,846; pascal: 3,448; lex: 1,720; ruby: 1,003; php: 436; lisp: 258; awk: 247; sql: 66; sed: 54; csh: 10; exp: 6
file content (59 lines) | stat: -rw-r--r-- 1,823 bytes parent folder | download | duplicates (17)
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
<!DOCTYPE html>
<meta charset=utf-8>
<title>Test for 814497</title>
<script src="chrome://mochikit/content/tests/SimpleTest/SimpleTest.js"></script>
<div id="log"></div>
<script>
  var c = Cc;

  SimpleTest.waitForExplicitFinish();
  SimpleTest.expectUncaughtException();

  // /!\ Line number is important in this test,
  //     we are asserting the following functions line #
  function failingStack() {
    nestedFunction();
  }
  function nestedFunction() {
    // eslint-disable-next-line no-undef
    doesntExistsAndThrow();
  }

  var TestObserver = {
    QueryInterface: ChromeUtils.generateQI(["nsIObserver"]),

    observe: function test_observe(aSubject)
    {
      if (!(aSubject instanceof Ci.nsIScriptError)) {
        return;
      }
      dump("stack: "+aSubject.stack+"\n");

      // Main assertions
      var s = aSubject.stack;
      ok(!!s, "has first frame");
      ok(s.source.includes("test_nsScriptErrorWithStack.html"), "source is correct");
      is(s.line, 19, "line is correct");
      is(s.column, 5, "column is correct");
      is(s.functionDisplayName, "nestedFunction");
      s = s.parent;
      ok(!!s, "has second frame");
      ok(s.source.includes("test_nsScriptErrorWithStack.html"), "source is correct");
      is(s.line, 15, "line is correct");
      is(s.column, 5, "column is correct");
      is(s.functionDisplayName, "failingStack");
      // We shouldn't have any more frame as we used setTimeout
      ok(!s.parent, "has no more frames");

      // Cleanup
      Services.console.unregisterListener(TestObserver);
      SimpleTest.finish();
    }
  };

  Services.console.registerListener(TestObserver);

  // use setTimeout in order to prevent throwing from test frame
  // and so have a clean stack frame with just our method calls
  setTimeout(failingStack, 0);
</script>