telephonyserver/etelmultimode/TETEL/te_EtelMM/TE_mmmemonstore.cpp
author ivan.fildichev@opencode.com
Thu, 18 Nov 2010 15:42:16 +0200
branchopencode
changeset 88 5e27cc612ac7
parent 24 6638e7f4bd8f
permissions -rw-r--r--
Latest bug-fixes with added tests.

// 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:
//

#include <e32test.h>

#include "TE_EtelMMTestStepBase.h"
#include "TE_mmmemonstore.h"
#include "testdef.h"

CTestMemOnStore::CTestMemOnStore()
/** Each test step initialises it's own name
*/
	{
	// store the name of this test case
	// this is the name that is used by the script file
	SetTestStepName(_L("TestMemOnStore"));
	}

enum TVerdict CTestMemOnStore::doTestStepL()
	{
	iTestCount=1;
	INFO_PRINTF1(_L(""));
	INFO_PRINTF1(_L("Test RMobileONStore coping with OOM"));
	
	RMobilePhone mmPhone;
	TInt ret=mmPhone.Open(iTelServer,DMMTSY_PHONE_NAME);
	TEST(ret==KErrNone);

	RMobileONStore onStore;
	ret=onStore.Open(mmPhone);
    TEST(ret==KErrNone);

	CMemTestGetONList* getONList=CMemTestGetONList::NewLC(onStore, this);
    getONList->Start();
    CActiveScheduler::Start();
	CleanupStack::PopAndDestroy();
	
	RMobileONStore::TMobileONEntryV1 storeEntry;

	CMobilePhoneONList* onList = CMobilePhoneONList::NewL();
	CleanupStack::PushL(onList);

	CTestOnStore::InitONEntry(storeEntry);
	storeEntry.iIndex = DMMTSY_ON_STORE_INDEX1;

	onList->AddEntryL(storeEntry);
	storeEntry.iIndex = DMMTSY_ON_STORE_INDEX2;
	onList->AddEntryL(storeEntry);

	TRequestStatus reqStatus;
	TInt err = KErrNone;
	TInt failNext = 0;
	do
		{
		__UHEAP_FAILNEXT(++failNext);
		TRAP(err,onStore.StoreAllL(reqStatus, onList));
		if (err == KErrNone)
			{
			User::WaitForRequest(reqStatus);
			err = reqStatus.Int();
			}
		TEST(err == KErrNone || err == KErrNoMemory);
		} while (err != KErrNone);
	__UHEAP_RESET;
	INFO_PRINTF3(_L("Test %d - OOM test on RMobileOnStore::StoreAllL required %d allocations to succeed"),iTestCount++,failNext);
//	INFO_PRINTF2(_L("OOM test on RMobileOnStore::StoreAllL OK"));
	CleanupStack::PopAndDestroy();


	onStore.Close();
	mmPhone.Close();
	INFO_PRINTF1(_L(""));
	
	return TestStepResult();
	}

CTestMemOnStore::CMemTestGetONList* CTestMemOnStore::CMemTestGetONList::NewLC(RMobilePhoneStore& aStore, CTestMemOnStore* aTestMemOnStore)
	{
    CMemTestGetONList* r = new (ELeave) CMemTestGetONList(aStore, aTestMemOnStore);
	CleanupStack::PushL(r);
	r->ConstructL();
    return r;	
	}

void CTestMemOnStore::CMemTestGetONList::Start()
	{
	iFailEvery = 1;
	StartMemTest();
	}

void CTestMemOnStore::CMemTestGetONList::StartMemTest()
	{
	__UHEAP_FAILNEXT(iFailEvery);
	CTestGetONList::Start();
	}
	
CTestMemOnStore::CMemTestGetONList::CMemTestGetONList(RMobilePhoneStore& aStore, CTestMemOnStore* aTestMemOnStore) :
	CTestGetONList(aStore, aTestMemOnStore), iTestMemOnStore(aTestMemOnStore)
	{

	}

void CTestMemOnStore::CMemTestGetONList::RunL()
	{
	CTestGetONList::RunL();
	__UHEAP_RESET;
	iTestMemOnStore->INFO_PRINTF3(_L("Test %d - CRetrieveMobilePhoneONList OOM Test required %d allocations to succeed"),iTestMemOnStore->iTestCount++,iFailEvery);
	}

TInt CTestMemOnStore::CMemTestGetONList::RunError(TInt aError)
	{
	if (aError == KErrNoMemory)
		{
		iFailEvery++;
		StartMemTest();
		return KErrNone;
		}
	else
		return aError;
	}