mirror of
https://github.com/roytam1/palemoon27.git
synced 2026-07-04 22:29:01 +00:00
98894236c9
- Bug 1171200 - Add means of checking if a document links to a manifest. r=billm (066ddad20) - Bug 1167300 - Consolidate the performance tool directory, r=jsantell (c7dd7dc34) - Bug 1167300 - Create a way to get strings from multiple localization files, r=jsantell (0973b8d3e) - modules not in gre (914e4080e) - Bug 1153011 - Remove zoom button from call tree. r=vporof (797b8f91d) - Bug 1151973 - Inverted call tree should be ordered by 'self cost', not 'total cost', r=jsantell (f2800b272) - more gre removal (27aed87a0) - Bug 1144034 - Flamegraph text is barely readable on non-retina display, r=jsantell (cb19fd9f2) - Bug 1151973 - Inverted call tree should be ordered by 'self cost', not 'total cost', r=jsantell (9c579599e) - Bug 1167300 - Fix all performance tool imports to work with the new file locations, r=jsantell (70b2995c4) - Bug 1167298 - Remove the ordinal property on categories, r=jsantell (00b3f5830) - Bug 1167733 - Consolidate prefs access and usage in the new performance tool, r=jsantell (4dab15e7f) - Bug 1167006 - part 3 fully revert merge from 780e1f999f54. (8aaa33c9c) - Bug 1167961 - Task is incorrectly used in compatibility.js, r=jsantell (7291f68d1) - Bug 1138641 - Updated remaining callsites to use newChannel2 in browser/devtools (r=vporof) (60ac4b2c8) - Bug 1164130 - Correctly include RecordingUtils when importing older version 2 profiler data. r=vp (8169d0398) - Bug 1167962 - Keep exports at bottom of modules, r=jsantell (7426919db) - Bug 1167962 - Fix import in synthesizeProfileForTest, r=orange (cc7fab771) - fix merge of later patch Bug 1167006 (c0b57b0e2) - Bug 1157523 - Fix intermittent where markers are selected in the waterfall views when there is no recording selected. r=vp (35cec0bd1) - Bug 1196253 - update in-tree psutil to 3.1.1. r=gps (80f243738)
91 lines
2.9 KiB
JavaScript
91 lines
2.9 KiB
JavaScript
/* Any copyright is dedicated to the Public Domain.
|
|
http://creativecommons.org/publicdomain/zero/1.0/ */
|
|
|
|
// Tests that text metrics in the flame graph widget work properly.
|
|
|
|
let HTML_NS = "http://www.w3.org/1999/xhtml";
|
|
let {ViewHelpers} = Cu.import("resource:///modules/devtools/ViewHelpers.jsm", {});
|
|
let {FlameGraph} = devtools.require("devtools/shared/widgets/FlameGraph");
|
|
let {FLAME_GRAPH_BLOCK_TEXT_FONT_SIZE} = devtools.require("devtools/shared/widgets/FlameGraph");
|
|
let {FLAME_GRAPH_BLOCK_TEXT_FONT_FAMILY} = devtools.require("devtools/shared/widgets/FlameGraph");
|
|
let {Promise} = devtools.require("resource://gre/modules/Promise.jsm");
|
|
|
|
let L10N = new ViewHelpers.L10N();
|
|
|
|
add_task(function*() {
|
|
yield promiseTab("about:blank");
|
|
yield performTest();
|
|
gBrowser.removeCurrentTab();
|
|
});
|
|
|
|
function* performTest() {
|
|
let [host, win, doc] = yield createHost();
|
|
let graph = new FlameGraph(doc.body, 1);
|
|
yield graph.ready();
|
|
|
|
testGraph(graph);
|
|
|
|
yield graph.destroy();
|
|
host.destroy();
|
|
}
|
|
|
|
function testGraph(graph) {
|
|
is(graph._averageCharWidth, getAverageCharWidth(),
|
|
"The average char width was calculated correctly.");
|
|
is(graph._overflowCharWidth, getCharWidth(L10N.ellipsis),
|
|
"The ellipsis char width was calculated correctly.");
|
|
|
|
let text = "This text is maybe overflowing";
|
|
let text1000px = graph._getFittedText(text, 1000);
|
|
let text50px = graph._getFittedText(text, 50);
|
|
let text10px = graph._getFittedText(text, 10);
|
|
let text1px = graph._getFittedText(text, 1);
|
|
|
|
is(graph._getTextWidthApprox(text), getAverageCharWidth() * text.length,
|
|
"The approximate width was calculated correctly.");
|
|
|
|
info("Text at 1000px width: " + text1000px);
|
|
info("Text at 50px width : " + text50px);
|
|
info("Text at 10px width : " + text10px);
|
|
info("Text at 1px width : " + text1px);
|
|
|
|
is(text1000px, text,
|
|
"The fitted text for 1000px width is correct.");
|
|
|
|
isnot(text50px, text,
|
|
"The fitted text for 50px width is correct (1).");
|
|
|
|
ok(text50px.includes(L10N.ellipsis),
|
|
"The fitted text for 50px width is correct (2).");
|
|
|
|
is(graph._getFittedText(text, FLAME_GRAPH_BLOCK_TEXT_FONT_SIZE + 1), L10N.ellipsis,
|
|
"The fitted text for text font size width is correct.");
|
|
|
|
is(graph._getFittedText(text, 1), "",
|
|
"The fitted text for 1px width is correct.");
|
|
}
|
|
|
|
function getAverageCharWidth() {
|
|
let letterWidthsSum = 0;
|
|
let start = 32; // space
|
|
let end = 123; // "z"
|
|
|
|
for (let i = start; i < end; i++) {
|
|
let char = String.fromCharCode(i);
|
|
letterWidthsSum += getCharWidth(char);
|
|
}
|
|
|
|
return letterWidthsSum / (end - start);
|
|
}
|
|
|
|
function getCharWidth(char) {
|
|
let canvas = document.createElementNS(HTML_NS, "canvas");
|
|
let ctx = canvas.getContext("2d");
|
|
|
|
let fontSize = FLAME_GRAPH_BLOCK_TEXT_FONT_SIZE;
|
|
let fontFamily = FLAME_GRAPH_BLOCK_TEXT_FONT_FAMILY;
|
|
ctx.font = fontSize + "px " + fontFamily;
|
|
|
|
return ctx.measureText(char).width;
|
|
}
|