Source code

Revision control

Copy as Markdown

Other Tools

Test Info: Warnings

/* Any copyright is dedicated to the Public Domain.
"use strict";
// Test computing shortest paths with invalid arguments.
function run_test() {
const path = ChromeUtils.saveHeapSnapshot({ runtime: true });
const snapshot = ChromeUtils.readHeapSnapshot(path);
const dominatorTree = snapshot.computeDominatorTree();
const target = dominatorTree
.getImmediatelyDominated(dominatorTree.root)
.pop();
ok(target);
let threw = false;
try {
snapshot.computeShortestPaths(0, [target], 2);
} catch (_) {
threw = true;
}
ok(threw, "invalid start node should throw");
threw = false;
try {
snapshot.computeShortestPaths(dominatorTree.root, [0], 2);
} catch (_) {
threw = true;
}
ok(threw, "invalid target nodes should throw");
threw = false;
try {
snapshot.computeShortestPaths(dominatorTree.root, [], 2);
} catch (_) {
threw = true;
}
ok(threw, "empty target nodes should throw");
threw = false;
try {
snapshot.computeShortestPaths(dominatorTree.root, [target], 0);
} catch (_) {
threw = true;
}
ok(threw, "0 max paths should throw");
do_test_finished();
}