/**
* Copyright (C) 2010 The Android Open Source Project
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
/**
* TODO:update tests in the format of test incoming call
* Have a global counter to count passes and failures
*/
/**
* A test to test set signal strength
*/
if (false) {
function testSetSignalStrength() {
print('testSetSignalStrength E:');
simulatedRadio.printSignalStrength();
try {
simulatedRadio.setSignalStrength(0, -1, -1, -1, -1, -1, -1);
} catch (err) {
print('test failed');
}
simulatedRadio.printSignalStrength();
try {
simulatedRadio.setSignalStrength(60, 30, 29 , 28, 27, 26, 25);
} catch (err) {
print('test success: ' + err);
}
simulatedRadio.printSignalStrength();
}
testSetSignalStrength();
}
/**
* TODO: A test for RIL_REQUEST_GET_CURRENT_CALLS,
* remove when satisfied all is well.
*/
if (false) {
var calls = simulatedRadio.getCalls();
function testCalls() {
print('testCalls E:');
var c0 = simulatedRadio.addCall(CALLSTATE_ACTIVE, '16502859848', 'w');
simulatedRadio.printCalls();
var c1 = simulatedRadio.addCall(CALLSTATE_ACTIVE, '16502583456', 'm');
simulatedRadio.printCalls();
var c2 = simulatedRadio.addCall(CALLSTATE_ACTIVE, '16502345678', 'x');
simulatedRadio.printCalls();
var c3 = simulatedRadio.addCall(CALLSTATE_ACTIVE, '16502349876', 'y');
simulatedRadio.printCalls();
simulatedRadio.removeCall(c0.index);
simulatedRadio.printCalls();
simulatedRadio.removeCall(c1.index);
simulatedRadio.printCalls();
simulatedRadio.removeCall(c2.index);
simulatedRadio.printCalls();
result = simulatedRadio.rilRequestGetCurrentCalls();
newCalls = rilSchema[packageNameAndSeperator +
'RspGetCurrentCalls'].parse(result.responseProtobuf);
simulatedRadio.printCalls(newCalls.calls);
// Set to false to test RIL_REQUEST_GET_CURRENT_CALLS as there will
// be on call still active on the first RIL_REQUEST_GET_CURRENT_CALLS
// request.
if (false) {
simulatedRadio.removeCall(c3.index);
simulatedRadio.printCalls();
}
print('testCalls X:');
}
testCalls();
}
/**
* A test for creating incoming call
*/
if (false) {
/* Only one incoming call is in the call list */
function verifyIncomingCall() {
var calls = simulatedRadio.getCalls();
var numIncomingCalls = 0;
for (var i = 0; i < calls.length; i++) {
if (typeof calls[i] != 'undefined') {
if (calls[i].state == CALLSTATE_INCOMING) {
numIncomingCalls++;
}
}
}
return (numIncomingCalls == 1);
}
function testStartIncomingCall() {
print('testCreateIncomingCall E:');
var req = new Object();
req.reqNum = CTRL_CMD_SET_MT_CALL;
req.data = new Object();
req.data.phoneNumber = '6502249208';
var numberTestPass = 0;
var numberTestFail = 0;
// case 1: incoming call is the only active call
var result = new Object();
result = simulatedRadio.ctrlServerCmdStartInComingCall(req);
if ( (result.rilErrCode == CTRL_STATUS_OK) && verifyIncomingCall()) {
numberTestPass++;
} else {
numberTestFail++;
print('testStartIncomingCall: TEST CASE 1 FAIL');
}
// case 2: one incoming call, add another incoming call will fail
req.data.phoneNumber = '6502223456';
result = simulatedRadio.ctrlServerCmdStartInComingCall(req);
if ((result.rilErrCode == CTRL_STATUS_ERR) && verifyIncomingCall()) {
numberTestPass++;
} else {
numberTestFail++;
print('testStartIncomingCall: TEST CASE 2 FAIL');
}
// case 3: one dialing call, add another incoming call will fail
// Make the first call in dialing state
var calls = simulatedRadio.getCalls();
for (var i = 0; i < calls.length; i++) {
if (typeof calls[i] != 'undefined') {
if (calls[i].state == CALLSTATE_INCOMING) {
calls[i].state = CALLSTATE_DIALING;
break;
}
}
}
result = simulatedRadio.ctrlServerCmdStartInComingCall(req);
if (result.rilErrCode == CTRL_STATUS_ERR) {
numberTestPass++;
} else {
numberTestFail++;
print('testStartIncomingCall: TEST CASE 3 FAIL');
}
// case 4: one dialing call, adding another incoming call will fail
calls[i].state = CALLSTATE_ALERTING;
result = simulatedRadio.ctrlServerCmdStartInComingCall(req);
if (result.rilErrCode == CTRL_STATUS_ERR) {
numberTestPass++;
} else {
numberTestFail++;
print('testStartIncomingCall: TEST CASE 4 FAIL');
}
// case 5: one active call, adding another incoming call will succeed
calls[i].state = CALLSTATE_ACTIVE;
result = simulatedRadio.ctrlServerCmdStartInComingCall(req);
if (result.rilErrCode == CTRL_STATUS_OK) {
numberTestPass++;
} else {
numberTestFail++;
print('testStartIncomingCall: TEST CASE 5 FAIL');
}
print('*************TEST RESULT ****************');
print('Number of Test Passed: ' + numberTestPass);
print('Number of Test Failed: ' + numberTestFail);
print('************ End **********************');
// after the test, remove any calls
for (i = 0; i < calls.length; i++) {
simulatedRadio.removeCall(i);
}
print('testStartIncomingCall X:');
}
testStartIncomingCall();
}
/**
* A test for RIL_REQUEST_HANGUP_FOREGROUND_RESUME_BACKGROUND
*/
if (false) {
var calls = simulatedRadio.getCalls();
function testHangUpForegroundResumeBackground() {
print('testHangUpForegroundResumeBackground E:');
var testOutput = false;
for (var state = CALLSTATE_ACTIVE; state <= CALLSTATE_WAITING; state++) {
var c0 = simulatedRadio.addCall(state, '16502849230', 'smith');
var req = new Object();
req.reqNum = RIL_REQUEST_HANGUP_FOREGROUND_RESUME_BACKGROUND;
var testResult = simulatedRadio.rilRequestHangUpForegroundResumeBackground(req);
if (state == CALLSTATE_ACTIVE) {
var testCalls = simulatedRadio.getCalls();
if (testCalls.length == 0) {
testOutput = true;
} else {
testOutput = false;
}
} else if (state == CALLSTATE_WAITING) {
if (c0.state == CALLSTATE_ACTIVE) {
testOutput = true;
} else {
testOutput = false;
}
} else if (state == CALLSTATE_HOLDING) {
if (c0.state == CALLSTATE_ACTIVE) {
testOutput = true;
} else {
testOutput = false;
}
} else {
if (testResult.rilErrCode == RIL_E_GENERIC_FAILURE) {
testOutput = true;
} else {
testOutput = false;
}
}
if (testOutput == true) {
print('testHangUpForegroundResumeBackground, call ' + state + ' PASS \n');
} else {
print('testHangUpForegroundResumeBackground, call ' + state + ' FAIL \n');
}
simulatedRadio.removeCall(c0.index);
simulatedRadio.printCalls();
}
}
testHangUpForegroundResumeBackground();
}
/**
* Test RIL_REQUEST_CONFERENCE
*/
if(false) {
var calls = simulatedRadio.getCalls();
function testConference() {
print('testConference E');
// test case 1: one holding, one dialing
var c0 = simulatedRadio.addCall(CALLSTATE_HOLDING, '16502859848', 'w');
simulatedRadio.printCalls();
var c1 = simulatedRadio.addCall(CALLSTATE_DIALING, '16502583456', 'm');
simulatedRadio.printCalls();
var req = new Object();
req.reqNum = RIL_REQUEST_CONFERENCE;
var testResult = new Object();
testResult.rilErrCode = RIL_E_SUCCESS;
testResult = simulatedRadio.rilRequestConference(req);
if (testResult.rilErrCode == RIL_E_GENERIC_FAILURE) {
print('testConference: holding & dialing: pass');
} else {
print('testConference: holding & dialing: fail');
}
// test case 2: one holding, one alerting
c1.state = CALLSTATE_ALERTING;
testResult.rilErrCode = RIL_E_SUCCESS;
testResult = simulatedRadio.rilRequestConference(req);
if (testResult.rilErrCode == RIL_E_GENERIC_FAILURE) {
print('testConference: holding & alerting: pass');
} else {
print('testConference: holding & alerting: fail');
}
// test case 3: one holding, one active
c1.state = CALLSTATE_ACTIVE;
testResult.rilErrCode = RIL_E_SUCCESS;
testResult = simulatedRadio.rilRequestConference(req);
if (testResult.rilErrCode == RIL_E_SUCCESS) {
print('testConference: holding & active: pass');
} else {
print('testConference: holding & active: fail');
}
// test case 4: one holding, one incoming
c1.state = CALLSTATE_INCOMING;
testResult.rilErrCode = RIL_E_SUCCESS;
testResult = simulatedRadio.rilRequestConference(req);
if (testResult.rilErrCode == RIL_E_GENERIC_FAILURE) {
print('testConference: holding & incoming: pass');
} else {
print('testConference: holding & incoming: fail');
}
// test case 5: one holding, one waiting
c1.state = CALLSTATE_WAITING;
testResult.rilErrCode = RIL_E_SUCCESS;
testResult = simulatedRadio.rilRequestConference(req);
if (testResult.rilErrCode == RIL_E_GENERIC_FAILURE) {
print('testConference: holding & waiting: pass');
} else {
print('testConference: holding & waiting: fail');
}
simulatedRadio.removeCall(c0.index);
simulatedRadio.removeCall(c1.index);
print('testConference: X');
}
testConference();
}
/**
* Test serialization of bad numeric enum
*/
if (false) {
var c = new RilCall(1000, '11234567890', 'me');
rsp = new Object();
rsp.calls = [ c ];
try {
rilSchema[packageNameAndSeperator + 'RspGetCurrentCalls'].serialize(rsp);
print('test-enum a bad numeric enum value, FAILURE exception expected');
} catch (err) {
print('test-enum a bad numeric enum value, SUCCESS exception expected: ' + err);
}
}
/**
* Test serialization of bad string enum
*/
if (false) {
// The state parameter 'NOT_CALLSTATE_ACTIVE' can get corrupted in ToProto?
var c = new RilCall('NOT_CALLSTATE_ACTIVE', '11234567890', 'me');
rsp = new Object();
rsp.calls = [ c ];
try {
rilSchema[packageNameAndSeperator + 'RspGetCurrentCalls'].serialize(rsp);
print('test-enum a bad string enum value, FAILURE exception expected');
} catch (err) {
print('test-enum a bad string enum value, SUCCESS exception expected: ' + err);
}
}
/**
* Test addDelayed
*/
if (false) {
print("test addDelayed E");
simulatedRadioWorker.add( {
'reqNum' : CMD_DELAY_TEST,
'hello' : 'hi no delay' });
simulatedRadioWorker.addDelayed( {
'reqNum' : CMD_DELAY_TEST,
'hello' : 'hi not-a-number is 0 delay' }, "not-a-number");
simulatedRadioWorker.addDelayed( {
'reqNum' : CMD_DELAY_TEST,
'hello' : 'hi negative delay is 0 delay' }, -1000);
simulatedRadioWorker.addDelayed( {
'reqNum' : CMD_DELAY_TEST,
'hello' : 'hi delayed 2 seconds' }, 2000);
print("test addDelayed X");
}
/**
* A test for setRadioState, verify it can handle valid string variable,
* undefined varilabe, and invalid radio state correctly.
*/
if (false) {
function testSetRadioState() {
print('testSetRadioState E:');
// defined string variable
newState = 'RADIOSTATE_UNAVAILABLE';
try {
setRadioState(newState);
} catch (err) {
print('test failed');
}
print('Expecting gRadioState to be ' + RADIOSTATE_UNAVAILABLE +
', gRadioState is: ' + gRadioState);
// undefined string variable, expecting exception
try {
setRadioState('RADIOSTATE_UNDEFINED');
} catch (err) {
if (err.indexOf('Unknow string') >= 0) {
print('test success');
print('err: ' + err);
} else {
print('test failed');
}
}
// valid radio state
try {
setRadioState(RADIOSTATE_NV_READY);
} catch (err) {
print('test failed');
}
print('Expecting gRadioState to be ' + RADIOSTATE_NV_READY +
', gRadioState is: ' + gRadioState);
// invalid radio state
try {
setRadioState(-1);
} catch (err) {
if (err.indexOf('invalid') >= 0) {
print('test success');
print('err: ' + err);
} else {
print('test failed, err: ' + err);
}
}
print('gRadioState should not be set: ' + gRadioState);
// set radio state to be SIM_READY
setRadioState(RADIOSTATE_SIM_READY);
print('Expecting gRadioState to be ' + RADIOSTATE_SIM_READY +
', gRadioState is: ' + gRadioState);
print('testSetRadioState X:');
}
testSetRadioState();
}