mirror of
https://github.com/mozilla/gecko-dev.git
synced 2024-10-19 00:05:36 +00:00
640fe52298
MozReview-Commit-ID: F6xUXCgdRE4 --HG-- extra : rebase_source : 65de1b0aba412d9044b5196115f74276caa058f2
68 lines
2.5 KiB
JavaScript
68 lines
2.5 KiB
JavaScript
/* Any copyright is dedicated to the Public Domain.
|
|
http://creativecommons.org/publicdomain/zero/1.0/ */
|
|
"use strict";
|
|
|
|
/**
|
|
* Tests that the details view toggles subviews.
|
|
*/
|
|
|
|
const { SIMPLE_URL } = require("devtools/client/performance/test/helpers/urls");
|
|
const { initPerformanceInNewTab, teardownToolboxAndRemoveTab } = require("devtools/client/performance/test/helpers/panel-utils");
|
|
const { startRecording, stopRecording } = require("devtools/client/performance/test/helpers/actions");
|
|
const { once } = require("devtools/client/performance/test/helpers/event-utils");
|
|
const { command } = require("devtools/client/performance/test/helpers/input-utils");
|
|
|
|
add_task(async function() {
|
|
const { panel } = await initPerformanceInNewTab({
|
|
url: SIMPLE_URL,
|
|
win: window
|
|
});
|
|
|
|
const { EVENTS, $, DetailsView } = panel.panelWin;
|
|
|
|
await startRecording(panel);
|
|
await stopRecording(panel);
|
|
|
|
info("Checking views on startup.");
|
|
checkViews(DetailsView, $, "waterfall");
|
|
|
|
// Select calltree view.
|
|
let viewChanged = once(DetailsView, EVENTS.UI_DETAILS_VIEW_SELECTED,
|
|
{ spreadArgs: true });
|
|
command($("toolbarbutton[data-view='js-calltree']"));
|
|
let [viewName] = await viewChanged;
|
|
is(viewName, "js-calltree", "UI_DETAILS_VIEW_SELECTED fired with view name");
|
|
checkViews(DetailsView, $, "js-calltree");
|
|
|
|
// Select js flamegraph view.
|
|
viewChanged = once(DetailsView, EVENTS.UI_DETAILS_VIEW_SELECTED, { spreadArgs: true });
|
|
command($("toolbarbutton[data-view='js-flamegraph']"));
|
|
[viewName] = await viewChanged;
|
|
is(viewName, "js-flamegraph", "UI_DETAILS_VIEW_SELECTED fired with view name");
|
|
checkViews(DetailsView, $, "js-flamegraph");
|
|
|
|
// Select waterfall view.
|
|
viewChanged = once(DetailsView, EVENTS.UI_DETAILS_VIEW_SELECTED, { spreadArgs: true });
|
|
command($("toolbarbutton[data-view='waterfall']"));
|
|
[viewName] = await viewChanged;
|
|
is(viewName, "waterfall", "UI_DETAILS_VIEW_SELECTED fired with view name");
|
|
checkViews(DetailsView, $, "waterfall");
|
|
|
|
await teardownToolboxAndRemoveTab(panel);
|
|
});
|
|
|
|
function checkViews(DetailsView, $, currentView) {
|
|
for (const viewName in DetailsView.components) {
|
|
const button = $(`toolbarbutton[data-view="${viewName}"]`);
|
|
|
|
is(DetailsView.el.selectedPanel.id, DetailsView.components[currentView].id,
|
|
`DetailsView correctly has ${currentView} selected.`);
|
|
|
|
if (viewName == currentView) {
|
|
ok(button.getAttribute("checked"), `${viewName} button checked.`);
|
|
} else {
|
|
ok(!button.getAttribute("checked"), `${viewName} button not checked.`);
|
|
}
|
|
}
|
|
}
|