diff options
author | Matt A. Tobin <mattatobin@localhost.localdomain> | 2018-02-02 04:16:08 -0500 |
---|---|---|
committer | Matt A. Tobin <mattatobin@localhost.localdomain> | 2018-02-02 04:16:08 -0500 |
commit | 5f8de423f190bbb79a62f804151bc24824fa32d8 (patch) | |
tree | 10027f336435511475e392454359edea8e25895d /devtools/client/performance/test/browser_perf-details-07-bleed-events.js | |
parent | 49ee0794b5d912db1f95dce6eb52d781dc210db5 (diff) | |
download | UXP-5f8de423f190bbb79a62f804151bc24824fa32d8.tar UXP-5f8de423f190bbb79a62f804151bc24824fa32d8.tar.gz UXP-5f8de423f190bbb79a62f804151bc24824fa32d8.tar.lz UXP-5f8de423f190bbb79a62f804151bc24824fa32d8.tar.xz UXP-5f8de423f190bbb79a62f804151bc24824fa32d8.zip |
Add m-esr52 at 52.6.0
Diffstat (limited to 'devtools/client/performance/test/browser_perf-details-07-bleed-events.js')
-rw-r--r-- | devtools/client/performance/test/browser_perf-details-07-bleed-events.js | 48 |
1 files changed, 48 insertions, 0 deletions
diff --git a/devtools/client/performance/test/browser_perf-details-07-bleed-events.js b/devtools/client/performance/test/browser_perf-details-07-bleed-events.js new file mode 100644 index 000000000..f299aadad --- /dev/null +++ b/devtools/client/performance/test/browser_perf-details-07-bleed-events.js @@ -0,0 +1,48 @@ +/* Any copyright is dedicated to the Public Domain. + http://creativecommons.org/publicdomain/zero/1.0/ */ +"use strict"; + +/** + * Tests that events don't bleed between detail 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, DetailsView, JsCallTreeView } = panel.panelWin; + + yield startRecording(panel); + yield stopRecording(panel); + + // The waterfall should render by default, and we want to make + // sure that the render events don't bleed between detail views + // so test that's the case after both views have been created. + let callTreeRendered = once(JsCallTreeView, EVENTS.UI_JS_CALL_TREE_RENDERED); + yield DetailsView.selectView("js-calltree"); + yield callTreeRendered; + + let waterfallSelected = once(DetailsView, EVENTS.UI_DETAILS_VIEW_SELECTED); + yield DetailsView.selectView("waterfall"); + yield waterfallSelected; + + once(JsCallTreeView, EVENTS.UI_WATERFALL_RENDERED).then(() => + ok(false, "JsCallTreeView should not receive UI_WATERFALL_RENDERED event.")); + + yield startRecording(panel); + yield stopRecording(panel); + + let callTreeRerendered = once(JsCallTreeView, EVENTS.UI_JS_CALL_TREE_RENDERED); + yield DetailsView.selectView("js-calltree"); + yield callTreeRerendered; + + ok(true, "Test passed."); + yield teardownToolboxAndRemoveTab(panel); +}); |