Sat, 03 Jan 2015 20:18:00 +0100
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();