blob: 5c038c8226a7c391b59d2ae4647e8f601c52d0e3 (
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
|
function run_test()
{
if (!("@mozilla.org/toolkit/crash-reporter;1" in Components.classes)) {
dump("INFO | test_crash_after_js_oom_reported_2.js | Can't test crashreporter in a non-libxul build.\n");
return;
}
do_crash(
function() {
crashType = CrashTestUtils.CRASH_MOZ_CRASH;
crashReporter.annotateCrashReport("TestingOOMCrash", "Yes");
Components.utils.getJSTestingFunctions().reportOutOfMemory();
Components.utils.forceGC(); // recover from first OOM
Components.utils.getJSTestingFunctions().reportOutOfMemory();
},
function(mdump, extra) {
do_check_eq(extra.TestingOOMCrash, "Yes");
// Technically, GC can happen at any time, but it would be really
// peculiar for it to happen again heuristically right after a GC was
// forced. If extra.JSOutOfMemory is "Recovered" here, that's most
// likely a bug in the error reporting machinery.
do_check_eq(extra.JSOutOfMemory, "Reported");
},
true);
}
|