1.1 --- /dev/null Thu Jan 01 00:00:00 1970 +0000 1.2 +++ b/dom/mobilemessage/tests/marionette/test_getmessage_notfound.js Wed Dec 31 06:09:35 2014 +0100 1.3 @@ -0,0 +1,120 @@ 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 +let manager = window.navigator.mozMobileMessage; 1.13 +let myNumber = "15555215554"; 1.14 +let inText = "Incoming SMS message. Mozilla Firefox OS!"; 1.15 +let remoteNumber = "5559997777"; 1.16 +let inSmsId = 0; 1.17 + 1.18 +function verifyInitialState() { 1.19 + log("Verifying initial state."); 1.20 + ok(manager instanceof MozMobileMessageManager, 1.21 + "manager is instance of " + manager.constructor); 1.22 + simulateIncomingSms(); 1.23 +} 1.24 + 1.25 +function simulateIncomingSms() { 1.26 + log("Simulating incoming SMS."); 1.27 + 1.28 + manager.onreceived = function onreceived(event) { 1.29 + log("Received 'onreceived' event."); 1.30 + let incomingSms = event.message; 1.31 + ok(incomingSms, "incoming sms"); 1.32 + ok(incomingSms.id, "sms id"); 1.33 + inSmsId = incomingSms.id; 1.34 + log("Received SMS (id: " + inSmsId + ")."); 1.35 + is(incomingSms.body, inText, "msg body"); 1.36 + is(incomingSms.delivery, "received", "delivery"); 1.37 + getNonExistentMsg(); 1.38 + }; 1.39 + // Simulate incoming sms sent from remoteNumber to our emulator 1.40 + runEmulatorCmd("sms send " + remoteNumber + " " + inText, function(result) { 1.41 + is(result[0], "OK", "emulator output"); 1.42 + }); 1.43 +} 1.44 + 1.45 +function getNonExistentMsg() { 1.46 + let msgIdNoExist = inSmsId + 1; 1.47 + log("Attempting to get non-existent message (id: " + msgIdNoExist + ")."); 1.48 + let requestRet = manager.getMessage(msgIdNoExist); 1.49 + ok(requestRet, "smsrequest obj returned"); 1.50 + 1.51 + requestRet.onsuccess = function(event) { 1.52 + log("Received 'onsuccess' smsrequest event."); 1.53 + ok(event.target.result, "smsrequest event.target.result"); 1.54 + let foundSms = event.target.result; 1.55 + log("Got SMS (id: " + foundSms.id + ") but should not have."); 1.56 + ok(false, "Smsrequest successful when tried to get non-existent sms"); 1.57 + getMsgInvalidId(); 1.58 + }; 1.59 + 1.60 + requestRet.onerror = function(event) { 1.61 + log("Received 'onerror' smsrequest event."); 1.62 + ok(event.target.error, "domerror obj"); 1.63 + is(event.target.error.name, "NotFoundError", "error returned"); 1.64 + log("Could not get SMS (id: " + msgIdNoExist + ") as expected."); 1.65 + getMsgInvalidId(); 1.66 + }; 1.67 +} 1.68 + 1.69 +function getMsgInvalidId() { 1.70 + invalidId = -1; 1.71 + log("Attempting to get sms with invalid id (id: " + invalidId + ")."); 1.72 + let requestRet = manager.getMessage(invalidId); 1.73 + ok(requestRet, "smsrequest obj returned"); 1.74 + 1.75 + requestRet.onsuccess = function(event) { 1.76 + log("Received 'onsuccess' smsrequest event."); 1.77 + ok(event.target.result, "smsrequest event.target.result"); 1.78 + let foundSms = event.target.result; 1.79 + log("Got SMS (id: " + foundSms.id + ") but should not have."); 1.80 + ok(false, "Smsrequest successful when tried to get message with " + 1.81 + "invalid id (id: " + invalidId + ")."); 1.82 + deleteMsg(); 1.83 + }; 1.84 + 1.85 + requestRet.onerror = function(event) { 1.86 + log("Received 'onerror' smsrequest event."); 1.87 + ok(event.target.error, "domerror obj"); 1.88 + is(event.target.error.name, "NotFoundError", "error returned"); 1.89 + log("Could not get SMS (id: -1) as expected."); 1.90 + deleteMsg(); 1.91 + }; 1.92 +} 1.93 + 1.94 +function deleteMsg() { 1.95 + log("Deleting SMS (id: " + inSmsId + ")."); 1.96 + let requestRet = manager.delete(inSmsId); 1.97 + ok(requestRet,"smsrequest obj returned"); 1.98 + 1.99 + requestRet.onsuccess = function(event) { 1.100 + log("Received 'onsuccess' smsrequest event."); 1.101 + if(event.target.result){ 1.102 + cleanUp(); 1.103 + } 1.104 + }; 1.105 + 1.106 + requestRet.onerror = function(event) { 1.107 + log("Received 'onerror' smsrequest event."); 1.108 + ok(event.target.error, "domerror obj"); 1.109 + ok(false, "manager.delete request returned unexpected error: " 1.110 + + event.target.error.name ); 1.111 + cleanUp(); 1.112 + }; 1.113 +} 1.114 + 1.115 +function cleanUp() { 1.116 + manager.onreceived = null; 1.117 + SpecialPowers.removePermission("sms", document); 1.118 + SpecialPowers.setBoolPref("dom.sms.enabled", false); 1.119 + finish(); 1.120 +} 1.121 + 1.122 +// Start the test 1.123 +verifyInitialState();