gecko/dom/mobilemessage/tests/marionette/test_mark_msg_read.js
2013-07-26 18:40:27 +08:00

229 lines
6.6 KiB
JavaScript

/* Any copyright is dedicated to the Public Domain.
* http://creativecommons.org/publicdomain/zero/1.0/ */
MARIONETTE_TIMEOUT = 60000;
SpecialPowers.addPermission("sms", true, document);
SpecialPowers.setBoolPref("dom.sms.enabled", true);
let manager = window.navigator.mozMobileMessage;
let smsList = new Array();
function verifyInitialState() {
log("Verifying initial state.");
ok(manager instanceof MozMobileMessageManager,
"manager is instance of " + manager.constructor);
simulateIncomingSms();
}
function simulateIncomingSms() {
let text = "Incoming SMS courtesy of Firefox OS";
let remoteNumber = "5557779999";
log("Simulating incoming SMS.");
// Simulate incoming SMS sent from remoteNumber to our emulator
rcvdEmulatorCallback = false;
runEmulatorCmd("sms send " + remoteNumber + " " + text, function(result) {
is(result[0], "OK", "emulator callback");
rcvdEmulatorCallback = true;
});
}
// Callback for incoming SMS
manager.onreceived = function onreceived(event) {
log("Received 'onreceived' sms event.");
let incomingSms = event.message;
log("Received SMS (id: " + incomingSms.id + ").");
is(incomingSms.read, false, "incoming message read");
log("SMS read attribute: " + incomingSms.read + ".");
// Add newly received message id to array of msgs
smsList.push(incomingSms.id);
// Wait for emulator to catch up before continuing
waitFor(sendSms, function() {
return(rcvdEmulatorCallback);
});
};
function sendSms() {
let gotSmsSent = false;
let gotRequestSuccess = false;
let remoteNumber = "5557779999";
let text = "Mo Mo Mo Zilla Zilla Zilla!";
log("Sending an SMS.");
manager.onsent = function(event) {
log("Received 'onsent' event.");
gotSmsSent = true;
let sentSms = event.message;
log("Sent SMS (id: " + sentSms.id + ").");
is(sentSms.read, true, "sent sms read");
log("SMS read attribute: " + sentSms.read + ".");
// Add newly received message id to array of msgs
smsList.push(sentSms.id);
if (gotSmsSent && gotRequestSuccess) {
test1();
}
};
let request = manager.send(remoteNumber, text);
request.onsuccess = function(event) {
log("Received 'onsuccess' smsrequest event.");
if(event.target.result) {
gotRequestSuccess = true;
if (gotSmsSent && gotRequestSuccess) {
test1();
}
} else {
log("smsrequest returned false for manager.send");
ok(false, "SMS send failed");
deleteMsgs();
}
};
request.onerror = function(event) {
log("Received 'onerror' smsrequest event.");
ok(event.target.error, "domerror obj");
ok(false, "manager.send request returned unexpected error: "
+ event.target.error.name );
deleteMsgs();
};
}
function markMessageAndVerify(smsId, readBool, nextFunction) {
let request = manager.markMessageRead(smsId, readBool);
ok(request instanceof DOMRequest,
"request is instanceof " + request.constructor);
request.onsuccess = function(event) {
log("Received 'onsuccess' smsrequest event.");
// Success from MarkMessageRead, the result should match what we set
is(event.target.result, readBool, "result matches what was set");
// Message marked read/unread, now verify
log("Getting SMS message (id: " + smsId + ").");
let requestRet = manager.getMessage(smsId);
ok(requestRet, "smsrequest obj returned");
requestRet.onsuccess = function(event) {
log("Received 'onsuccess' smsrequest event.");
ok(event.target.result, "smsrequest event.target.result");
let foundSms = event.target.result;
is(foundSms.id, smsId, "SMS id matches");
log("SMS read attribute: " + foundSms.read + ".");
let text = readBool ? "read" : "unread";
if (foundSms.read == readBool) {
ok(true, "marked sms " + text);
} else {
ok(false, "marking sms " + text + " didn't work");
log("Expected SMS (id: " + foundSms.id + ") to be marked " + text
+ " but it is not.");
}
nextFunction();
};
requestRet.onerror = function(event) {
log("Received 'onerror' smsrequest event.");
ok(event.target.error, "domerror obj");
is(event.target.error.name, "NotFoundError", "error returned");
log("Could not get SMS (id: " + outSmsId + ") but should have.");
ok(false, "Could not get SMS");
deleteMsgs();
};
};
request.onerror = function(event) {
log("Received 'onerror' smsrequest event.");
ok(event.target.error, "domerror obj");
ok(false, "manager.markMessageRead request returned unexpected error: "
+ event.target.error.name );
nextFunction();
};
}
function test1() {
rcvdSms = smsList[0];
log("Test 1: Marking received SMS (id: " + rcvdSms + ") read.");
markMessageAndVerify(rcvdSms, true, test2);
}
function test2() {
rcvdSms = smsList[0];
log("Test 2: Marking received SMS (id: " + rcvdSms + ") unread.");
markMessageAndVerify(rcvdSms, false, test3);
}
function test3() {
sentSms = smsList[1];
log("Test 3: Marking sent SMS (id: " + sentSms + ") unread.");
markMessageAndVerify(sentSms, false, test4);
}
function test4() {
sentSms = smsList[1];
log("Test 4: Marking sent SMS (id: " + sentSms + ") read.");
markMessageAndVerify(sentSms, true, test5);
}
function test5() {
sentSms = smsList[1];
log("Test 5: Marking an already read SMS (id: " + sentSms + ") read.");
markMessageAndVerify(sentSms, true, test6);
}
function test6() {
rcvdSms = smsList[0];
log("Test 6: Marking an already unread SMS (id: " + rcvdSms + ") unread.");
markMessageAndVerify(rcvdSms, false, deleteMsgs);
}
function deleteMsgs() {
let smsId = smsList.shift();
log("Deleting SMS (id: " + smsId + ").");
let request = manager.delete(smsId);
ok(request instanceof DOMRequest,
"request is instanceof " + request.constructor);
request.onsuccess = function(event) {
log("Received 'onsuccess' smsrequest event.");
if (event.target.result) {
// Message deleted, continue until none are left
if (smsList.length) {
deleteMsgs();
} else {
cleanUp();
}
} else {
log("SMS delete failed.");
ok(false, "manager.delete request returned false");
cleanUp();
}
};
request.onerror = function(event) {
log("Received 'onerror' smsrequest event.");
ok(event.target.error, "domerror obj");
ok(false, "manager.delete request returned unexpected error: "
+ event.target.error.name );
cleanUp();
};
}
function cleanUp() {
manager.onreceived = null;
SpecialPowers.removePermission("sms", document);
SpecialPowers.clearUserPref("dom.sms.enabled");
finish();
}
// Start the test
verifyInitialState();