mirror of
https://gitlab.winehq.org/wine/wine-gecko.git
synced 2024-09-13 09:24:08 -07:00
Bug 1159238. Generate UUID internally to ContentSender
r=dburns
This commit is contained in:
parent
d0288d07e7
commit
3337bfb2a9
@ -150,11 +150,6 @@ CommandProcessor.prototype.execute = function(payload, okHandler, respHandler, c
|
||||
// yet been converted to use the new form of request dispatching.
|
||||
cmd.id = cmdId;
|
||||
|
||||
// For as long as the old form of request dispatching is in use,
|
||||
// we need to tell ListenerProxy what the current command ID is
|
||||
// so that individual commands in driver.js can define it explicitly.
|
||||
this.driver.listener.curCmdId = cmd.id;
|
||||
|
||||
let req = Task.spawn(function*() {
|
||||
let fn = this.driver.commands[cmd.name];
|
||||
if (typeof fn == "undefined") {
|
||||
|
@ -1171,16 +1171,20 @@ GeckoDriver.prototype.get = function(cmd, resp) {
|
||||
|
||||
switch (this.context) {
|
||||
case Context.CONTENT:
|
||||
let get = this.listener.get({url: url, pageTimeout: this.pageTimeout});
|
||||
let id = this.listener.curId;
|
||||
|
||||
// If a remoteness update interrupts our page load, this will never return
|
||||
// We need to re-issue this request to correctly poll for readyState and
|
||||
// send errors.
|
||||
this.curBrowser.pendingCommands.push(() => {
|
||||
cmd.parameters.command_id = cmd.id;
|
||||
cmd.parameters.command_id = id;
|
||||
this.mm.broadcastAsyncMessage(
|
||||
"Marionette:pollForReadyState" + this.curBrowser.curFrameId,
|
||||
cmd.parameters);
|
||||
});
|
||||
yield this.listener.get({url: url, pageTimeout: this.pageTimeout});
|
||||
|
||||
yield get;
|
||||
break;
|
||||
|
||||
case Context.CHROME:
|
||||
|
@ -4,14 +4,19 @@
|
||||
|
||||
"use strict";
|
||||
|
||||
const {utils: Cu} = Components;
|
||||
const {classes: Cc, interfaces: Ci, utils: Cu} = Components;
|
||||
|
||||
Cu.import("resource://gre/modules/Log.jsm");
|
||||
Cu.import("chrome://marionette/content/modal.js");
|
||||
|
||||
this.EXPORTED_SYMBOLS = ["proxy"];
|
||||
|
||||
const MARIONETTE_OK = "Marionette:ok";
|
||||
const MARIONETTE_DONE = "Marionette:done";
|
||||
const MARIONETTE_ERROR = "Marionette:error";
|
||||
|
||||
const logger = Log.repository.getLogger("Marionette");
|
||||
const uuidgen = Cc["@mozilla.org/uuid-generator;1"].getService(Ci.nsIUUIDGenerator);
|
||||
|
||||
this.proxy = {};
|
||||
|
||||
@ -36,8 +41,12 @@ this.proxy = {};
|
||||
proxy.toListener = function(mmFn, sendAsyncFn) {
|
||||
let sender = new ContentSender(mmFn, sendAsyncFn);
|
||||
let handler = {
|
||||
set: (obj, prop, val) => { obj[prop] = val; return true; },
|
||||
get: (obj, prop) => (...args) => obj.send(prop, args),
|
||||
get: (obj, prop) => {
|
||||
if (obj.hasOwnProperty(prop)) {
|
||||
return obj[prop];
|
||||
}
|
||||
return (...args) => obj.send(prop, args);
|
||||
}
|
||||
};
|
||||
return new Proxy(sender, handler);
|
||||
};
|
||||
@ -60,7 +69,7 @@ proxy.toListener = function(mmFn, sendAsyncFn) {
|
||||
* Callback for sending async messages to the current listener.
|
||||
*/
|
||||
let ContentSender = function(mmFn, sendAsyncFn) {
|
||||
this.curCmdId = null;
|
||||
this.curId = null;
|
||||
this.sendAsync = sendAsyncFn;
|
||||
this.mmFn_ = mmFn;
|
||||
};
|
||||
@ -85,16 +94,15 @@ Object.defineProperty(ContentSender.prototype, "mm", {
|
||||
* A promise that resolves to the result of the command.
|
||||
*/
|
||||
ContentSender.prototype.send = function(name, args) {
|
||||
const ok = "Marionette:ok";
|
||||
const val = "Marionette:done";
|
||||
const err = "Marionette:error";
|
||||
this.curId = uuidgen.generateUUID().toString();
|
||||
|
||||
let proxy = new Promise((resolve, reject) => {
|
||||
let removeListeners = (name, fn) => {
|
||||
let removeListeners = (n, fn) => {
|
||||
let rmFn = msg => {
|
||||
if (this.isOutOfSync(msg.json.command_id)) {
|
||||
if (this.curId !== msg.json.command_id) {
|
||||
logger.warn("Skipping out-of-sync response from listener: " +
|
||||
msg.name + msg.json.toSource());
|
||||
`Expected response to \`${name}' with ID ${this.curId}, ` +
|
||||
"but got: " + msg.name + msg.json.toSource());
|
||||
return;
|
||||
}
|
||||
|
||||
@ -102,18 +110,18 @@ ContentSender.prototype.send = function(name, args) {
|
||||
modal.removeHandler(handleDialog);
|
||||
|
||||
fn(msg);
|
||||
this.curCmdId = null;
|
||||
this.curId = null;
|
||||
};
|
||||
|
||||
listeners.push([name, rmFn]);
|
||||
listeners.push([n, rmFn]);
|
||||
return rmFn;
|
||||
};
|
||||
|
||||
let listeners = [];
|
||||
listeners.add = () => {
|
||||
this.mm.addMessageListener(ok, removeListeners(ok, okListener));
|
||||
this.mm.addMessageListener(val, removeListeners(val, valListener));
|
||||
this.mm.addMessageListener(err, removeListeners(err, errListener));
|
||||
this.mm.addMessageListener(MARIONETTE_OK, removeListeners(MARIONETTE_OK, okListener));
|
||||
this.mm.addMessageListener(MARIONETTE_DONE, removeListeners(MARIONETTE_DONE, valListener));
|
||||
this.mm.addMessageListener(MARIONETTE_ERROR, removeListeners(MARIONETTE_ERROR, errListener));
|
||||
};
|
||||
listeners.remove = () =>
|
||||
listeners.map(l => this.mm.removeMessageListener(l[0], l[1]));
|
||||
@ -141,14 +149,10 @@ ContentSender.prototype.send = function(name, args) {
|
||||
msg = args[0];
|
||||
}
|
||||
|
||||
this.sendAsync(name, msg, this.curCmdId);
|
||||
this.sendAsync(name, msg, this.curId);
|
||||
});
|
||||
|
||||
return proxy;
|
||||
};
|
||||
|
||||
ContentSender.prototype.isOutOfSync = function(id) {
|
||||
return this.curCmdId !== id;
|
||||
};
|
||||
|
||||
proxy.ContentSender = ContentSender;
|
||||
|
Loading…
Reference in New Issue
Block a user