Source code

Revision control

Copy as Markdown

Other Tools

Test Info: Warnings

/* Any copyright is dedicated to the Public Domain.
"use strict";
// Test very basic CDP features.
add_task(async function testCDP({ client }) {
const { Browser, Log, Page } = client;
ok("Browser" in client, "Browser domain is available");
ok("Log" in client, "Log domain is available");
ok("Page" in client, "Page domain is available");
const version = await Browser.getVersion();
const { isHeadless } = Cc["@mozilla.org/gfx/info;1"].getService(
Ci.nsIGfxInfo
);
is(
version.product,
(isHeadless ? "Headless" : "") +
`${Services.appinfo.name}/${Services.appinfo.version}`,
"Browser.getVersion works and depends on headless mode"
);
is(
version.userAgent,
window.navigator.userAgent,
"Browser.getVersion().userAgent is correct"
);
is(
version.revision,
Services.appinfo.sourceURL.split("/").pop(),
"Browser.getVersion().revision is correct"
);
is(
version.jsVersion,
Services.appinfo.version,
"Browser.getVersion().jsVersion is correct"
);
// receive console.log messages and print them
let result = await Log.enable();
info("Log domain has been enabled");
Assert.deepEqual(result, {}, "Got expected result value");
Log.entryAdded(({ entry }) => {
const { timestamp, level, text, args } = entry;
const msg = text || args.join(" ");
console.log(`${new Date(timestamp)}\t${level.toUpperCase()}\t${msg}`);
});
// turn on navigation related events, such as DOMContentLoaded et al.
result = await Page.enable();
info("Page domain has been enabled");
Assert.deepEqual(result, {}, "Got expected result value");
const frameStoppedLoading = Page.frameStoppedLoading();
const frameNavigated = Page.frameNavigated();
const loadEventFired = Page.loadEventFired();
await Page.navigate({
url: toDataURL(`<script>console.log("foo")</script>`),
});
info("A new page has been requested");
await loadEventFired;
info("`Page.loadEventFired` fired");
await frameStoppedLoading;
info("`Page.frameStoppedLoading` fired");
await frameNavigated;
info("`Page.frameNavigated` fired");
});