mirror of
https://github.com/mozilla/gecko-dev.git
synced 2024-11-23 21:01:08 +00:00
Merge mozilla-central to inbound. a=merge CLOSED TREE
--HG-- rename : testing/profiles/prefs_general.js => testing/profiles/common/user.js extra : rebase_source : e56a2d784bd87af73d03cc5fcdca84d8156ed054
This commit is contained in:
commit
2f93cbd6cb
2
CLOBBER
2
CLOBBER
@ -22,4 +22,4 @@
|
||||
# changes to stick? As of bug 928195, this shouldn't be necessary! Please
|
||||
# don't change CLOBBER for WebIDL changes any more.
|
||||
|
||||
Bug 1453317 - Update VS2017 used for builds in automation to version 15.6.6.
|
||||
Bug 1451159 - Moved testing/profiles/prefs_general.js (prevents symlinked file does not exist)
|
||||
|
@ -76,8 +76,9 @@ async function pause(tab, options) {
|
||||
ok(!tab.hasAttribute("soundplaying"), "The tab should not have the soundplaying attribute after the timeout has resolved");
|
||||
} finally {
|
||||
// Make sure other tests don't timeout if an exception gets thrown above.
|
||||
// Need to use setIntPref instead of clearUserPref because prefs_general.js
|
||||
// overrides the default value to help this and other tests run faster.
|
||||
// Need to use setIntPref instead of clearUserPref because
|
||||
// testing/profiles/common/user.js overrides the default value to help this and
|
||||
// other tests run faster.
|
||||
Services.prefs.setIntPref(TABATTR_REMOVAL_PREFNAME, INITIAL_TABATTR_REMOVAL_DELAY_MS);
|
||||
}
|
||||
}
|
||||
|
@ -23,6 +23,12 @@ NS_IMPL_ISUPPORTS(AboutRedirector, nsIAboutModule)
|
||||
|
||||
bool AboutRedirector::sNewTabPageEnabled = false;
|
||||
|
||||
static const uint32_t ACTIVITY_STREAM_FLAGS =
|
||||
nsIAboutModule::ALLOW_SCRIPT |
|
||||
nsIAboutModule::ENABLE_INDEXED_DB |
|
||||
nsIAboutModule::URI_MUST_LOAD_IN_CHILD |
|
||||
nsIAboutModule::URI_SAFE_FOR_UNTRUSTED_CONTENT;
|
||||
|
||||
struct RedirEntry {
|
||||
const char* id;
|
||||
const char* url;
|
||||
@ -78,21 +84,11 @@ static const RedirEntry kRedirMap[] = {
|
||||
nsIAboutModule::ALLOW_SCRIPT |
|
||||
nsIAboutModule::HIDE_FROM_ABOUTABOUT },
|
||||
// Actual activity stream URL for home and newtab are set in channel creation
|
||||
// Linkable because of indexeddb use (bug 1228118)
|
||||
{ "home", "about:blank",
|
||||
nsIAboutModule::URI_SAFE_FOR_UNTRUSTED_CONTENT |
|
||||
nsIAboutModule::URI_MUST_LOAD_IN_CHILD |
|
||||
nsIAboutModule::ALLOW_SCRIPT |
|
||||
nsIAboutModule::MAKE_LINKABLE |
|
||||
nsIAboutModule::ENABLE_INDEXED_DB },
|
||||
{ "home", "about:blank", ACTIVITY_STREAM_FLAGS },
|
||||
{ "newtab", "about:blank", ACTIVITY_STREAM_FLAGS },
|
||||
{ "library", "chrome://browser/content/aboutLibrary.xhtml",
|
||||
nsIAboutModule::URI_MUST_LOAD_IN_CHILD |
|
||||
nsIAboutModule::URI_SAFE_FOR_UNTRUSTED_CONTENT },
|
||||
{ "newtab", "about:blank",
|
||||
nsIAboutModule::ENABLE_INDEXED_DB |
|
||||
nsIAboutModule::URI_MUST_LOAD_IN_CHILD |
|
||||
nsIAboutModule::URI_SAFE_FOR_UNTRUSTED_CONTENT |
|
||||
nsIAboutModule::ALLOW_SCRIPT },
|
||||
{ "preferences", "chrome://browser/content/preferences/in-content/preferences.xul",
|
||||
nsIAboutModule::ALLOW_SCRIPT },
|
||||
{ "downloads", "chrome://browser/content/downloads/contentAreaDownloadsView.xul",
|
||||
|
@ -16,10 +16,10 @@ add_task(async function test_disable_firefox_screenshots() {
|
||||
// that pref is being watched, and it makes the Firefox Screenshots system add-on
|
||||
// to start or stop, causing intermittency.
|
||||
//
|
||||
// Firefox Screenshots is disabled by default on tests (in prefs_general.js).
|
||||
// What we do here to test this policy is to enable it on this specific
|
||||
// test folder (through browser.ini) and then we let the policy engine
|
||||
// be responsible for disabling Firefox Screenshots in this case.
|
||||
// Firefox Screenshots is disabled by default on tests (in
|
||||
// testing/profiles/common/user.js). What we do here to test this policy is to enable
|
||||
// it on this specific test folder (through browser.ini) and then we let the policy
|
||||
// engine be responsible for disabling Firefox Screenshots in this case.
|
||||
|
||||
is(Services.prefs.getBoolPref(PREF_DISABLE_FX_SCREENSHOTS), true, "Screenshots pref is disabled");
|
||||
|
||||
|
@ -50,8 +50,8 @@
|
||||
<radiogroup id="networkProxyType" preference="network.proxy.type"
|
||||
onsyncfrompreference="return gConnectionsDialog.readProxyType();">
|
||||
<radio value="0" data-l10n-id="connection-proxy-option-no" />
|
||||
<radio value="4" data-l10n-id="connection-proxy-option-system" />
|
||||
<radio value="5" data-l10n-id="connection-proxy-option-auto" id="systemPref" hidden="true" />
|
||||
<radio value="4" data-l10n-id="connection-proxy-option-auto" />
|
||||
<radio value="5" data-l10n-id="connection-proxy-option-system" id="systemPref" hidden="true" />
|
||||
<radio value="1" data-l10n-id="connection-proxy-option-manual"/>
|
||||
<grid class="indent" flex="1">
|
||||
<columns>
|
||||
|
@ -26,7 +26,7 @@ function promisePocketDisabled() {
|
||||
return Promise.resolve(true);
|
||||
}
|
||||
info("reset pocket enabled pref");
|
||||
// testing/profiles/prefs_general.js uses user_pref to disable pocket, set
|
||||
// testing/profiles/common/user.js uses user_pref to disable pocket, set
|
||||
// back to false.
|
||||
Services.prefs.setBoolPref("extensions.pocket.enabled", false);
|
||||
return BrowserTestUtils.waitForCondition(() => {
|
||||
|
File diff suppressed because one or more lines are too long
@ -698,8 +698,8 @@ html|*.urlbar-input:-moz-lwtheme::placeholder,
|
||||
|
||||
@media (-moz-windows-default-theme: 0) {
|
||||
/* For high contrast themes. */
|
||||
tabbrowser,
|
||||
:root[privatebrowsingmode=temporary] tabbrowser {
|
||||
#tabbrowser-tabpanels,
|
||||
:root[privatebrowsingmode=temporary] #tabbrowser-tabpanels {
|
||||
background-color: -moz-default-background-color;
|
||||
}
|
||||
}
|
||||
|
@ -35,8 +35,6 @@ from mozscreenshot import printstatus, dump_screen
|
||||
|
||||
# ---------------------------------------------------------------
|
||||
|
||||
_DEFAULT_PREFERENCE_FILE = os.path.join(SCRIPT_DIR, 'prefs_general.js')
|
||||
|
||||
_DEFAULT_WEB_SERVER = "127.0.0.1"
|
||||
_DEFAULT_HTTP_PORT = 8888
|
||||
_DEFAULT_SSL_PORT = 4443
|
||||
|
@ -55,6 +55,7 @@ MACH_MODULES = [
|
||||
'testing/mochitest/mach_commands.py',
|
||||
'testing/mozharness/mach_commands.py',
|
||||
'testing/raptor/mach_commands.py',
|
||||
'testing/tps/mach_commands.py',
|
||||
'testing/talos/mach_commands.py',
|
||||
'testing/web-platform/mach_commands.py',
|
||||
'testing/xpcshell/mach_commands.py',
|
||||
|
@ -4,7 +4,6 @@
|
||||
# License, v. 2.0. If a copy of the MPL was not distributed with this
|
||||
# file, You can obtain one at http://mozilla.org/MPL/2.0/.
|
||||
|
||||
import json
|
||||
import os
|
||||
|
||||
from buildconfig import substs
|
||||
@ -14,6 +13,7 @@ from mozhttpd import MozHttpd
|
||||
from mozprofile import FirefoxProfile, Profile, Preferences
|
||||
from mozprofile.permissions import ServerLocations
|
||||
from mozrunner import FirefoxRunner, CLI
|
||||
from six import string_types
|
||||
|
||||
PORT = 8888
|
||||
|
||||
@ -44,7 +44,7 @@ if __name__ == '__main__':
|
||||
with TemporaryDirectory() as profilePath:
|
||||
# TODO: refactor this into mozprofile
|
||||
prefpath = os.path.join(
|
||||
build.topsrcdir, "testing", "profiles", "prefs_general.js")
|
||||
build.topsrcdir, "testing", "profiles", "common", "user.js")
|
||||
overridepath = os.path.join(
|
||||
build.topsrcdir, "build", "pgo", "prefs_override.js")
|
||||
|
||||
@ -54,9 +54,10 @@ if __name__ == '__main__':
|
||||
|
||||
interpolation = {"server": "%s:%d" % httpd.httpd.server_address,
|
||||
"OOP": "false"}
|
||||
prefs = json.loads(json.dumps(prefs) % interpolation)
|
||||
for pref in prefs:
|
||||
prefs[pref] = Preferences.cast(prefs[pref])
|
||||
for k, v in prefs.items():
|
||||
if isinstance(v, string_types):
|
||||
v = v.format(**interpolation)
|
||||
prefs[k] = Preferences.cast(v)
|
||||
|
||||
profile = FirefoxProfile(profile=profilePath,
|
||||
preferences=prefs,
|
||||
|
5
build/sparse-profiles/tps
Normal file
5
build/sparse-profiles/tps
Normal file
@ -0,0 +1,5 @@
|
||||
%include build/sparse-profiles/mach
|
||||
|
||||
[include]
|
||||
path:services/sync/tps/
|
||||
path:testing/tps/
|
@ -43,7 +43,6 @@ class MachCommands(MachCommandBase):
|
||||
'--suppression multiple times to specify multiple suppression '
|
||||
'files.')
|
||||
def valgrind_test(self, suppressions):
|
||||
import json
|
||||
import sys
|
||||
import tempfile
|
||||
|
||||
@ -54,6 +53,7 @@ class MachCommands(MachCommandBase):
|
||||
from mozprofile.permissions import ServerLocations
|
||||
from mozrunner import FirefoxRunner
|
||||
from mozrunner.utils import findInPath
|
||||
from six import string_types
|
||||
from valgrind.output_handler import OutputHandler
|
||||
|
||||
build_dir = os.path.join(self.topsrcdir, 'build')
|
||||
@ -65,14 +65,16 @@ class MachCommands(MachCommandBase):
|
||||
|
||||
with TemporaryDirectory() as profilePath:
|
||||
#TODO: refactor this into mozprofile
|
||||
prefpath = os.path.join(self.topsrcdir, 'testing', 'profiles', 'prefs_general.js')
|
||||
prefpath = os.path.join(self.topsrcdir, 'testing', 'profiles', 'common', 'user.js')
|
||||
prefs = {}
|
||||
prefs.update(Preferences.read_prefs(prefpath))
|
||||
interpolation = { 'server': '%s:%d' % httpd.httpd.server_address,
|
||||
'OOP': 'false'}
|
||||
prefs = json.loads(json.dumps(prefs) % interpolation)
|
||||
for pref in prefs:
|
||||
prefs[pref] = Preferences.cast(prefs[pref])
|
||||
interpolation = {
|
||||
'server': '%s:%d' % httpd.httpd.server_address,
|
||||
}
|
||||
for k, v in prefs.items():
|
||||
if isinstance(v, string_types):
|
||||
v = v.format(**interpolation)
|
||||
prefs[k] = Preferences.cast(v)
|
||||
|
||||
quitter = os.path.join(self.topsrcdir, 'tools', 'quitter', 'quitter@mozilla.org.xpi')
|
||||
|
||||
|
@ -20,6 +20,7 @@ support-files =
|
||||
service-workers/push-sw.html
|
||||
service-workers/push-sw.js
|
||||
!/devtools/client/shared/test/shared-head.js
|
||||
!/devtools/client/shared/test/telemetry-test-helpers.js
|
||||
|
||||
[browser_addons_debug_bootstrapped.js]
|
||||
skip-if = coverage # Bug 1387827
|
||||
|
@ -6,6 +6,7 @@ support-files =
|
||||
!/devtools/client/shared/test/shared-head.js
|
||||
!/devtools/client/inspector/test/shared-head.js
|
||||
!/devtools/client/shared/test/shared-redux-head.js
|
||||
!/devtools/client/shared/test/telemetry-test-helpers.js
|
||||
|
||||
[browser_accessibility_context_menu_browser.js]
|
||||
[browser_accessibility_context_menu_inspector.js]
|
||||
|
@ -9,6 +9,7 @@ support-files =
|
||||
service-workers/simple.html
|
||||
!/devtools/client/shared/test/frame-script-utils.js
|
||||
!/devtools/client/shared/test/shared-head.js
|
||||
!/devtools/client/shared/test/telemetry-test-helpers.js
|
||||
|
||||
[browser_application_panel_list-domain-workers.js]
|
||||
[browser_application_panel_list-several-workers.js]
|
||||
|
@ -17,6 +17,7 @@ support-files =
|
||||
head.js
|
||||
!/devtools/client/shared/test/frame-script-utils.js
|
||||
!/devtools/client/shared/test/shared-head.js
|
||||
!/devtools/client/shared/test/telemetry-test-helpers.js
|
||||
|
||||
[browser_canvas-actor-test-01.js]
|
||||
[browser_canvas-actor-test-02.js]
|
||||
|
@ -122,6 +122,7 @@ skip-if = true # Bug 1093205 - Test does not run in Firefox due to missing termi
|
||||
[browser_gcli_spell.js]
|
||||
[browser_gcli_split.js]
|
||||
[browser_gcli_telemetry.js]
|
||||
skip-if = true # Disabling: Monkeypatches telemetry and GCLI is soon to be removed.
|
||||
[browser_gcli_tokenize.js]
|
||||
[browser_gcli_tooltip.js]
|
||||
skip-if = true # Bug 1093205 - Test does not run in Firefox due to missing terminal
|
||||
|
@ -14,6 +14,9 @@ var { require } = ChromeUtils.import("resource://devtools/shared/Loader.jsm", {}
|
||||
var flags = require("devtools/shared/flags");
|
||||
var { Task } = require("devtools/shared/task");
|
||||
|
||||
Services.scriptloader.loadSubScript(
|
||||
"chrome://mochitests/content/browser/devtools/client/shared/test/telemetry-test-helpers.js", this);
|
||||
|
||||
// Import the GCLI test helper
|
||||
var testDir = gTestPath.substr(0, gTestPath.lastIndexOf("/"));
|
||||
Services.scriptloader.loadSubScript(testDir + "/helpers.js", this);
|
||||
|
@ -106,7 +106,7 @@ const { BreadcrumbsWidget } = require("resource://devtools/client/shared/widgets
|
||||
const { SideMenuWidget } = require("resource://devtools/client/shared/widgets/SideMenuWidget.jsm");
|
||||
const { VariablesView } = require("resource://devtools/client/shared/widgets/VariablesView.jsm");
|
||||
const { VariablesViewController, StackFrameUtils } = require("resource://devtools/client/shared/widgets/VariablesViewController.jsm");
|
||||
const EventEmitter = require("devtools/shared/old-event-emitter");
|
||||
const EventEmitter = require("devtools/shared/event-emitter");
|
||||
const { extend } = require("devtools/shared/extend");
|
||||
const { gDevTools } = require("devtools/client/framework/devtools");
|
||||
const { ViewHelpers, WidgetMethods, setNamedTimeout,
|
||||
@ -450,7 +450,7 @@ var DebuggerController = {
|
||||
|
||||
waitForSourceShown: function (name) {
|
||||
const deferred = promise.defer();
|
||||
window.on(EVENTS.SOURCE_SHOWN, function onShown(_, source) {
|
||||
window.on(EVENTS.SOURCE_SHOWN, function onShown(source) {
|
||||
if (source.url.includes(name)) {
|
||||
window.off(EVENTS.SOURCE_SHOWN, onShown);
|
||||
deferred.resolve();
|
||||
|
@ -6,6 +6,7 @@ support-files =
|
||||
head.js
|
||||
!/devtools/client/commandline/test/helpers.js
|
||||
!/devtools/client/shared/test/shared-head.js
|
||||
!/devtools/client/shared/test/telemetry-test-helpers.js
|
||||
examples/babel/polyfill-bundle.js
|
||||
examples/babel/fixtures/eval-source-maps/output.js
|
||||
examples/babel/fixtures/eval-source-maps/output.js.map
|
||||
|
@ -7,7 +7,7 @@
|
||||
|
||||
const { Cc, Ci, Cu, Cr } = require("chrome");
|
||||
const promise = require("promise");
|
||||
const EventEmitter = require("devtools/shared/old-event-emitter");
|
||||
const EventEmitter = require("devtools/shared/event-emitter");
|
||||
const DevToolsUtils = require("devtools/shared/DevToolsUtils");
|
||||
|
||||
function DebuggerPanel(iframeWindow, toolbox) {
|
||||
|
@ -132,6 +132,7 @@ support-files =
|
||||
testactors.js
|
||||
!/devtools/client/commandline/test/helpers.js
|
||||
!/devtools/client/shared/test/shared-head.js
|
||||
!/devtools/client/shared/test/telemetry-test-helpers.js
|
||||
|
||||
[browser_dbg_aaa_run_first_leaktest.js]
|
||||
uses-unsafe-cpows = true
|
||||
|
@ -132,6 +132,7 @@ support-files =
|
||||
testactors.js
|
||||
!/devtools/client/commandline/test/helpers.js
|
||||
!/devtools/client/shared/test/shared-head.js
|
||||
!/devtools/client/shared/test/telemetry-test-helpers.js
|
||||
|
||||
[browser_dbg_no-dangling-breakpoints.js]
|
||||
uses-unsafe-cpows = true
|
||||
|
@ -19,7 +19,7 @@ var { DebuggerServer } = require("devtools/server/main");
|
||||
var { DebuggerClient } = require("devtools/shared/client/debugger-client");
|
||||
var ObjectClient = require("devtools/shared/client/object-client");
|
||||
var { AddonManager } = ChromeUtils.import("resource://gre/modules/AddonManager.jsm", {});
|
||||
var EventEmitter = require("devtools/shared/old-event-emitter");
|
||||
var EventEmitter = require("devtools/shared/event-emitter");
|
||||
var { Toolbox } = require("devtools/client/framework/toolbox");
|
||||
var { Task } = require("devtools/shared/task");
|
||||
|
||||
@ -380,7 +380,7 @@ function waitForDebuggerEvents(aPanel, aEventName, aEventRepeat = 1) {
|
||||
let panelWin = aPanel.panelWin;
|
||||
let count = 0;
|
||||
|
||||
panelWin.on(aEventName, function onEvent(aEventName, ...aArgs) {
|
||||
panelWin.on(aEventName, function onEvent(...aArgs) {
|
||||
info("Debugger event '" + aEventName + "' fired: " + (++count) + " time(s).");
|
||||
|
||||
if (count == aEventRepeat) {
|
||||
|
@ -7,6 +7,7 @@ support-files =
|
||||
page_basic.html
|
||||
!/devtools/client/shared/test/frame-script-utils.js
|
||||
!/devtools/client/shared/test/shared-head.js
|
||||
!/devtools/client/shared/test/telemetry-test-helpers.js
|
||||
|
||||
[browser_dom_array.js]
|
||||
[browser_dom_basic.js]
|
||||
|
@ -47,6 +47,7 @@ support-files =
|
||||
!/devtools/client/shared/test/frame-script-utils.js
|
||||
!/devtools/client/shared/test/shared-head.js
|
||||
!/devtools/client/shared/test/shared-redux-head.js
|
||||
!/devtools/client/shared/test/telemetry-test-helpers.js
|
||||
|
||||
[browser_browser_toolbox.js]
|
||||
skip-if = coverage # Bug 1387827
|
||||
|
@ -1,6 +1,8 @@
|
||||
/* Any copyright is dedicated to the Public Domain.
|
||||
* http://creativecommons.org/publicdomain/zero/1.0/ */
|
||||
|
||||
/* import-globals-from head.js */
|
||||
|
||||
"use strict";
|
||||
|
||||
const {Toolbox} = require("devtools/client/framework/toolbox");
|
||||
@ -8,13 +10,8 @@ const {SIDE, BOTTOM, WINDOW} = Toolbox.HostType;
|
||||
|
||||
const URL = "data:text/html;charset=utf8,browser_toolbox_hosts_telemetry.js";
|
||||
|
||||
function getHostHistogram() {
|
||||
return Services.telemetry.getHistogramById("DEVTOOLS_TOOLBOX_HOST");
|
||||
}
|
||||
|
||||
add_task(async function() {
|
||||
// Reset it to make counting easier
|
||||
getHostHistogram().clear();
|
||||
startTelemetry();
|
||||
|
||||
info("Create a test tab and open the toolbox");
|
||||
let tab = await addTab(URL);
|
||||
@ -23,13 +20,6 @@ add_task(async function() {
|
||||
|
||||
await changeToolboxHost(toolbox);
|
||||
await checkResults();
|
||||
await toolbox.destroy();
|
||||
|
||||
toolbox = target = null;
|
||||
gBrowser.removeCurrentTab();
|
||||
|
||||
// Cleanup
|
||||
getHostHistogram().clear();
|
||||
});
|
||||
|
||||
async function changeToolboxHost(toolbox) {
|
||||
@ -43,8 +33,9 @@ async function changeToolboxHost(toolbox) {
|
||||
}
|
||||
|
||||
function checkResults() {
|
||||
let counts = getHostHistogram().snapshot().counts;
|
||||
is(counts[0], 3, "Toolbox HostType bottom has 3 successful entries");
|
||||
is(counts[1], 2, "Toolbox HostType side has 2 successful entries");
|
||||
is(counts[2], 2, "Toolbox HostType window has 2 successful entries");
|
||||
// Check for:
|
||||
// - 3 "bottom" entries.
|
||||
// - 2 "side" entries.
|
||||
// - 2 "window" entries.
|
||||
checkTelemetry("DEVTOOLS_TOOLBOX_HOST", "", [3, 2, 2, 0, 0, 0, 0, 0, 0, 0], "array");
|
||||
}
|
||||
|
@ -4,6 +4,7 @@
|
||||
* http://creativecommons.org/publicdomain/zero/1.0/ */
|
||||
|
||||
/* import-globals-from ../../shared/test/shared-head.js */
|
||||
/* import-globals-from ../../shared/test/telemetry-test-helpers.js */
|
||||
|
||||
// shared-head.js handles imports, constants, and utility functions
|
||||
Services.scriptloader.loadSubScript("chrome://mochitests/content/browser/devtools/client/shared/test/shared-head.js", this);
|
||||
|
@ -24,6 +24,7 @@ support-files =
|
||||
!/devtools/client/inspector/test/shared-head.js
|
||||
!/devtools/client/shared/test/frame-script-utils.js
|
||||
!/devtools/client/shared/test/shared-head.js
|
||||
!/devtools/client/shared/test/telemetry-test-helpers.js
|
||||
!/devtools/client/shared/test/test-actor-registry.js
|
||||
!/devtools/client/shared/test/test-actor.js
|
||||
|
||||
|
@ -13,6 +13,7 @@ support-files =
|
||||
!/devtools/client/inspector/test/shared-head.js
|
||||
!/devtools/client/shared/test/frame-script-utils.js
|
||||
!/devtools/client/shared/test/shared-head.js
|
||||
!/devtools/client/shared/test/telemetry-test-helpers.js
|
||||
!/devtools/client/shared/test/test-actor-registry.js
|
||||
!/devtools/client/shared/test/test-actor.js
|
||||
|
||||
|
@ -9,6 +9,7 @@ support-files =
|
||||
!/devtools/client/inspector/test/head.js
|
||||
!/devtools/client/inspector/test/shared-head.js
|
||||
!/devtools/client/shared/test/shared-head.js
|
||||
!/devtools/client/shared/test/telemetry-test-helpers.js
|
||||
!/devtools/client/shared/test/test-actor.js
|
||||
!/devtools/client/shared/test/test-actor-registry.js
|
||||
|
||||
|
@ -14,6 +14,7 @@ support-files =
|
||||
!/devtools/client/inspector/test/head.js
|
||||
!/devtools/client/inspector/test/shared-head.js
|
||||
!/devtools/client/shared/test/shared-head.js
|
||||
!/devtools/client/shared/test/telemetry-test-helpers.js
|
||||
!/devtools/client/shared/test/test-actor.js
|
||||
!/devtools/client/shared/test/test-actor-registry.js
|
||||
|
||||
|
@ -8,7 +8,8 @@ support-files =
|
||||
!/devtools/client/inspector/test/head.js
|
||||
!/devtools/client/inspector/test/shared-head.js
|
||||
!/devtools/client/shared/test/shared-head.js
|
||||
!/devtools/client/shared/test/telemetry-test-helpers.js
|
||||
!/devtools/client/shared/test/test-actor.js
|
||||
!/devtools/client/shared/test/test-actor-registry.js
|
||||
|
||||
[browser_inspector_extension_sidebar.js]
|
||||
[browser_inspector_extension_sidebar.js]
|
||||
|
@ -11,6 +11,7 @@ support-files =
|
||||
!/devtools/client/inspector/test/head.js
|
||||
!/devtools/client/inspector/test/shared-head.js
|
||||
!/devtools/client/shared/test/shared-head.js
|
||||
!/devtools/client/shared/test/telemetry-test-helpers.js
|
||||
!/devtools/client/shared/test/test-actor.js
|
||||
!/devtools/client/shared/test/test-actor-registry.js
|
||||
|
||||
|
@ -9,6 +9,7 @@ support-files =
|
||||
!/devtools/client/inspector/test/shared-head.js
|
||||
!/devtools/client/shared/test/shared-head.js
|
||||
!/devtools/client/shared/test/shared-redux-head.js
|
||||
!/devtools/client/shared/test/telemetry-test-helpers.js
|
||||
!/devtools/client/shared/test/test-actor.js
|
||||
!/devtools/client/shared/test/test-actor-registry.js
|
||||
|
||||
|
@ -22,11 +22,11 @@ const TEST_URI2 = `
|
||||
</div>
|
||||
`;
|
||||
|
||||
const CSS_GRID_COUNT_HISTOGRAM_ID = "DEVTOOLS_NUMBER_OF_CSS_GRIDS_IN_A_PAGE";
|
||||
|
||||
add_task(async function() {
|
||||
await addTab("data:text/html;charset=utf-8," + encodeURIComponent(TEST_URI1));
|
||||
|
||||
startTelemetry();
|
||||
|
||||
let { inspector } = await openLayoutView();
|
||||
let { store } = inspector;
|
||||
|
||||
@ -37,9 +37,13 @@ add_task(async function() {
|
||||
"data:text/html;charset=utf-8," + encodeURIComponent(TEST_URI2));
|
||||
await onGridListUpdate;
|
||||
|
||||
let histogram = Services.telemetry.getHistogramById(CSS_GRID_COUNT_HISTOGRAM_ID);
|
||||
let snapshot = histogram.snapshot();
|
||||
|
||||
is(snapshot.counts[1], 1, "Got a count of 1 for 1 CSS Grid element seen.");
|
||||
is(snapshot.sum, 1, "Got the correct sum.");
|
||||
checkResults();
|
||||
});
|
||||
|
||||
function checkResults() {
|
||||
// Check for:
|
||||
// - 1 CSS Grid Element
|
||||
checkTelemetry("DEVTOOLS_NUMBER_OF_CSS_GRIDS_IN_A_PAGE", "",
|
||||
[0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
|
||||
0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0], "array");
|
||||
}
|
||||
|
@ -3,6 +3,7 @@
|
||||
http://creativecommons.org/publicdomain/zero/1.0/ */
|
||||
/* eslint no-unused-vars: [2, {"vars": "local"}] */
|
||||
/* import-globals-from ../../../shared/test/shared-head.js */
|
||||
/* import-globals-from ../../../shared/test/telemetry-test-helpers.js */
|
||||
/* import-globals-from ../../test/head.js */
|
||||
"use strict";
|
||||
|
||||
|
@ -2147,7 +2147,7 @@ Inspector.prototype = {
|
||||
return;
|
||||
}
|
||||
|
||||
this.telemetry.toolOpened("copyuniquecssselector");
|
||||
this.telemetry.logScalar("devtools.copy.unique.css.selector.opened", 1);
|
||||
this.selection.nodeFront.getUniqueSelector().then(selector => {
|
||||
clipboardHelper.copyString(selector);
|
||||
}).catch(console.error);
|
||||
@ -2161,7 +2161,7 @@ Inspector.prototype = {
|
||||
return;
|
||||
}
|
||||
|
||||
this.telemetry.toolOpened("copyfullcssselector");
|
||||
this.telemetry.logScalar("devtools.copy.full.css.selector.opened", 1);
|
||||
this.selection.nodeFront.getCssPath().then(path => {
|
||||
clipboardHelper.copyString(path);
|
||||
}).catch(console.error);
|
||||
@ -2175,7 +2175,7 @@ Inspector.prototype = {
|
||||
return;
|
||||
}
|
||||
|
||||
this.telemetry.toolOpened("copyxpath");
|
||||
this.telemetry.logScalar("devtools.copy.xpath.opened", 1);
|
||||
this.selection.nodeFront.getXPath().then(path => {
|
||||
clipboardHelper.copyString(path);
|
||||
}).catch(console.error);
|
||||
|
@ -72,6 +72,7 @@ support-files =
|
||||
!/devtools/client/inspector/test/head.js
|
||||
!/devtools/client/inspector/test/shared-head.js
|
||||
!/devtools/client/shared/test/shared-head.js
|
||||
!/devtools/client/shared/test/telemetry-test-helpers.js
|
||||
!/devtools/client/shared/test/test-actor.js
|
||||
!/devtools/client/shared/test/test-actor-registry.js
|
||||
|
||||
|
@ -44,6 +44,7 @@ support-files =
|
||||
!/devtools/client/inspector/test/head.js
|
||||
!/devtools/client/inspector/test/shared-head.js
|
||||
!/devtools/client/shared/test/shared-head.js
|
||||
!/devtools/client/shared/test/telemetry-test-helpers.js
|
||||
!/devtools/client/shared/test/test-actor.js
|
||||
!/devtools/client/shared/test/test-actor-registry.js
|
||||
|
||||
|
@ -17,6 +17,7 @@ support-files =
|
||||
!/devtools/client/inspector/test/head.js
|
||||
!/devtools/client/inspector/test/shared-head.js
|
||||
!/devtools/client/shared/test/shared-head.js
|
||||
!/devtools/client/shared/test/telemetry-test-helpers.js
|
||||
!/devtools/client/shared/test/test-actor.js
|
||||
!/devtools/client/shared/test/test-actor-registry.js
|
||||
|
||||
|
@ -45,6 +45,7 @@ support-files =
|
||||
shared-head.js
|
||||
!/devtools/client/commandline/test/helpers.js
|
||||
!/devtools/client/shared/test/shared-head.js
|
||||
!/devtools/client/shared/test/telemetry-test-helpers.js
|
||||
!/devtools/client/shared/test/test-actor.js
|
||||
!/devtools/client/shared/test/test-actor-registry.js
|
||||
|
||||
@ -146,9 +147,6 @@ skip-if = (os == 'linux' && bits == 32 && debug) # bug 1328915, disable linux32
|
||||
[browser_inspector_menu-01-sensitivity.js]
|
||||
subsuite = clipboard
|
||||
skip-if = (os == 'linux' && bits == 32 && debug) # bug 1328915, disable linux32 debug devtools for timeouts
|
||||
[browser_inspector_menu-02-copy-items.js]
|
||||
subsuite = clipboard
|
||||
skip-if = (os == 'linux' && bits == 32 && debug) # bug 1328915, disable linux32 debug devtools for timeouts
|
||||
[browser_inspector_menu-03-paste-items.js]
|
||||
subsuite = clipboard
|
||||
skip-if = (os == 'linux' && bits == 32 && debug) # bug 1328915, disable linux32 debug devtools for timeouts
|
||||
|
@ -1,98 +0,0 @@
|
||||
/* vim: set ts=2 et sw=2 tw=80: */
|
||||
/* Any copyright is dedicated to the Public Domain.
|
||||
http://creativecommons.org/publicdomain/zero/1.0/ */
|
||||
"use strict";
|
||||
|
||||
// Test that the various copy items in the context menu works correctly.
|
||||
|
||||
const TEST_URL = URL_ROOT + "doc_inspector_menu.html";
|
||||
const SELECTOR_UNIQUE = "devtools.copy.unique.css.selector.opened";
|
||||
const SELECTOR_FULL = "devtools.copy.full.css.selector.opened";
|
||||
const XPATH = "devtools.copy.xpath.opened";
|
||||
|
||||
const COPY_ITEMS_TEST_DATA = [
|
||||
{
|
||||
desc: "copy inner html",
|
||||
id: "node-menu-copyinner",
|
||||
selector: "[data-id=\"copy\"]",
|
||||
text: "Paragraph for testing copy",
|
||||
},
|
||||
{
|
||||
desc: "copy outer html",
|
||||
id: "node-menu-copyouter",
|
||||
selector: "[data-id=\"copy\"]",
|
||||
text: "<p data-id=\"copy\">Paragraph for testing copy</p>",
|
||||
},
|
||||
{
|
||||
desc: "copy unique selector",
|
||||
id: "node-menu-copyuniqueselector",
|
||||
selector: "[data-id=\"copy\"]",
|
||||
text: "body > div:nth-child(1) > p:nth-child(2)",
|
||||
},
|
||||
{
|
||||
desc: "copy CSS path",
|
||||
id: "node-menu-copycsspath",
|
||||
selector: "[data-id=\"copy\"]",
|
||||
text: "html body div p",
|
||||
},
|
||||
{
|
||||
desc: "copy XPath",
|
||||
id: "node-menu-copyxpath",
|
||||
selector: "[data-id=\"copy\"]",
|
||||
text: "/html/body/div/p[1]",
|
||||
},
|
||||
{
|
||||
desc: "copy image data uri",
|
||||
id: "node-menu-copyimagedatauri",
|
||||
selector: "#copyimage",
|
||||
text: "" +
|
||||
"AAAAAA6fptVAAAACklEQVQYV2P4DwABAQEAWk1v8QAAAABJRU5ErkJggg==",
|
||||
},
|
||||
];
|
||||
|
||||
add_task(async function() {
|
||||
let Telemetry = loadTelemetryAndRecordLogs();
|
||||
let { inspector } = await openInspectorForURL(TEST_URL);
|
||||
|
||||
for (let {desc, id, selector, text} of COPY_ITEMS_TEST_DATA) {
|
||||
info("Testing " + desc);
|
||||
await selectNode(selector, inspector);
|
||||
|
||||
let allMenuItems = openContextMenuAndGetAllItems(inspector);
|
||||
let item = allMenuItems.find(i => i.id === id);
|
||||
ok(item, "The popup has a " + desc + " menu item.");
|
||||
|
||||
await waitForClipboardPromise(() => item.click(), text);
|
||||
}
|
||||
|
||||
checkTelemetryResults(Telemetry);
|
||||
stopRecordingTelemetryLogs(Telemetry);
|
||||
});
|
||||
|
||||
function checkTelemetryResults(Telemetry) {
|
||||
let data = Telemetry.prototype.telemetryInfo;
|
||||
let results = new Map();
|
||||
|
||||
for (let key in data) {
|
||||
if (key.toLowerCase() === key) {
|
||||
let pings = data[key].length;
|
||||
|
||||
results.set(key, pings);
|
||||
}
|
||||
}
|
||||
|
||||
is(results.size, 3, "The correct number of scalars were logged");
|
||||
|
||||
let pings = checkPings(SELECTOR_UNIQUE, results);
|
||||
is(pings, 1, `${SELECTOR_UNIQUE} has just 1 ping`);
|
||||
|
||||
pings = checkPings(SELECTOR_FULL, results);
|
||||
is(pings, 1, `${SELECTOR_FULL} has just 1 ping`);
|
||||
|
||||
pings = checkPings(XPATH, results);
|
||||
is(pings, 1, `${XPATH} has just 1 ping`);
|
||||
}
|
||||
|
||||
function checkPings(scalarId, results) {
|
||||
return results.get(scalarId);
|
||||
}
|
@ -22,6 +22,7 @@ support-files =
|
||||
!/devtools/client/framework/test/head.js
|
||||
!/devtools/client/shared/test/frame-script-utils.js
|
||||
!/devtools/client/shared/test/shared-head.js
|
||||
!/devtools/client/shared/test/telemetry-test-helpers.js
|
||||
|
||||
[browser_json_refresh.js]
|
||||
[browser_jsonview_bug_1380828.js]
|
||||
|
@ -8,6 +8,7 @@ support-files =
|
||||
doc_steady_allocation.html
|
||||
!/devtools/client/shared/test/shared-head.js
|
||||
!/devtools/client/shared/test/shared-redux-head.js
|
||||
!/devtools/client/shared/test/telemetry-test-helpers.js
|
||||
|
||||
[browser_memory_allocationStackDisplay_01.js]
|
||||
skip-if = debug # bug 1219554
|
||||
|
@ -12,8 +12,8 @@
|
||||
"codemirror": "^5.24.2",
|
||||
"devtools-config": "=0.0.12",
|
||||
"devtools-contextmenu": "=0.0.3",
|
||||
"devtools-launchpad": "^0.0.117",
|
||||
"devtools-modules": "=0.0.32",
|
||||
"devtools-launchpad": "^0.0.119",
|
||||
"devtools-modules": "=0.0.35",
|
||||
"devtools-source-editor": "=0.0.3",
|
||||
"file-loader": "^1.1.6",
|
||||
"jszip": "^3.1.3",
|
||||
|
@ -11,6 +11,7 @@ support-files =
|
||||
!/devtools/client/netmonitor/test/head.js
|
||||
!/devtools/client/netmonitor/test/html_simple-test-page.html
|
||||
!/devtools/client/shared/test/shared-head.js
|
||||
!/devtools/client/shared/test/telemetry-test-helpers.js
|
||||
|
||||
[browser_net_har_copy_all_as_har.js]
|
||||
[browser_net_har_import.js]
|
||||
|
@ -60,6 +60,7 @@ support-files =
|
||||
xhr_original.js
|
||||
!/devtools/client/shared/test/frame-script-utils.js
|
||||
!/devtools/client/shared/test/shared-head.js
|
||||
!/devtools/client/shared/test/telemetry-test-helpers.js
|
||||
|
||||
[browser_net_accessibility-01.js]
|
||||
[browser_net_accessibility-02.js]
|
||||
|
@ -12,9 +12,6 @@ add_task(async function() {
|
||||
|
||||
let { document, store, windowRequire } = monitor.panelWin;
|
||||
let Actions = windowRequire("devtools/client/netmonitor/src/actions/index");
|
||||
let {
|
||||
getSortedRequests,
|
||||
} = windowRequire("devtools/client/netmonitor/src/selectors/index");
|
||||
|
||||
store.dispatch(Actions.batchEnable(false));
|
||||
|
||||
@ -27,10 +24,7 @@ add_task(async function() {
|
||||
document.querySelectorAll(".request-list-item")[0]);
|
||||
await wait;
|
||||
|
||||
await waitUntil(() => {
|
||||
let request = getSortedRequests(store.getState()).get(0);
|
||||
return request.requestHeaders && request.responseHeaders;
|
||||
});
|
||||
await waitForRequestData(store, ["requestHeaders", "responseHeaders"]);
|
||||
|
||||
document.querySelectorAll(".devtools-filterinput")[1].focus();
|
||||
EventUtils.synthesizeKey("con", {});
|
||||
|
@ -32,10 +32,7 @@ add_task(async function() {
|
||||
});
|
||||
|
||||
async function verifyHeaders(monitor) {
|
||||
let { document, store, windowRequire } = monitor.panelWin;
|
||||
let {
|
||||
getSortedRequests,
|
||||
} = windowRequire("devtools/client/netmonitor/src/selectors/index");
|
||||
let { document, store } = monitor.panelWin;
|
||||
|
||||
info("Check if Request-Headers and Response-Headers are sorted");
|
||||
|
||||
@ -44,10 +41,7 @@ async function verifyHeaders(monitor) {
|
||||
document.querySelectorAll(".request-list-item")[0]);
|
||||
await wait;
|
||||
|
||||
await waitUntil(() => {
|
||||
let request = getSortedRequests(store.getState()).get(0);
|
||||
return request.requestHeaders && request.responseHeaders;
|
||||
});
|
||||
await waitForRequestData(store, ["requestHeaders", "responseHeaders"]);
|
||||
|
||||
let expectedResponseHeaders = ["cache-control", "connection", "content-length",
|
||||
"content-type", "date", "expires", "foo-bar",
|
||||
|
@ -28,18 +28,17 @@ add_task(async function() {
|
||||
// Execute requests.
|
||||
await performRequests(monitor, tab, 2);
|
||||
|
||||
let origItem = getSortedRequests(store.getState()).get(0);
|
||||
let origItemId = getSortedRequests(store.getState()).get(0).id;
|
||||
|
||||
store.dispatch(Actions.selectRequest(origItem.id));
|
||||
store.dispatch(Actions.selectRequest(origItemId));
|
||||
await waitForRequestData(store, ["requestHeaders", "requestPostData"], origItemId);
|
||||
|
||||
let origItem = getSortedRequests(store.getState()).get(0);
|
||||
|
||||
// add a new custom request cloned from selected request
|
||||
|
||||
store.dispatch(Actions.cloneSelectedRequest());
|
||||
// FIXME: This used to be a generator function that nothing awaited on
|
||||
// and therefore didn't run. It has been broken for some time.
|
||||
if (false) {
|
||||
testCustomForm(origItem);
|
||||
}
|
||||
await testCustomForm(origItem);
|
||||
|
||||
let customItem = getSelectedRequest(store.getState());
|
||||
testCustomItem(customItem, origItem);
|
||||
|
@ -48,11 +48,9 @@ add_task(async function() {
|
||||
}
|
||||
|
||||
// Wait until requestHeaders packet gets updated.
|
||||
await waitUntil(() => {
|
||||
item = getSortedRequests(store.getState()).get(0);
|
||||
return item.requestHeaders;
|
||||
});
|
||||
await waitForRequestData(store, ["requestHeaders"]);
|
||||
|
||||
item = getSortedRequests(store.getState()).get(0);
|
||||
is(item.method, "POST", "The request has the right method");
|
||||
is(item.url, requestUrl, "The request has the right URL");
|
||||
|
||||
|
@ -104,10 +104,7 @@ function test() {
|
||||
});
|
||||
|
||||
expectEvent(EVENTS.RECEIVED_REQUEST_HEADERS, async () => {
|
||||
await waitUntil(() => {
|
||||
let requestItem = getSortedRequests(store.getState()).get(0);
|
||||
return requestItem && requestItem.requestHeaders;
|
||||
});
|
||||
await waitForRequestData(store, ["requestHeaders"]);
|
||||
|
||||
let requestItem = getSortedRequests(store.getState()).get(0);
|
||||
|
||||
@ -130,10 +127,7 @@ function test() {
|
||||
});
|
||||
|
||||
expectEvent(EVENTS.RECEIVED_REQUEST_COOKIES, async () => {
|
||||
await waitUntil(() => {
|
||||
let requestItem = getSortedRequests(store.getState()).get(0);
|
||||
return requestItem && requestItem.requestCookies;
|
||||
});
|
||||
await waitForRequestData(store, ["requestCookies"]);
|
||||
|
||||
let requestItem = getSortedRequests(store.getState()).get(0);
|
||||
|
||||
@ -156,10 +150,7 @@ function test() {
|
||||
});
|
||||
|
||||
expectEvent(EVENTS.RECEIVED_RESPONSE_HEADERS, async () => {
|
||||
await waitUntil(() => {
|
||||
let requestItem = getSortedRequests(store.getState()).get(0);
|
||||
return requestItem && requestItem.responseHeaders;
|
||||
});
|
||||
await waitForRequestData(store, ["responseHeaders"]);
|
||||
|
||||
let requestItem = getSortedRequests(store.getState()).get(0);
|
||||
|
||||
@ -180,10 +171,7 @@ function test() {
|
||||
});
|
||||
|
||||
expectEvent(EVENTS.RECEIVED_RESPONSE_COOKIES, async () => {
|
||||
await waitUntil(() => {
|
||||
let requestItem = getSortedRequests(store.getState()).get(0);
|
||||
return requestItem && requestItem.responseCookies;
|
||||
});
|
||||
await waitForRequestData(store, ["responseCookies"]);
|
||||
|
||||
let requestItem = getSortedRequests(store.getState()).get(0);
|
||||
|
||||
@ -202,14 +190,12 @@ function test() {
|
||||
});
|
||||
|
||||
expectEvent(EVENTS.STARTED_RECEIVING_RESPONSE, async () => {
|
||||
await waitUntil(() => {
|
||||
let requestItem = getSortedRequests(store.getState()).get(0);
|
||||
return requestItem &&
|
||||
requestItem.httpVersion &&
|
||||
requestItem.status &&
|
||||
requestItem.statusText &&
|
||||
requestItem.headersSize;
|
||||
});
|
||||
await waitForRequestData(store, [
|
||||
"httpVersion",
|
||||
"status",
|
||||
"statusText",
|
||||
"headersSize"
|
||||
]);
|
||||
|
||||
let requestItem = getSortedRequests(store.getState()).get(0);
|
||||
|
||||
@ -242,13 +228,11 @@ function test() {
|
||||
});
|
||||
|
||||
expectEvent(EVENTS.PAYLOAD_READY, async () => {
|
||||
await waitUntil(() => {
|
||||
let requestItem = getSortedRequests(store.getState()).get(0);
|
||||
return requestItem &&
|
||||
requestItem.transferredSize &&
|
||||
requestItem.contentSize &&
|
||||
requestItem.mimeType;
|
||||
});
|
||||
await waitForRequestData(store, [
|
||||
"transferredSize",
|
||||
"contentSize",
|
||||
"mimeType"
|
||||
]);
|
||||
|
||||
let requestItem = getSortedRequests(store.getState()).get(0);
|
||||
|
||||
@ -275,10 +259,7 @@ function test() {
|
||||
});
|
||||
|
||||
expectEvent(EVENTS.UPDATING_EVENT_TIMINGS, async () => {
|
||||
await waitUntil(() => {
|
||||
let requestItem = getSortedRequests(store.getState()).get(0);
|
||||
return requestItem && requestItem.eventTimings;
|
||||
});
|
||||
await waitForRequestData(store, ["eventTimings"]);
|
||||
|
||||
let requestItem = getSortedRequests(store.getState()).get(0);
|
||||
|
||||
@ -300,10 +281,7 @@ function test() {
|
||||
});
|
||||
|
||||
expectEvent(EVENTS.RECEIVED_EVENT_TIMINGS, async () => {
|
||||
await waitUntil(() => {
|
||||
let requestItem = getSortedRequests(store.getState()).get(0);
|
||||
return requestItem && requestItem.eventTimings;
|
||||
});
|
||||
await waitForRequestData(store, ["eventTimings"]);
|
||||
|
||||
let requestItem = getSortedRequests(store.getState()).get(0);
|
||||
|
||||
|
@ -49,10 +49,7 @@ async function throttleTest(actuallyThrottle) {
|
||||
await triggerActivity(ACTIVITY_TYPE.RELOAD.WITH_CACHE_DISABLED);
|
||||
await wait;
|
||||
|
||||
await waitUntil(() => {
|
||||
let requestItem = getSortedRequests(store.getState()).get(0);
|
||||
return requestItem && requestItem.eventTimings;
|
||||
});
|
||||
await waitForRequestData(store, ["eventTimings"]);
|
||||
|
||||
let requestItem = getSortedRequests(store.getState()).get(0);
|
||||
const reportedOneSecond = requestItem.eventTimings.timings.receive > 1000;
|
||||
|
@ -5,7 +5,7 @@
|
||||
/* exported Toolbox, restartNetMonitor, teardown, waitForExplicitFinish,
|
||||
verifyRequestItemTarget, waitFor, testFilterButtons,
|
||||
performRequestsInContent, waitForNetworkEvents, selectIndexAndWaitForSourceEditor,
|
||||
testColumnsAlignment, hideColumn, showColumn, performRequests */
|
||||
testColumnsAlignment, hideColumn, showColumn, performRequests, waitForRequestData */
|
||||
|
||||
"use strict";
|
||||
|
||||
@ -18,6 +18,12 @@ const {
|
||||
getFormattedIPAndPort,
|
||||
getFormattedTime,
|
||||
} = require("devtools/client/netmonitor/src/utils/format-utils");
|
||||
|
||||
const {
|
||||
getSortedRequests,
|
||||
getRequestById
|
||||
} = require("devtools/client/netmonitor/src/selectors/index");
|
||||
|
||||
const {
|
||||
getUnicodeUrl,
|
||||
getUnicodeHostname,
|
||||
@ -764,3 +770,30 @@ async function performRequests(monitor, tab, count) {
|
||||
});
|
||||
await wait;
|
||||
}
|
||||
|
||||
/**
|
||||
* Wait for lazy fields to be loaded in a request.
|
||||
*
|
||||
* @param Object Store redux store containing request list.
|
||||
* @param array fields array of strings which contain field names to be checked
|
||||
* on the request.
|
||||
*/
|
||||
function waitForRequestData(store, fields, id) {
|
||||
return waitUntil(() => {
|
||||
let item;
|
||||
if (id) {
|
||||
item = getRequestById(store.getState(), id);
|
||||
} else {
|
||||
item = getSortedRequests(store.getState()).get(0);
|
||||
}
|
||||
if (!item) {
|
||||
return false;
|
||||
}
|
||||
for (const field of fields) {
|
||||
if (!item[field]) {
|
||||
return false;
|
||||
}
|
||||
}
|
||||
return true;
|
||||
});
|
||||
}
|
||||
|
@ -88,7 +88,7 @@ let webpackConfig = {
|
||||
"devtools/shared/fronts/timeline": path.join(__dirname, "../../client/shared/webpack/shims/fronts-timeline-shim"),
|
||||
"devtools/shared/platform/clipboard": path.join(__dirname, "../../client/shared/webpack/shims/platform-clipboard-stub"),
|
||||
"devtools/client/netmonitor/src/utils/firefox/open-request-in-tab": path.join(__dirname, "src/utils/open-request-in-tab"),
|
||||
"devtools/client/shared/unicode-url": path.join(__dirname, "../../client/shared/webpack/shims/unicode-url-stub"),
|
||||
"devtools/client/shared/unicode-url": "./node_modules/devtools-modules/src/unicode-url",
|
||||
|
||||
// Locales need to be explicitly mapped to the en-US subfolder
|
||||
"devtools/client/locales": path.join(__dirname, "../../client/locales/en-US"),
|
||||
|
@ -11,6 +11,7 @@ support-files =
|
||||
js_simpleWorker.js
|
||||
head.js
|
||||
!/devtools/client/shared/test/frame-script-utils.js
|
||||
!/devtools/client/shared/test/telemetry-test-helpers.js
|
||||
|
||||
[browser_aaa-run-first-leaktest.js]
|
||||
[browser_perf-button-states.js]
|
||||
|
@ -1,5 +1,6 @@
|
||||
/* Any copyright is dedicated to the Public Domain.
|
||||
http://creativecommons.org/publicdomain/zero/1.0/ */
|
||||
|
||||
"use strict";
|
||||
|
||||
/**
|
||||
@ -13,20 +14,13 @@ const { initPerformanceInNewTab, teardownToolboxAndRemoveTab } = require("devtoo
|
||||
const { startRecording, stopRecording } = require("devtools/client/performance/test/helpers/actions");
|
||||
|
||||
add_task(async function() {
|
||||
startTelemetry();
|
||||
|
||||
let { panel } = await initPerformanceInNewTab({
|
||||
url: SIMPLE_URL,
|
||||
win: window
|
||||
});
|
||||
|
||||
let { PerformanceController } = panel.panelWin;
|
||||
|
||||
let telemetry = PerformanceController._telemetry;
|
||||
let logs = telemetry.getLogs();
|
||||
let DURATION = "DEVTOOLS_PERFTOOLS_RECORDING_DURATION_MS";
|
||||
let COUNT = "DEVTOOLS_PERFTOOLS_RECORDING_COUNT";
|
||||
let CONSOLE_COUNT = "DEVTOOLS_PERFTOOLS_CONSOLE_RECORDING_COUNT";
|
||||
let FEATURES = "DEVTOOLS_PERFTOOLS_RECORDING_FEATURES_USED";
|
||||
|
||||
Services.prefs.setBoolPref(UI_ENABLE_MEMORY_PREF, false);
|
||||
|
||||
await startRecording(panel);
|
||||
@ -37,17 +31,22 @@ add_task(async function() {
|
||||
await startRecording(panel);
|
||||
await stopRecording(panel);
|
||||
|
||||
is(logs[DURATION].length, 2, `There are two entries for ${DURATION}.`);
|
||||
ok(logs[DURATION].every(d => typeof d === "number"),
|
||||
`Every ${DURATION} entry is a number.`);
|
||||
is(logs[COUNT].length, 2, `There are two entries for ${COUNT}.`);
|
||||
is(logs[CONSOLE_COUNT], void 0, `There are no entries for ${CONSOLE_COUNT}.`);
|
||||
is(logs[FEATURES].length, 8,
|
||||
`There are two recordings worth of entries for ${FEATURES}.`);
|
||||
ok(logs[FEATURES].find(r => r[0] === "withMemory" && r[1] === true),
|
||||
"One feature entry for memory enabled.");
|
||||
ok(logs[FEATURES].find(r => r[0] === "withMemory" && r[1] === false),
|
||||
"One feature entry for memory disabled.");
|
||||
checkResults();
|
||||
|
||||
await teardownToolboxAndRemoveTab(panel);
|
||||
});
|
||||
|
||||
function checkResults() {
|
||||
// For help generating these tests use generateTelemetryTests("DEVTOOLS_PERFTOOLS_")
|
||||
// here.
|
||||
checkTelemetry("DEVTOOLS_PERFTOOLS_RECORDING_COUNT", "", [2, 0, 0], "array");
|
||||
checkTelemetry("DEVTOOLS_PERFTOOLS_RECORDING_DURATION_MS", "", null, "hasentries");
|
||||
checkTelemetry(
|
||||
"DEVTOOLS_PERFTOOLS_RECORDING_FEATURES_USED", "withMarkers", [0, 2, 0], "array");
|
||||
checkTelemetry(
|
||||
"DEVTOOLS_PERFTOOLS_RECORDING_FEATURES_USED", "withMemory", [1, 1, 0], "array");
|
||||
checkTelemetry(
|
||||
"DEVTOOLS_PERFTOOLS_RECORDING_FEATURES_USED", "withAllocations", [2, 0, 0], "array");
|
||||
checkTelemetry(
|
||||
"DEVTOOLS_PERFTOOLS_RECORDING_FEATURES_USED", "withTicks", [0, 2, 0], "array");
|
||||
}
|
||||
|
@ -13,6 +13,8 @@ const { startRecording, stopRecording } = require("devtools/client/performance/t
|
||||
const { once } = require("devtools/client/performance/test/helpers/event-utils");
|
||||
|
||||
add_task(async function() {
|
||||
startTelemetry();
|
||||
|
||||
let { panel } = await initPerformanceInNewTab({
|
||||
url: SIMPLE_URL,
|
||||
win: window
|
||||
@ -20,11 +22,6 @@ add_task(async function() {
|
||||
|
||||
let { EVENTS, PerformanceController } = panel.panelWin;
|
||||
|
||||
let telemetry = PerformanceController._telemetry;
|
||||
let logs = telemetry.getLogs();
|
||||
let EXPORTED = "DEVTOOLS_PERFTOOLS_RECORDING_EXPORT_FLAG";
|
||||
let IMPORTED = "DEVTOOLS_PERFTOOLS_RECORDING_IMPORT_FLAG";
|
||||
|
||||
await startRecording(panel);
|
||||
await stopRecording(panel);
|
||||
|
||||
@ -36,13 +33,17 @@ add_task(async function() {
|
||||
file);
|
||||
await exported;
|
||||
|
||||
ok(logs[EXPORTED], `A telemetry entry for ${EXPORTED} exists after exporting.`);
|
||||
|
||||
let imported = once(PerformanceController, EVENTS.RECORDING_IMPORTED);
|
||||
await PerformanceController.importRecording(file);
|
||||
await imported;
|
||||
|
||||
ok(logs[IMPORTED], `A telemetry entry for ${IMPORTED} exists after importing.`);
|
||||
|
||||
checkResults();
|
||||
await teardownToolboxAndRemoveTab(panel);
|
||||
});
|
||||
|
||||
function checkResults() {
|
||||
// For help generating these tests use generateTelemetryTests("DEVTOOLS_PERFTOOLS_")
|
||||
// here.
|
||||
checkTelemetry("DEVTOOLS_PERFTOOLS_RECORDING_IMPORT_FLAG", "", [0, 1, 0], "array");
|
||||
checkTelemetry("DEVTOOLS_PERFTOOLS_RECORDING_EXPORT_FLAG", "", [0, 1, 0], "array");
|
||||
}
|
||||
|
@ -13,6 +13,8 @@ const { startRecording, stopRecording } = require("devtools/client/performance/t
|
||||
const { once } = require("devtools/client/performance/test/helpers/event-utils");
|
||||
|
||||
add_task(async function() {
|
||||
startTelemetry();
|
||||
|
||||
let { panel } = await initPerformanceInNewTab({
|
||||
url: SIMPLE_URL,
|
||||
win: window
|
||||
@ -20,16 +22,11 @@ add_task(async function() {
|
||||
|
||||
let {
|
||||
EVENTS,
|
||||
PerformanceController,
|
||||
DetailsView,
|
||||
JsCallTreeView,
|
||||
JsFlameGraphView
|
||||
} = panel.panelWin;
|
||||
|
||||
let telemetry = PerformanceController._telemetry;
|
||||
let logs = telemetry.getLogs();
|
||||
let VIEWS = "DEVTOOLS_PERFTOOLS_SELECTED_VIEW_MS";
|
||||
|
||||
await startRecording(panel);
|
||||
await stopRecording(panel);
|
||||
|
||||
@ -45,12 +42,16 @@ add_task(async function() {
|
||||
|
||||
await teardownToolboxAndRemoveTab(panel);
|
||||
|
||||
// Check views after destruction to ensure `js-flamegraph` gets called
|
||||
// with a time during destruction.
|
||||
ok(logs[VIEWS].find(r => r[0] === "waterfall" && typeof r[1] === "number"),
|
||||
`${VIEWS} for waterfall view and time.`);
|
||||
ok(logs[VIEWS].find(r => r[0] === "js-calltree" && typeof r[1] === "number"),
|
||||
`${VIEWS} for js-calltree view and time.`);
|
||||
ok(logs[VIEWS].find(r => r[0] === "js-flamegraph" && typeof r[1] === "number"),
|
||||
`${VIEWS} for js-flamegraph view and time.`);
|
||||
checkResults();
|
||||
});
|
||||
|
||||
function checkResults() {
|
||||
// For help generating these tests use generateTelemetryTests("DEVTOOLS_PERFTOOLS_")
|
||||
// here.
|
||||
checkTelemetry(
|
||||
"DEVTOOLS_PERFTOOLS_SELECTED_VIEW_MS", "js-calltree", null, "hasentries");
|
||||
checkTelemetry(
|
||||
"DEVTOOLS_PERFTOOLS_SELECTED_VIEW_MS", "js-flamegraph", null, "hasentries");
|
||||
checkTelemetry(
|
||||
"DEVTOOLS_PERFTOOLS_SELECTED_VIEW_MS", "waterfall", null, "hasentries");
|
||||
}
|
||||
|
@ -11,19 +11,14 @@ const { initPerformanceInTab, initConsoleInNewTab, teardownToolboxAndRemoveTab }
|
||||
const { waitForRecordingStartedEvents, waitForRecordingStoppedEvents } = require("devtools/client/performance/test/helpers/actions");
|
||||
|
||||
add_task(async function() {
|
||||
startTelemetry();
|
||||
|
||||
let { target, console } = await initConsoleInNewTab({
|
||||
url: SIMPLE_URL,
|
||||
win: window
|
||||
});
|
||||
|
||||
let { panel } = await initPerformanceInTab({ tab: target.tab });
|
||||
let { PerformanceController } = panel.panelWin;
|
||||
|
||||
let telemetry = PerformanceController._telemetry;
|
||||
let logs = telemetry.getLogs();
|
||||
let DURATION = "DEVTOOLS_PERFTOOLS_RECORDING_DURATION_MS";
|
||||
let CONSOLE_COUNT = "DEVTOOLS_PERFTOOLS_CONSOLE_RECORDING_COUNT";
|
||||
let FEATURES = "DEVTOOLS_PERFTOOLS_RECORDING_FEATURES_USED";
|
||||
|
||||
let started = waitForRecordingStartedEvents(panel, {
|
||||
// only emitted for manual recordings
|
||||
@ -39,12 +34,21 @@ add_task(async function() {
|
||||
await console.profileEnd("rust");
|
||||
await stopped;
|
||||
|
||||
is(logs[DURATION].length, 1, `There is one entry for ${DURATION}.`);
|
||||
ok(logs[DURATION].every(d => typeof d === "number"),
|
||||
`Every ${DURATION} entry is a number.`);
|
||||
is(logs[CONSOLE_COUNT].length, 1, `There is one entry for ${CONSOLE_COUNT}.`);
|
||||
is(logs[FEATURES].length, 4,
|
||||
`There is one recording worth of entries for ${FEATURES}.`);
|
||||
|
||||
checkResults();
|
||||
await teardownToolboxAndRemoveTab(panel);
|
||||
});
|
||||
|
||||
function checkResults() {
|
||||
// For help generating these tests use generateTelemetryTests("DEVTOOLS_PERFTOOLS_")
|
||||
// here.
|
||||
checkTelemetry("DEVTOOLS_PERFTOOLS_CONSOLE_RECORDING_COUNT", "", [1, 0, 0], "array");
|
||||
checkTelemetry("DEVTOOLS_PERFTOOLS_RECORDING_DURATION_MS", "", null, "hasentries");
|
||||
checkTelemetry(
|
||||
"DEVTOOLS_PERFTOOLS_RECORDING_FEATURES_USED", "withMarkers", [0, 1, 0], "array");
|
||||
checkTelemetry(
|
||||
"DEVTOOLS_PERFTOOLS_RECORDING_FEATURES_USED", "withMemory", [1, 0, 0], "array");
|
||||
checkTelemetry(
|
||||
"DEVTOOLS_PERFTOOLS_RECORDING_FEATURES_USED", "withAllocations", [1, 0, 0], "array");
|
||||
checkTelemetry(
|
||||
"DEVTOOLS_PERFTOOLS_RECORDING_FEATURES_USED", "withTicks", [0, 1, 0], "array");
|
||||
}
|
||||
|
@ -1,9 +1,15 @@
|
||||
/* Any copyright is dedicated to the Public Domain.
|
||||
http://creativecommons.org/publicdomain/zero/1.0/ */
|
||||
|
||||
/* import-globals-from ../../shared/test/telemetry-test-helpers.js */
|
||||
|
||||
"use strict";
|
||||
|
||||
const { require, loader } = ChromeUtils.import("resource://devtools/shared/Loader.jsm", {});
|
||||
|
||||
Services.scriptloader.loadSubScript(
|
||||
"chrome://mochitests/content/browser/devtools/client/shared/test/telemetry-test-helpers.js", this);
|
||||
|
||||
/* exported loader, either, click, dblclick, mousedown, rightMousedown, key */
|
||||
// All tests are asynchronous.
|
||||
waitForExplicitFinish();
|
||||
|
@ -14,6 +14,7 @@ support-files =
|
||||
!/devtools/client/inspector/test/shared-head.js
|
||||
!/devtools/client/shared/test/shared-head.js
|
||||
!/devtools/client/shared/test/shared-redux-head.js
|
||||
!/devtools/client/shared/test/telemetry-test-helpers.js
|
||||
!/devtools/client/shared/test/test-actor.js
|
||||
!/devtools/client/shared/test/test-actor-registry.js
|
||||
|
||||
|
@ -2,8 +2,7 @@
|
||||
* http://creativecommons.org/publicdomain/zero/1.0/ */
|
||||
|
||||
"use strict";
|
||||
const URL =
|
||||
"data:text/html;charset=utf8,browser_telemetry_activate_rdm.js";
|
||||
const URL = "data:text/html;charset=utf8,browser_telemetry_activate_rdm.js";
|
||||
const OPTOUT = Ci.nsITelemetry.DATASET_RELEASE_CHANNEL_OPTOUT;
|
||||
const DATA = [
|
||||
{
|
||||
|
@ -10,6 +10,7 @@ support-files =
|
||||
head.js
|
||||
!/devtools/client/shared/test/frame-script-utils.js
|
||||
!/devtools/client/shared/test/shared-head.js
|
||||
!/devtools/client/shared/test/telemetry-test-helpers.js
|
||||
|
||||
[browser_se_aaa_run_first_leaktest.js]
|
||||
[browser_se_bfcache.js]
|
||||
|
@ -3,5 +3,6 @@ tags = devtools
|
||||
subsuite = devtools
|
||||
support-files =
|
||||
!/devtools/client/shared/test/shared-head.js
|
||||
!/devtools/client/shared/test/telemetry-test-helpers.js
|
||||
|
||||
[browser_notification_box_basic.js]
|
||||
|
@ -150,15 +150,6 @@ class Telemetry {
|
||||
toolbareyedropper: {
|
||||
scalar: "devtools.toolbar.eyedropper.opened",
|
||||
},
|
||||
copyuniquecssselector: {
|
||||
scalar: "devtools.copy.unique.css.selector.opened",
|
||||
},
|
||||
copyfullcssselector: {
|
||||
scalar: "devtools.copy.full.css.selector.opened",
|
||||
},
|
||||
copyxpath: {
|
||||
scalar: "devtools.copy.xpath.opened",
|
||||
},
|
||||
developertoolbar: {
|
||||
histogram: "DEVTOOLS_DEVELOPERTOOLBAR_OPENED_COUNT",
|
||||
timerHistogram: "DEVTOOLS_DEVELOPERTOOLBAR_TIME_ACTIVE_SECONDS"
|
||||
|
@ -35,6 +35,7 @@ support-files =
|
||||
leakhunt.js
|
||||
shared-head.js
|
||||
shared-redux-head.js
|
||||
telemetry-test-helpers.js
|
||||
test-actor-registry.js
|
||||
test-actor.js
|
||||
!/devtools/client/responsive.html/test/browser/devices.json
|
||||
@ -174,10 +175,10 @@ skip-if = e10s # Test intermittently fails with e10s. Bug 1124162.
|
||||
[browser_tableWidget_mouse_interaction.js]
|
||||
[browser_telemetry_button_eyedropper.js]
|
||||
[browser_telemetry_button_paintflashing.js]
|
||||
skip-if = e10s # Bug 937167 - e10s paintflashing
|
||||
[browser_telemetry_button_responsive.js]
|
||||
skip-if = !e10s || os == "win" # RDM only works for remote tabs, Win: bug 1404197
|
||||
[browser_telemetry_button_scratchpad.js]
|
||||
[browser_telemetry_misc.js]
|
||||
[browser_telemetry_sidebar.js]
|
||||
[browser_telemetry_toolbox.js]
|
||||
[browser_telemetry_toolboxtabs_canvasdebugger.js]
|
||||
|
@ -1,23 +1,21 @@
|
||||
/* Any copyright is dedicated to the Public Domain.
|
||||
http://creativecommons.org/publicdomain/zero/1.0/ */
|
||||
|
||||
"use strict";
|
||||
|
||||
const TEST_URI = "data:text/html;charset=utf-8," +
|
||||
"<p>browser_telemetry_button_eyedropper.js</p><div>test</div>";
|
||||
const EYEDROPPER_OPENED = "devtools.toolbar.eyedropper.opened";
|
||||
|
||||
add_task(async function() {
|
||||
await addTab(TEST_URI);
|
||||
let Telemetry = loadTelemetryAndRecordLogs();
|
||||
startTelemetry();
|
||||
|
||||
let target = TargetFactory.forTab(gBrowser.selectedTab);
|
||||
let toolbox = await gDevTools.showToolbox(target, "inspector");
|
||||
info("inspector opened");
|
||||
|
||||
info("testing the eyedropper button");
|
||||
await testButton(toolbox, Telemetry);
|
||||
await testButton(toolbox);
|
||||
|
||||
stopRecordingTelemetryLogs(Telemetry);
|
||||
await gDevTools.closeToolbox(target);
|
||||
gBrowser.removeCurrentTab();
|
||||
});
|
||||
@ -28,27 +26,11 @@ async function testButton(toolbox, Telemetry) {
|
||||
// only concerned about testing the telemetry probe.
|
||||
await toolbox.getPanel("inspector").showEyeDropper();
|
||||
|
||||
checkTelemetryResults(Telemetry);
|
||||
checkResults();
|
||||
}
|
||||
|
||||
function checkTelemetryResults(Telemetry) {
|
||||
let data = Telemetry.prototype.telemetryInfo;
|
||||
let results = new Map();
|
||||
|
||||
for (let key in data) {
|
||||
if (key.toLowerCase() === key) {
|
||||
let pings = data[key].length;
|
||||
|
||||
results.set(key, pings);
|
||||
}
|
||||
}
|
||||
|
||||
is(results.size, 1, "The correct number of scalars were logged");
|
||||
|
||||
let pings = checkPings(EYEDROPPER_OPENED, results);
|
||||
is(pings, 1, `${EYEDROPPER_OPENED} has just 1 ping`);
|
||||
}
|
||||
|
||||
function checkPings(scalarId, results) {
|
||||
return results.get(scalarId);
|
||||
function checkResults() {
|
||||
// For help generating these tests use generateTelemetryTests("devtools.")
|
||||
// here.
|
||||
checkTelemetry("devtools.toolbar.eyedropper.opened", "", 1, "scalar");
|
||||
}
|
||||
|
@ -13,7 +13,8 @@ const TOOL_DELAY = 200;
|
||||
|
||||
add_task(async function() {
|
||||
await addTab(TEST_URI);
|
||||
let Telemetry = loadTelemetryAndRecordLogs();
|
||||
startTelemetry();
|
||||
|
||||
await pushPref("devtools.command-button-paintflashing.enabled", true);
|
||||
|
||||
let target = TargetFactory.forTab(gBrowser.selectedTab);
|
||||
@ -21,21 +22,20 @@ add_task(async function() {
|
||||
info("inspector opened");
|
||||
|
||||
info("testing the paintflashing button");
|
||||
await testButton(toolbox, Telemetry);
|
||||
await testButton(toolbox);
|
||||
|
||||
stopRecordingTelemetryLogs(Telemetry);
|
||||
await gDevTools.closeToolbox(target);
|
||||
gBrowser.removeCurrentTab();
|
||||
});
|
||||
|
||||
async function testButton(toolbox, Telemetry) {
|
||||
async function testButton(toolbox) {
|
||||
info("Testing command-button-paintflashing");
|
||||
|
||||
let button = toolbox.doc.querySelector("#command-button-paintflashing");
|
||||
ok(button, "Captain, we have the button");
|
||||
|
||||
await delayedClicks(toolbox, button, 4);
|
||||
checkResults("_PAINTFLASHING_", Telemetry);
|
||||
checkResults();
|
||||
}
|
||||
|
||||
async function delayedClicks(toolbox, node, clicks) {
|
||||
@ -47,7 +47,7 @@ async function delayedClicks(toolbox, node, clicks) {
|
||||
|
||||
let { CommandState } = require("devtools/shared/gcli/command-state");
|
||||
let clicked = new Promise(resolve => {
|
||||
CommandState.on("changed", function changed(type, { command }) {
|
||||
CommandState.on("changed", function changed({command}) {
|
||||
if (command === "paintflashing") {
|
||||
CommandState.off("changed", changed);
|
||||
resolve();
|
||||
@ -62,34 +62,9 @@ async function delayedClicks(toolbox, node, clicks) {
|
||||
}
|
||||
}
|
||||
|
||||
function checkResults(histIdFocus, Telemetry) {
|
||||
let result = Telemetry.prototype.telemetryInfo;
|
||||
|
||||
for (let [histId, value] of Object.entries(result)) {
|
||||
if (histId.startsWith("DEVTOOLS_INSPECTOR_") ||
|
||||
!histId.includes(histIdFocus)) {
|
||||
// Inspector stats are tested in
|
||||
// browser_telemetry_toolboxtabs_{toolname}.js so we skip them here
|
||||
// because we only open the inspector once for this test.
|
||||
continue;
|
||||
}
|
||||
|
||||
if (histId.endsWith("OPENED_COUNT")) {
|
||||
ok(value.length > 1, histId + " has more than one entry");
|
||||
|
||||
let okay = value.every(function(element) {
|
||||
return element === true;
|
||||
});
|
||||
|
||||
ok(okay, "All " + histId + " entries are === true");
|
||||
} else if (histId.endsWith("TIME_ACTIVE_SECONDS")) {
|
||||
ok(value.length > 1, histId + " has more than one entry");
|
||||
|
||||
let okay = value.every(function(element) {
|
||||
return element > 0;
|
||||
});
|
||||
|
||||
ok(okay, "All " + histId + " entries have time > 0");
|
||||
}
|
||||
}
|
||||
function checkResults() {
|
||||
// For help generating these tests use generateTelemetryTests("DEVTOOLS_PAINTFLASHING_")
|
||||
// here.
|
||||
checkTelemetry("DEVTOOLS_PAINTFLASHING_OPENED_COUNT", "", [2, 0, 0], "array");
|
||||
checkTelemetry("DEVTOOLS_PAINTFLASHING_TIME_ACTIVE_SECONDS", "", null, "hasentries");
|
||||
}
|
||||
|
@ -34,21 +34,20 @@ loader.lazyRequireGetter(this, "ResponsiveUIManager", "devtools/client/responsiv
|
||||
|
||||
add_task(async function() {
|
||||
await addTab(TEST_URI);
|
||||
let Telemetry = loadTelemetryAndRecordLogs();
|
||||
startTelemetry();
|
||||
|
||||
let target = TargetFactory.forTab(gBrowser.selectedTab);
|
||||
let toolbox = await gDevTools.showToolbox(target, "inspector");
|
||||
info("inspector opened");
|
||||
|
||||
info("testing the responsivedesign button");
|
||||
await testButton(toolbox, Telemetry);
|
||||
await testButton(toolbox);
|
||||
|
||||
stopRecordingTelemetryLogs(Telemetry);
|
||||
await gDevTools.closeToolbox(target);
|
||||
gBrowser.removeCurrentTab();
|
||||
});
|
||||
|
||||
async function testButton(toolbox, Telemetry) {
|
||||
async function testButton(toolbox) {
|
||||
info("Testing command-button-responsive");
|
||||
|
||||
let button = toolbox.doc.querySelector("#command-button-responsive");
|
||||
@ -56,7 +55,7 @@ async function testButton(toolbox, Telemetry) {
|
||||
|
||||
await delayedClicks(button, 4);
|
||||
|
||||
checkResults("_RESPONSIVE_", Telemetry);
|
||||
checkResults();
|
||||
}
|
||||
|
||||
function waitForToggle() {
|
||||
@ -82,34 +81,9 @@ var delayedClicks = async function(node, clicks) {
|
||||
}
|
||||
};
|
||||
|
||||
function checkResults(histIdFocus, Telemetry) {
|
||||
let result = Telemetry.prototype.telemetryInfo;
|
||||
|
||||
for (let [histId, value] of Object.entries(result)) {
|
||||
if (histId.startsWith("DEVTOOLS_INSPECTOR_") ||
|
||||
!histId.includes(histIdFocus)) {
|
||||
// Inspector stats are tested in
|
||||
// browser_telemetry_toolboxtabs_{toolname}.js so we skip them here
|
||||
// because we only open the inspector once for this test.
|
||||
continue;
|
||||
}
|
||||
|
||||
if (histId.endsWith("OPENED_COUNT")) {
|
||||
ok(value.length > 1, histId + " has more than one entry");
|
||||
|
||||
let okay = value.every(function(element) {
|
||||
return element === true;
|
||||
});
|
||||
|
||||
ok(okay, "All " + histId + " entries are === true");
|
||||
} else if (histId.endsWith("TIME_ACTIVE_SECONDS")) {
|
||||
ok(value.length > 1, histId + " has more than one entry");
|
||||
|
||||
let okay = value.every(function(element) {
|
||||
return element > 0;
|
||||
});
|
||||
|
||||
ok(okay, "All " + histId + " entries have time > 0");
|
||||
}
|
||||
}
|
||||
function checkResults() {
|
||||
// For help generating these tests use generateTelemetryTests("DEVTOOLS_RESPONSIVE_")
|
||||
// here.
|
||||
checkTelemetry("DEVTOOLS_RESPONSIVE_OPENED_COUNT", "", [2, 0, 0], "array");
|
||||
checkTelemetry("DEVTOOLS_RESPONSIVE_TIME_ACTIVE_SECONDS", "", null, "hasentries");
|
||||
}
|
||||
|
@ -13,7 +13,7 @@ const TOOL_DELAY = 200;
|
||||
|
||||
add_task(async function() {
|
||||
await addTab(TEST_URI);
|
||||
let Telemetry = loadTelemetryAndRecordLogs();
|
||||
startTelemetry();
|
||||
|
||||
await pushPref("devtools.command-button-scratchpad.enabled", true);
|
||||
|
||||
@ -24,12 +24,11 @@ add_task(async function() {
|
||||
let onAllWindowsOpened = trackScratchpadWindows();
|
||||
|
||||
info("testing the scratchpad button");
|
||||
await testButton(toolbox, Telemetry);
|
||||
await testButton(toolbox);
|
||||
await onAllWindowsOpened;
|
||||
|
||||
checkResults("_SCRATCHPAD_", Telemetry);
|
||||
checkResults();
|
||||
|
||||
stopRecordingTelemetryLogs(Telemetry);
|
||||
await gDevTools.closeToolbox(target);
|
||||
gBrowser.removeCurrentTab();
|
||||
});
|
||||
@ -68,7 +67,7 @@ function trackScratchpadWindows() {
|
||||
});
|
||||
}
|
||||
|
||||
async function testButton(toolbox, Telemetry) {
|
||||
async function testButton(toolbox) {
|
||||
info("Testing command-button-scratchpad");
|
||||
let button = toolbox.doc.querySelector("#command-button-scratchpad");
|
||||
ok(button, "Captain, we have the button");
|
||||
@ -95,34 +94,8 @@ function delayedClicks(node, clicks) {
|
||||
});
|
||||
}
|
||||
|
||||
function checkResults(histIdFocus, Telemetry) {
|
||||
let result = Telemetry.prototype.telemetryInfo;
|
||||
|
||||
for (let [histId, value] of Object.entries(result)) {
|
||||
if (histId.startsWith("DEVTOOLS_INSPECTOR_") ||
|
||||
!histId.includes(histIdFocus)) {
|
||||
// Inspector stats are tested in
|
||||
// browser_telemetry_toolboxtabs_{toolname}.js so we skip them here
|
||||
// because we only open the inspector once for this test.
|
||||
continue;
|
||||
}
|
||||
|
||||
if (histId.endsWith("OPENED_COUNT")) {
|
||||
ok(value.length > 1, histId + " has more than one entry");
|
||||
|
||||
let okay = value.every(function(element) {
|
||||
return element === true;
|
||||
});
|
||||
|
||||
ok(okay, "All " + histId + " entries are === true");
|
||||
} else if (histId.endsWith("TIME_ACTIVE_SECONDS")) {
|
||||
ok(value.length > 1, histId + " has more than one entry");
|
||||
|
||||
let okay = value.every(function(element) {
|
||||
return element > 0;
|
||||
});
|
||||
|
||||
ok(okay, "All " + histId + " entries have time > 0");
|
||||
}
|
||||
}
|
||||
function checkResults() {
|
||||
// For help generating these tests use generateTelemetryTests("DEVTOOLS_SCRATCHPAD_")
|
||||
// here.
|
||||
checkTelemetry("DEVTOOLS_SCRATCHPAD_WINDOW_OPENED_COUNT", "", [4, 0, 0], "array");
|
||||
}
|
||||
|
32
devtools/client/shared/test/browser_telemetry_misc.js
Normal file
32
devtools/client/shared/test/browser_telemetry_misc.js
Normal file
@ -0,0 +1,32 @@
|
||||
/* Any copyright is dedicated to the Public Domain.
|
||||
http://creativecommons.org/publicdomain/zero/1.0/ */
|
||||
|
||||
"use strict";
|
||||
|
||||
const TEST_URI = "data:text/html;charset=utf-8,<p>browser_telemetry_misc.js</p>";
|
||||
const TOOL_DELAY = 0;
|
||||
|
||||
add_task(async function() {
|
||||
await addTab(TEST_URI);
|
||||
|
||||
startTelemetry();
|
||||
|
||||
await openAndCloseToolbox(1, TOOL_DELAY, "inspector");
|
||||
checkResults();
|
||||
|
||||
gBrowser.removeCurrentTab();
|
||||
});
|
||||
|
||||
function checkResults() {
|
||||
// For help generating these tests use generateTelemetryTests("DEVTOOLS_")
|
||||
// here.
|
||||
checkTelemetry("DEVTOOLS_TOOLBOX_OPENED_COUNT", "", [1, 0, 0], "array");
|
||||
checkTelemetry("DEVTOOLS_INSPECTOR_OPENED_COUNT", "", [1, 0, 0], "array");
|
||||
checkTelemetry("DEVTOOLS_RULEVIEW_OPENED_COUNT", "", [1, 0, 0], "array");
|
||||
checkTelemetry("DEVTOOLS_TOOLBOX_TIME_ACTIVE_SECONDS", "", null, "hasentries");
|
||||
checkTelemetry("DEVTOOLS_INSPECTOR_TIME_ACTIVE_SECONDS", "", null, "hasentries");
|
||||
checkTelemetry("DEVTOOLS_RULEVIEW_TIME_ACTIVE_SECONDS", "", null, "hasentries");
|
||||
checkTelemetry(
|
||||
"DEVTOOLS_SCREEN_RESOLUTION_ENUMERATED_PER_USER", "", null, "hasentries");
|
||||
checkTelemetry("DEVTOOLS_TOOLBOX_HOST", "", null, "hasentries");
|
||||
}
|
@ -12,16 +12,15 @@ const TOOL_DELAY = 200;
|
||||
|
||||
add_task(async function() {
|
||||
await addTab(TEST_URI);
|
||||
let Telemetry = loadTelemetryAndRecordLogs();
|
||||
startTelemetry();
|
||||
|
||||
let target = TargetFactory.forTab(gBrowser.selectedTab);
|
||||
let toolbox = await gDevTools.showToolbox(target, "inspector");
|
||||
info("inspector opened");
|
||||
|
||||
await testSidebar(toolbox);
|
||||
checkResults(Telemetry);
|
||||
checkResults();
|
||||
|
||||
stopRecordingTelemetryLogs(Telemetry);
|
||||
await gDevTools.closeToolbox(target);
|
||||
gBrowser.removeCurrentTab();
|
||||
});
|
||||
@ -34,7 +33,7 @@ function testSidebar(toolbox) {
|
||||
"animationinspector"];
|
||||
|
||||
// Concatenate the array with itself so that we can open each tool twice.
|
||||
sidebarTools.push.apply(sidebarTools, sidebarTools);
|
||||
sidebarTools = [...sidebarTools, ...sidebarTools];
|
||||
|
||||
return new Promise(resolve => {
|
||||
// See TOOL_DELAY for why we need setTimeout here
|
||||
@ -52,34 +51,16 @@ function testSidebar(toolbox) {
|
||||
});
|
||||
}
|
||||
|
||||
function checkResults(Telemetry) {
|
||||
let result = Telemetry.prototype.telemetryInfo;
|
||||
|
||||
for (let [histId, value] of Object.entries(result)) {
|
||||
if (histId.startsWith("DEVTOOLS_INSPECTOR_")) {
|
||||
// Inspector stats are tested in browser_telemetry_toolboxtabs.js so we
|
||||
// skip them here because we only open the inspector once for this test.
|
||||
continue;
|
||||
}
|
||||
|
||||
if (histId === "DEVTOOLS_TOOLBOX_OPENED_COUNT") {
|
||||
is(value.length, 1, histId + " has only one entry");
|
||||
} else if (histId.endsWith("OPENED_COUNT")) {
|
||||
ok(value.length > 1, histId + " has more than one entry");
|
||||
|
||||
let okay = value.every(function(element) {
|
||||
return element === true;
|
||||
});
|
||||
|
||||
ok(okay, "All " + histId + " entries are === true");
|
||||
} else if (histId.endsWith("TIME_ACTIVE_SECONDS")) {
|
||||
ok(value.length > 1, histId + " has more than one entry");
|
||||
|
||||
let okay = value.every(function(element) {
|
||||
return element > 0;
|
||||
});
|
||||
|
||||
ok(okay, "All " + histId + " entries have time > 0");
|
||||
}
|
||||
}
|
||||
function checkResults() {
|
||||
// For help generating these tests use generateTelemetryTests("DEVTOOLS_")
|
||||
// here.
|
||||
checkTelemetry("DEVTOOLS_INSPECTOR_OPENED_COUNT", "", [1, 0, 0], "array");
|
||||
checkTelemetry("DEVTOOLS_RULEVIEW_OPENED_COUNT", "", [3, 0, 0], "array");
|
||||
checkTelemetry("DEVTOOLS_COMPUTEDVIEW_OPENED_COUNT", "", [2, 0, 0], "array");
|
||||
checkTelemetry("DEVTOOLS_LAYOUTVIEW_OPENED_COUNT", "", [2, 0, 0], "array");
|
||||
checkTelemetry("DEVTOOLS_FONTINSPECTOR_OPENED_COUNT", "", [2, 0, 0], "array");
|
||||
checkTelemetry("DEVTOOLS_RULEVIEW_TIME_ACTIVE_SECONDS", "", null, "hasentries");
|
||||
checkTelemetry("DEVTOOLS_COMPUTEDVIEW_TIME_ACTIVE_SECONDS", "", null, "hasentries");
|
||||
checkTelemetry("DEVTOOLS_LAYOUTVIEW_TIME_ACTIVE_SECONDS", "", null, "hasentries");
|
||||
checkTelemetry("DEVTOOLS_FONTINSPECTOR_TIME_ACTIVE_SECONDS", "", null, "hasentries");
|
||||
}
|
||||
|
@ -12,11 +12,18 @@ const TOOL_DELAY = 200;
|
||||
|
||||
add_task(async function() {
|
||||
await addTab(TEST_URI);
|
||||
let Telemetry = loadTelemetryAndRecordLogs();
|
||||
startTelemetry();
|
||||
|
||||
await openAndCloseToolbox(3, TOOL_DELAY, "inspector");
|
||||
checkTelemetryResults(Telemetry);
|
||||
checkResults();
|
||||
|
||||
stopRecordingTelemetryLogs(Telemetry);
|
||||
gBrowser.removeCurrentTab();
|
||||
});
|
||||
|
||||
function checkResults() {
|
||||
// For help generating these tests use generateTelemetryTests("DEVTOOLS_TOOLBOX_")
|
||||
// here.
|
||||
checkTelemetry("DEVTOOLS_TOOLBOX_OPENED_COUNT", "", [3, 0, 0], "array");
|
||||
checkTelemetry("DEVTOOLS_TOOLBOX_TIME_ACTIVE_SECONDS", "", null, "hasentries");
|
||||
checkTelemetry("DEVTOOLS_TOOLBOX_HOST", "", null, "hasentries");
|
||||
}
|
||||
|
@ -16,14 +16,20 @@ add_task(async function() {
|
||||
Services.prefs.setBoolPref("devtools.canvasdebugger.enabled", true);
|
||||
|
||||
await addTab(TEST_URI);
|
||||
let Telemetry = loadTelemetryAndRecordLogs();
|
||||
startTelemetry();
|
||||
|
||||
await openAndCloseToolbox(2, TOOL_DELAY, "canvasdebugger");
|
||||
checkTelemetryResults(Telemetry);
|
||||
checkResults();
|
||||
|
||||
stopRecordingTelemetryLogs(Telemetry);
|
||||
gBrowser.removeCurrentTab();
|
||||
|
||||
info("De-activate the canvasdebugger");
|
||||
Services.prefs.setBoolPref("devtools.canvasdebugger.enabled", originalPref);
|
||||
});
|
||||
|
||||
function checkResults() {
|
||||
// For help generating these tests use generateTelemetryTests("DEVTOOLS_CANVASDEBUGGER")
|
||||
// here.
|
||||
checkTelemetry("DEVTOOLS_CANVASDEBUGGER_OPENED_COUNT", "", [2, 0, 0], "array");
|
||||
checkTelemetry("DEVTOOLS_CANVASDEBUGGER_TIME_ACTIVE_SECONDS", "", null, "hasentries");
|
||||
}
|
||||
|
@ -12,11 +12,17 @@ const TOOL_DELAY = 200;
|
||||
|
||||
add_task(async function() {
|
||||
await addTab(TEST_URI);
|
||||
let Telemetry = loadTelemetryAndRecordLogs();
|
||||
startTelemetry();
|
||||
|
||||
await openAndCloseToolbox(2, TOOL_DELAY, "inspector");
|
||||
checkTelemetryResults(Telemetry);
|
||||
checkResults();
|
||||
|
||||
stopRecordingTelemetryLogs(Telemetry);
|
||||
gBrowser.removeCurrentTab();
|
||||
});
|
||||
|
||||
function checkResults() {
|
||||
// For help generating these tests use generateTelemetryTests("DEVTOOLS_INSPECTOR_")
|
||||
// here.
|
||||
checkTelemetry("DEVTOOLS_INSPECTOR_OPENED_COUNT", "", [2, 0, 0], "array");
|
||||
checkTelemetry("DEVTOOLS_INSPECTOR_TIME_ACTIVE_SECONDS", "", null, "hasentries");
|
||||
}
|
||||
|
@ -12,11 +12,17 @@ const TOOL_DELAY = 200;
|
||||
|
||||
add_task(async function() {
|
||||
await addTab(TEST_URI);
|
||||
let Telemetry = loadTelemetryAndRecordLogs();
|
||||
startTelemetry();
|
||||
|
||||
await openAndCloseToolbox(2, TOOL_DELAY, "jsdebugger");
|
||||
checkTelemetryResults(Telemetry);
|
||||
checkResults();
|
||||
|
||||
stopRecordingTelemetryLogs(Telemetry);
|
||||
gBrowser.removeCurrentTab();
|
||||
});
|
||||
|
||||
function checkResults() {
|
||||
// For help generating these tests use generateTelemetryTests("DEVTOOLS_JSDEBUGGER_")
|
||||
// here.
|
||||
checkTelemetry("DEVTOOLS_JSDEBUGGER_OPENED_COUNT", "", [2, 0, 0], "array");
|
||||
checkTelemetry("DEVTOOLS_JSDEBUGGER_TIME_ACTIVE_SECONDS", "", null, "hasentries");
|
||||
}
|
||||
|
@ -12,11 +12,17 @@ const TOOL_DELAY = 200;
|
||||
|
||||
add_task(async function() {
|
||||
await addTab(TEST_URI);
|
||||
let Telemetry = loadTelemetryAndRecordLogs();
|
||||
startTelemetry();
|
||||
|
||||
await openAndCloseToolbox(2, TOOL_DELAY, "performance");
|
||||
checkTelemetryResults(Telemetry);
|
||||
checkResults();
|
||||
|
||||
stopRecordingTelemetryLogs(Telemetry);
|
||||
gBrowser.removeCurrentTab();
|
||||
});
|
||||
|
||||
function checkResults() {
|
||||
// For help generating these tests use generateTelemetryTests("DEVTOOLS_JSPROFILER")
|
||||
// here.
|
||||
checkTelemetry("DEVTOOLS_JSPROFILER_OPENED_COUNT", "", [2, 0, 0], "array");
|
||||
checkTelemetry("DEVTOOLS_JSPROFILER_TIME_ACTIVE_SECONDS", "", null, "hasentries");
|
||||
}
|
||||
|
@ -12,12 +12,17 @@ const TOOL_DELAY = 200;
|
||||
|
||||
add_task(async function() {
|
||||
await addTab(TEST_URI);
|
||||
let Telemetry = loadTelemetryAndRecordLogs();
|
||||
startTelemetry();
|
||||
|
||||
await openAndCloseToolbox(2, TOOL_DELAY, "netmonitor");
|
||||
checkTelemetryResults(Telemetry);
|
||||
checkResults();
|
||||
|
||||
stopRecordingTelemetryLogs(Telemetry);
|
||||
gBrowser.removeCurrentTab();
|
||||
});
|
||||
|
||||
function checkResults() {
|
||||
// For help generating these tests use generateTelemetryTests("DEVTOOLS_NETMONITOR_")
|
||||
// here.
|
||||
checkTelemetry("DEVTOOLS_NETMONITOR_OPENED_COUNT", "", [2, 0, 0], "array");
|
||||
checkTelemetry("DEVTOOLS_NETMONITOR_TIME_ACTIVE_SECONDS", "", null, "hasentries");
|
||||
}
|
||||
|
@ -12,11 +12,17 @@ const TOOL_DELAY = 200;
|
||||
|
||||
add_task(async function() {
|
||||
await addTab(TEST_URI);
|
||||
let Telemetry = loadTelemetryAndRecordLogs();
|
||||
startTelemetry();
|
||||
|
||||
await openAndCloseToolbox(2, TOOL_DELAY, "options");
|
||||
checkTelemetryResults(Telemetry);
|
||||
checkResults();
|
||||
|
||||
stopRecordingTelemetryLogs(Telemetry);
|
||||
gBrowser.removeCurrentTab();
|
||||
});
|
||||
|
||||
function checkResults() {
|
||||
// For help generating these tests use generateTelemetryTests("DEVTOOLS_OPTIONS_")
|
||||
// here.
|
||||
checkTelemetry("DEVTOOLS_OPTIONS_OPENED_COUNT", "", [2, 0, 0], "array");
|
||||
checkTelemetry("DEVTOOLS_OPTIONS_TIME_ACTIVE_SECONDS", "", null, "hasentries");
|
||||
}
|
||||
|
@ -17,14 +17,20 @@ add_task(async function() {
|
||||
Services.prefs.setBoolPref(TOOL_PREF, true);
|
||||
|
||||
await addTab(TEST_URI);
|
||||
let Telemetry = loadTelemetryAndRecordLogs();
|
||||
startTelemetry();
|
||||
|
||||
await openAndCloseToolbox(2, TOOL_DELAY, "shadereditor");
|
||||
checkTelemetryResults(Telemetry);
|
||||
checkResults();
|
||||
|
||||
stopRecordingTelemetryLogs(Telemetry);
|
||||
gBrowser.removeCurrentTab();
|
||||
|
||||
info("De-activate the sharer editor");
|
||||
Services.prefs.setBoolPref(TOOL_PREF, originalPref);
|
||||
});
|
||||
|
||||
function checkResults() {
|
||||
// For help generating these tests use generateTelemetryTests("DEVTOOLS_SHADEREDITOR_")
|
||||
// here.
|
||||
checkTelemetry("DEVTOOLS_SHADEREDITOR_OPENED_COUNT", "", [2, 0, 0], "array");
|
||||
checkTelemetry("DEVTOOLS_SHADEREDITOR_TIME_ACTIVE_SECONDS", "", null, "hasentries");
|
||||
}
|
||||
|
@ -12,11 +12,17 @@ const TOOL_DELAY = 1000;
|
||||
|
||||
add_task(async function() {
|
||||
await addTab(TEST_URI);
|
||||
let Telemetry = loadTelemetryAndRecordLogs();
|
||||
startTelemetry();
|
||||
|
||||
await openAndCloseToolbox(2, TOOL_DELAY, "storage");
|
||||
checkTelemetryResults(Telemetry);
|
||||
checkResults();
|
||||
|
||||
stopRecordingTelemetryLogs(Telemetry);
|
||||
gBrowser.removeCurrentTab();
|
||||
});
|
||||
|
||||
function checkResults() {
|
||||
// For help generating these tests use generateTelemetryTests("DEVTOOLS_STORAGE_")
|
||||
// here.
|
||||
checkTelemetry("DEVTOOLS_STORAGE_OPENED_COUNT", "", [2, 0, 0], "array");
|
||||
checkTelemetry("DEVTOOLS_STORAGE_TIME_ACTIVE_SECONDS", "", null, "hasentries");
|
||||
}
|
||||
|
@ -12,12 +12,17 @@ const TOOL_DELAY = 200;
|
||||
|
||||
add_task(async function() {
|
||||
await addTab(TEST_URI);
|
||||
let Telemetry = loadTelemetryAndRecordLogs();
|
||||
startTelemetry();
|
||||
|
||||
await openAndCloseToolbox(2, TOOL_DELAY, "styleeditor");
|
||||
checkTelemetryResults(Telemetry);
|
||||
checkResults();
|
||||
|
||||
stopRecordingTelemetryLogs(Telemetry);
|
||||
gBrowser.removeCurrentTab();
|
||||
});
|
||||
|
||||
function checkResults() {
|
||||
// For help generating these tests use generateTelemetryTests("DEVTOOLS_STYLEEDITOR_")
|
||||
// here.
|
||||
checkTelemetry("DEVTOOLS_STYLEEDITOR_OPENED_COUNT", "", [2, 0, 0], "array");
|
||||
checkTelemetry("DEVTOOLS_STYLEEDITOR_TIME_ACTIVE_SECONDS", "", null, "hasentries");
|
||||
}
|
||||
|
@ -16,14 +16,20 @@ add_task(async function() {
|
||||
Services.prefs.setBoolPref("devtools.webaudioeditor.enabled", true);
|
||||
|
||||
await addTab(TEST_URI);
|
||||
let Telemetry = loadTelemetryAndRecordLogs();
|
||||
startTelemetry();
|
||||
|
||||
await openAndCloseToolbox(2, TOOL_DELAY, "webaudioeditor");
|
||||
checkTelemetryResults(Telemetry);
|
||||
checkResults();
|
||||
|
||||
stopRecordingTelemetryLogs(Telemetry);
|
||||
gBrowser.removeCurrentTab();
|
||||
|
||||
info("De-activating the webaudioeditor");
|
||||
Services.prefs.setBoolPref("devtools.webaudioeditor.enabled", originalPref);
|
||||
});
|
||||
|
||||
function checkResults() {
|
||||
// For help generating these tests use generateTelemetryTests("DEVTOOLS_WEBAUDIOEDITOR")
|
||||
// here.
|
||||
checkTelemetry("DEVTOOLS_WEBAUDIOEDITOR_OPENED_COUNT", "", [2, 0, 0], "array");
|
||||
checkTelemetry("DEVTOOLS_WEBAUDIOEDITOR_TIME_ACTIVE_SECONDS", "", null, "hasentries");
|
||||
}
|
||||
|
@ -12,11 +12,17 @@ const TOOL_DELAY = 200;
|
||||
|
||||
add_task(async function() {
|
||||
await addTab(TEST_URI);
|
||||
let Telemetry = loadTelemetryAndRecordLogs();
|
||||
startTelemetry();
|
||||
|
||||
await openAndCloseToolbox(2, TOOL_DELAY, "webconsole");
|
||||
checkTelemetryResults(Telemetry);
|
||||
checkResults();
|
||||
|
||||
stopRecordingTelemetryLogs(Telemetry);
|
||||
gBrowser.removeCurrentTab();
|
||||
});
|
||||
|
||||
function checkResults() {
|
||||
// For help generating these tests use generateTelemetryTests("DEVTOOLS_WEBCONSOLE_")
|
||||
// here.
|
||||
checkTelemetry("DEVTOOLS_WEBCONSOLE_OPENED_COUNT", "", [2, 0, 0], "array");
|
||||
checkTelemetry("DEVTOOLS_WEBCONSOLE_TIME_ACTIVE_SECONDS", "", null, "hasentries");
|
||||
}
|
||||
|
@ -3,6 +3,7 @@
|
||||
* file, You can obtain one at http://mozilla.org/MPL/2.0/. */
|
||||
/* eslint no-unused-vars: [2, {"vars": "local", "args": "none"}] */
|
||||
/* import-globals-from shared-head.js */
|
||||
/* import-globals-from telemetry-test-helpers.js */
|
||||
|
||||
"use strict";
|
||||
|
||||
@ -118,36 +119,6 @@ async function(type = "bottom", src = CHROME_URL_ROOT + "dummy.html") {
|
||||
return [host, iframe.contentWindow, iframe.contentDocument];
|
||||
};
|
||||
|
||||
/**
|
||||
* Check the correctness of the data recorded in Telemetry after
|
||||
* loadTelemetryAndRecordLogs was called.
|
||||
*/
|
||||
function checkTelemetryResults(Telemetry) {
|
||||
let result = Telemetry.prototype.telemetryInfo;
|
||||
|
||||
for (let histId in result) {
|
||||
let value = result[histId];
|
||||
|
||||
if (histId.endsWith("OPENED_COUNT")) {
|
||||
ok(value.length > 1, histId + " has more than one entry");
|
||||
|
||||
let okay = value.every(function(element) {
|
||||
return element === true;
|
||||
});
|
||||
|
||||
ok(okay, "All " + histId + " entries are === true");
|
||||
} else if (histId.endsWith("TIME_ACTIVE_SECONDS")) {
|
||||
ok(value.length > 1, histId + " has more than one entry");
|
||||
|
||||
let okay = value.every(function(element) {
|
||||
return element > 0;
|
||||
});
|
||||
|
||||
ok(okay, "All " + histId + " entries have time > 0");
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Open and close the toolbox in the current browser tab, several times, waiting
|
||||
* some amount of time in between.
|
||||
|
@ -37,6 +37,9 @@ const URL_ROOT = CHROME_URL_ROOT.replace("chrome://mochitests/content/",
|
||||
const URL_ROOT_SSL = CHROME_URL_ROOT.replace("chrome://mochitests/content/",
|
||||
"https://example.com/");
|
||||
|
||||
Services.scriptloader.loadSubScript(
|
||||
"chrome://mochitests/content/browser/devtools/client/shared/test/telemetry-test-helpers.js", this);
|
||||
|
||||
// Force devtools to be initialized so menu items and keyboard shortcuts get installed
|
||||
require("devtools/client/framework/devtools-browser");
|
||||
|
||||
@ -581,57 +584,6 @@ var closeToolbox = async function() {
|
||||
await gDevTools.closeToolbox(target);
|
||||
};
|
||||
|
||||
/**
|
||||
* Load the Telemetry utils, then stub Telemetry.prototype.log and
|
||||
* Telemetry.prototype.logKeyed in order to record everything that's logged in
|
||||
* it.
|
||||
* Store all recordings in Telemetry.telemetryInfo.
|
||||
* @return {Telemetry}
|
||||
*/
|
||||
function loadTelemetryAndRecordLogs() {
|
||||
info("Mock the Telemetry log function to record logged information");
|
||||
|
||||
let Telemetry = require("devtools/client/shared/telemetry");
|
||||
Telemetry.prototype.telemetryInfo = {};
|
||||
Telemetry.prototype._oldlog = Telemetry.prototype.log;
|
||||
Telemetry.prototype.log = function(histogramId, value) {
|
||||
if (!this.telemetryInfo) {
|
||||
// Telemetry instance still in use after stopRecordingTelemetryLogs
|
||||
return;
|
||||
}
|
||||
if (histogramId) {
|
||||
if (!this.telemetryInfo[histogramId]) {
|
||||
this.telemetryInfo[histogramId] = [];
|
||||
}
|
||||
this.telemetryInfo[histogramId].push(value);
|
||||
}
|
||||
};
|
||||
Telemetry.prototype._oldlogScalar = Telemetry.prototype.logScalar;
|
||||
Telemetry.prototype.logScalar = Telemetry.prototype.log;
|
||||
Telemetry.prototype._oldlogKeyed = Telemetry.prototype.logKeyed;
|
||||
Telemetry.prototype.logKeyed = function(histogramId, key, value) {
|
||||
this.log(`${histogramId}|${key}`, value);
|
||||
};
|
||||
|
||||
return Telemetry;
|
||||
}
|
||||
|
||||
/**
|
||||
* Stop recording the Telemetry logs and put back the utils as it was before.
|
||||
* @param {Telemetry} Required Telemetry
|
||||
* Telemetry object that needs to be stopped.
|
||||
*/
|
||||
function stopRecordingTelemetryLogs(Telemetry) {
|
||||
info("Stopping Telemetry");
|
||||
Telemetry.prototype.log = Telemetry.prototype._oldlog;
|
||||
Telemetry.prototype.logScalar = Telemetry.prototype._oldlogScalar;
|
||||
Telemetry.prototype.logKeyed = Telemetry.prototype._oldlogKeyed;
|
||||
delete Telemetry.prototype._oldlog;
|
||||
delete Telemetry.prototype._oldlogScalar;
|
||||
delete Telemetry.prototype._oldlogKeyed;
|
||||
delete Telemetry.prototype.telemetryInfo;
|
||||
}
|
||||
|
||||
/**
|
||||
* Clean the logical clipboard content. This method only clears the OS clipboard on
|
||||
* Windows (see Bug 666254).
|
||||
|
294
devtools/client/shared/test/telemetry-test-helpers.js
Normal file
294
devtools/client/shared/test/telemetry-test-helpers.js
Normal file
@ -0,0 +1,294 @@
|
||||
/* Any copyright is dedicated to the Public Domain.
|
||||
* http://creativecommons.org/publicdomain/zero/1.0/ */
|
||||
|
||||
/* global is ok registerCleanupFunction Services */
|
||||
|
||||
"use strict";
|
||||
|
||||
// We try to avoid polluting the global scope as far as possible by defining
|
||||
// constants in the methods that use them because this script is not sandboxed
|
||||
// meaning that it is loaded via Services.scriptloader.loadSubScript()
|
||||
|
||||
class TelemetryHelpers {
|
||||
constructor() {
|
||||
this.oldCanRecord = Services.telemetry.canRecordExtended;
|
||||
this.generateTelemetryTests = this.generateTelemetryTests.bind(this);
|
||||
registerCleanupFunction(this.stopTelemetry.bind(this));
|
||||
}
|
||||
|
||||
/**
|
||||
* Allow collection of extended telemetry data.
|
||||
*/
|
||||
startTelemetry() {
|
||||
Services.telemetry.canRecordExtended = true;
|
||||
}
|
||||
|
||||
/**
|
||||
* Clear all telemetry types.
|
||||
*/
|
||||
stopTelemetry() {
|
||||
this.clearToolsOpenedPref();
|
||||
Services.telemetry.canRecordExtended = this.oldCanRecord;
|
||||
|
||||
// Clear histograms, scalars and Telemetry Events.
|
||||
this.clearHistograms(Services.telemetry.snapshotHistograms);
|
||||
this.clearHistograms(Services.telemetry.snapshotKeyedHistograms);
|
||||
Services.telemetry.clearScalars();
|
||||
Services.telemetry.clearEvents();
|
||||
}
|
||||
|
||||
/**
|
||||
* Clears both OPTIN and OPTOUT versions of Telemetry Histograms.
|
||||
*
|
||||
* @param {Function} snapshotFunc
|
||||
* The function used to take the snapshot. This can be one of the
|
||||
* following:
|
||||
* - Services.telemetry.snapshotHistograms
|
||||
* - Services.telemetry.snapshotKeyedHistograms
|
||||
*
|
||||
* `snapshotFunc(OPTIN, true, true)` should clear the histograms but this
|
||||
* only deletes seemingly random histograms, hence this method.
|
||||
*/
|
||||
clearHistograms(snapshotFunc) {
|
||||
// Although most of our Telemetry probes are OPTOUT, OPTIN includes all OPTIN
|
||||
// *and* OPTOUT data.
|
||||
const OPTIN = Ci.nsITelemetry.DATASET_RELEASE_CHANNEL_OPTIN;
|
||||
const OPTOUT = Ci.nsITelemetry.DATASET_RELEASE_CHANNEL_OPTOUT;
|
||||
const tel = Services.telemetry;
|
||||
|
||||
for (let optInOut of [OPTIN, OPTOUT]) {
|
||||
const snapshot = snapshotFunc(optInOut, true, false).parent;
|
||||
const histKeys = Object.keys(snapshot);
|
||||
|
||||
for (let getHistogram of [tel.getHistogramById, tel.getKeyedHistogramById]) {
|
||||
for (let key of histKeys) {
|
||||
try {
|
||||
getHistogram(key).clear();
|
||||
} catch (e) {
|
||||
// Some histograms may have already been cleaned up by the system so we
|
||||
// swallow the "histogram does not exist" error silently here.
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Clears the pref that is used to log telemetry data once per browser version.
|
||||
*/
|
||||
clearToolsOpenedPref() {
|
||||
const TOOLS_OPENED_PREF = "devtools.telemetry.tools.opened.version";
|
||||
|
||||
Services.prefs.clearUserPref(TOOLS_OPENED_PREF);
|
||||
}
|
||||
|
||||
/**
|
||||
* Check the value of a given telemetry histogram.
|
||||
*
|
||||
* @param {String} histId
|
||||
* Histogram id
|
||||
* @param {String} key
|
||||
* Keyed histogram key
|
||||
* @param {Array|Number} expected
|
||||
* Expected value
|
||||
* @param {String} checkType
|
||||
* "array" (default) - Check that an array matches the histogram data.
|
||||
* "hasentries" - For non-enumerated linear and exponential
|
||||
* histograms. This checks for at least one entry.
|
||||
* "scalar" - Telemetry type is a scalar.
|
||||
* "keyedscalar" - Telemetry type is a keyed scalar.
|
||||
*/
|
||||
checkTelemetry(histId, key, expected, checkType) {
|
||||
// Although most of our Telemetry probes are OPTOUT, OPTIN includes all OPTIN
|
||||
// *and* OPTOUT data.
|
||||
const OPTIN = Ci.nsITelemetry.DATASET_RELEASE_CHANNEL_OPTIN;
|
||||
|
||||
let actual;
|
||||
let msg;
|
||||
|
||||
if (checkType === "array" || checkType === "hasentries") {
|
||||
if (key) {
|
||||
const keyedHistogram =
|
||||
Services.telemetry.getKeyedHistogramById(histId).snapshot();
|
||||
const result = keyedHistogram[key];
|
||||
|
||||
if (result) {
|
||||
actual = result.counts;
|
||||
} else {
|
||||
ok(false, `${histId}[${key}] exists`);
|
||||
return;
|
||||
}
|
||||
} else {
|
||||
actual = Services.telemetry.getHistogramById(histId).snapshot().counts;
|
||||
}
|
||||
}
|
||||
|
||||
switch (checkType) {
|
||||
case "array":
|
||||
msg = key ? `${histId}["${key}"] correct.` : `${histId} correct.`;
|
||||
is(JSON.stringify(actual), JSON.stringify(expected), msg);
|
||||
break;
|
||||
case "hasentries":
|
||||
let hasEntry = actual.some(num => num > 0);
|
||||
if (key) {
|
||||
ok(hasEntry, `${histId}["${key}"] has at least one entry.`);
|
||||
} else {
|
||||
ok(hasEntry, `${histId} has at least one entry.`);
|
||||
}
|
||||
break;
|
||||
case "scalar":
|
||||
const scalars =
|
||||
Services.telemetry.snapshotScalars(OPTIN, false).parent;
|
||||
|
||||
is(scalars[histId], expected, `${histId} correct`);
|
||||
break;
|
||||
case "keyedscalar":
|
||||
const keyedScalars =
|
||||
Services.telemetry.snapshotKeyedScalars(OPTIN, false).parent;
|
||||
const value = keyedScalars[histId][key];
|
||||
|
||||
msg = key ? `${histId}["${key}"] correct.` : `${histId} correct.`;
|
||||
is(value, expected, msg);
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Generate telemetry tests. You should call generateTelemetryTests("DEVTOOLS_")
|
||||
* from your result checking code in telemetry tests. It logs checkTelemetry
|
||||
* calls for all changed telemetry values.
|
||||
*
|
||||
* @param {String} prefix
|
||||
* Optionally limits results to histogram ids starting with prefix.
|
||||
*/
|
||||
generateTelemetryTests(prefix = "") {
|
||||
// Although most of our Telemetry probes are OPTOUT, OPTIN includes all OPTIN
|
||||
// *and* OPTOUT data.
|
||||
const OPTIN = Ci.nsITelemetry.DATASET_RELEASE_CHANNEL_OPTIN;
|
||||
|
||||
// Get all histograms and scalars
|
||||
const histograms =
|
||||
Services.telemetry.snapshotHistograms(OPTIN, true, false).parent;
|
||||
const keyedHistograms =
|
||||
Services.telemetry.snapshotKeyedHistograms(OPTIN, true, false).parent;
|
||||
const scalars =
|
||||
Services.telemetry.snapshotScalars(OPTIN, false).parent;
|
||||
const keyedScalars =
|
||||
Services.telemetry.snapshotKeyedScalars(OPTIN, false).parent;
|
||||
const allHistograms = Object.assign({},
|
||||
histograms,
|
||||
keyedHistograms,
|
||||
scalars,
|
||||
keyedScalars);
|
||||
// Get all keys
|
||||
const histIds = Object.keys(allHistograms)
|
||||
.filter(histId => histId.startsWith(prefix));
|
||||
|
||||
dump("=".repeat(80) + "\n");
|
||||
for (let histId of histIds) {
|
||||
let snapshot = allHistograms[histId];
|
||||
|
||||
if (histId === histId.toLowerCase()) {
|
||||
if (typeof snapshot === "object") {
|
||||
// Keyed Scalar
|
||||
const keys = Object.keys(snapshot);
|
||||
|
||||
for (let key of keys) {
|
||||
const value = snapshot[key];
|
||||
|
||||
dump(`checkTelemetry("${histId}", "${key}", ${value}, "keyedscalar");\n`);
|
||||
}
|
||||
} else {
|
||||
// Scalar
|
||||
dump(`checkTelemetry("${histId}", "", ${snapshot}, "scalar");\n`);
|
||||
}
|
||||
} else if (typeof snapshot.histogram_type !== "undefined" &&
|
||||
typeof snapshot.counts !== "undefined") {
|
||||
// Histogram
|
||||
const actual = snapshot.counts;
|
||||
|
||||
this.displayDataFromHistogramSnapshot(snapshot, "", histId, actual);
|
||||
} else {
|
||||
// Keyed Histogram
|
||||
const keys = Object.keys(snapshot);
|
||||
|
||||
for (let key of keys) {
|
||||
const value = snapshot[key];
|
||||
const actual = value.counts;
|
||||
|
||||
this.displayDataFromHistogramSnapshot(value, key, histId, actual);
|
||||
}
|
||||
}
|
||||
}
|
||||
dump("=".repeat(80) + "\n");
|
||||
}
|
||||
|
||||
/**
|
||||
* Generates the inner contents of a test's checkTelemetry() method.
|
||||
*
|
||||
* @param {HistogramSnapshot} snapshot
|
||||
* A snapshot of a telemetry chart obtained via snapshotHistograms or
|
||||
* similar.
|
||||
* @param {String} key
|
||||
* Only used for keyed histograms. This is the key we are interested in
|
||||
* checking.
|
||||
* @param {String} histId
|
||||
* The histogram ID.
|
||||
* @param {Array|String|Boolean} actual
|
||||
* The value of the histogram data.
|
||||
*/
|
||||
displayDataFromHistogramSnapshot(snapshot, key, histId, actual) {
|
||||
key = key ? `"${key}"` : `""`;
|
||||
|
||||
switch (snapshot.histogram_type) {
|
||||
case Services.telemetry.HISTOGRAM_EXPONENTIAL:
|
||||
case Services.telemetry.HISTOGRAM_LINEAR:
|
||||
let total = 0;
|
||||
for (let val of actual) {
|
||||
total += val;
|
||||
}
|
||||
|
||||
if (histId.endsWith("_ENUMERATED")) {
|
||||
if (total > 0) {
|
||||
actual = actual.toSource();
|
||||
dump(`checkTelemetry("${histId}", ${key}, ${actual}, "array");\n`);
|
||||
}
|
||||
return;
|
||||
}
|
||||
|
||||
dump(`checkTelemetry("${histId}", ${key}, null, "hasentries");\n`);
|
||||
break;
|
||||
case Services.telemetry.HISTOGRAM_BOOLEAN:
|
||||
actual = actual.toSource();
|
||||
|
||||
if (actual !== "[0, 0, 0]") {
|
||||
dump(`checkTelemetry("${histId}", ${key}, ${actual}, "array");\n`);
|
||||
}
|
||||
break;
|
||||
case Services.telemetry.HISTOGRAM_FLAG:
|
||||
actual = actual.toSource();
|
||||
|
||||
if (actual !== "[1, 0, 0]") {
|
||||
dump(`checkTelemetry("${histId}", ${key}, ${actual}, "array");\n`);
|
||||
}
|
||||
break;
|
||||
case Services.telemetry.HISTOGRAM_COUNT:
|
||||
actual = actual.toSource();
|
||||
|
||||
dump(`checkTelemetry("${histId}", ${key}, ${actual}, "array");\n`);
|
||||
break;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
// "exports"... because this is a helper and not imported via require we need to
|
||||
// expose the three main methods that should be used by tests. The reason this
|
||||
// is not imported via require is because it needs access to test methods
|
||||
// (is, ok etc).
|
||||
|
||||
/* eslint-disable no-unused-vars */
|
||||
const telemetryHelpers = new TelemetryHelpers();
|
||||
const generateTelemetryTests = telemetryHelpers.generateTelemetryTests;
|
||||
const checkTelemetry = telemetryHelpers.checkTelemetry;
|
||||
const startTelemetry = telemetryHelpers.startTelemetry;
|
||||
/* eslint-enable no-unused-vars */
|
@ -3,14 +3,17 @@
|
||||
* file, You can obtain one at http://mozilla.org/MPL/2.0/. */
|
||||
"use strict";
|
||||
|
||||
// This file is a chrome-API-dependent version of the module
|
||||
// devtools/client/shared/webpack/shims/unicode-url-stub.js, so that it can
|
||||
// take advantage of utilizing chrome APIs. But because of this, it isn't
|
||||
// intended to be used in Chrome-API-free applications, such as the Launchpad.
|
||||
// This file is a chrome-API-dependent version of the file
|
||||
// packages/devtools-modules/src/unicode-url.js at
|
||||
// https://github.com/devtools-html/devtools-core, so that this
|
||||
// chrome-API-dependent version can take advantage of utilizing chrome APIs. But
|
||||
// because of this, it isn't intended to be used in Chrome-API-free
|
||||
// applications, such as the Launchpad.
|
||||
//
|
||||
// Please keep in mind that if the feature in this file has changed, don't
|
||||
// forget to also change that accordingly in
|
||||
// devtools/client/shared/webpack/shims/unicode-url-stub.js.
|
||||
// forget to also change that accordingly in the file
|
||||
// packages/devtools-modules/src/unicode-url.js at
|
||||
// https://github.com/devtools-html/devtools-core
|
||||
|
||||
const { Cc, Ci } = require("chrome");
|
||||
const idnService =
|
||||
|
@ -1,32 +0,0 @@
|
||||
/* This Source Code Form is subject to the terms of the Mozilla Public
|
||||
* License, v. 2.0. If a copy of the MPL was not distributed with this
|
||||
* file, You can obtain one at http://mozilla.org/MPL/2.0/. */
|
||||
|
||||
// TODO This file aims to implement a Chrome-API-free replacement for
|
||||
// devtools/client/shared/unicode-url.js, so that it can be used in the
|
||||
// Launchpad.
|
||||
//
|
||||
// Currently this is just a dummpy mock of
|
||||
// devtools/client/shared/unicode-url.js, no actual functionaly involved.
|
||||
// Eventually we'll want to implement it. Once implemented, we should keep the
|
||||
// feature the same as devtools/client/shared/unicode-url.js.
|
||||
|
||||
"use strict";
|
||||
|
||||
function getUnicodeHostname(hostname) {
|
||||
return hostname;
|
||||
}
|
||||
|
||||
function getUnicodeUrlPath(urlPath) {
|
||||
return urlPath;
|
||||
}
|
||||
|
||||
function getUnicodeUrl(url) {
|
||||
return url;
|
||||
}
|
||||
|
||||
module.exports = {
|
||||
getUnicodeHostname,
|
||||
getUnicodeUrlPath,
|
||||
getUnicodeUrl,
|
||||
};
|
@ -25,6 +25,7 @@ support-files =
|
||||
cm_mode_ruby.js
|
||||
cm_script_injection_test.js
|
||||
!/devtools/client/shared/test/shared-head.js
|
||||
!/devtools/client/shared/test/telemetry-test-helpers.js
|
||||
|
||||
[browser_editor_autocomplete_basic.js]
|
||||
[browser_editor_autocomplete_events.js]
|
||||
|
@ -25,6 +25,7 @@ support-files =
|
||||
storage-updates.html
|
||||
head.js
|
||||
!/devtools/client/shared/test/shared-head.js
|
||||
!/devtools/client/shared/test/telemetry-test-helpers.js
|
||||
|
||||
[browser_storage_basic.js]
|
||||
[browser_storage_basic_usercontextid_1.js]
|
||||
|
@ -67,6 +67,7 @@ support-files =
|
||||
!/devtools/client/inspector/test/shared-head.js
|
||||
!/devtools/client/responsive.html/test/browser/devices.json
|
||||
!/devtools/client/shared/test/shared-head.js
|
||||
!/devtools/client/shared/test/telemetry-test-helpers.js
|
||||
!/devtools/client/shared/test/test-actor-registry.js
|
||||
!/devtools/client/shared/test/test-actor.js
|
||||
|
||||
|
@ -20,6 +20,7 @@ support-files =
|
||||
head.js
|
||||
!/devtools/client/shared/test/frame-script-utils.js
|
||||
!/devtools/client/shared/test/shared-head.js
|
||||
!/devtools/client/shared/test/telemetry-test-helpers.js
|
||||
|
||||
[browser_audionode-actor-get-param-flags.js]
|
||||
[browser_audionode-actor-get-params-01.js]
|
||||
|
@ -14,8 +14,8 @@
|
||||
"babel-plugin-transform-object-rest-spread": "^6.26.0",
|
||||
"cross-env": "^3.1.3",
|
||||
"devtools-config": "0.0.12",
|
||||
"devtools-launchpad": "^0.0.117",
|
||||
"devtools-modules": "0.0.31",
|
||||
"devtools-launchpad": "^0.0.119",
|
||||
"devtools-modules": "0.0.35",
|
||||
"file-loader": "^1.1.6",
|
||||
"netmonitor": "file:../netmonitor",
|
||||
"raw-loader": "^0.5.1",
|
||||
|
@ -4,6 +4,7 @@ subsuite = devtools
|
||||
support-files =
|
||||
head.js
|
||||
!/devtools/client/shared/test/shared-head.js
|
||||
!/devtools/client/shared/test/telemetry-test-helpers.js
|
||||
../stubs/*
|
||||
test-console-api.html
|
||||
test-css-message.html
|
||||
|
@ -156,6 +156,7 @@ support-files =
|
||||
!/devtools/client/netmonitor/test/sjs_cors-test-server.sjs
|
||||
!/image/test/mochitest/blue.png
|
||||
!/devtools/client/shared/test/shared-head.js
|
||||
!/devtools/client/shared/test/telemetry-test-helpers.js
|
||||
!/devtools/client/shared/test/test-actor.js
|
||||
!/devtools/client/shared/test/test-actor-registry.js
|
||||
|
||||
|
@ -92,11 +92,10 @@ webpackConfig.resolve = {
|
||||
"devtools/client/framework/menu": "devtools-modules/src/menu",
|
||||
"devtools/client/sourceeditor/editor": "devtools-source-editor/src/source-editor",
|
||||
|
||||
"devtools/client/shared/unicode-url": path.join(__dirname, "../../client/shared/webpack/shims/unicode-url-stub"),
|
||||
"devtools/client/shared/unicode-url": "./node_modules/devtools-modules/src/unicode-url",
|
||||
"devtools/client/shared/zoom-keys": "devtools-modules/src/zoom-keys",
|
||||
|
||||
"devtools/shared/fronts/timeline": path.join(__dirname, "../../client/shared/webpack/shims/fronts-timeline-shim"),
|
||||
"devtools/shared/old-event-emitter": "devtools-modules/src/utils/event-emitter",
|
||||
"devtools/shared/event-emitter": "devtools-modules/src/utils/event-emitter",
|
||||
"devtools/shared/client/debugger-client": path.join(__dirname, "test/fixtures/DebuggerClient"),
|
||||
"devtools/shared/platform/clipboard": path.join(__dirname, "../../client/shared/webpack/shims/platform-clipboard-stub"),
|
||||
|
Some files were not shown because too many files have changed in this diff Show More
Loading…
Reference in New Issue
Block a user