michael@0: /* Any copyright is dedicated to the Public Domain. michael@0: http://creativecommons.org/publicdomain/zero/1.0/ */ michael@0: michael@0: /** michael@0: * Test that text describing the tracing state is correctly displayed. michael@0: */ michael@0: michael@0: const TAB_URL = EXAMPLE_URL + "doc_tracing-01.html"; michael@0: michael@0: let gTab, gDebuggee, gPanel, gDebugger; michael@0: let gTracer, gL10N; michael@0: michael@0: function test() { michael@0: SpecialPowers.pushPrefEnv({'set': [["devtools.debugger.tracer", true]]}, () => { michael@0: initDebugger(TAB_URL).then(([aTab, aDebuggee, aPanel]) => { michael@0: gTab = aTab; michael@0: gDebuggee = aDebuggee; michael@0: gPanel = aPanel; michael@0: gDebugger = gPanel.panelWin; michael@0: gTracer = gDebugger.DebuggerView.Tracer; michael@0: gL10N = gDebugger.L10N; michael@0: michael@0: waitForSourceShown(gPanel, "code_tracing-01.js") michael@0: .then(testTracingNotStartedText) michael@0: .then(() => gTracer._onStartTracing()) michael@0: .then(testFunctionCallsUnavailableText) michael@0: .then(clickButton) michael@0: .then(() => waitForClientEvents(aPanel, "traces")) michael@0: .then(testNoEmptyText) michael@0: .then(() => gTracer._onClear()) michael@0: .then(testFunctionCallsUnavailableText) michael@0: .then(() => gTracer._onStopTracing()) michael@0: .then(testTracingNotStartedText) michael@0: .then(() => gTracer._onClear()) michael@0: .then(testTracingNotStartedText) michael@0: .then(() => { michael@0: const deferred = promise.defer(); michael@0: SpecialPowers.popPrefEnv(deferred.resolve); michael@0: return deferred.promise; michael@0: }) michael@0: .then(() => closeDebuggerAndFinish(gPanel)) michael@0: .then(null, aError => { michael@0: DevToolsUtils.reportException("browser_dbg_tracing-05.js", aError); michael@0: ok(false, "Got an error: " + aError.message + "\n" + aError.stack); michael@0: }); michael@0: }); michael@0: }); michael@0: } michael@0: michael@0: function testTracingNotStartedText() { michael@0: let label = gDebugger.document.querySelector("#tracer-tabpanel .fast-list-widget-empty-text"); michael@0: ok(label, michael@0: "A label is displayed in the tracer tabpanel."); michael@0: is(label.getAttribute("value"), gL10N.getStr("tracingNotStartedText"), michael@0: "The correct {{tracingNotStartedText}} is displayed in the tracer tabpanel."); michael@0: } michael@0: michael@0: function testFunctionCallsUnavailableText() { michael@0: let label = gDebugger.document.querySelector("#tracer-tabpanel .fast-list-widget-empty-text"); michael@0: ok(label, michael@0: "A label is displayed in the tracer tabpanel."); michael@0: is(label.getAttribute("value"), gL10N.getStr("noFunctionCallsText"), michael@0: "The correct {{noFunctionCallsText}} is displayed in the tracer tabpanel."); michael@0: } michael@0: michael@0: function testNoEmptyText() { michael@0: let label = gDebugger.document.querySelector("#tracer-tabpanel .fast-list-widget-empty-text"); michael@0: ok(!label, michael@0: "No label should be displayed in the tracer tabpanel."); michael@0: } michael@0: michael@0: function clickButton() { michael@0: EventUtils.sendMouseEvent({ type: "click" }, michael@0: gDebuggee.document.querySelector("button"), michael@0: gDebuggee); michael@0: } michael@0: michael@0: registerCleanupFunction(function() { michael@0: gTab = null; michael@0: gDebuggee = null; michael@0: gPanel = null; michael@0: gDebugger = null; michael@0: gTracer = null; michael@0: gL10N = null; michael@0: });