mirror of
https://github.com/roytam1/palemoon27.git
synced 2026-05-26 14:18:48 +00:00
7edec4880a
- Bug 859764 - Part 5: Changes in Test Cases. r=echen (f1a5cd4fd3) - Bug 859764 - Part 6: Changes in Payment. r=ferjm, r=smaug (2b47641375) - Bug 1010756 - Helpful errors for using nsCOMPtr on non-XPCOM types; r=froydnj (6b1521c482) - leftover (e1a24351e9) - Bug 1192102 - Remove unused file embedded/android/GeckoSmsManager.java. r=blassey (ac05ae649d) - var-let (8ddb529f96) - Bug 1181466 - Fix observe function in SmsService/MmsService. r=btseng (ca93122404) - Bug 733331 - Part 2: Update enabledGsmTableTuples when MCC changes in SmsService.js and fix segmentChars in SmsSegmentHelper.jsm. r=btseng (24fa23e4be) - Bug 1173156 - Fix typo and add a Marionette test case. r=btseng (e7199eb55a) - Bug 1132774 - [B2G][SMS] Enable DEBUG Flag in SmsService if the default value of "ril.debugging.enabled" is true. r=btseng (7300d24fb7) - Bug 1169160 - [MobileConnection] Support more call barring program: all service, outgoing service and incoming service. r=hsinyi,aknow (872c2cc056) - Bug 1169225 - [MobileConnectionService] Support setting/getting call waiting on all serviceClass. r=aknow (14c546a9ca) - Bug 1110619 - Part 1: IDL Interface Changes. r=echen (beae2b4b77) - Bug 1168064 - B2G RIL: filter out cell info with unknown values. r=echen (11dfc5a7e8) - Bug 1159591 - Part 2: Move MMI logic from ril_worker to telephonyService (Call Forwarding). r=aknow (b4edb76863) - Bug 1159591 - Part 3: Move MMI logic from ril_worker to telephonyService (Icc Lock). r=aknow (3faba76808) - Bug 1138263 - Make TelephonyService.js JSHint friendly. r=hsinyi (454bd4c765) - Bug 1159591 - Part 4: Move MMI logic from ril_worker to telephonyService (IMEI). r=aknow (57f423ecdd) - Bug 1159591 - Part 5: Move MMI logic from ril_worker to telephonyService (CLIP). r=aknow (c6611dbcb8) - Bug 1159591 - Part 6: Move MMI logic from ril_worker to telephonyService (CLIR). r=aknow (8c1fc03edb) - Bug 1159591 - Part 7: Move MMI logic from ril_worker to telephonyService (Call Barring Password). r=aknow (5d8bcbf177) - Bug 1159591 - Part 8: Move MMI logic from ril_worker to telephonyService (Call Barring). r=aknow (aa0b89aea1) - Bug 1159591 - Part 9: Move MMI logic from ril_worker to telephonyService (Call Waiting). r=aknow (1d14d2b864) - Bug 1159591 - Part 10: Move MMI logic from ril_worker to telephonyService (USSD). r=aknow (c92130b5b2) - Bug 1159591 - Part 11: Move MMI consts from ril_consts to telephonyService. r=aknow (0e7b3fea9a) - Bug 1159591 - Part 12: Move radio check for MMI to a common place. r=aknow (dcdc3178ad) - Bug 1110619 - Part 2: Implementation Changes. r=echen (6d8e78d684) - Bug 1110619 - Part 3: Bluetooth Changes. r=btian (9787727be0) - Bug 1147736 - Part 1: Extend TelephonyCallInfo. r=aknow (2a426cc99f) - Bug 1147736 - Part 2: Bypass NotifyError. r=aknow (6cd6fd6867) - Bug 1147736 - Part 3: Deprecate NotifyError. r=aknow (e41c719442) - Bug 1147736 - Part 4: Deprecate NotifyError(Bluetooth). r=btian (9c8f97bb22) - Bug 1204817 - Delete the child property of a parent call only when the parent call exists. r=btseng (d35dc6b08f) - Bug 1191205 - Cancel USSD sessions only when needed. r=edgar (01a72dbacb) - Bug 1200134 - Control USSD Sessions with State-Transitions instead of Boolean. r=echen (a4e55b3d9d) - Bug 1163511 - Use defineLazyModuleGetter. r=hsinyi (8a97a4912c) - Bug 991582 - Part 2: Handle the result of RIL request in a consistent way. r=aknow (914ecc2bbb) - Bug 1164248 - Handling of session/sessionEnded for notifyUssdReceived. r=edgar (a79df75d38) - Bug 1223662 - Part 1: Check mmiServiceCode with correct constant. r=echen (abeb286050) - Bug 1174673 - Part 1: Automatically resume the held call. r=hsinyi (280543af7d) - Bug 1174673 - Part 2: Update test case. r=hsinyi (cfe19f1a52) - Bug 1185156 - Fix bug in resuming held call. r=hsinyi (b96346d319) - Bug 1162426 - Part 1: Provide TelephonyUtils. r=hsinyi (62b71e6e83) - Bug 1162426 - Part 2: Test case. r=hsniyi (13a0b3c6f5) - Bug 1171807 - Part 1: Add enums for TelephonyCall::State and TelephonyCallGroup::State (WebIDL). r=hsinyi (0b698eecc4) - Bug 1145551 - DTMF should be sent using the active SIM, the given or the default one (in that order). r=aknow (6157636493) - Bug 1171807 - Part 2: Move to enums and deprecate TelephonyCall.mCallState and TelephonyCallGroup.mCallState (DOM). r=btseng (5faef22d91) - Bug 1168515 - do not block incall MMI requests on alerting state. r=aknow (b1f85c5789) - Bug 1155072 - Part 1: Deprecate nsITelephonyListener.conferenceCallStateChanged (Telephony). r=btseng (e41d1a4bc9) - Bug 1155072 - Part 2: Deprecate nsITelephonyListener.conferenceCallStateChanged (Bluetooth). r=btian (27e69fa89b) - Bug 1166936 - JS Warning in TelephonyService.js r=aknow (3559d3ad3d) - Bug 1191237 - Part 1: Enhance |TelephonyService.js|. r=aknow (86576a6d32) - Bug 1202902 - Fix the world. (0dc256d67d) - Bug 1161438 - Part 1 - Exporting contact to SIM should also return updated contact. r=echen (505d7d7f83) - Bug 1159622 - Split test_icc_contact.js into read contact and add contact. r=echen (fec0c428df) - Bug 1122376 - Support read SIM contact dialling number exceed 20 digits. r=echen (5d0599e93c) - Bug 1161438 - Part 2 - marionette testcase. r=echen (1f0d18a479) - Bug 1114937 - Part 5: Fix Test Case to Remove Contact with Correct Contact Id. r=echen (8d746fdbd2) - Bug 1194149 - Continue importing contacts when there is no sufficient Type 2 USIM contact fields record. r=echen (e9be40dbf2) - Bug 962995 - xpcshell tests for write ICC UCS2 characters for 0x81 and 0x82 encoding. r=echen (9500afaa4d) - Bug 1161438 - Part 3 - xpcshell testcase. r=echen (01f7fb4514) - Bug 1122376 - Support write SIM contact dialling number exceed 20 digits. r=echen (91133e286d) - Bug 999300 - Part 1: Removed the Ril v5 legacy support. r=edgar (ded77fcb6f) - Bug 999300 - Part 2: Update the related testcases. r=edgar (f77a8b96cc) - Bug 1177146 - [Aries][RIL] Reply from QUERY_AVAILABLE_NETWORKS has extra strings. r=hsinyi (a6816cbbab) - Bug 1043250 - Part 1: Update ril_worker and xpcshell test. r=btseng (8b9b25b5cf) - Bug 1185406 - B2G RIL: Read 'pcscf' and expose it in nsIRilNetworkInfo. r=hsinyi (ce707ecb83) - Bug 1174998 - Part 3: Read data call's MTU from network/apn settings. r=echen (bfa08d8380) - Bug 1166320 - Make volume service safer to use off main thread. r=dhylands (b3976622ad) - Bug 1177374 - Call realpath on volume mount points so thatVolumeService::GetVolumeByPath works properly. r=achen (aea97080eb) - Bug 1195166 - AutoMounter: add ignore command to allow volumes to be ignored. r=alchen (f265d832c8) - Bug 1196724 - Refactoring of AudioManager r=alwu (e5b896b7ce) - Bug 1222564 - Save audio volume to database r=alwu (1303d01ae7) - Bug 1164049 - Fix some mode lines in embedding/. r=smaug (79ddce4871)
261 lines
8.0 KiB
JavaScript
261 lines
8.0 KiB
JavaScript
/* Any copyright is dedicated to the Public Domain.
|
|
* http://creativecommons.org/publicdomain/zero/1.0/ */
|
|
|
|
MARIONETTE_TIMEOUT = 60000;
|
|
|
|
const PDU_SMSC = "00"; // No SMSC Address
|
|
const PDU_FIRST_OCTET = "00"; // RP:no, UDHI:no, SRI:no, MMS:no, MTI:SMS-DELIVER
|
|
const PDU_SENDER = "0191F1"; // +1
|
|
const PDU_PID_NORMAL = "00";
|
|
const PDU_PID_ANSI_136_R_DATA = "7C";
|
|
const PDU_PID_USIM_DATA_DOWNLOAD = "7F";
|
|
const PDU_TIMESTAMP = "00101000000000"; // 2000/01/01
|
|
const PDU_UDL = "01";
|
|
const PDU_UD = "41";
|
|
|
|
const SENT_TIMESTAMP = Date.UTC(2000, 0, 1); // Must be equal to PDU_TIMESTAMP.
|
|
|
|
SpecialPowers.addPermission("sms", true, document);
|
|
|
|
let manager = window.navigator.mozMobileMessage;
|
|
ok(manager instanceof MozMobileMessageManager,
|
|
"manager is instance of " + manager.constructor);
|
|
|
|
let pendingEmulatorCmdCount = 0;
|
|
function sendSmsPduToEmulator(pdu) {
|
|
++pendingEmulatorCmdCount;
|
|
|
|
let cmd = "sms pdu " + pdu;
|
|
runEmulatorCmd(cmd, function(result) {
|
|
--pendingEmulatorCmdCount;
|
|
|
|
is(result[0], "OK", "Emulator response");
|
|
});
|
|
}
|
|
|
|
function checkMessage(message, id, threadId, messageClass) {
|
|
ok(message instanceof SmsMessage,
|
|
"message is instanceof " + message.constructor);
|
|
if (id == null) {
|
|
ok(message.id > 0, "message.id");
|
|
} else {
|
|
is(message.id, id, "message.id");
|
|
}
|
|
if (threadId == null) {
|
|
ok(message.threadId > 0, "message.threadId");
|
|
} else {
|
|
is(message.threadId, threadId, "message.threadId");
|
|
}
|
|
is(message.delivery, "received", "message.delivery");
|
|
is(message.deliveryStatus, "success", "message.deliveryStatus");
|
|
is(message.sender, "+1", "message.sender");
|
|
is(message.body, "A", "message.body");
|
|
is(message.messageClass, messageClass, "message.messageClass");
|
|
is(message.deliveryTimestamp, 0, "deliveryTimestamp is 0");
|
|
is(message.read, false, "message.read");
|
|
}
|
|
|
|
function test_message_class_0() {
|
|
let allDCSs = [
|
|
"10", // General Group: 00xx
|
|
"50", // Automatica Deletion Group: 01xx
|
|
"F0" // (no name) Group: 1111
|
|
];
|
|
|
|
function do_test(dcsIndex) {
|
|
manager.addEventListener("received", function onReceived(event) {
|
|
manager.removeEventListener("received", onReceived);
|
|
|
|
let message = event.message;
|
|
checkMessage(message, -1, 0, "class-0");
|
|
ok(event.message.timestamp >= timeBeforeSend,
|
|
"Message's timestamp should be greater then the timetamp of sending");
|
|
ok(event.message.timestamp <= Date.now(),
|
|
"Message's timestamp should be lesser than the timestamp of now");
|
|
is(event.message.sentTimestamp, SENT_TIMESTAMP,
|
|
"Message's sentTimestamp should be equal to SENT_TIMESTAMP");
|
|
|
|
// Make sure the message is not stored.
|
|
let cursor = manager.getMessages();
|
|
cursor.onsuccess = function onsuccess() {
|
|
if (cursor.result) {
|
|
// Here we check whether there is any message of the same sender.
|
|
isnot(cursor.result.sender, message.sender, "cursor.result.sender");
|
|
|
|
cursor.continue();
|
|
return;
|
|
}
|
|
|
|
// All messages checked. Done.
|
|
++dcsIndex;
|
|
if (dcsIndex >= allDCSs.length) {
|
|
window.setTimeout(test_message_class_1, 0);
|
|
} else {
|
|
window.setTimeout(do_test.bind(null, dcsIndex), 0);
|
|
}
|
|
};
|
|
cursor.onerror = function onerror() {
|
|
ok(false, "Can't fetch messages from SMS database");
|
|
};
|
|
});
|
|
|
|
let dcs = allDCSs[dcsIndex];
|
|
log(" Testing DCS " + dcs);
|
|
let pdu = PDU_SMSC + PDU_FIRST_OCTET + PDU_SENDER + PDU_PID_NORMAL +
|
|
dcs + PDU_TIMESTAMP + PDU_UDL + PDU_UD;
|
|
let timeBeforeSend = Date.now();
|
|
sendSmsPduToEmulator(pdu);
|
|
}
|
|
|
|
log("Checking Message Class 0");
|
|
do_test(0);
|
|
}
|
|
|
|
function doTestMessageClassGeneric(allDCSs, messageClass, next) {
|
|
function do_test(dcsIndex) {
|
|
manager.addEventListener("received", function onReceived(event) {
|
|
manager.removeEventListener("received", onReceived);
|
|
|
|
// Make sure we can correctly receive the message
|
|
checkMessage(event.message, null, null, messageClass);
|
|
ok(event.message.timestamp >= timeBeforeSend,
|
|
"Message's timestamp should be greater then the timetamp of sending");
|
|
ok(event.message.timestamp <= Date.now(),
|
|
"Message's timestamp should be lesser than the timestamp of now");
|
|
is(event.message.sentTimestamp, SENT_TIMESTAMP,
|
|
"Message's sentTimestamp should be equal to SENT_TIMESTAMP");
|
|
|
|
++dcsIndex;
|
|
if (dcsIndex >= allDCSs.length) {
|
|
window.setTimeout(next, 0);
|
|
} else {
|
|
window.setTimeout(do_test.bind(null, dcsIndex), 0);
|
|
}
|
|
});
|
|
|
|
let dcs = allDCSs[dcsIndex];
|
|
log(" Testing DCS " + dcs);
|
|
let pdu = PDU_SMSC + PDU_FIRST_OCTET + PDU_SENDER + PDU_PID_NORMAL +
|
|
dcs + PDU_TIMESTAMP + PDU_UDL + PDU_UD;
|
|
|
|
let timeBeforeSend = Date.now();
|
|
sendSmsPduToEmulator(pdu);
|
|
}
|
|
|
|
do_test(0);
|
|
}
|
|
|
|
function test_message_class_1() {
|
|
let allDCSs = [
|
|
"11", // General Group: 00xx
|
|
"51", // Automatica Deletion Group: 01xx
|
|
"F1" // (no name) Group: 1111
|
|
];
|
|
|
|
log("Checking Message Class 1");
|
|
doTestMessageClassGeneric(allDCSs, "class-1", test_message_class_2);
|
|
}
|
|
|
|
function test_message_class_2() {
|
|
let allDCSs = [
|
|
"12", // General Group: 00xx
|
|
"52", // Automatica Deletion Group: 01xx
|
|
"F2" // (no name) Group: 1111
|
|
];
|
|
|
|
let allPIDs = [
|
|
PDU_PID_NORMAL,
|
|
PDU_PID_ANSI_136_R_DATA,
|
|
PDU_PID_USIM_DATA_DOWNLOAD
|
|
];
|
|
|
|
function do_test_dcs(dcsIndex) {
|
|
function do_test_pid(pidIndex) {
|
|
function onReceived(event) {
|
|
if (pidIndex == 0) {
|
|
// Make sure we can correctly receive the message
|
|
checkMessage(event.message, null, null, "class-2");
|
|
ok(event.message.timestamp >= timeBeforeSend,
|
|
"Message's timestamp should be greater then the timetamp of sending");
|
|
ok(event.message.timestamp <= Date.now(),
|
|
"Message's timestamp should be lesser than the timestamp of now");
|
|
is(event.message.sentTimestamp, SENT_TIMESTAMP,
|
|
"Message's sentTimestamp should be equal to SENT_TIMESTAMP");
|
|
|
|
next();
|
|
return;
|
|
}
|
|
|
|
// TODO: Bug 792798 - B2G SMS: develop test cases for Message Class 2
|
|
// Since we have "data download via SMS Point-to-Point" service enabled
|
|
// but no working implementation in emulator SIM, all class 2 messages
|
|
// bug normal ones should goto `dataDownloadViaSMSPP()` and we should
|
|
// not receive the message in content page.
|
|
ok(false, "SMS-PP messages shouldn't be sent to content");
|
|
}
|
|
|
|
function next() {
|
|
manager.removeEventListener("received", onReceived);
|
|
|
|
++pidIndex;
|
|
if (pidIndex >= allPIDs.length) {
|
|
++dcsIndex;
|
|
if (dcsIndex >= allDCSs.length) {
|
|
window.setTimeout(test_message_class_3, 0);
|
|
} else {
|
|
window.setTimeout(do_test_dcs.bind(null, dcsIndex), 0);
|
|
}
|
|
} else {
|
|
window.setTimeout(do_test_pid.bind(null, pidIndex), 0);
|
|
}
|
|
}
|
|
|
|
manager.addEventListener("received", onReceived);
|
|
|
|
if (pidIndex != 0) {
|
|
// Wait for three seconds to ensure we don't receive the message.
|
|
window.setTimeout(next, 3000);
|
|
}
|
|
|
|
let pid = allPIDs[pidIndex];
|
|
log(" Testing PID " + pid);
|
|
|
|
let pdu = PDU_SMSC + PDU_FIRST_OCTET + PDU_SENDER + pid + dcs +
|
|
PDU_TIMESTAMP + PDU_UDL + PDU_UD;
|
|
let timeBeforeSend = Date.now();
|
|
sendSmsPduToEmulator(pdu);
|
|
}
|
|
|
|
let dcs = allDCSs[dcsIndex];
|
|
log(" Testing DCS " + dcs);
|
|
|
|
do_test_pid(0);
|
|
}
|
|
|
|
log("Checking Message Class 2");
|
|
do_test_dcs(0);
|
|
}
|
|
|
|
function test_message_class_3() {
|
|
let allDCSs = [
|
|
"13", // General Group: 00xx
|
|
"53", // Automatica Deletion Group: 01xx
|
|
"F3" // (no name) Group: 1111
|
|
];
|
|
|
|
log("Checking Message Class 3");
|
|
doTestMessageClassGeneric(allDCSs, "class-3", cleanUp);
|
|
}
|
|
|
|
function cleanUp() {
|
|
if (pendingEmulatorCmdCount) {
|
|
window.setTimeout(cleanUp, 100);
|
|
return;
|
|
}
|
|
|
|
SpecialPowers.removePermission("sms", document);
|
|
finish();
|
|
}
|
|
|
|
test_message_class_0();
|