dom/mobilemessage/tests/marionette/test_mark_msg_read.js

Sat, 03 Jan 2015 20:18:00 +0100

author
Michael Schloh von Bennewitz <michael@schloh.com>
date
Sat, 03 Jan 2015 20:18:00 +0100
branch
TOR_BUG_3246
changeset 7
129ffea94266
permissions
-rw-r--r--

Conditionally enable double key logic according to:
private browsing mode or privacy.thirdparty.isolate preference and
implement in GetCookieStringCommon and FindCookie where it counts...
With some reservations of how to convince FindCookie users to test
condition and pass a nullptr when disabling double key logic.

     1 /* Any copyright is dedicated to the Public Domain.
     2  * http://creativecommons.org/publicdomain/zero/1.0/ */
     4 MARIONETTE_TIMEOUT = 60000;
     6 SpecialPowers.addPermission("sms", true, document);
     7 SpecialPowers.setBoolPref("dom.sms.enabled", true);
     9 let manager = window.navigator.mozMobileMessage;
    10 let smsList = new Array();
    12 function verifyInitialState() {
    13   log("Verifying initial state.");
    14   ok(manager instanceof MozMobileMessageManager,
    15      "manager is instance of " + manager.constructor);
    16   simulateIncomingSms();
    17 }
    19 function simulateIncomingSms() {
    20   let text = "Incoming SMS courtesy of Firefox OS";
    21   let remoteNumber = "5557779999";
    23   log("Simulating incoming SMS.");
    25   // Simulate incoming SMS sent from remoteNumber to our emulator
    26   rcvdEmulatorCallback = false;
    27   runEmulatorCmd("sms send " + remoteNumber + " " + text, function(result) {
    28     is(result[0], "OK", "emulator callback");
    29     rcvdEmulatorCallback = true;
    30   });
    31 }
    33 // Callback for incoming SMS
    34 manager.onreceived = function onreceived(event) {
    35   log("Received 'onreceived' sms event.");
    36   let incomingSms = event.message;
    37   log("Received SMS (id: " + incomingSms.id + ").");
    38   is(incomingSms.read, false, "incoming message read");
    39   log("SMS read attribute: " + incomingSms.read + ".");
    41   // Add newly received message id to array of msgs
    42   smsList.push(incomingSms.id);
    44   // Wait for emulator to catch up before continuing
    45   waitFor(sendSms, function() {
    46     return(rcvdEmulatorCallback);
    47   });
    48 };
    50 function sendSms() {
    51   let gotSmsSent = false;
    52   let gotRequestSuccess = false;
    53   let remoteNumber = "5557779999";
    54   let text = "Mo Mo Mo Zilla Zilla Zilla!";
    56   log("Sending an SMS.");
    58   manager.onsent = function(event) {
    59     log("Received 'onsent' event.");
    60     gotSmsSent = true;
    61     let sentSms = event.message;
    62     log("Sent SMS (id: " + sentSms.id + ").");
    63     is(sentSms.read, true, "sent sms read");
    64     log("SMS read attribute: " + sentSms.read + ".");
    66     // Add newly received message id to array of msgs
    67     smsList.push(sentSms.id);
    69     if (gotSmsSent && gotRequestSuccess) {
    70       test1();
    71     }
    72   };
    74   let request = manager.send(remoteNumber, text);
    76   request.onsuccess = function(event) {
    77     log("Received 'onsuccess' smsrequest event.");
    78     if(event.target.result) {
    79       gotRequestSuccess = true;
    80       if (gotSmsSent && gotRequestSuccess) {
    81         test1();
    82       }
    83     } else {
    84       log("smsrequest returned false for manager.send");
    85       ok(false, "SMS send failed");
    86       deleteMsgs();
    87     }
    88   };
    90   request.onerror = function(event) {
    91     log("Received 'onerror' smsrequest event.");
    92     ok(event.target.error, "domerror obj");
    93     ok(false, "manager.send request returned unexpected error: "
    94         + event.target.error.name );
    95     deleteMsgs();
    96   };
    97 }
    99 function markMessageAndVerify(smsId, readBool, nextFunction) {
   100   let request = manager.markMessageRead(smsId, readBool);
   101   ok(request instanceof DOMRequest,
   102       "request is instanceof " + request.constructor);
   104   request.onsuccess = function(event) {
   105     log("Received 'onsuccess' smsrequest event.");
   107     // Success from MarkMessageRead, the result should match what we set
   108     is(event.target.result, readBool, "result matches what was set");
   110     // Message marked read/unread, now verify
   111     log("Getting SMS message (id: " + smsId + ").");
   112     let requestRet = manager.getMessage(smsId);
   113     ok(requestRet, "smsrequest obj returned");
   115     requestRet.onsuccess = function(event) {
   116       log("Received 'onsuccess' smsrequest event.");
   117       ok(event.target.result, "smsrequest event.target.result");
   118       let foundSms = event.target.result;
   119       is(foundSms.id, smsId, "SMS id matches");
   120       log("SMS read attribute: " + foundSms.read + ".");
   121       let text = readBool ? "read" : "unread";
   122       if (foundSms.read == readBool) {
   123         ok(true, "marked sms " + text);
   124       } else {
   125         ok(false, "marking sms " + text + " didn't work");
   126         log("Expected SMS (id: " + foundSms.id + ") to be marked " + text
   127             + " but it is not.");
   128       }
   129       nextFunction();
   130     };
   132     requestRet.onerror = function(event) {
   133       log("Received 'onerror' smsrequest event.");
   134       ok(event.target.error, "domerror obj");
   135       is(event.target.error.name, "NotFoundError", "error returned");
   136       log("Could not get SMS (id: " + outSmsId + ") but should have.");
   137       ok(false, "Could not get SMS");
   138       deleteMsgs();
   139     };
   140   };
   142   request.onerror = function(event) {
   143     log("Received 'onerror' smsrequest event.");
   144     ok(event.target.error, "domerror obj");
   145     ok(false, "manager.markMessageRead request returned unexpected error: "
   146         + event.target.error.name );
   147     nextFunction();
   148   };
   149 }
   151 function test1() {
   152   rcvdSms = smsList[0];
   153   log("Test 1: Marking received SMS (id: " + rcvdSms + ") read.");
   154   markMessageAndVerify(rcvdSms, true, test2);
   155 }
   157 function test2() {
   158   rcvdSms = smsList[0];
   159   log("Test 2: Marking received SMS (id: " + rcvdSms + ") unread.");
   160   markMessageAndVerify(rcvdSms, false, test3);
   161 }
   163 function test3() {
   164   sentSms = smsList[1];
   165   log("Test 3: Marking sent SMS (id: " + sentSms + ") unread.");
   166   markMessageAndVerify(sentSms, false, test4);
   167 }
   169 function test4() {
   170   sentSms = smsList[1];
   171   log("Test 4: Marking sent SMS (id: " + sentSms + ") read.");
   172   markMessageAndVerify(sentSms, true, test5);
   173 }
   175 function test5() {
   176   sentSms = smsList[1];
   177   log("Test 5: Marking an already read SMS (id: " + sentSms + ") read.");
   178   markMessageAndVerify(sentSms, true, test6);
   179 }
   181 function test6() {
   182   rcvdSms = smsList[0];
   183   log("Test 6: Marking an already unread SMS (id: " + rcvdSms + ") unread.");
   184   markMessageAndVerify(rcvdSms, false, deleteMsgs);
   185 }
   187 function deleteMsgs() {
   188   let smsId = smsList.shift();
   190   log("Deleting SMS (id: " + smsId + ").");
   191   let request = manager.delete(smsId);
   192   ok(request instanceof DOMRequest,
   193       "request is instanceof " + request.constructor);
   195   request.onsuccess = function(event) {
   196     log("Received 'onsuccess' smsrequest event.");
   197     if (event.target.result) {
   198       // Message deleted, continue until none are left
   199       if (smsList.length) {
   200         deleteMsgs();
   201       } else {
   202         cleanUp();
   203       }
   204     } else {
   205       log("SMS delete failed.");
   206       ok(false, "manager.delete request returned false");
   207       cleanUp();
   208     }
   209   };
   211   request.onerror = function(event) {
   212     log("Received 'onerror' smsrequest event.");
   213     ok(event.target.error, "domerror obj");
   214     ok(false, "manager.delete request returned unexpected error: "
   215         + event.target.error.name );
   216     cleanUp();
   217   };
   218 }
   220 function cleanUp() {
   221   manager.onreceived = null;
   222   SpecialPowers.removePermission("sms", document);
   223   SpecialPowers.clearUserPref("dom.sms.enabled");
   224   finish();
   225 }
   227 // Start the test
   228 verifyInitialState();

mercurial