summaryrefslogtreecommitdiffstats
path: root/devtools/server/tests/browser/browser_perf-recording-actor-01.js
diff options
context:
space:
mode:
Diffstat (limited to 'devtools/server/tests/browser/browser_perf-recording-actor-01.js')
-rw-r--r--devtools/server/tests/browser/browser_perf-recording-actor-01.js80
1 files changed, 80 insertions, 0 deletions
diff --git a/devtools/server/tests/browser/browser_perf-recording-actor-01.js b/devtools/server/tests/browser/browser_perf-recording-actor-01.js
new file mode 100644
index 000000000..683493121
--- /dev/null
+++ b/devtools/server/tests/browser/browser_perf-recording-actor-01.js
@@ -0,0 +1,80 @@
+/* Any copyright is dedicated to the Public Domain.
+ http://creativecommons.org/publicdomain/zero/1.0/ */
+
+/**
+ * Tests the state of a recording rec from start to finish for recording,
+ * completed, and rec data.
+ */
+
+const { PerformanceFront } = require("devtools/shared/fronts/performance");
+
+add_task(function* () {
+ let browser = yield addTab(MAIN_DOMAIN + "doc_perf.html");
+ let doc = browser.contentDocument;
+
+ initDebuggerServer();
+ let client = new DebuggerClient(DebuggerServer.connectPipe());
+ let form = yield connectDebuggerClient(client);
+ let front = PerformanceFront(client, form);
+ yield front.connect();
+
+ let rec = yield front.startRecording({ withMarkers: true, withTicks: true, withMemory: true });
+ ok(rec.isRecording(), "RecordingModel is recording when created");
+ yield busyWait(100);
+ yield waitUntil(() => rec.getMemory().length);
+ ok(true, "RecordingModel populates memory while recording");
+ yield waitUntil(() => rec.getTicks().length);
+ ok(true, "RecordingModel populates ticks while recording");
+ yield waitUntil(() => rec.getMarkers().length);
+ ok(true, "RecordingModel populates markers while recording");
+
+ ok(!rec.isCompleted(), "RecordingModel is not completed when still recording");
+
+ let stopping = once(front, "recording-stopping");
+ let stopped = once(front, "recording-stopped");
+ front.stopRecording(rec);
+
+ yield stopping;
+ ok(!rec.isRecording(), "on 'recording-stopping', model is no longer recording");
+ // This handler should be called BEFORE "recording-stopped" is called, as
+ // there is some delay, but in the event where "recording-stopped" finishes
+ // before we check here, ensure that we're atleast in the right state
+ if (rec.getProfile()) {
+ ok(rec.isCompleted(), "recording is completed once it has profile data");
+ } else {
+ ok(!rec.isCompleted(), "recording is not yet completed on 'recording-stopping'");
+ ok(rec.isFinalizing(), "recording is considered finalizing between 'recording-stopping' and 'recording-stopped'");
+ }
+
+ yield stopped;
+ ok(!rec.isRecording(), "on 'recording-stopped', model is still no longer recording");
+ ok(rec.isCompleted(), "on 'recording-stopped', model is considered 'complete'");
+
+ checkSystemInfo(rec, "Host");
+ checkSystemInfo(rec, "Client");
+
+ // Export and import a rec, and ensure it has the correct state.
+ let file = FileUtils.getFile("TmpD", ["tmpprofile.json"]);
+ file.createUnique(Ci.nsIFile.NORMAL_FILE_TYPE, parseInt("666", 8));
+ yield rec.exportRecording(file);
+
+ let importedModel = yield front.importRecording(file);
+
+ ok(importedModel.isCompleted(), "All imported recordings should be completed");
+ ok(!importedModel.isRecording(), "All imported recordings should not be recording");
+ ok(importedModel.isImported(), "All imported recordings should be considerd imported");
+
+ checkSystemInfo(importedModel, "Host");
+ checkSystemInfo(importedModel, "Client");
+
+ yield front.destroy();
+ yield client.close();
+ gBrowser.removeCurrentTab();
+});
+
+function checkSystemInfo(recording, type) {
+ let data = recording[`get${type}SystemInfo`]();
+ for (let field of ["appid", "apptype", "vendor", "name", "version"]) {
+ ok(data[field], `get${type}SystemInfo() has ${field} property`);
+ }
+}