diff options
Diffstat (limited to 'devtools/client/performance/test/browser_perf-console-record-09.js')
-rw-r--r-- | devtools/client/performance/test/browser_perf-console-record-09.js | 64 |
1 files changed, 64 insertions, 0 deletions
diff --git a/devtools/client/performance/test/browser_perf-console-record-09.js b/devtools/client/performance/test/browser_perf-console-record-09.js new file mode 100644 index 000000000..06c14faa5 --- /dev/null +++ b/devtools/client/performance/test/browser_perf-console-record-09.js @@ -0,0 +1,64 @@ +/* Any copyright is dedicated to the Public Domain. + http://creativecommons.org/publicdomain/zero/1.0/ */ +"use strict"; + +/** + * Tests that an error is not thrown when clearing out the recordings if there's + * an in-progress console profile and that console profiles are not cleared + * if in progress. + */ + +const { SIMPLE_URL } = require("devtools/client/performance/test/helpers/urls"); +const { initPerformanceInTab, initConsoleInNewTab, teardownToolboxAndRemoveTab } = require("devtools/client/performance/test/helpers/panel-utils"); +const { startRecording, stopRecording } = require("devtools/client/performance/test/helpers/actions"); +const { waitForRecordingStartedEvents } = require("devtools/client/performance/test/helpers/actions"); +const { idleWait } = require("devtools/client/performance/test/helpers/wait-utils"); + +add_task(function* () { + let { target, console } = yield initConsoleInNewTab({ + url: SIMPLE_URL, + win: window + }); + + let { panel } = yield initPerformanceInTab({ tab: target.tab }); + let { PerformanceController } = panel.panelWin; + + yield startRecording(panel); + yield stopRecording(panel); + + info("Starting console.profile()..."); + let started = waitForRecordingStartedEvents(panel, { + // only emitted for manual recordings + skipWaitingForBackendReady: true, + // only emitted when an in-progress recording is selected + skipWaitingForOverview: true, + // the view state won't switch to "console-recording" unless the new + // in-progress recording is selected, which won't happen + skipWaitingForViewState: true, + }); + yield console.profile(); + yield started; + + yield PerformanceController.clearRecordings(); + let recordings = PerformanceController.getRecordings(); + is(recordings.length, 1, "One recording found in the performance panel."); + is(recordings[0].isConsole(), true, "Recording came from console.profile."); + is(recordings[0].getLabel(), "", "Correct label in the recording model."); + is(PerformanceController.getCurrentRecording(), recordings[0], + "There current recording should be the first one."); + + info("Attempting to end console.profileEnd()..."); + yield console.profileEnd(); + yield idleWait(1000); + + ok(true, + "Stopping an in-progress console profile after clearing recordings does not throw."); + + yield PerformanceController.clearRecordings(); + recordings = PerformanceController.getRecordings(); + is(recordings.length, 0, "No recordings found"); + is(PerformanceController.getCurrentRecording(), null, + "There should be no current recording."); + + yield teardownToolboxAndRemoveTab(panel); +}); |