1.1 --- /dev/null Thu Jan 01 00:00:00 1970 +0000 1.2 +++ b/dom/mobilemessage/tests/marionette/test_outgoing_delete.js Wed Dec 31 06:09:35 2014 +0100 1.3 @@ -0,0 +1,163 @@ 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.setBoolPref("dom.sms.requestStatusReport", true); 1.11 +SpecialPowers.addPermission("sms", true, document); 1.12 + 1.13 +const SENDER = "15555215554"; // the emulator's number 1.14 +const RECEIVER = "5551117777"; // the destination number 1.15 + 1.16 +let manager = window.navigator.mozMobileMessage; 1.17 +let msgText = "Mozilla Firefox OS!"; 1.18 +let gotSmsOnsent = false; 1.19 +let gotReqOnsuccess = false; 1.20 + 1.21 +function verifyInitialState() { 1.22 + log("Verifying initial state."); 1.23 + ok(manager instanceof MozMobileMessageManager, 1.24 + "manager is instance of " + manager.constructor); 1.25 + sendSms(); 1.26 +} 1.27 + 1.28 +function sendSms() { 1.29 + let smsId = 0; 1.30 + 1.31 + log("Sending an SMS."); 1.32 + manager.onsent = function(event) { 1.33 + log("Received 'onsent' event."); 1.34 + gotSmsOnsent = true; 1.35 + let sentSms = event.message; 1.36 + ok(sentSms, "outgoing sms"); 1.37 + ok(sentSms.id, "sms id"); 1.38 + smsId = sentSms.id; 1.39 + log("Sent SMS (id: " + smsId + ")."); 1.40 + ok(sentSms.threadId, "thread id"); 1.41 + is(sentSms.body, msgText, "msg body"); 1.42 + is(sentSms.delivery, "sent", "delivery"); 1.43 + is(sentSms.deliveryStatus, "pending", "deliveryStatus"); 1.44 + is(sentSms.read, true, "read"); 1.45 + is(sentSms.receiver, RECEIVER, "receiver"); 1.46 + is(sentSms.sender, SENDER, "sender"); 1.47 + is(sentSms.messageClass, "normal", "messageClass"); 1.48 + is(sentSms.deliveryTimestamp, 0, "deliveryTimestamp is 0"); 1.49 + 1.50 + if (gotSmsOnsent && gotReqOnsuccess) { verifySmsExists(smsId); } 1.51 + }; 1.52 + 1.53 + let requestRet = manager.send(RECEIVER, msgText); 1.54 + ok(requestRet, "smsrequest obj returned"); 1.55 + 1.56 + requestRet.onsuccess = function(event) { 1.57 + log("Received 'onsuccess' smsrequest event."); 1.58 + gotReqOnsuccess = true; 1.59 + if(event.target.result){ 1.60 + if (gotSmsOnsent && gotReqOnsuccess) { verifySmsExists(smsId); } 1.61 + } else { 1.62 + log("smsrequest returned false for manager.send"); 1.63 + ok(false,"SMS send failed"); 1.64 + cleanUp(); 1.65 + } 1.66 + }; 1.67 + 1.68 + requestRet.onerror = function(event) { 1.69 + log("Received 'onerror' smsrequest event."); 1.70 + ok(event.target.error, "domerror obj"); 1.71 + ok(false, "manager.send request returned unexpected error: " 1.72 + + event.target.error.name ); 1.73 + cleanUp(); 1.74 + }; 1.75 +} 1.76 + 1.77 +function verifySmsExists(smsId) { 1.78 + log("Getting SMS (id: " + smsId + ")."); 1.79 + let requestRet = manager.getMessage(smsId); 1.80 + ok(requestRet, "smsrequest obj returned"); 1.81 + 1.82 + requestRet.onsuccess = function(event) { 1.83 + log("Received 'onsuccess' smsrequest event."); 1.84 + ok(event.target.result, "smsrequest event.target.result"); 1.85 + let foundSms = event.target.result; 1.86 + is(foundSms.id, smsId, "found SMS id matches"); 1.87 + is(foundSms.body, msgText, "found SMS msg text matches"); 1.88 + is(foundSms.delivery, "sent", "delivery"); 1.89 + is(foundSms.read, true, "read"); 1.90 + is(foundSms.receiver, RECEIVER, "receiver"); 1.91 + is(foundSms.sender, SENDER, "sender"); 1.92 + is(foundSms.messageClass, "normal", "messageClass"); 1.93 + log("Got SMS (id: " + foundSms.id + ") as expected."); 1.94 + deleteSms(smsId); 1.95 + }; 1.96 + 1.97 + requestRet.onerror = function(event) { 1.98 + log("Received 'onerror' smsrequest event."); 1.99 + ok(event.target.error, "domerror obj"); 1.100 + is(event.target.error.name, "NotFoundError", "error returned"); 1.101 + log("Could not get SMS (id: " + smsId + ") but should have."); 1.102 + ok(false,"SMS was not found"); 1.103 + cleanUp(); 1.104 + }; 1.105 +} 1.106 + 1.107 +function deleteSms(smsId){ 1.108 + log("Deleting SMS (id: " + smsId + ") using sms id parameter."); 1.109 + let requestRet = manager.delete(smsId); 1.110 + ok(requestRet,"smsrequest obj returned"); 1.111 + 1.112 + requestRet.onsuccess = function(event) { 1.113 + log("Received 'onsuccess' smsrequest event."); 1.114 + if(event.target.result){ 1.115 + verifySmsDeleted(smsId); 1.116 + } else { 1.117 + log("smsrequest returned false for manager.delete"); 1.118 + ok(false,"SMS delete failed"); 1.119 + cleanUp(); 1.120 + } 1.121 + }; 1.122 + 1.123 + requestRet.onerror = function(event) { 1.124 + log("Received 'onerror' smsrequest event."); 1.125 + ok(event.target.error, "domerror obj"); 1.126 + ok(false, "manager.delete request returned unexpected error: " 1.127 + + event.target.error.name ); 1.128 + cleanUp(); 1.129 + }; 1.130 +} 1.131 + 1.132 +function verifySmsDeleted(smsId) { 1.133 + log("Getting SMS (id: " + smsId + ")."); 1.134 + let requestRet = manager.getMessage(smsId); 1.135 + ok(requestRet, "smsrequest obj returned"); 1.136 + 1.137 + requestRet.onsuccess = function(event) { 1.138 + log("Received 'onsuccess' smsrequest event."); 1.139 + ok(event.target.result, "smsrequest event.target.result"); 1.140 + let foundSms = event.target.result; 1.141 + is(foundSms.id, smsId, "found SMS id matches"); 1.142 + is(foundSms.body, msgText, "found SMS msg text matches"); 1.143 + log("Got SMS (id: " + foundSms.id + ") but should not have."); 1.144 + ok(false, "SMS was not deleted"); 1.145 + cleanUp(); 1.146 + }; 1.147 + 1.148 + requestRet.onerror = function(event) { 1.149 + log("Received 'onerror' smsrequest event."); 1.150 + ok(event.target.error, "domerror obj"); 1.151 + is(event.target.error.name, "NotFoundError", "error returned"); 1.152 + log("Could not get SMS (id: " + smsId + ") as expected."); 1.153 + cleanUp(); 1.154 + }; 1.155 +} 1.156 + 1.157 +function cleanUp() { 1.158 + manager.onsent = null; 1.159 + SpecialPowers.removePermission("sms", document); 1.160 + SpecialPowers.clearUserPref("dom.sms.enabled"); 1.161 + SpecialPowers.clearUserPref("dom.sms.requestStatusReport"); 1.162 + finish(); 1.163 +} 1.164 + 1.165 +// Start the test 1.166 +verifyInitialState();