messagingfw/msgtestfw/TestActions/Email/Imap4/src/CMtfTestActionDoImap4PopulateAllMailWhenAlreadyConnected.cpp
changeset 0 8e480a14352b
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/messagingfw/msgtestfw/TestActions/Email/Imap4/src/CMtfTestActionDoImap4PopulateAllMailWhenAlreadyConnected.cpp	Mon Jan 18 20:36:02 2010 +0200
@@ -0,0 +1,110 @@
+// 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]
+// DoImap4PopulateAllMailWhenAlreadyConnected
+// [Action Parameters]
+// TMsvId				paramServiceId	<input>		: Value of IMAP4 Service Id
+// CImap4ClientMtm		paramMtm		<input>		: Reference to Imap4 client MTM
+// TImImap4GetMailInfo or TImImap4GetMailInfo	paramDownloadLimits	<input>	
+// : The Full or Partial download 
+// download limits
+// TMsvId				paramFolderId	<input>		: Destination folder id
+// [Action Description]
+// Populates all mails available on the IMAP4 Server.  The connection to the IMAP4 server
+// should be establieshed before executing this Test Action. Does a Partial or Full download of mails based on the
+// type of the download limits (TImImap4GetMailInfo  or  TImImap4GetPartialMailInfo) provided 
+// as input to the Test Action.
+// Calls the CImap4ClientMtm::InvokeAsyncFunctionL() with the IMAP4 command 
+// KIMAP4MTMPopulateAllMailWhenAlreadyConnected by calling the ExecuteIMAP4CommandL()
+// function of the base class.
+// [APIs Used]
+// CMsvEntry::SetEntryL()
+// CMsvEntrySelection::AppendL()
+// CMsvEntrySelection::ResizeL()
+// CImap4ClientMtm::InvokeAsyncFunctionL()
+// __ACTION_INFO_END__
+// 
+//
+
+/**
+ @file 
+ @internalTechnology 
+*/
+
+
+// User include
+#include "CMtfTestActionDoImap4PopulateAllMailWhenAlreadyConnected.h"
+#include "CMtfTestCase.h"
+
+
+/**
+  NewL()
+  Constructs a CMtfTestActionDoImap4PopulateAllMailWhenAlreadyConnected 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 CMtfTestActionDoImap4PopulateAllMailWhenAlreadyConnected
+  @pre    None
+  @post   CMtfTestActionDoImap4PopulateAllMailWhenAlreadyConnected object is created
+*/
+CMtfTestAction* CMtfTestActionDoImap4PopulateAllMailWhenAlreadyConnected::
+			NewL(CMtfTestCase& aTestCase,CMtfTestActionParameters* aActionParameters)
+	{
+	CMtfTestActionDoImap4PopulateAllMailWhenAlreadyConnected* self = 
+			new (ELeave) CMtfTestActionDoImap4PopulateAllMailWhenAlreadyConnected(aTestCase);
+
+	CleanupStack::PushL(self);
+	self->ConstructL(aActionParameters);
+	CleanupStack::Pop(self);
+	return self;
+	}
+	
+
+/**
+  CMtfTestActionDoImap4PopulateAllMailWhenAlreadyConnected constructor
+  Calls the base class' constructor
+  @internalTechnology  
+  @param  aTestCase  Test Case to which this Test Action belongs
+  @pre    None
+  @post   None
+*/ 
+CMtfTestActionDoImap4PopulateAllMailWhenAlreadyConnected::
+			CMtfTestActionDoImap4PopulateAllMailWhenAlreadyConnected
+											(CMtfTestCase& aTestCase)
+	: CMtfDoInvokeAsyncFunctionWithoutSelectionTestAction(aTestCase)
+	{
+	}
+
+
+/**
+  ExecuteActionL
+  Invokes the asynchronous operation for IMAP4 command 
+  KIMAP4MTMPopulateAllMailWhenAlreadyConnected by calling the base class
+  function ExecuteIMAP4CommandL()
+
+  @internalTechnology 
+  @pre    None
+  @post   None
+  @leave  System wide errors
+*/
+void CMtfTestActionDoImap4PopulateAllMailWhenAlreadyConnected::ExecuteActionL()
+	{
+	TestCase().INFO_PRINTF2(_L("Test Action %S start..."), &KTestActionDoImap4PopulateAllMailWhenAlreadyConnected);
+	TestCase().INFO_PRINTF1(_L("KIMAP4MTMPopulateAllMailWhenAlreadyConnected Imap4 command execution"));
+	// Call the base class function to invoke the IMAP4 command asynchronously
+	ExecuteIMAP4CommandL(KIMAP4MTMPopulateAllMailWhenAlreadyConnected);
+	TestCase().INFO_PRINTF2(_L("Test Action %S completed."), &KTestActionDoImap4PopulateAllMailWhenAlreadyConnected);
+	}