summaryrefslogtreecommitdiffstats
path: root/devtools/client/performance/test/browser_perf-telemetry-03.js
diff options
context:
space:
mode:
Diffstat (limited to 'devtools/client/performance/test/browser_perf-telemetry-03.js')
-rw-r--r--devtools/client/performance/test/browser_perf-telemetry-03.js56
1 files changed, 56 insertions, 0 deletions
diff --git a/devtools/client/performance/test/browser_perf-telemetry-03.js b/devtools/client/performance/test/browser_perf-telemetry-03.js
new file mode 100644
index 000000000..a10f314d2
--- /dev/null
+++ b/devtools/client/performance/test/browser_perf-telemetry-03.js
@@ -0,0 +1,56 @@
+/* Any copyright is dedicated to the Public Domain.
+ http://creativecommons.org/publicdomain/zero/1.0/ */
+"use strict";
+
+/**
+ * Tests that the performance telemetry module records events at appropriate times.
+ * Specifically the destruction of certain views.
+ */
+
+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");
+
+add_task(function* () {
+ let { panel } = yield initPerformanceInNewTab({
+ url: SIMPLE_URL,
+ win: window
+ });
+
+ let {
+ EVENTS,
+ PerformanceController,
+ DetailsView,
+ JsCallTreeView,
+ JsFlameGraphView
+ } = panel.panelWin;
+
+ let telemetry = PerformanceController._telemetry;
+ let logs = telemetry.getLogs();
+ let VIEWS = "DEVTOOLS_PERFTOOLS_SELECTED_VIEW_MS";
+
+ yield startRecording(panel);
+ yield stopRecording(panel);
+
+ let calltreeRendered = once(JsCallTreeView, EVENTS.UI_JS_CALL_TREE_RENDERED);
+ let flamegraphRendered = once(JsFlameGraphView, EVENTS.UI_JS_FLAMEGRAPH_RENDERED);
+
+ // Go through some views to check later.
+ yield DetailsView.selectView("js-calltree");
+ yield calltreeRendered;
+
+ yield DetailsView.selectView("js-flamegraph");
+ yield flamegraphRendered;
+
+ yield teardownToolboxAndRemoveTab(panel);
+
+ // Check views after destruction to ensure `js-flamegraph` gets called
+ // with a time during destruction.
+ ok(logs[VIEWS].find(r => r[0] === "waterfall" && typeof r[1] === "number"),
+ `${VIEWS} for waterfall view and time.`);
+ ok(logs[VIEWS].find(r => r[0] === "js-calltree" && typeof r[1] === "number"),
+ `${VIEWS} for js-calltree view and time.`);
+ ok(logs[VIEWS].find(r => r[0] === "js-flamegraph" && typeof r[1] === "number"),
+ `${VIEWS} for js-flamegraph view and time.`);
+});