diff -r 000000000000 -r 8e480a14352b messagingfw/msgtestfw/TestActions/Base/src/CMtfTestActionReadMessage.cpp --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/messagingfw/msgtestfw/TestActions/Base/src/CMtfTestActionReadMessage.cpp Mon Jan 18 20:36:02 2010 +0200 @@ -0,0 +1,100 @@ +// 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] +// ReadMessage +// [Action Parameters] +// Session : Reference to the session. +// Entry : Reference to the entry. +// [Action Description] +// Reads the contents of a message and prints it in the log. +// [APIs Used] +// CMsvEntry::Entry +// CMtfTestActionUtilsEmailMessage::GetBodyTextL +// CRichText::Read +// __ACTION_INFO_END__ +// +// + + +#include "CMtfTestActionReadMessage.h" +#include "CMtfTestCase.h" +#include "CMtfTestActionParameters.h" +#include "CMtfTestActionUtilsEmailMessage.h" + +#include + + + +CMtfTestAction* CMtfTestActionReadMessage::NewL(CMtfTestCase& aTestCase,CMtfTestActionParameters* aActionParameters) + { + CMtfTestActionReadMessage* self = new(ELeave) CMtfTestActionReadMessage(aTestCase); + CleanupStack::PushL(self); + self->ConstructL(aActionParameters); + CleanupStack::Pop(); + return self; + } + + +CMtfTestActionReadMessage::CMtfTestActionReadMessage(CMtfTestCase& aTestCase) + : CMtfSynchronousTestAction(aTestCase) + { + } + + +CMtfTestActionReadMessage::~CMtfTestActionReadMessage() + { + } + +void CMtfTestActionReadMessage::ExecuteActionL() + { + TestCase().INFO_PRINTF2(_L("Test Action %S start..."), &KTestActionAddReadMessage); + + CMsvSession* paramSession = ObtainParameterReferenceL(TestCase(),ActionParameters().Parameter(0)); + CMsvEntry* messageEntry = ObtainParameterReferenceL(TestCase(),ActionParameters().Parameter(1)); + + // print message subject in log + TestCase().INFO_PRINTF1(_L("Message subject:")); + TPtrC subject = messageEntry->Entry().iDescription; + TestCase().INFO_PRINTF1(subject); + + // get and read message body + CMtfTestActionUtilsEmailMessage* messageInfo = CMtfTestActionUtilsEmailMessage::NewL(*messageEntry, TestCase()); + CleanupStack::PushL(messageInfo); + + CParaFormatLayer* paraFormatLayer = CParaFormatLayer::NewL(); + CleanupStack::PushL(paraFormatLayer); + + CCharFormatLayer* charFormatLayer = CCharFormatLayer::NewL(); + CleanupStack::PushL(charFormatLayer); + + CRichText* plainBodyText = CRichText::NewL(paraFormatLayer, charFormatLayer, CEditableText::EFlatStorage, 256); + CleanupStack::PushL(plainBodyText); + + messageInfo->GetBodyTextL(*plainBodyText, *paraFormatLayer, *charFormatLayer); + + TPtrC bodyText = plainBodyText->Read(0); + + // print message body in log + TestCase().INFO_PRINTF1(_L("Message body:")); + TestCase().INFO_PRINTF1(bodyText); + + CleanupStack::PopAndDestroy(4); + + TestCase().INFO_PRINTF2(_L("Test Action %S completed."), &KTestActionAddReadMessage); + TestCase().ActionCompletedL(*this); + } + + +