mirror of
https://gitlab.winehq.org/wine/wine-gecko.git
synced 2024-09-13 09:24:08 -07:00
Backed out 1 changesets (bug 1207645) for Mulet Gaia JS Integration Test Gij 21 and 4 perma test failures
Backed out changeset a23053342d5b (bug 1207645)
This commit is contained in:
parent
6cc43d7835
commit
62f9c7974d
@ -317,28 +317,10 @@ TabTarget.prototype = {
|
||||
return this._form;
|
||||
},
|
||||
|
||||
// Get a promise of the root form returned by a listTabs request. This promise
|
||||
// is cached.
|
||||
get root() {
|
||||
if (!this._root) {
|
||||
this._root = this._getRoot();
|
||||
}
|
||||
return this._root;
|
||||
},
|
||||
|
||||
_getRoot: function () {
|
||||
return new Promise((resolve, reject) => {
|
||||
this.client.listTabs(response => {
|
||||
if (response.error) {
|
||||
reject(new Error(response.error + ": " + response.message));
|
||||
return;
|
||||
}
|
||||
|
||||
resolve(response);
|
||||
});
|
||||
});
|
||||
},
|
||||
|
||||
get client() {
|
||||
return this._client;
|
||||
},
|
||||
|
@ -3,21 +3,12 @@
|
||||
* file, You can obtain one at http://mozilla.org/MPL/2.0/. */
|
||||
|
||||
// This shared-head.js file is used for multiple directories in devtools.
|
||||
|
||||
const {classes: Cc, interfaces: Ci, utils: Cu, results: Cr} = Components;
|
||||
|
||||
function scopedCuImport(path) {
|
||||
const scope = {};
|
||||
Cu.import(path, scope);
|
||||
return scope;
|
||||
}
|
||||
|
||||
const {Services} = scopedCuImport("resource://gre/modules/Services.jsm");
|
||||
const {gDevTools} = scopedCuImport("resource:///modules/devtools/client/framework/gDevTools.jsm");
|
||||
const {console} = scopedCuImport("resource://gre/modules/devtools/shared/Console.jsm");
|
||||
const {ScratchpadManager} = scopedCuImport("resource:///modules/devtools/client/scratchpad/scratchpad-manager.jsm");
|
||||
const {require} = scopedCuImport("resource://gre/modules/devtools/shared/Loader.jsm");
|
||||
|
||||
const {Services} = Cu.import("resource://gre/modules/Services.jsm", {});
|
||||
const {gDevTools} = Cu.import("resource:///modules/devtools/client/framework/gDevTools.jsm", {});
|
||||
const {console} = Cu.import("resource://gre/modules/devtools/shared/Console.jsm", {});
|
||||
const {ScratchpadManager} = Cu.import("resource:///modules/devtools/client/scratchpad/scratchpad-manager.jsm", {});
|
||||
const {require} = Cu.import("resource://gre/modules/devtools/shared/Loader.jsm", {});
|
||||
const {TargetFactory} = require("devtools/client/framework/target");
|
||||
const DevToolsUtils = require("devtools/shared/DevToolsUtils");
|
||||
const promise = require("promise");
|
||||
@ -78,25 +69,6 @@ function addTab(url) {
|
||||
return def.promise;
|
||||
}
|
||||
|
||||
/**
|
||||
* Remove the given tab.
|
||||
* @param {Object} tab The tab to be removed.
|
||||
* @return Promise<undefined> resolved when the tab is successfully removed.
|
||||
*/
|
||||
function removeTab(tab) {
|
||||
info("Removing tab.");
|
||||
return new Promise(resolve => {
|
||||
let tabContainer = gBrowser.tabContainer;
|
||||
tabContainer.addEventListener("TabClose", function onClose(aEvent) {
|
||||
tabContainer.removeEventListener("TabClose", onClose, false);
|
||||
info("Tab removed and finished closing.");
|
||||
resolve();
|
||||
}, false);
|
||||
|
||||
gBrowser.removeTab(tab);
|
||||
});
|
||||
}
|
||||
|
||||
function synthesizeKeyFromKeyTag(aKeyId, document) {
|
||||
let key = document.getElementById(aKeyId);
|
||||
isnot(key, null, "Successfully retrieved the <key> node");
|
||||
|
@ -19,10 +19,10 @@ var gToolbox, gTarget, gFront;
|
||||
*/
|
||||
const MemoryController = {
|
||||
initialize: Task.async(function *() {
|
||||
yield gFront.attach();
|
||||
|
||||
}),
|
||||
|
||||
destroy: Task.async(function *() {
|
||||
yield gFront.detach();
|
||||
|
||||
})
|
||||
};
|
||||
|
@ -12,4 +12,3 @@ DevToolsModules(
|
||||
)
|
||||
|
||||
MOCHITEST_CHROME_MANIFESTS += ['test/mochitest/chrome.ini']
|
||||
BROWSER_CHROME_MANIFESTS += ['test/browser/browser.ini']
|
||||
|
@ -26,19 +26,14 @@ MemoryPanel.prototype = {
|
||||
|
||||
this.panelWin.gToolbox = this._toolbox;
|
||||
this.panelWin.gTarget = this.target;
|
||||
|
||||
const rootForm = yield this.target.root;
|
||||
this.panelWin.gFront = new MemoryFront(this.target.client,
|
||||
this.target.form,
|
||||
rootForm);
|
||||
this.panelWin.gFront = new MemoryFront(this.target.client, this.target.form);
|
||||
|
||||
console.log(this.panelWin, this.panelWin.MemoryController);
|
||||
this._opening = this.panelWin.MemoryController.initialize().then(() => {
|
||||
return this._opening = this.panelWin.MemoryController.initialize().then(() => {
|
||||
this.isReady = true;
|
||||
this.emit("ready");
|
||||
return this;
|
||||
});
|
||||
return this._opening;
|
||||
}),
|
||||
|
||||
// DevToolPanel API
|
||||
@ -53,14 +48,12 @@ MemoryPanel.prototype = {
|
||||
return this._destroyer;
|
||||
}
|
||||
|
||||
this._destroyer = this.panelWin.MemoryController.destroy().then(() => {
|
||||
return this._destroyer = this.panelWin.MemoryController.destroy().then(() => {
|
||||
// Destroy front to ensure packet handler is removed from client
|
||||
this.panelWin.gFront.destroy();
|
||||
this.panelWin = null;
|
||||
this.emit("destroyed");
|
||||
return this;
|
||||
});
|
||||
return this._destroyer;
|
||||
}
|
||||
};
|
||||
|
||||
|
@ -1,7 +0,0 @@
|
||||
[DEFAULT]
|
||||
tags = devtools
|
||||
subsuite = devtools
|
||||
support-files =
|
||||
head.js
|
||||
|
||||
[browser_memory_transferHeapSnapshot_e10s_01.js]
|
@ -1,28 +0,0 @@
|
||||
/* Any copyright is dedicated to the Public Domain.
|
||||
http://creativecommons.org/publicdomain/zero/1.0/ */
|
||||
|
||||
// Test that we can save a heap snapshot and transfer it over the RDP in e10s
|
||||
// where the child process is sandboxed and so we have to use
|
||||
// HeapSnapshotFileActor to get the heap snapshot file.
|
||||
|
||||
"use strict";
|
||||
|
||||
const TEST_URL = "data:text/html,<html><body></body></html>";
|
||||
|
||||
this.test = makeMemoryTest(TEST_URL, function* ({ tab, panel }) {
|
||||
const memoryFront = panel.panelWin.gFront;
|
||||
ok(memoryFront, "Should get the MemoryFront");
|
||||
|
||||
const snapshotFilePath = yield memoryFront.saveHeapSnapshot({
|
||||
// Force a copy so that we go through the HeapSnapshotFileActor's
|
||||
// transferHeapSnapshot request and exercise this code path on e10s.
|
||||
forceCopy: true
|
||||
});
|
||||
|
||||
ok(!!(yield OS.File.stat(snapshotFilePath)),
|
||||
"Should have the heap snapshot file");
|
||||
|
||||
const snapshot = ChromeUtils.readHeapSnapshot(snapshotFilePath);
|
||||
ok(snapshot instanceof HeapSnapshot,
|
||||
"And we should be able to read a HeapSnapshot instance from the file");
|
||||
});
|
@ -1,65 +0,0 @@
|
||||
/* Any copyright is dedicated to the Public Domain.
|
||||
http://creativecommons.org/publicdomain/zero/1.0/ */
|
||||
|
||||
"use strict";
|
||||
|
||||
// Load the shared test helpers into this compartment.
|
||||
Services.scriptloader.loadSubScript(
|
||||
"chrome://mochitests/content/browser/devtools/client/framework/test/shared-head.js",
|
||||
this);
|
||||
|
||||
Services.prefs.setBoolPref("devtools.memory.enabled", true);
|
||||
|
||||
/**
|
||||
* Open the memory panel for the given tab.
|
||||
*/
|
||||
this.openMemoryPanel = Task.async(function* (tab) {
|
||||
info("Opening memory panel.");
|
||||
const target = TargetFactory.forTab(tab);
|
||||
const toolbox = yield gDevTools.showToolbox(target, "memory");
|
||||
info("Memory panel shown successfully.");
|
||||
let panel = toolbox.getCurrentPanel();
|
||||
return { tab, panel };
|
||||
});
|
||||
|
||||
/**
|
||||
* Close the memory panel for the given tab.
|
||||
*/
|
||||
this.closeMemoryPanel = Task.async(function* (tab) {
|
||||
info("Closing memory panel.");
|
||||
const target = TargetFactory.forTab(tab);
|
||||
const toolbox = gDevTools.getToolbox(target);
|
||||
yield toolbox.destroy();
|
||||
info("Closed memory panel successfully.");
|
||||
});
|
||||
|
||||
/**
|
||||
* Return a test function that adds a tab with the given url, opens the memory
|
||||
* panel, runs the given generator, closes the memory panel, removes the tab,
|
||||
* and finishes.
|
||||
*
|
||||
* Example usage:
|
||||
*
|
||||
* this.test = makeMemoryTest(TEST_URL, function* ({ tab, panel }) {
|
||||
* // Your tests go here...
|
||||
* });
|
||||
*/
|
||||
function makeMemoryTest(url, generator) {
|
||||
return Task.async(function* () {
|
||||
waitForExplicitFinish();
|
||||
|
||||
const tab = yield addTab(url);
|
||||
const results = yield openMemoryPanel(tab);
|
||||
|
||||
try {
|
||||
yield* generator(results);
|
||||
} catch (err) {
|
||||
ok(false, "Got an error: " + DevToolsUtils.safeErrorString(err));
|
||||
}
|
||||
|
||||
yield closeMemoryPanel(tab);
|
||||
yield removeTab(tab);
|
||||
|
||||
finish();
|
||||
});
|
||||
}
|
@ -1,74 +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/. */
|
||||
|
||||
"use strict";
|
||||
|
||||
const protocol = require("devtools/server/protocol");
|
||||
const { method, Arg } = protocol;
|
||||
const Services = require("Services");
|
||||
|
||||
loader.lazyRequireGetter(this, "DevToolsUtils",
|
||||
"devtools/shared/DevToolsUtils");
|
||||
loader.lazyRequireGetter(this, "OS", "resource://gre/modules/osfile.jsm", true);
|
||||
loader.lazyRequireGetter(this, "Task", "resource://gre/modules/Task.jsm", true);
|
||||
loader.lazyRequireGetter(this, "HeapSnapshotFileUtils",
|
||||
"devtools/shared/heapsnapshot/HeapSnapshotFileUtils");
|
||||
|
||||
/**
|
||||
* The HeapSnapshotFileActor handles transferring heap snapshot files from the
|
||||
* server to the client. This has to be a global actor in the parent process
|
||||
* because child processes are sandboxed and do not have access to the file
|
||||
* system.
|
||||
*/
|
||||
exports.HeapSnapshotFileActor = protocol.ActorClass({
|
||||
typeName: "heapSnapshotFile",
|
||||
|
||||
initialize: function (conn, parent) {
|
||||
if (Services.appInfo &&
|
||||
(Services.appInfo.processType !==
|
||||
Services.appInfo.PROCESS_TYPE_DEFAULT)) {
|
||||
const err = new Error("Attempt to create a HeapSnapshotFileActor in a " +
|
||||
"child process! The HeapSnapshotFileActor *MUST* " +
|
||||
"be in the parent process!");
|
||||
DevToolsUtils.reportException(
|
||||
"HeapSnapshotFileActor.prototype.initialize", err);
|
||||
return;
|
||||
}
|
||||
|
||||
protocol.Actor.prototype.initialize.call(this, conn, parent);
|
||||
},
|
||||
|
||||
/**
|
||||
* @see MemoryFront.prototype.transferHeapSnapshot
|
||||
*/
|
||||
transferHeapSnapshot: method(Task.async(function* (snapshotId) {
|
||||
const snapshotFilePath =
|
||||
HeapSnapshotFileUtils.getHeapSnapshotTempFilePath(snapshotId);
|
||||
if (!snapshotFilePath) {
|
||||
throw new Error(`No heap snapshot with id: ${snapshotId}`);
|
||||
}
|
||||
|
||||
const streamPromise = DevToolsUtils.openFileStream(snapshotFilePath);
|
||||
|
||||
const { size } = yield OS.File.stat(snapshotFilePath);
|
||||
const bulkPromise = this.conn.startBulkSend({
|
||||
actor: this.actorID,
|
||||
type: "heap-snapshot",
|
||||
length: size
|
||||
});
|
||||
|
||||
const [bulk, stream] = yield Promise.all([bulkPromise, streamPromise]);
|
||||
|
||||
try {
|
||||
yield bulk.copyFrom(stream);
|
||||
} finally {
|
||||
stream.close();
|
||||
}
|
||||
}), {
|
||||
request: {
|
||||
snapshotId: Arg(0, "string")
|
||||
}
|
||||
}),
|
||||
|
||||
});
|
@ -5,6 +5,7 @@
|
||||
"use strict";
|
||||
|
||||
const { Cc, Ci, Cu, components } = require("chrome");
|
||||
const { openFileStream } = require("devtools/shared/DevToolsUtils");
|
||||
const protocol = require("devtools/server/protocol");
|
||||
const { method, RetVal, Arg, types } = protocol;
|
||||
const { Memory } = require("devtools/shared/shared/memory");
|
||||
@ -16,6 +17,7 @@ loader.lazyRequireGetter(this, "FileUtils",
|
||||
"resource://gre/modules/FileUtils.jsm", true);
|
||||
loader.lazyRequireGetter(this, "NetUtil", "resource://gre/modules/NetUtil.jsm", true);
|
||||
loader.lazyRequireGetter(this, "Task", "resource://gre/modules/Task.jsm", true);
|
||||
loader.lazyRequireGetter(this, "OS", "resource://gre/modules/osfile.jsm", true);
|
||||
loader.lazyRequireGetter(this, "HeapSnapshotFileUtils",
|
||||
"devtools/shared/heapsnapshot/HeapSnapshotFileUtils");
|
||||
loader.lazyRequireGetter(this, "ThreadSafeChromeUtils");
|
||||
@ -113,6 +115,35 @@ var MemoryActor = exports.MemoryActor = protocol.ActorClass({
|
||||
}
|
||||
}),
|
||||
|
||||
transferHeapSnapshot: method(Task.async(function* (snapshotId) {
|
||||
const snapshotFilePath =
|
||||
HeapSnapshotFileUtils.getHeapSnapshotTempFilePath(snapshotId);
|
||||
if (!snapshotFilePath) {
|
||||
throw new Error(`No heap snapshot with id: ${snapshotId}`);
|
||||
}
|
||||
|
||||
const streamPromise = openFileStream(snapshotFilePath);
|
||||
|
||||
const { size } = yield OS.File.stat(snapshotFilePath);
|
||||
const bulkPromise = this.conn.startBulkSend({
|
||||
actor: this.actorID,
|
||||
type: "heap-snapshot",
|
||||
length: size
|
||||
});
|
||||
|
||||
const [bulk, stream] = yield Promise.all([bulkPromise, streamPromise]);
|
||||
|
||||
try {
|
||||
yield bulk.copyFrom(stream);
|
||||
} finally {
|
||||
stream.close();
|
||||
}
|
||||
}), {
|
||||
request: {
|
||||
snapshotId: Arg(0, "string")
|
||||
}
|
||||
}),
|
||||
|
||||
takeCensus: actorBridge("takeCensus", {
|
||||
request: {},
|
||||
response: RetVal("json")
|
||||
@ -182,11 +213,10 @@ var MemoryActor = exports.MemoryActor = protocol.ActorClass({
|
||||
});
|
||||
|
||||
exports.MemoryFront = protocol.FrontClass(MemoryActor, {
|
||||
initialize: function(client, form, rootForm) {
|
||||
initialize: function(client, form) {
|
||||
protocol.Front.prototype.initialize.call(this, client, form);
|
||||
this._client = client;
|
||||
this.actorID = form.memoryActor;
|
||||
this.heapSnapshotFileActorID = rootForm.heapSnapshotFileActor;
|
||||
this.manage(this);
|
||||
},
|
||||
|
||||
@ -195,8 +225,9 @@ exports.MemoryFront = protocol.FrontClass(MemoryActor, {
|
||||
* server and client do not share a file system, and return the local file
|
||||
* path to the heap snapshot.
|
||||
*
|
||||
* Note that this is safe to call for actors inside sandoxed child processes,
|
||||
* as we jump through the correct IPDL hoops.
|
||||
* NB: This will not work with sandboxed child processes, as they do not have
|
||||
* access to the filesystem and the hep snapshot APIs do not support that use
|
||||
* case yet.
|
||||
*
|
||||
* @params Boolean options.forceCopy
|
||||
* Always force a bulk data copy of the saved heap snapshot, even when
|
||||
@ -228,7 +259,7 @@ exports.MemoryFront = protocol.FrontClass(MemoryActor, {
|
||||
*/
|
||||
transferHeapSnapshot: protocol.custom(function (snapshotId) {
|
||||
const request = this._client.request({
|
||||
to: this.heapSnapshotFileActorID,
|
||||
to: this.actorID,
|
||||
type: "transferHeapSnapshot",
|
||||
snapshotId
|
||||
});
|
||||
|
@ -26,7 +26,6 @@ DevToolsModules(
|
||||
'eventlooplag.js',
|
||||
'framerate.js',
|
||||
'gcli.js',
|
||||
'heap-snapshot-file.js',
|
||||
'highlighters.css',
|
||||
'highlighters.js',
|
||||
'inspector.js',
|
||||
|
@ -413,11 +413,6 @@ var DebuggerServer = {
|
||||
constructor: "DirectorRegistryActor",
|
||||
type: { global: true }
|
||||
});
|
||||
this.registerModule("devtools/server/actors/heap-snapshot-file", {
|
||||
prefix: "heapSnapshotFile",
|
||||
constructor: "HeapSnapshotFileActor",
|
||||
type: { global: true }
|
||||
});
|
||||
},
|
||||
|
||||
/**
|
||||
|
@ -36,7 +36,7 @@ function startServerAndGetSelectedTabMemory() {
|
||||
}
|
||||
|
||||
var form = response.tabs[response.selected];
|
||||
var memory = MemoryFront(client, form, response);
|
||||
var memory = MemoryFront(client, form);
|
||||
|
||||
resolve({ memory, client });
|
||||
});
|
||||
|
@ -52,21 +52,10 @@ function makeMemoryActorTest(testGeneratorFunction) {
|
||||
return function run_test() {
|
||||
do_test_pending();
|
||||
startTestDebuggerServer(TEST_GLOBAL_NAME).then(client => {
|
||||
DebuggerServer.registerModule("devtools/server/actors/heap-snapshot-file", {
|
||||
prefix: "heapSnapshotFile",
|
||||
constructor: "HeapSnapshotFileActor",
|
||||
type: { global: true }
|
||||
});
|
||||
|
||||
getTestTab(client, TEST_GLOBAL_NAME, function (tabForm, rootForm) {
|
||||
if (!tabForm || !rootForm) {
|
||||
ok(false, "Could not attach to test tab: " + TEST_GLOBAL_NAME);
|
||||
return;
|
||||
}
|
||||
|
||||
getTestTab(client, TEST_GLOBAL_NAME, function (tabForm) {
|
||||
Task.spawn(function* () {
|
||||
try {
|
||||
const memoryFront = new MemoryFront(client, tabForm, rootForm);
|
||||
const memoryFront = new MemoryFront(client, tabForm);
|
||||
yield memoryFront.attach();
|
||||
yield* testGeneratorFunction(client, memoryFront);
|
||||
yield memoryFront.detach();
|
||||
@ -305,7 +294,7 @@ function getTestTab(aClient, aTitle, aCallback) {
|
||||
aClient.listTabs(function (aResponse) {
|
||||
for (let tab of aResponse.tabs) {
|
||||
if (tab.title === aTitle) {
|
||||
aCallback(tab, aResponse);
|
||||
aCallback(tab);
|
||||
return;
|
||||
}
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user