messaging/Src/TestMessProcessor.cpp
author Maciej Seroka <maciejs@symbian.org>
Tue, 04 May 2010 08:45:48 +0100
branchSymbian3
changeset 34 06a067118393
parent 6 c108117318cb
permissions -rw-r--r--
Moved target (Syborg_tef) back from plan to set

// Copyright (c) 2002-2009 Nokia Corporation and/or its subsidiary(-ies).
// All rights reserved.
// This component and the accompanying materials are made available
// under the terms of the License "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 contains CTestMessProcessor which an active object utility
// used for send/recieving or any time consuming 
// 
//

#include "TestMessProcessor.h"
#include "TestMessBase.h"

CTestMessProcessor* CTestMessProcessor::NewL(CTestStep& aTestStep, CMsvSession& aSession)
	{
	CTestMessProcessor*	self=new(ELeave) CTestMessProcessor(aTestStep, aSession);
	CleanupStack::PushL(self);
	self->ConstructL();
	CleanupStack::Pop();
	return self;
	}

CTestMessProcessor::CTestMessProcessor(CTestStep& aTestStep, CMsvSession& aSession)
:	CActive(EPriorityStandard)
,	iState(EStatePrepareToSendMsg)
,	iTestStep(aTestStep)
,	iSession(aSession)
,	iEntry(NULL)
,	iMsgId(KMsvRootIndexEntryId)
,	iClient(NULL)
,	iMsvOperation(NULL)
,	iCancelSms(EFalse)
	{
	}

CTestMessProcessor::~CTestMessProcessor()
	{
	delete iEntry;
	iEntry=NULL;
	delete iMsvOperation;
	iMsvOperation=NULL;
	}

void CTestMessProcessor::ConstructL()
	{
	CActiveScheduler::Add(this);
	}

void CTestMessProcessor::DoCancel()
	{
	iTestStep.INFO_PRINTF1(_L("Cancel operation"));
	iMsvOperation->Cancel();
	}

void CTestMessProcessor::DisplayProgress()
	{
	// display the current progress
	switch(iState)
		{
	case EStatePrepareToSendMsg:
		{
		TMsvLocalOperationProgress			temp;
		TPckgC<TMsvLocalOperationProgress>	progress(temp);

		progress.Set(iMsvOperation->ProgressL());
		iTestStep.INFO_PRINTF1(_L("   Progress"));
		iTestStep.INFO_PRINTF2(_L("       Operation              :%d"), progress().iType);
		iTestStep.INFO_PRINTF2(_L("       Total Number Of Entries:%d"), progress().iTotalNumberOfEntries);
		iTestStep.INFO_PRINTF2(_L("       Number Completed       :%d"), progress().iNumberCompleted);
		iTestStep.INFO_PRINTF2(_L("       Number Failed          :%d"), progress().iNumberFailed);
		iTestStep.INFO_PRINTF2(_L("       Number Remaining       :%d"), progress().iNumberRemaining);
		iTestStep.INFO_PRINTF2(_L("       Error                  :%d"), progress().iError);
		iTestStep.INFO_PRINTF2(_L("       Id                     :%x"), progress().iId);
		}
		break;
	case EStateRequest:
		iClient->DisplayProgressL(EFalse, iMsvOperation);
		break;
	default:
		break;
		}
	}

void CTestMessProcessor::SendEmailMessageL(TMsvId aMsgId, MTestMessProcessorClient* aClient)
	{
	iMsgId=aMsgId;
	iClient=aClient;
	iState=EStatePrepareToSendMsg;

	delete iEntry;
	iEntry=NULL;
	iEntry=iSession.GetEntryL(iMsgId);
	iMsgEntry=iEntry->Entry();
	iMsgEntry.SetSendingState(KMsvSendStateWaiting);
	delete iMsvOperation;
	iMsvOperation=NULL;
	iMsvOperation=iEntry->ChangeL(iMsgEntry, iStatus);
	SetActive();
	}

/**
 Sends the sms message. It sets the fields of the enty.
 @param aMsgId - TMsvId of the message
 @param aClient - Pointer to the MTestMessProcessClient
 @param aCancelSms - Bool value for the Cancel sms flag
*/
void CTestMessProcessor::SendSmsMessageL(TMsvId aMsgId, MTestMessProcessorClient* aClient, TBool aCancelSms)
	{
	iMsgId=aMsgId;
	iClient=aClient;
	iState=EStatePrepareToSendMsg;
	iCancelSms = aCancelSms;

	delete iEntry;
	iEntry=NULL;
	iEntry=iSession.GetEntryL(iMsgId);
	iMsgEntry=iEntry->Entry();
	iMsgEntry.SetConnected(ETrue);
	iMsgEntry.SetFailed(EFalse);
	iMsgEntry.SetSendingState(KMsvSendStateWaiting);
	iMsgEntry.iError = KErrNone;
	delete iMsvOperation;
	iMsvOperation=NULL;
	iMsvOperation=iEntry->ChangeL(iMsgEntry, iStatus);
	SetActive();
	}

