commonappservices/alarmservertest/TestAlarmSrv/EASShdOpCodeGetAlarmData1_CStep.cpp
changeset 0 2e3d3ce01487
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/commonappservices/alarmservertest/TestAlarmSrv/EASShdOpCodeGetAlarmData1_CStep.cpp	Tue Feb 02 10:12:00 2010 +0200
@@ -0,0 +1,100 @@
+// Copyright (c) 1997-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:
+// This file contains the functions to construct the Test Step and the 
+// Exec_SendReceiveL() function that connects to the server and makes IPC calls.
+// 
+//
+
+// Test Step header
+#include "EASShdOpCodeGetAlarmData1_CStep.h"
+
+// TO BE SAFE
+IMPORT_C TInt StartDialogThread();
+
+/** 
+Constructor called from the respective Suite.cpp from their "AddTestStep" function
+Each test step initialises it's own name
+*/
+CEASShdOpCodeGetAlarmData1Step::CEASShdOpCodeGetAlarmData1Step()
+	{
+	// The server name and IPC number is obtained and all messages are checked Sync
+	iSrServerName		= _L("!AlarmServer");
+	iSrMessageType		= 2;
+	iSrMessageId		= 101;
+	iSrMessageMask		= 32768;
+	iServerPanic		= _L("ALARMSERVER");
+
+	// NOT expected to be rejected as this test step will test for the condition: 
+	// none capapbility and same SID, and so has to pass
+	iExpectRejection = EFalse;
+	
+	iStepCap = 32768;
+
+	// Get a unique thread name
+	iSrChildThread.Format(_L("ChildThread_%S_%d"),&iSrServerName,iSrMessageId);
+	}
+
+/**
+This function is called by the Child Thread
+1.	Create a session with the server
+2.	Test an SendReceive call
+3.	Informs the main thread about the status of the call using
+	a.	iSessionCreated, if the a connection is established
+	b.	iResultServer, holds the return value for connection 
+	c.	iResultSr, the return value of SendReceive	call
+*/
+TInt CEASShdOpCodeGetAlarmData1Step::Exec_SendReceiveL()
+	{
+	iResultServer = CreateSession(iSrServerName,Version(),KAlarmServerAsynchronousSlotCount);
+
+	if (iResultServer!=KErrNone)
+		{
+		iResultServer=StartServer();
+		if (iResultServer!=KErrNone)
+			{
+			return(iResultServer);
+			}
+		iResultServer = CreateSession(iSrServerName,Version(),KAlarmServerAsynchronousSlotCount);
+		}
+	if(iResultServer == 0)
+		{
+		iSessionCreated = ETrue;
+		if(iSrMessageId >= 0)
+			{
+			// Get the alarm id
+			TAlarmId alarmId;
+			alarmId = CCapabilityTestStep::GetAlarmId();
+			
+			if(alarmId >= 0)
+				{
+				// If valid alarm id, perform IPC call
+				_LIT8(KSomeAlarmData, "This is some 8-bit data");
+				HBufC8* buf = HBufC8::NewLC(KSomeAlarmData().Size());
+				TPtr8 pBuf(buf->Des());
+				TIpcArgs args(alarmId,pBuf.MaxLength(),&pBuf);
+				iResultSr =	SendReceive(iSrMessageId, args);
+				
+				// NewLC was used. So clean up
+				CleanupStack::PopAndDestroy(buf);
+				}
+			else
+				{
+				// else leave
+				User::Leave(alarmId);
+				}	
+			}
+		}
+	return iResultServer;
+	}
+