gecko/dom/telephony/test/marionette/test_outgoing_reject.js

78 lines
1.9 KiB
JavaScript
Raw Normal View History

/* Any copyright is dedicated to the Public Domain.
* http://creativecommons.org/publicdomain/zero/1.0/ */
MARIONETTE_TIMEOUT = 10000;
const WHITELIST_PREF = "dom.telephony.app.phone.url";
SpecialPowers.setCharPref(WHITELIST_PREF, window.location.href);
let telephony = window.navigator.mozTelephony;
let number = "5555552368";
let outgoing;
let calls;
function verifyInitialState() {
log("Verifying initial state.");
ok(telephony);
is(telephony.active, null);
ok(telephony.calls);
is(telephony.calls.length, 0);
calls = telephony.calls;
runEmulatorCmd("gsm list", function(result) {
log("Initial call list: " + result);
is(result[0], "OK");
dial();
});
}
function dial() {
log("Make an outgoing call.");
outgoing = telephony.dial(number);
ok(outgoing);
is(outgoing.number, number);
is(outgoing.state, "dialing");
//is(outgoing, telephony.active); // bug 757587
//ok(telephony.calls === calls); // bug 757587
//is(calls.length, 1); // bug 757587
//is(calls[0], outgoing); // bug 757587
runEmulatorCmd("gsm list", function(result) {
log("Call list is now: " + result);
is(result[0], "outbound to " + number + " : unknown");
is(result[1], "OK");
reject();
});
}
function reject() {
log("Reject the outgoing call on the other end.");
// We get no "disconnecting" event when the remote party rejects the call.
outgoing.ondisconnected = function ondisconnected(event) {
log("Received 'disconnected' call event.");
is(outgoing, event.call);
is(outgoing.state, "disconnected");
//is(telephony.active, null); // bug 757587
is(telephony.calls.length, 0);
runEmulatorCmd("gsm list", function(result) {
log("Call list is now: " + result);
is(result[0], "OK");
cleanUp();
});
};
runEmulatorCmd("gsm cancel " + number);
};
function cleanUp() {
SpecialPowers.clearUserPref(WHITELIST_PREF);
finish();
}
verifyInitialState();