diff -r 6b1d113cdff3 -r 6638e7f4bd8f telephonyserverplugins/multimodetsy/test/Te_LoopBack/Te_Loopbackcoomvoicecall.cpp --- a/telephonyserverplugins/multimodetsy/test/Te_LoopBack/Te_Loopbackcoomvoicecall.cpp Mon May 03 13:37:20 2010 +0300 +++ b/telephonyserverplugins/multimodetsy/test/Te_LoopBack/Te_Loopbackcoomvoicecall.cpp Thu May 06 15:10:38 2010 +0100 @@ -1,234 +1,234 @@ -// Copyright (c) 1997-2009 Nokia Corporation and/or its subsidiary(-ies). -// All rights reserved. -// This component and the accompanying materials are made available -// under the terms of "Eclipse Public License v1.0" -// which accompanies this distribution, and is available -// at the URL "http://www.eclipse.org/legal/epl-v10.html". -// -// Initial Contributors: -// Nokia Corporation - initial contribution. -// -// Contributors: -// -// Description: -// This file implements OOM voice call scenarios. -// See CDataCall.cpp for fully documented test scenario. -// -// - -/** - @file -*/ - -#include -#include -#include -#include "Te_Loopbackcoomvoicecall.h" -#include "../../hayes/TSYCONFG.H" // for KInternetAccessPoint - -const TInt KETelServerShutdownGuardPeriod=500000; - -// -// Test-side class -// With the assistance of the base class, this class must start the emulator -// and drive the ETel API. -// -CTestDriveOOMVoiceCall* CTestDriveOOMVoiceCall::NewL(const TScriptList aScriptListEntry) - { - CTestDriveOOMVoiceCall* aA = new(ELeave) CTestDriveOOMVoiceCall(aScriptListEntry); - CleanupStack::PushL(aA); - aA->ConstructL(); - CleanupStack::Pop(); - return aA; - } - -CTestDriveOOMVoiceCall::CTestDriveOOMVoiceCall(const TScriptList aScriptListEntry) : - iScriptListEntry(aScriptListEntry) - {} - -TInt CTestDriveOOMVoiceCall::RunTestL() - { - iCurrentScript = iScriptListEntry; - return StartEmulatorL(); - } - -void CTestDriveOOMVoiceCall::CloseDown() - { - iPhone2.Close(); - iPhone.Close(); - iServer2.Close(); - iServer.Close(); - } - -void CTestDriveOOMVoiceCall::OpenUpL() - { - TESTL(iServer.Connect()==KErrNone); - TESTL(iServer.LoadPhoneModule(MODULE_NAME)==KErrNone); - TESTL(iServer2.Connect()==KErrNone); - TESTL(iPhone.Open(iServer, PHONE_NAME)==KErrNone); - TESTL(iPhone2.Open(iServer, PHONE_NAME)==KErrNone); - } - -TInt CTestDriveOOMVoiceCall::DriveETelApiL() -// -// This function contains the real meat of the Client-side test code -// - { - CloseDown(); - User::After(KETelServerShutdownGuardPeriod); - - TInt n=1; - for(;;n++) - { - INFO_PRINTF2(_L("Fail After %d allocs... "),n); - TInt res=DoTestL(n); - INFO_PRINTF2(_L("Result=%d"),res); - if(res==KErrNone) - break; - RestartScript(); - User::After(KETelServerShutdownGuardPeriod); - } - - OpenUpL(); - TerminateScript(); - return KErrNone; - } - -TInt CTestDriveOOMVoiceCall::DoTestL(TInt aAllocFailNumber) - { - _LIT(KPhoneModule,"MM"); - _LIT(KPhoneName, "GsmPhone1"); - _LIT(KLineName, "Voice"); - - RTelServer telServer; - TInt ret=telServer.Connect(); - if(ret!=KErrNone) - return ret; - - telServer.__DbgFailNext(aAllocFailNumber); - - ret=telServer.LoadPhoneModule(KPhoneModule); - if(ret!=KErrNone) - { - telServer.Close(); - return ret; - } - - RMobilePhone mobilePhone; - ret=mobilePhone.Open(telServer, KPhoneName); - if(ret!=KErrNone) - { - mobilePhone.Close(); - telServer.Close(); - return ret; - } - - RLine line; - INFO_PRINTF1(_L("Opening Voice Line")); - ret=line.Open(mobilePhone,KLineName); - if(ret!=KErrNone) - { - line.Close(); - mobilePhone.Close(); - telServer.Close(); - return ret; - } - - INFO_PRINTF1(_L("Opening New Voice Call")); - RCall call; - ret=call.OpenNewCall(line); - if(ret!=KErrNone) - { - call.Close(); - line.Close(); - mobilePhone.Close(); - telServer.Close(); - return ret; - } - - INFO_PRINTF1(_L("Initialise the Phone...")); - - TRequestStatus reqStatus; - RMobilePhone::TMMTableSettings tableSettings; - tableSettings.iLocId=KInternetAccessPoint; - RMobilePhone::TMMTableSettingsPckg tableSettingsPckg(tableSettings); - mobilePhone.InitialiseMM(reqStatus, tableSettingsPckg); - User::WaitForRequest(reqStatus); - TESTL(reqStatus == KErrNone); - - if(reqStatus!=KErrNone) - { - call.Close(); - line.Close(); - mobilePhone.Close(); - telServer.Close(); - return ret; - } - - INFO_PRINTF1(_L("Dial a number...")); - _LIT(KDialString, "+1234"); - ret=call.Dial(KDialString); - if(ret!=KErrNone) - { - call.Close(); - line.Close(); - mobilePhone.Close(); - telServer.Close(); - return ret; - } - - INFO_PRINTF1(_L("Hangup a call...")); - ret=call.HangUp(); - if(ret!=KErrNone) - { - call.Close(); - line.Close(); - mobilePhone.Close(); - telServer.Close(); - return ret; - } - - INFO_PRINTF1(_L("Close the call, line & iPhone...")); - call.Close(); - line.Close(); - mobilePhone.Close(); - - return KErrNone; - } - -// -// Emulator-side class -// With the assistance of the base class, this class must run the designated script -// -CTestOOMVoiceCall* CTestOOMVoiceCall::NewL(const TScript* aScript) - { - CTestOOMVoiceCall* aA = new(ELeave) CTestOOMVoiceCall(aScript); - CleanupStack::PushL(aA); - aA->ConstructL(); - CleanupStack::Pop(); - return aA; - } - -CTestOOMVoiceCall::CTestOOMVoiceCall(const TScript* aScript) : iScript(aScript) - {} - -void CTestOOMVoiceCall::ConstructL() - { - CATScriptEng::ConstructL(); - } - -TInt CTestOOMVoiceCall::Start() - { - StartScript(iScript); - return KErrNone; - } - -void CTestOOMVoiceCall::SpecificAlgorithmL(TInt /* aParam */) - { - } - -void CTestOOMVoiceCall::Complete(TInt aError) - { - iReturnValue = aError; - CActiveScheduler::Stop(); - } +// Copyright (c) 1997-2009 Nokia Corporation and/or its subsidiary(-ies). +// All rights reserved. +// This component and the accompanying materials are made available +// under the terms of "Eclipse Public License v1.0" +// which accompanies this distribution, and is available +// at the URL "http://www.eclipse.org/legal/epl-v10.html". +// +// Initial Contributors: +// Nokia Corporation - initial contribution. +// +// Contributors: +// +// Description: +// This file implements OOM voice call scenarios. +// See CDataCall.cpp for fully documented test scenario. +// +// + +/** + @file +*/ + +#include +#include +#include +#include "Te_Loopbackcoomvoicecall.h" +#include "../../hayes/TSYCONFG.H" // for KInternetAccessPoint + +const TInt KETelServerShutdownGuardPeriod=500000; + +// +// Test-side class +// With the assistance of the base class, this class must start the emulator +// and drive the ETel API. +// +CTestDriveOOMVoiceCall* CTestDriveOOMVoiceCall::NewL(const TScriptList aScriptListEntry) + { + CTestDriveOOMVoiceCall* aA = new(ELeave) CTestDriveOOMVoiceCall(aScriptListEntry); + CleanupStack::PushL(aA); + aA->ConstructL(); + CleanupStack::Pop(); + return aA; + } + +CTestDriveOOMVoiceCall::CTestDriveOOMVoiceCall(const TScriptList aScriptListEntry) : + iScriptListEntry(aScriptListEntry) + {} + +TInt CTestDriveOOMVoiceCall::RunTestL() + { + iCurrentScript = iScriptListEntry; + return StartEmulatorL(); + } + +void CTestDriveOOMVoiceCall::CloseDown() + { + iPhone2.Close(); + iPhone.Close(); + iServer2.Close(); + iServer.Close(); + } + +void CTestDriveOOMVoiceCall::OpenUpL() + { + TESTL(iServer.Connect()==KErrNone); + TESTL(iServer.LoadPhoneModule(MODULE_NAME)==KErrNone); + TESTL(iServer2.Connect()==KErrNone); + TESTL(iPhone.Open(iServer, PHONE_NAME)==KErrNone); + TESTL(iPhone2.Open(iServer, PHONE_NAME)==KErrNone); + } + +TInt CTestDriveOOMVoiceCall::DriveETelApiL() +// +// This function contains the real meat of the Client-side test code +// + { + CloseDown(); + User::After(KETelServerShutdownGuardPeriod); + + TInt n=1; + for(;;n++) + { + INFO_PRINTF2(_L("Fail After %d allocs... "),n); + TInt res=DoTestL(n); + INFO_PRINTF2(_L("Result=%d"),res); + if(res==KErrNone) + break; + RestartScript(); + User::After(KETelServerShutdownGuardPeriod); + } + + OpenUpL(); + TerminateScript(); + return KErrNone; + } + +TInt CTestDriveOOMVoiceCall::DoTestL(TInt aAllocFailNumber) + { + _LIT(KPhoneModule,"MM"); + _LIT(KPhoneName, "GsmPhone1"); + _LIT(KLineName, "Voice"); + + RTelServer telServer; + TInt ret=telServer.Connect(); + if(ret!=KErrNone) + return ret; + + telServer.__DbgFailNext(aAllocFailNumber); + + ret=telServer.LoadPhoneModule(KPhoneModule); + if(ret!=KErrNone) + { + telServer.Close(); + return ret; + } + + RMobilePhone mobilePhone; + ret=mobilePhone.Open(telServer, KPhoneName); + if(ret!=KErrNone) + { + mobilePhone.Close(); + telServer.Close(); + return ret; + } + + RLine line; + INFO_PRINTF1(_L("Opening Voice Line")); + ret=line.Open(mobilePhone,KLineName); + if(ret!=KErrNone) + { + line.Close(); + mobilePhone.Close(); + telServer.Close(); + return ret; + } + + INFO_PRINTF1(_L("Opening New Voice Call")); + RCall call; + ret=call.OpenNewCall(line); + if(ret!=KErrNone) + { + call.Close(); + line.Close(); + mobilePhone.Close(); + telServer.Close(); + return ret; + } + + INFO_PRINTF1(_L("Initialise the Phone...")); + + TRequestStatus reqStatus; + RMobilePhone::TMMTableSettings tableSettings; + tableSettings.iLocId=KInternetAccessPoint; + RMobilePhone::TMMTableSettingsPckg tableSettingsPckg(tableSettings); + mobilePhone.InitialiseMM(reqStatus, tableSettingsPckg); + User::WaitForRequest(reqStatus); + TESTL(reqStatus == KErrNone); + + if(reqStatus!=KErrNone) + { + call.Close(); + line.Close(); + mobilePhone.Close(); + telServer.Close(); + return ret; + } + + INFO_PRINTF1(_L("Dial a number...")); + _LIT(KDialString, "+1234"); + ret=call.Dial(KDialString); + if(ret!=KErrNone) + { + call.Close(); + line.Close(); + mobilePhone.Close(); + telServer.Close(); + return ret; + } + + INFO_PRINTF1(_L("Hangup a call...")); + ret=call.HangUp(); + if(ret!=KErrNone) + { + call.Close(); + line.Close(); + mobilePhone.Close(); + telServer.Close(); + return ret; + } + + INFO_PRINTF1(_L("Close the call, line & iPhone...")); + call.Close(); + line.Close(); + mobilePhone.Close(); + + return KErrNone; + } + +// +// Emulator-side class +// With the assistance of the base class, this class must run the designated script +// +CTestOOMVoiceCall* CTestOOMVoiceCall::NewL(const TScript* aScript) + { + CTestOOMVoiceCall* aA = new(ELeave) CTestOOMVoiceCall(aScript); + CleanupStack::PushL(aA); + aA->ConstructL(); + CleanupStack::Pop(); + return aA; + } + +CTestOOMVoiceCall::CTestOOMVoiceCall(const TScript* aScript) : iScript(aScript) + {} + +void CTestOOMVoiceCall::ConstructL() + { + CATScriptEng::ConstructL(); + } + +TInt CTestOOMVoiceCall::Start() + { + StartScript(iScript); + return KErrNone; + } + +void CTestOOMVoiceCall::SpecificAlgorithmL(TInt /* aParam */) + { + } + +void CTestOOMVoiceCall::Complete(TInt aError) + { + iReturnValue = aError; + CActiveScheduler::Stop(); + }