Bug 1159238. Generate UUID internally to ContentSender

r=dburns
This commit is contained in:
Andreas Tolfsen 2015-04-28 18:15:08 +01:00
parent 5d21719632
commit 8f3ff4e71b
3 changed files with 30 additions and 27 deletions

View File

@ -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") {

View File

@ -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:

View File

@ -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;