--- /dev/null Thu Jan 01 00:00:00 1970 +0000
+++ b/telephonyserverplugins/multimodetsy/test/Te_PhBk/Te_PhBkTestStepBase.cpp Tue Feb 02 01:41:59 2010 +0200
@@ -0,0 +1,355 @@
+// Copyright (c) 2005-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:
+//
+
+#include "Te_PhBkTestStepBase.h"
+
+TVerdict CPhBkTestStep::doTestStepPreambleL()
+ {
+ __UHEAP_MARK;
+
+ TInt ret = iTelServer.Connect();
+ if (ret!=KErrNone)
+ {
+ INFO_PRINTF1(_L("Failed to connect to telephony server"));
+ User::Leave(ret);
+ }
+ ret=iTelServer.LoadPhoneModule(KMmtsyName);
+ if (ret!=KErrNone)
+ {
+ INFO_PRINTF1(_L("Failed to load phone module"));
+ iTelServer.Close();
+ User::Leave(ret);
+ }
+ ret=iPhone.Open(iTelServer,KPhoneName) ;
+ if (ret!=KErrNone)
+ {
+ INFO_PRINTF1(_L("Failed to open phone module"));
+ iTelServer.UnloadPhoneModule(KMmtsyName);
+ iTelServer.Close();
+ User::Leave(ret);
+ }
+//
+// This test requires a mobile phone to be connected to the serial port
+// specified in the .cfg file for the initialise below to work
+//
+ ret=iPhone.Initialise();
+ if (ret!=KErrNone)
+ {
+ INFO_PRINTF2(_L("Failed to initialise the phone (%d)"), ret);
+ iPhone.Close();
+ iTelServer.UnloadPhoneModule(KMmtsyName);
+ iTelServer.Close();
+ User::Leave(ret);
+ }
+ RPhone::TCaps oPhoneCaps;
+ ret = iPhone.GetCaps(oPhoneCaps) ;
+ if ((KErrNone != ret) || !(oPhoneCaps.iFlags & RPhone::KCapsVoice))
+ {
+ INFO_PRINTF2(_L("This phone does not support Voice Calls (caps=0x%x)"), oPhoneCaps.iFlags);
+ iPhone.Close();
+ iTelServer.UnloadPhoneModule(KMmtsyName);
+ iTelServer.Close();
+ User::Leave(ret);
+ }
+
+ return TestStepResult();
+ }
+
+TVerdict CPhBkTestStep::doTestStepPostambleL()
+ {
+ iPhone.Close();
+ iTelServer.UnloadPhoneModule(KMmtsyName);
+ iTelServer.Close();
+
+ __UHEAP_MARKEND;
+ return TestStepResult();
+ }
+
+void CPhBkTestStep::WaitWithTimeout(TRequestStatus& aStatus, TInt aNumberOfMicroSeconds)
+/**
+ * Timeout function
+ */
+ {
+ TRequestStatus timerStatus;
+ RTimer timer ;
+ timer.CreateLocal() ;
+ timer.After(timerStatus,aNumberOfMicroSeconds);
+
+ User::WaitForRequest(aStatus, timerStatus);
+ if (timerStatus == KRequestPending)
+ {
+ timer.Cancel();
+ User::WaitForRequest(timerStatus);
+ }
+ else
+ {
+ INFO_PRINTF1(_L("Time is over!!!")) ;
+ }
+ timer.Close() ;
+ }
+
+TInt CPhBkTestStep::CheckPhoneStoreInfo(RMobilePhone& aPhone,
+ const TDesC& aPhoneStoreName,
+ const TDesC& aMode,
+ const TDesC& aPhoneStoreDescription)
+/**
+ * Checks a specific phone store information features when mode is specified.
+ *
+ * @return status code, as an integer of the request for GetPhoneStoreInfo
+ */
+ {
+ RMobilePhoneStore::TMobilePhoneStoreInfoV1 info;
+ RMobilePhoneStore::TMobilePhoneStoreInfoV1Pckg infoPckg(info);
+
+ INFO_PRINTF2(_L("Testing %S"), &aPhoneStoreDescription);
+
+ TRequestStatus status;
+ aPhone.GetPhoneStoreInfo(status, infoPckg, aPhoneStoreName, aMode);
+ User::WaitForRequest(status);
+
+ if( status.Int() == KErrNone )
+ {
+ INFO_PRINTF4(_L("%S is using %d of %d entries"), &aPhoneStoreDescription, info.iUsedEntries, info.iTotalEntries);
+ }
+ else if ( (aPhoneStoreName == KETelIccFdnPhoneBook && status.Int() == KErrGeneral) || // failure from PIN not entered
+ (status.Int() == KErrNotSupported))
+ {
+ // Not a critical failure
+ status = KErrNone;
+ INFO_PRINTF2(_L("%S Unusable"), &aPhoneStoreDescription);
+ }
+ else
+ {
+ INFO_PRINTF3(_L("%S Test failure, result:%d"), &aPhoneStoreDescription, status.Int());
+ }
+
+
+ return status.Int();
+ }
+
+TInt CPhBkTestStep::clearPhoneBookL(const TDesC& aPhoneBookName)
+/**
+ * This function deletes the first 15 entries in the specified Phone Book.
+ * It is called by the clearPhoneBooks() function.
+ * @test GT83-TPHBK-008.00 Test deleting an individual phonebook entry from a ME-based phonebook of abbreviated dialling numbers.
+ * @test GT83-TPHBK-002.06 GT83-AT-070 Test closing an ICC-based phonebook of abbreviated dialling numbers
+ */
+ {
+ TRequestStatus status;
+ RMobilePhoneBookStore thePhBk;
+ TInt ret(KErrNone);
+
+ if(thePhBk.Open(iPhone,aPhoneBookName)==KErrNone)
+ {
+ RMobilePhoneBookStore::TMobilePhoneBookInfoV1Pckg dummyInfoPckg(iDummyInfo);
+ thePhBk.GetInfo(status, dummyInfoPckg); // Recommended by EtelMM API documentation
+ User::WaitForRequest(status);
+
+ INFO_PRINTF2(_L("Deleting %S phonebook 15 first entries..."), &aPhoneBookName);
+ TInt i;
+ for (i=1; i<=15; i++)
+ {
+ thePhBk.Delete(status, i);
+ User::WaitForRequest(status);
+ if (status!=KErrNone && status!=KErrNotFound)
+ {
+ //it's checked by "if"
+ TEST_CHECKL(1, KErrNone, _L("GT83-TPHBK-008.00")) ;
+ break;
+ }
+ }
+ }
+ thePhBk.Close();
+ TEST_CHECKL(ret, KErrNone, _L("GT83-TPHBK-002.00")) ;
+ return ret;
+ }
+
+void CPhBkTestStep::checkPhoneBookInfoL(RMobilePhoneStore::TMobilePhoneStoreInfoV1& aInfo)
+/**
+ * This function is called by the testPhoneInfo() function. It checks
+ * the validity of the information in the TPhoneBookInfo struct.
+ */
+ {
+// TESTL(info.iTotalEntries>0);
+
+ // A phone book containing the recently dialled calls (RO)
+ if (!aInfo.iName.Compare(KETelMeDialledPhoneBook()))
+ {
+ TEST(!(aInfo.iCaps & RMobilePhoneStore::KCapsWriteAccess)); // Shouldn't be able to write in this store
+ TEST(aInfo.iCaps & RMobilePhoneStore::KCapsReadAccess); // But we should be able to read
+ INFO_PRINTF1(_L("\"DIALLED_CALLS\" tested RO successfully"));
+ }
+
+ // A phone book containing missed calls. (RO)
+ else if (!aInfo.iName.Compare(KETelMeMissedPhoneBook()))
+ {
+ TEST(!(aInfo.iCaps & RMobilePhoneStore::KCapsWriteAccess));
+ TEST(aInfo.iCaps & RMobilePhoneStore::KCapsReadAccess);
+ INFO_PRINTF1(_L("\"MISSED_CALLS\" tested RO successfully"));
+ }
+
+ //A phone book containing received calls (RO)
+ else if (!aInfo.iName.Compare(KETelMeReceivedPhoneBook()))
+ {
+ TEST(!(aInfo.iCaps & RMobilePhoneStore::KCapsWriteAccess));
+ TEST(aInfo.iCaps & RMobilePhoneStore::KCapsReadAccess);
+ INFO_PRINTF1(_L("\"RECEIVED_CALLS\" tested RO successfully"));
+ }
+
+ // A ME based phone book of abbreviated dialling numbers (RW)
+ else if (!aInfo.iName.Compare(KETelMeAdnPhoneBook()))
+ {
+ TEST(aInfo.iCaps & RMobilePhoneStore::KCapsWriteAccess);
+ TEST(aInfo.iCaps & RMobilePhoneStore::KCapsReadAccess);
+ INFO_PRINTF1(_L("\"ME_PHONEBOOK\" tested RW successfully"));
+ }
+
+ //A phone book containing voice mailbox numbers (RO)
+ else if (!aInfo.iName.Compare(KETelIccVoiceMailBox()))
+ {
+ TEST(aInfo.iCaps & RMobilePhoneStore::KCapsWriteAccess);
+ TEST(aInfo.iCaps & RMobilePhoneStore::KCapsReadAccess);
+ INFO_PRINTF1(_L("\"VOICE_MAILBOX\" tested RO successfully"));
+ }
+
+ //A SIM based phone book of abbreviated dialling numbers (RW)
+ else if (!aInfo.iName.Compare(KETelIccAdnPhoneBook()))
+ {
+ TEST(aInfo.iCaps & RMobilePhoneStore::KCapsWriteAccess);
+ TEST(aInfo.iCaps & RMobilePhoneStore::KCapsReadAccess);
+ INFO_PRINTF1(_L("\"SIM_PHONEBOOK\" tested RW successfully"));
+ }
+
+
+ //A combination of ME and SIM based phone books (RO)
+ else if (!aInfo.iName.Compare(KETelCombinedAdnPhoneBook()))
+ {
+ TEST(!(aInfo.iCaps & RMobilePhoneStore::KCapsWriteAccess));
+ TEST(aInfo.iCaps & RMobilePhoneStore::KCapsReadAccess);
+ INFO_PRINTF1(_L("\"COMBINED_SIM_ME\" tested RO successfully"));
+ }
+
+ //A phone book containing the fixed dialling list(RO)
+ else if (!aInfo.iName.Compare(KETelIccFdnPhoneBook()))
+ {
+ TEST(!(aInfo.iCaps & RMobilePhoneStore::KCapsWriteAccess));
+ TEST(aInfo.iCaps & RMobilePhoneStore::KCapsReadAccess);
+ INFO_PRINTF1(_L("\"FIXED_DIAL_NUM\" tested RO successfully"));
+ }
+
+ //A phone book containing service dialling number list (RO)
+ else if (!aInfo.iName.Compare(KETelIccSdnPhoneBook()))
+ {
+ TEST(!(aInfo.iCaps & RMobilePhoneStore::KCapsWriteAccess));
+ TEST(aInfo.iCaps & RMobilePhoneStore::KCapsReadAccess);
+ INFO_PRINTF1(_L("\"SERV_DIAL_NUM\" tested RO successfully"));
+ }
+
+ //A phone book containing the barred dialling numbers (RO)
+ else if (!aInfo.iName.Compare(KETelIccBdnPhoneBook()))
+ {
+ TEST(!(aInfo.iCaps & RMobilePhoneStore::KCapsWriteAccess));
+ TEST(aInfo.iCaps & RMobilePhoneStore::KCapsReadAccess);
+ INFO_PRINTF1(_L("\"BARRED_DIAL_NUM\" tested RO successfully"));
+ }
+ }
+
+void CPhBkTestStep::WriteBatchOfEntriesToThePhoneL()
+/**
+ * This function writes 15 entries to the phone.
+ * @test GT83-TPHBK-001.06 Test opening an ICC-based phonebook of abbreviated dialling numbers
+ * @test GT83-TPHBK-002.06 Test closing an ICC-based phonebook of abbreviated dialling numbers
+ * @test GT83-TPHBK-007.06 "Test writing a single phonebook entry to a specified location in an ICC-based phonebook containing voice mailbox numbers, where the location is empty"
+ */
+ {
+ TInt ret=KErrNone;
+ TRequestStatus status;
+ RMobilePhoneBookStore simPhBk;
+ TBuf8<KPBDataClientBuf> pbData; // Client reserved space for phonebook data
+ CPhoneBookBuffer* pbBuffer=new(ELeave) CPhoneBookBuffer();
+
+ pbBuffer->Set(&pbData); // Set it to point to the Client buffer
+ ret = simPhBk.Open(iPhone, KETelIccAdnPhoneBook);
+ TEST_CHECKL(ret, KErrNone, _L("*** Failed to open ICC ADN Phonebook ***"));
+
+ RMobilePhoneBookStore::TMobilePhoneBookInfoV1Pckg dummyInfoPckg(iDummyInfo);
+ simPhBk.GetInfo(status, dummyInfoPckg); // Recommended by EtelMM API documentation
+ User::WaitForRequest(status);
+
+ // Create array of names and numbers
+ const TText16* names[]={(TText16*)KAnnText.iBuf, (TText16*)KMattSText.iBuf, (TText16*)KAndyText.iBuf,
+ (TText16*)KMattMText.iBuf,(TText16*)KPaulText.iBuf, (TText16*)KMumAndDadText.iBuf,
+ (TText16*)KSymbolText.iBuf,(TText16*)KHenrikText.iBuf,(TText16*)KHenrikSVText.iBuf,
+ (TText16*)KMikaelText.iBuf,(TText16*)KIngeText.iBuf,(TText16*)KPatrickText.iBuf,
+ (TText16*)KPontusText.iBuf,(TText16*)KAndersText.iBuf,(TText16*)KHajText.iBuf};
+
+ const TText16* numbers[]={(TText16*)KAnnPhoneNum.iBuf, (TText16*)KMattSPhoneNum.iBuf, (TText16*)KAndyPhoneNum.iBuf,
+ (TText16*)KMattMPhoneNum.iBuf, (TText16*)KPaulPhoneNum.iBuf, (TText16*)KMumAndDadPhoneNum.iBuf,
+ (TText16*)KSymbolPhoneNum.iBuf,(TText16*)KHenrikPhoneNum.iBuf,(TText16*)KHenrikSVPhoneNum.iBuf,
+ (TText16*)KMikaelPhoneNum.iBuf,(TText16*)KIngePhoneNum.iBuf,(TText16*)KPatrickPhoneNum.iBuf,
+ (TText16*)KPontusPhoneNum.iBuf,(TText16*)KAndersPhoneNum.iBuf,(TText16*)KHajPhoneNum.iBuf};
+
+
+ // Write the entries to the SIM Phone Book
+ TInt size(KPPBEntriesNum);
+ TInt i(0), index(0);
+
+ TBuf16<KBufSize> entryNumber(numbers[0]);
+ TBuf16<KBufSize> entryName(names[0]);
+
+ for (i=1; i<=size; ++i)
+ {
+ //first reset the following three local buffers to delete any existing data
+ entryNumber.FillZ();
+ entryNumber.Zero();
+ entryName.FillZ();
+ entryName.Zero();
+ pbData.FillZ();
+ pbData.Zero();
+
+ entryNumber=numbers[i-1];
+ entryName=names[i-1];
+
+ // convert number into TLV format and append it to allocated buffer
+ ret=pbBuffer->PutTagAndValue(RMobilePhoneBookStore::ETagPBNumber, entryNumber);
+ TESTL(ret == KErrNone) ;
+
+ // convert type into TLV format and append it to allocated buffer
+ TUint8 tonNpi=KTypeOfNumber;
+ ret=pbBuffer->PutTagAndValue(RMobilePhoneBookStore::ETagPBTonNpi, tonNpi);
+ TESTL(ret == KErrNone) ;
+
+ // convert text into TLV format and append it to allocated buffer
+ ret=pbBuffer->PutTagAndValue(RMobilePhoneBookStore::ETagPBText, entryName);
+ TESTL(ret == KErrNone) ;
+
+ index=RMobilePhoneStore::TMobilePhoneStoreEntryV1::KIndexNotUsed;
+ // Note that KIndexNotUsed cannot be used anymore to write to next available phonebook slot
+ simPhBk.Write(status, pbData, index);
+ User::WaitForRequest(status);
+
+ if (status!=KErrNone) // First write request should fail
+ {
+ // This time client needs to specify the phonebook slot
+ index=i;
+ simPhBk.Write(status, pbData, index);
+ User::WaitForRequest(status);
+ TEST_CHECKL(status.Int(), KErrNone, _L("GT83-TPHBK-007.06")) ;
+ }
+ } // end for
+
+ simPhBk.Close();
+ delete pbBuffer;
+ }