void CTestMessProcessor::SendMmsMessageL(TMsvId aMsgId, MTestMessProcessorClient* aClient)
	{
	iMsgId=aMsgId;
	iClient=aClient;
	iState=EStatePrepareToSendMsg;

	delete iEntry;
	iEntry=NULL;
	iEntry=iSession.GetEntryL(iMsgId);
	iMsgEntry=iEntry->Entry();
	iMsgEntry.SetSendingState(KMsvSendStateWaiting);
	delete iMsvOperation;
	iMsvOperation=NULL;
	iMsvOperation=iEntry->ChangeL(iMsgEntry, iStatus);
	SetActive();
	}

void CTestMessProcessor::MtmRequestL(TMsvId aAccountId, MTestMessProcessorClient* aClient)
	{
	iMsgId=aAccountId;
	iClient=aClient;
	iState=EStateRequest;

	delete iEntry;
	iEntry=NULL;
	iEntry=iSession.GetEntryL(iMsgId);
	iStatus = KRequestPending;
	delete iMsvOperation;
	iMsvOperation=NULL;
	TRAPD(err, iMsvOperation=iClient->CreateOperationL(iStatus));
	if ( iTestStep.TestStepResult() == EPass && err==KErrNone )
		{
		SetActive();
		}
	}

void CTestMessProcessor::RunL()
	{
	switch(iState)
		{
	case EStatePrepareToSendMsg:
		switch (iStatus.Int())
			{
		case KErrNone:
			{
			delete iMsvOperation;
			iMsvOperation=NULL;
			delete iEntry;
			iEntry=NULL;
			iEntry=iSession.GetEntryL(iMsgId);
			iMsgEntry=iEntry->Entry();
			iMsgEntry.SetSendingState(KMsvSendStateWaiting);
			iEntry->ChangeL(iMsgEntry);
			if ( iMsgEntry.SendingState() == KMsvSendStateWaiting )
				{
				iState=EStateRequest;
				iStatus = KRequestPending;
				TRAPD(err, iMsvOperation=iClient->CreateOperationL(iStatus));
				if ( iTestStep.TestStepResult() == EPass && err==KErrNone )
					{
					SetActive();
					}
				else
					{
					CActiveScheduler::Stop();
					}
				}
			else
				{
				iTestStep.ERR_PRINTF2(_L("Sending State not Waiting :%d"), iMsgEntry.SendingState());
				iTestStep.SetTestStepResult(EFail);
				CActiveScheduler::Stop();
				}
			}
			break;
		case KErrCancel:
			{
			if(iCancelSms)
				{
				iTestStep.INFO_PRINTF1(_L("Sending of the mesage Cancelled successfully"));
				}
			else
				{
				iTestStep.ERR_PRINTF2(_L("Message failed to Send, Error = %d"), iStatus.Int());
				iTestStep.SetTestStepResult(EFail);
				}
			CActiveScheduler::Stop();
			break;
			}
		default:
			iTestStep.ERR_PRINTF2(_L("Unknown Event :%d"), iStatus.Int());
			iTestStep.SetTestStepResult(EFail);
			CActiveScheduler::Stop();
			}
		break;
	case EStateRequest:
		switch (iStatus.Int())
			{
		case KErrNone:
			{
			TInt	error=iClient->DisplayProgressL(ETrue, iMsvOperation);
			if ( error != KErrNone )
				{
				iTestStep.ERR_PRINTF2(_L("Progress Error:%d"), error);
				iTestStep.SetTestStepResult(EFail);
				}
			delete iMsvOperation;
			iMsvOperation=NULL;

			//	Is there another operation
			if ( iClient->MoreOperations() )
				{
				iStatus = KRequestPending;
				TRAPD(err, iMsvOperation=iClient->CreateOperationL(iStatus));
				if ( iTestStep.TestStepResult() == EPass && err==KErrNone )
					{
					SetActive();
					}
				else
					{
					CActiveScheduler::Stop();
					}
				}
			else
				{
				CActiveScheduler::Stop();
				}
			}
			break;
		case KErrServerTerminated:
			{
			TInt	error=iClient->DisplayProgressL(ETrue, iMsvOperation);
			if ( error != KErrServerTerminated )
				{
				iTestStep.ERR_PRINTF2(_L("Progress Error:%d"), error);
				iTestStep.SetTestStepResult(EFail);
				}
			delete iMsvOperation;
			iMsvOperation=NULL;
			CActiveScheduler::Stop();
			}
		default:
			iTestStep.ERR_PRINTF2(_L("Unknown Event :%d"), iStatus.Int());
			iTestStep.SetTestStepResult(EFail);
			CActiveScheduler::Stop();
			}
		break;
	default:
		iTestStep.ERR_PRINTF1(_L("No handler found in CTestMessProcessor class"));
		iTestStep.SetTestStepResult(EFail);
		CActiveScheduler::Stop();
		}
	}