tenfourfox/devtools/server/tests/unit/test_protocol_stack.js
Cameron Kaiser c9b2922b70 hello FPR
2017-04-19 00:56:45 -07:00

92 lines
2.2 KiB
JavaScript

/* Any copyright is dedicated to the Public Domain.
http://creativecommons.org/publicdomain/zero/1.0/ */
"use strict";
/**
* Client request stacks should span the entire process from before making the
* request to handling the reply from the server. The server frames are not
* included, nor can they be in most cases, since the server can be a remote
* device.
*/
var protocol = require("devtools/server/protocol");
var {method, Arg, Option, RetVal} = protocol;
var events = require("sdk/event/core");
function simpleHello() {
return {
from: "root",
applicationType: "xpcshell-tests",
traits: [],
};
}
var RootActor = protocol.ActorClass({
typeName: "root",
initialize: function(conn) {
protocol.Actor.prototype.initialize.call(this, conn);
// Root actor owns itself.
this.manage(this);
this.actorID = "root";
this.sequence = 0;
},
sayHello: simpleHello,
simpleReturn: method(function() {
return this.sequence++;
}, {
response: { value: RetVal() },
})
});
var RootFront = protocol.FrontClass(RootActor, {
initialize: function(client) {
this.actorID = "root";
protocol.Front.prototype.initialize.call(this, client);
// Root owns itself.
this.manage(this);
}
});
function run_test() {
if (!Services.prefs.getBoolPref("javascript.options.asyncstack")) {
do_print("Async stacks are disabled.");
return;
}
DebuggerServer.createRootActor = RootActor;
DebuggerServer.init();
let trace = connectPipeTracing();
let client = new DebuggerClient(trace);
let rootClient;
client.connect(function onConnect() {
rootClient = RootFront(client);
rootClient.simpleReturn().then(() => {
let stack = Components.stack;
while (stack) {
do_print(stack.name);
if (stack.name == "onConnect") {
// Reached back to outer function before request
ok(true, "Complete stack");
return;
}
stack = stack.asyncCaller || stack.caller;
}
ok(false, "Incomplete stack");
}, () => {
ok(false, "Request failed unexpectedly");
}).then(() => {
client.close(() => {
do_test_finished();
});
})
});
do_test_pending();
}