messagingfw/msgtestfw/TestActions/Capabilities/src/CMtfTestActionSendEMsvCreateEntry.cpp
changeset 0 8e480a14352b
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/messagingfw/msgtestfw/TestActions/Capabilities/src/CMtfTestActionSendEMsvCreateEntry.cpp	Mon Jan 18 20:36:02 2010 +0200
@@ -0,0 +1,239 @@
+// 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:
+//
+
+#include "CMtfTestActionSendEMsvCreateEntry.h"
+
+#include <e32std.h>
+#include <e32base.h>
+
+#include <msvipc.h>
+#include "MCLIENT.H"
+#include "MSERVER.H"
+
+
+#include "CMtfTestCase.h"
+#include "CMtfTestActionParameters.h"
+
+#include "IPCCommandForCapsPermissions.h"
+#include "SendProxyClient.h"
+#include "SendProxyserver.h"
+
+
+/**
+  Function : NewL
+  Description : 
+  @internalTechnology
+  @param : aTestCase - CMtfTestCase for the CMtfTestAction base class
+  @param : aActionParams - CMtfTestActionParameters 
+  @return : CMtfTestAction* - a base class pointer to the newly created CMtfTestActionSendEMsvCreateEntry object
+  @pre none
+  @post none
+*/
+CMtfTestAction* CMtfTestActionSendEMsvCreateEntry::NewL(CMtfTestCase& aTestCase,CMtfTestActionParameters* aActionParameters)
+	{
+	CMtfTestActionSendEMsvCreateEntry* self = new (ELeave) CMtfTestActionSendEMsvCreateEntry(aTestCase);
+	CleanupStack::PushL(self);
+	self->ConstructL(aActionParameters);
+	CleanupStack::Pop(self);
+	return self;
+	}
+
+/**
+  Function : CMtfTestActionSendEMsvCreateEntry
+  Description : Constructor
+  @internalTechnology
+  @param : aTestCase - CMtfTestCase for the CMtfTestAction base class
+  @return : N/A
+  @pre none
+  @post none
+*/
+CMtfTestActionSendEMsvCreateEntry::CMtfTestActionSendEMsvCreateEntry(CMtfTestCase& aTestCase) : CMtfSynchronousTestAction(aTestCase)
+	{
+	}
+	
+/**
+  Function : ~CMtfTestActionSendEMsvCreateEntry
+  Description : Destructor
+  @internalTechnology
+  @param :
+  @return : 
+  @pre 
+  @post 
+*/
+CMtfTestActionSendEMsvCreateEntry::~CMtfTestActionSendEMsvCreateEntry()
+	{
+	}
+
+/**
+  Function : ExecuteActionL
+  Description : Entry point for the this test action in the test framework
+  @internalTechnology
+  @param : none
+  @return : void
+  @pre none 
+  @post none
+*/
+ 
+
+
+
+void CMtfTestActionSendEMsvCreateEntry::ExecuteActionL()
+	{
+	TestCase().INFO_PRINTF2(_L("Test Action %S start..."), &KTestActionSendEMsvCreateEntry);
+	// input params
+	TMsvId paramServiceId = ObtainValueParameterL<TMsvId>(TestCase(),ActionParameters().Parameter(0), 0);
+	TMsvId paramParentId = ObtainValueParameterL<TMsvId>(TestCase(),ActionParameters().Parameter(1), 0);
+	TInt createEntryType = ObtainValueParameterL<TInt>(TestCase(),ActionParameters().Parameter(2));
+	TInt useProxyServerSecurityId = ObtainValueParameterL<TInt>(TestCase(),ActionParameters().Parameter(3) , 1);
+	TInt canReadBack = ObtainValueParameterL<TInt>(TestCase(),ActionParameters().Parameter(4) );
+	TInt pass = ObtainValueParameterL<TInt>(TestCase(),ActionParameters().Parameter(5) );
+
+
+	TSecureId ownerId = 0;
+		// Assume set caps had set this correctly.
+	RProxyServerSession RPSS;
+	TInt error = RPSS.Connect();
+	// Will auto start the server if not started.
+
+	// Allow us to change the owning process of the message.
+	if (useProxyServerSecurityId)
+	{	// Use the security Id of  the proxy server.		
+		RPSS.GetServerSecureId( ownerId  );
+	}
+	else
+	{	// Use the security id of the test server. 
+	 	ownerId = RProcess().SecureId();
+	}
+	
+	
+	if (error!=KErrNone)
+		{
+		TestCase().ERR_PRINTF2(_L("%S :: Unable to start proxy server. !"), &KTestActionSendEMsvCreateEntry);
+		TestCase().SetTestStepResult(EFail);
+		}
+	else
+		{
+		TInt32 serverCaps;
+		RPSS.GetServerCapabilities(serverCaps);
+		TestCase().INFO_PRINTF2(_L("Proxy Server has capabilities: %x"), serverCaps);
+				
+		error = 0;
+		CleanupClosePushL(RPSS);
+		
+					
+		HBufC8* buffer = HBufC8::NewLC(KMsvSessionBufferLength);						
+		TPtr8 ptr=buffer->Des();
+
+		
+		TMsvEntryForward entry;
+		if ( createEntryType == ECreateMessage )
+			{						
+			FillInSimpleMessageEntry( 0, paramParentId, paramServiceId, entry);
+				// aMessageId=0 will be filled in when we attempt to create the message.
+			}
+		else if (createEntryType == ECreateRemote)
+			{
+			FillInRemoteMessageEntry(0, paramParentId, paramServiceId, entry);
+			}
+		else if (createEntryType == ECreateService)
+			{
+			FillInServiceEntry(0, entry);
+			}
+		else if ( createEntryType == ECreateMessageSMS )
+			{						
+			FillInSimpleMessageEntry( 0, paramParentId, paramServiceId, entry);
+				// aMessageId=0 will be filled in when we attempt to create the message.
+			entry.iMtm = KUidMsgTypeSMS;
+			}
+		else if (createEntryType == ECreateServiceSMS)
+			{
+			FillInServiceEntry(0, entry);
+			entry.iMtm = KUidMsgTypeSMS;
+			}
+		else if (createEntryType == ECreateRemoteSMS)
+			{
+			FillInRemoteMessageEntry(0, paramParentId, paramServiceId, entry);
+			entry.iMtm = KUidMsgTypeSMS;
+			}
+		else
+			{
+			User::Leave(KErrGeneral);
+			}
+
+		TMsvPackedEntry packedEntry(buffer);
+		error = packedEntry.PackEntry(entry);
+		if (error)
+			{	
+			TestCase().ERR_PRINTF2(_L("%S :: FAIL :: Unable to pack the message") , &KTestActionSendEMsvCreateEntry );
+			TestCase().SetTestStepResult(EFail);						
+			User::LeaveIfError(error);			
+			}
+		
+						
+		TMsvOp operationId=1;
+		error= RPSS.SendReceive(EMsvOperationData, TIpcArgs(operationId,buffer));
+		if (error)
+			{	
+			TestCase().ERR_PRINTF2(_L("%S :: FAIL :: Unable to send the created message") , &KTestActionSendEMsvCreateEntry );
+			TestCase().SetTestStepResult(EFail);						
+			User::LeaveIfError(error);			
+			}
+				
+		error=RPSS.SendReceive(EMsvCreateEntry , TIpcArgs(operationId, ownerId));
+		IPCCommandReportPassOrFailForCapsPermissions( TestCase(), KMsvServerName, error , pass );
+		
+		
+		if ( (pass == 0) && (error!=KErrNone ) )
+			{ // We expected it to fail and it did so do nothing else basically ignore the error. 
+			  // Appears to be no need to do EMsvOperationCompletion.
+			}
+		else
+			{
+
+			TMsvLocalOperationProgress progress;
+			TPckg<TMsvLocalOperationProgress> progressPack(progress);
+			TInt ret=RPSS.SendReceive(EMsvOperationCompletion , TIpcArgs(operationId, &progressPack));
+				// We need to indicate that we have finished and clean up otherwise we will get 
+				// a panic.
+				
+			if (ret>0)
+				{ // We are happy some sort of length returned.
+				}
+			else if (ret<0)
+				{	
+				TestCase().ERR_PRINTF2(_L("%S :: FAIL :: Unable to finish sending the modified message") , &KTestActionSendEMsvCreateEntry );
+				TestCase().SetTestStepResult(EFail);						
+				User::LeaveIfError(error);			
+				}
+			// else KErrNone
+			
+			if ( pass && canReadBack )
+				{	// Lets just check that we get the same results out as an extra check. 
+					// If it passes we know we must have suffient rights.
+				CheckWentInStoreL( TestCase(), KTestActionSendEMsvCreateEntry, RPSS, progress.iId, entry, operationId);
+				}
+			}
+			
+		CleanupStack::Check(buffer);
+		CleanupStack::PopAndDestroy();
+		
+		CleanupStack::Check(&RPSS);
+		CleanupStack::PopAndDestroy();
+		}
+	
+		
+	TestCase().INFO_PRINTF2(_L("Test Action %S completed."), &KTestActionSendEMsvCreateEntry);
+	TestCase().ActionCompletedL(*this);
+	}