From 5f8de423f190bbb79a62f804151bc24824fa32d8 Mon Sep 17 00:00:00 2001 From: "Matt A. Tobin" Date: Fri, 2 Feb 2018 04:16:08 -0500 Subject: Add m-esr52 at 52.6.0 --- .../test/browser_perf-recording-selected-04.js | 59 ++++++++++++++++++++++ 1 file changed, 59 insertions(+) create mode 100644 devtools/client/performance/test/browser_perf-recording-selected-04.js (limited to 'devtools/client/performance/test/browser_perf-recording-selected-04.js') diff --git a/devtools/client/performance/test/browser_perf-recording-selected-04.js b/devtools/client/performance/test/browser_perf-recording-selected-04.js new file mode 100644 index 000000000..014ef5bdd --- /dev/null +++ b/devtools/client/performance/test/browser_perf-recording-selected-04.js @@ -0,0 +1,59 @@ +/* Any copyright is dedicated to the Public Domain. + http://creativecommons.org/publicdomain/zero/1.0/ */ +"use strict"; + +/** + * Tests that all components can get rerendered for a profile when switching. + */ + +const { SIMPLE_URL } = require("devtools/client/performance/test/helpers/urls"); +const { UI_ENABLE_MEMORY_PREF, UI_ENABLE_ALLOCATIONS_PREF } = require("devtools/client/performance/test/helpers/prefs"); +const { initPerformanceInNewTab, teardownToolboxAndRemoveTab } = require("devtools/client/performance/test/helpers/panel-utils"); +const { startRecording, stopRecording, waitForAllWidgetsRendered } = require("devtools/client/performance/test/helpers/actions"); +const { setSelectedRecording } = require("devtools/client/performance/test/helpers/recording-utils"); + +add_task(function* () { + let { panel } = yield initPerformanceInNewTab({ + url: SIMPLE_URL, + win: window + }); + + let { DetailsView, DetailsSubview } = panel.panelWin; + + // Enable memory to test the memory overview. + Services.prefs.setBoolPref(UI_ENABLE_MEMORY_PREF, true); + + // Enable allocations to test the memory-calltree and memory-flamegraph. + Services.prefs.setBoolPref(UI_ENABLE_ALLOCATIONS_PREF, true); + + yield startRecording(panel); + yield stopRecording(panel); + + // Ã…llow widgets to be updated while hidden, to make testing easier. + DetailsSubview.canUpdateWhileHidden = true; + + // Cycle through all the views to initialize them. The waterfall is shown + // by default, but all the other views are created lazily, so won't emit + // any events. + yield DetailsView.selectView("js-calltree"); + yield DetailsView.selectView("js-flamegraph"); + yield DetailsView.selectView("memory-calltree"); + yield DetailsView.selectView("memory-flamegraph"); + + yield startRecording(panel); + yield stopRecording(panel); + + let rerender = waitForAllWidgetsRendered(panel); + setSelectedRecording(panel, 0); + yield rerender; + + ok(true, "All widgets were rendered when selecting the first recording."); + + rerender = waitForAllWidgetsRendered(panel); + setSelectedRecording(panel, 1); + yield rerender; + + ok(true, "All widgets were rendered when selecting the second recording."); + + yield teardownToolboxAndRemoveTab(panel); +}); -- cgit v1.2.3