telephonyserverplugins/multimodetsy/test/Te_PhBk/Te_PhBkTestStepBase.cpp
author Oscar Gonzalez <oscar.1.gonzalez@nokia.com>
Thu, 06 May 2010 15:10:38 +0100
branchopencode
changeset 24 6638e7f4bd8f
parent 0 3553901f7fa8
permissions -rw-r--r--
opencode

// 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;
	}