/**
 * 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();
}