messagingfw/msgtestfw/TestActions/SendAs/src/CMtfTestActionGetMessageAtIndex.cpp
author hgs
Wed, 01 Sep 2010 14:40:02 +0530
changeset 45 5ba2fbae6cfe
parent 0 8e480a14352b
permissions -rw-r--r--
201035_02

// Copyright (c) 2004-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:
// __ACTION_INFO_BEGIN__ 
// [Action Name]
// GetMessageAtIndex
// [Action Parameters]
// CMsvEntrySelection	paramMessageSelection <input>	: Reference to Mail selection
// TInt					index	<input>					: Value of Index
// TMsvId				paramMessageId	<output>		: Value of message Id
// [Action Description]
// GetMessagAtIndex Test Action takes a CMsvEntrySelection and an array index 
// value as inputs.  The Test Action provides the TMsvId present in the 
// CMsvEntrySelection at the specified index as output
// [APIs Used]
// CMsvEntrySelection::At()
// __ACTION_INFO_END__
// 
//

/**
 @file 
 @internalTechnology 
*/


// User include
#include "CMtfTestActionGetMessageAtIndex.h"
#include "CMtfTestCase.h"
#include "CMtfTestActionParameters.h"



/**
  NewL()
  Constructs a CMtfTestActionGetMessageAtIndex object.
  Uses two phase construction and leaves nothing on the CleanupStack.   
  @internalTechnology
  @param  aTestCase         Test Case to which this Test Action belongs
  @param  aActionParameters Action parameters, must not be NULL
  @return Created object of type CMtfTestActionGetMessageAtIndex
  @pre    None
  @post   CMtfTestActionGetMessageAtIndex object is created
*/
CMtfTestAction* CMtfTestActionGetMessageAtIndex::
		NewL(CMtfTestCase& aTestCase,CMtfTestActionParameters* aActionParameters)
	{
	CMtfTestActionGetMessageAtIndex* self = 
							new (ELeave) CMtfTestActionGetMessageAtIndex(aTestCase);

	CleanupStack::PushL(self);
	self->ConstructL(aActionParameters);
	CleanupStack::Pop(self);
	return self;
	}
	

/**
  CMtfTestActionGetMessageAtIndex constructor
  Calls the base class' constructor
  @internalTechnology  
  @param  aTestCase  Test Case to which this Test Action belongs
  @pre    None
  @post   None
*/ 
CMtfTestActionGetMessageAtIndex::CMtfTestActionGetMessageAtIndex(CMtfTestCase& aTestCase)
	: CMtfSynchronousTestAction(aTestCase)
	{
	}

/**
  Function : ~CMtfTestActionGetMessageAtIndex
  Description : Destructor
  @internalTechnology
  @param :
  @return : 
  @pre 
  @post 
*/
CMtfTestActionGetMessageAtIndex::~CMtfTestActionGetMessageAtIndex()
	{
	}

/**
  ExecuteActionL
  Obtains the parameters for the test action. Get the Message Id at given index. The Message 
  Id is stored as output parameters of this Test Action
  @internalTechnology 
  @pre    None
  @post   None
  @leave  System wide errors
*/
void CMtfTestActionGetMessageAtIndex::ExecuteActionL()
	{
	if((TestCase().TestStepResult()) == EPass)
		{
		TestCase().INFO_PRINTF2(_L("Test Action %S start..."), &KTestActionGetMessageAtIndex);
		
		// Get test action input parameters
		CMsvEntrySelection* paramSelection = ObtainParameterReferenceL<CMsvEntrySelection>(TestCase(),
																	ActionParameters().Parameter(0));
			
		TInt index = ObtainValueParameterL<TInt>(TestCase(),ActionParameters().Parameter(1));
	
		// Validate the index value provided
		TMsvId paramMessageId;
		TInt length = paramSelection->Length();

		if(index > length)
			{
			TestCase().ERR_PRINTF3(_L("Index out of bounds, length of selection: %d, input provided = %d"),length, index);
			TestCase().SetTestStepResult(EFail);
			}
		else
			{
			// Valid index, get the message Id and store it as output parameter
			paramMessageId = paramSelection->At(index);
			StoreParameterL<TMsvId>(TestCase(),paramMessageId,ActionParameters().Parameter(2));
			}
		TestCase().INFO_PRINTF2(_L("Test Action %S completed."), &KTestActionGetMessageAtIndex);
		}
	TestCase().ActionCompletedL(*this);
	}