/* Any copyright is dedicated to the Public Domain. http://creativecommons.org/publicdomain/zero/1.0/ */ "use strict"; /** * Tests if the waterfall collapsing logic works properly * when filtering parents and children. */ function run_test() { run_next_test(); } add_task(function test() { const WaterfallUtils = require("devtools/client/performance/modules/logic/waterfall-utils"); [ [["DOMEvent"], gExpectedOutputNoDOMEvent], [["Javascript"], gExpectedOutputNoJS], [["DOMEvent", "Javascript"], gExpectedOutputNoDOMEventOrJS], ].forEach(([filter, expected]) => { let rootMarkerNode = WaterfallUtils.createParentNode({ name: "(root)" }); WaterfallUtils.collapseMarkersIntoNode({ rootNode: rootMarkerNode, markersList: gTestMarkers, filter }); compare(rootMarkerNode, expected); }); function compare(marker, expected) { for (let prop in expected) { if (prop === "submarkers") { for (let i = 0; i < expected.submarkers.length; i++) { compare(marker.submarkers[i], expected.submarkers[i]); } } else if (prop !== "uid") { equal(marker[prop], expected[prop], `${expected.name} matches ${prop}`); } } } }); const gTestMarkers = [ { start: 1, end: 18, name: "DOMEvent" }, // Test that JS markers can fold in DOM events and have marker children { start: 2, end: 16, name: "Javascript" }, // Test all these markers can be children { start: 3, end: 4, name: "Paint" }, { start: 5, end: 6, name: "Reflow" }, { start: 7, end: 8, name: "Styles" }, { start: 9, end: 9, name: "TimeStamp" }, { start: 10, end: 11, name: "Parse HTML" }, { start: 12, end: 13, name: "Parse XML" }, { start: 14, end: 15, name: "GarbageCollection" }, // Test that JS markers can be parents without being a child of DOM events { start: 25, end: 30, name: "Javascript" }, { start: 26, end: 27, name: "Paint" }, ]; const gExpectedOutputNoJS = { name: "(root)", submarkers: [ { start: 1, end: 18, name: "DOMEvent", submarkers: [ { start: 3, end: 4, name: "Paint" }, { start: 5, end: 6, name: "Reflow" }, { start: 7, end: 8, name: "Styles" }, { start: 9, end: 9, name: "TimeStamp" }, { start: 10, end: 11, name: "Parse HTML" }, { start: 12, end: 13, name: "Parse XML" }, { start: 14, end: 15, name: "GarbageCollection" }, ]}, { start: 26, end: 27, name: "Paint" }, ]}; const gExpectedOutputNoDOMEvent = { name: "(root)", submarkers: [ { start: 2, end: 16, name: "Javascript", submarkers: [ { start: 3, end: 4, name: "Paint" }, { start: 5, end: 6, name: "Reflow" }, { start: 7, end: 8, name: "Styles" }, { start: 9, end: 9, name: "TimeStamp" }, { start: 10, end: 11, name: "Parse HTML" }, { start: 12, end: 13, name: "Parse XML" }, { start: 14, end: 15, name: "GarbageCollection" }, ]}, { start: 25, end: 30, name: "Javascript", submarkers: [ { start: 26, end: 27, name: "Paint" }, ]} ]}; const gExpectedOutputNoDOMEventOrJS = { name: "(root)", submarkers: [ { start: 3, end: 4, name: "Paint" }, { start: 5, end: 6, name: "Reflow" }, { start: 7, end: 8, name: "Styles" }, { start: 9, end: 9, name: "TimeStamp" }, { start: 10, end: 11, name: "Parse HTML" }, { start: 12, end: 13, name: "Parse XML" }, { start: 14, end: 15, name: "GarbageCollection" }, { start: 26, end: 27, name: "Paint" }, ]};