phonebookengines/contactsmodel/tsrc/t_bench.h
author Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
Fri, 19 Mar 2010 09:27:18 +0200
changeset 24 0ba2181d7c28
parent 0 e686773b3f54
permissions -rw-r--r--
Revision: 201007 Kit: 201011

/*
* Copyright (c) 2001-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: 
*
*/


const TInt KNumSecondaryClients=3;


class CBenchMarker : public CBase, public MIdleFindObserver
	{
public:
	CBenchMarker();
	~CBenchMarker();
	void ConstructL(const TDesC& aCommandLine);
	void RunL();
private:
	enum TTest
		{
		EOpenNewDb,
		ECreateSecondaryClients,
		EAddContacts,
		ECompactDb,
		EAddAndCompact,
		EGetSortedItems,
		ELogContactSummary,
		ELogContactSummaryFast,
		EOpenRContactView,
		ESetSortOrderOfRContactView,
		EGetSortOrderOfRContactView,
		ELogContactSummaryWithRContactView,
		ELogContactSummaryFastWithRContactView,
		EFindWithRContactView,
		ECloseRContactView,
		EFindFromLargeFieldSetSuceed,
		EFindFromLargeFieldSetFail,
		EFindFromSmallFieldSetSuceed,
		EFindFromSmallFieldSetFail,
		EFindPhoneNumberSuceed,
		EFindPhoneNumberFail,
		EFindEmailAddressSuceed,
		EFindEmailAddressFail,
		EFindAsyncFromLargeFieldSet,
		EFindAsyncFromSmallFieldSet,
		ECloseDb,
		ECloseSecondaryClients,
		EOpenExistingDb,
		EMultiClientSort,
		ENumTests
		};
private: // From MIdleFindObserver.
	void IdleFindCallback();
private:
	void DecodeCommandLineL(const TDesC& aCommandLine);
	void PrepareLogL();
	TInt DoTestL(TTest aTest);
	void StartProfile();
	TReal EndProfile();
	void StartAverageProfile();
	void UpdateAverageProfile(TInt aNumIterations);
	TReal EndAverageProfile();
	TReal AddContactsL();
	TReal AddContactsCompactL();
	void LogContactSummaryL(TBool aFaster);
	void LogContactSummaryFromRContactViewL(TBool aFaster);
	void LogContactSummaryL(TBool aFaster,TContactItemId aContactItemId);
	void DoSortL();
	void OpenRContactViewL();
	void SetSortOrderOfRContactViewL();
	void GetSortOrderOfRContactViewL();
	void FindInRContactViewL();
	void FindFromLargeFieldSetL(const TDesC& aTextToFind);
	void FindFromSmallFieldSetL(const TDesC& aTextToFind);
	void FindPhoneNumberL(const TDesC& aTextToFind);
	void FindMobilePhoneNumberL(const TDesC& aTextToFind);
	void FindEmailAddressL(const TDesC& aTextToFind);
	TReal FindAsyncFromLargeFieldSetL(const TDesC& aTextToFind);
	TReal FindAsyncFromSmallFieldSetL(const TDesC& aTextToFind);
	void DoFindL(const TDesC& aTextToFind,const CContactItemFieldDef& aFieldDef);
	TReal DoFindAsyncL(const TDesC& aTextToFind,const CContactItemFieldDef& aFieldDef);
	void CreateSecondaryClients();
	void CloseSecondaryClients();
	void CreateSortClients();
	void IncVisualCounter();
	void EndVisualCounter();
	TInt DbFileSize();
	void LogResult(TInt aMajorTestNum,TInt aMinorTestNum,const TDesC& aDescription,TInt aResult);
	void LogResult(TInt aMajorTestNum,TInt aMinorTestNum,const TDesC& aDescription,TReal aResult);
private:
	RFs iFs;
	RTest iTest;
	TFileName iLogFileName;
	TFileName iDbFileName;
	CLog* iLog;
	CContactDatabase* iDb;
	CRandomContactGenerator* iGenerator;
	const CContactIdArray* iSortedItems;
	CContactTextDef* iTextDef;
	CIdleFinder* iIdleFinder;
	TInt iVisualCounter;
	TReal iAverageProfileCounter;
	TInt iNumAverageProfiles;
	TBool iNoDataGenerationTests;
	TInt iNumTypicalContacts;
	TInt iNumAtypicalContacts;
	TInt iNumTypicalContactsCompact;
	TInt iNumAtypicalContactsCompact;
	RThread secondaryClient[KNumSecondaryClients];
#ifdef __USE_NEW_INTERFACES
	RContactView iSortedIdList;
#endif
	};


class TThreadCommandLine
	{
public:
	TThreadCommandLine(TRequestStatus* aInitialStatus,TRequestStatus* aCompletionStatus,const TDesC& aDbFileName,TBool aExitAfterSort)
		: iInitialStatus(aInitialStatus),iCompletionStatus(aCompletionStatus),iDbFileName(aDbFileName),iExitAfterSort(aExitAfterSort) {}
	RThread iOwningThread;
	TRequestStatus* iInitialStatus;
	TRequestStatus* iCompletionStatus;
	const TDesC& iDbFileName;
	TBool iExitAfterSort;
	};