1.1 --- /dev/null Thu Jan 01 00:00:00 1970 +0000 1.2 +++ b/dom/mobilemessage/tests/marionette/test_incoming_multipart.js Wed Dec 31 06:09:35 2014 +0100 1.3 @@ -0,0 +1,115 @@ 1.4 +/* Any copyright is dedicated to the Public Domain. 1.5 + * http://creativecommons.org/publicdomain/zero/1.0/ */ 1.6 + 1.7 +MARIONETTE_TIMEOUT = 60000; 1.8 + 1.9 +SpecialPowers.setBoolPref("dom.sms.enabled", true); 1.10 +SpecialPowers.addPermission("sms", true, document); 1.11 + 1.12 +const SENDER = "5555552368"; // the remote number 1.13 +const RECEIVER = "15555215554"; // the emulator's number 1.14 + 1.15 +let manager = window.navigator.mozMobileMessage; 1.16 + 1.17 +function verifyInitialState() { 1.18 + log("Verifying initial state."); 1.19 + ok(manager instanceof MozMobileMessageManager, 1.20 + "manager is instance of " + manager.constructor); 1.21 + simulateIncomingSms(); 1.22 +} 1.23 + 1.24 +function simulateIncomingSms() { 1.25 + let msgText = ""; 1.26 + 1.27 + log("Simulating incoming SMS."); 1.28 + 1.29 + // Have message text > max SMS size (160 char) so will be a multi-part SMS 1.30 + for (var x = 1; x <= 24; x++) { 1.31 + msgText += 'FirefoxOS '; 1.32 + } 1.33 + 1.34 + manager.onreceived = function onreceived(event) { 1.35 + log("Received 'onreceived' event."); 1.36 + let incomingSms = event.message; 1.37 + ok(incomingSms, "incoming sms"); 1.38 + ok(incomingSms.id, "sms id"); 1.39 + log("Received SMS (id: " + incomingSms.id + ")."); 1.40 + ok(incomingSms.threadId, "thread id"); 1.41 + is(incomingSms.body, msgText, "msg body"); 1.42 + is(incomingSms.delivery, "received", "delivery"); 1.43 + is(incomingSms.read, false, "read"); 1.44 + is(incomingSms.receiver, RECEIVER, "receiver"); 1.45 + is(incomingSms.sender, SENDER, "sender"); 1.46 + is(incomingSms.deliveryTimestamp, 0, "deliveryTimestamp is 0"); 1.47 + 1.48 + verifySmsExists(incomingSms); 1.49 + }; 1.50 + runEmulatorCmd("sms send " + SENDER + " " + msgText, function(result) { 1.51 + is(result[0], "OK", "emulator output"); 1.52 + }); 1.53 +} 1.54 + 1.55 +function verifySmsExists(incomingSms) { 1.56 + log("Getting SMS (id: " + incomingSms.id + ")."); 1.57 + let requestRet = manager.getMessage(incomingSms.id); 1.58 + ok(requestRet, "smsrequest obj returned"); 1.59 + 1.60 + requestRet.onsuccess = function(event) { 1.61 + log("Received 'onsuccess' smsrequest event."); 1.62 + ok(event.target.result, "smsrequest event.target.result"); 1.63 + let foundSms = event.target.result; 1.64 + is(foundSms.id, incomingSms.id, "found SMS id matches"); 1.65 + is(foundSms.threadId, incomingSms.threadId, "found SMS thread id matches"); 1.66 + is(foundSms.body, incomingSms.body, "found SMS msg text matches"); 1.67 + is(foundSms.delivery, "received", "delivery"); 1.68 + is(foundSms.read, false, "read"); 1.69 + is(foundSms.receiver, RECEIVER, "receiver"); 1.70 + is(foundSms.sender, SENDER, "sender"); 1.71 + log("Got SMS (id: " + foundSms.id + ") as expected."); 1.72 + deleteSms(incomingSms); 1.73 + }; 1.74 + 1.75 + requestRet.onerror = function(event) { 1.76 + log("Received 'onerror' smsrequest event."); 1.77 + ok(event.target.error, "domerror obj"); 1.78 + is(event.target.error.name, "NotFoundError", "error returned"); 1.79 + log("Could not get SMS (id: " + incomingSms.id + ") but should have."); 1.80 + ok(false,"SMS was not found"); 1.81 + cleanUp(); 1.82 + }; 1.83 +} 1.84 + 1.85 +function deleteSms(smsMsgObj){ 1.86 + log("Deleting SMS (id: " + smsMsgObj.id + ") using smsmsg obj parameter."); 1.87 + let requestRet = manager.delete(smsMsgObj); 1.88 + ok(requestRet,"smsrequest obj returned"); 1.89 + 1.90 + requestRet.onsuccess = function(event) { 1.91 + log("Received 'onsuccess' smsrequest event."); 1.92 + if(event.target.result){ 1.93 + cleanUp(); 1.94 + } else { 1.95 + log("smsrequest returned false for manager.delete"); 1.96 + ok(false,"SMS delete failed"); 1.97 + cleanUp(); 1.98 + } 1.99 + }; 1.100 + 1.101 + requestRet.onerror = function(event) { 1.102 + log("Received 'onerror' smsrequest event."); 1.103 + ok(event.target.error, "domerror obj"); 1.104 + ok(false, "manager.delete request returned unexpected error: " 1.105 + + event.target.error.name ); 1.106 + cleanUp(); 1.107 + }; 1.108 +} 1.109 + 1.110 +function cleanUp() { 1.111 + manager.onreceived = null; 1.112 + SpecialPowers.removePermission("sms", document); 1.113 + SpecialPowers.clearUserPref("dom.sms.enabled"); 1.114 + finish(); 1.115 +} 1.116 + 1.117 +// Start the test 1.118 +verifyInitialState();