multimediacommsengine/tsrc/MMCTestDriver/MCETester/src/TCmdGetState.cpp
changeset 0 1bce908db942
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/multimediacommsengine/tsrc/MMCTestDriver/MCETester/src/TCmdGetState.cpp	Tue Feb 02 01:04:58 2010 +0200
@@ -0,0 +1,117 @@
+/*
+* Copyright (c) 2005 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:    Implementation
+*
+*/
+
+
+
+#include "MCEConstants.h"
+#include "TCmdGetState.h"
+#include "CTcMCEContext.h"
+#include <MCESession.h>
+#include "CTcMCEReceived.h"
+
+
+void TCmdGetState::ExecuteL()
+	{
+
+	// -- Execution ------
+	
+	// Get an item off the receive queue (waits until timeout if none is present)
+
+	TInt timeout = ExtractIntegerL( KParamTimeout, KDefaultReceiveTimeout, 
+									EFalse );
+	CTcMCEReceived& item = iContext.ReceivedSessionItemL( timeout );	
+	
+	const CMceSession* session = NULL;
+	
+	if ( item.Session() )
+		{
+		session = item.Session();
+		}
+	
+	if ( !session ) 
+		{	
+		// If first item doesn't contain a session
+		User::Leave(KErrNotFound); 	
+		}	
+
+ 	CMceSession* expectedSession = reinterpret_cast<CMceSession*>
+ 		(GetObjectForIdL(KSessionId, ETrue));
+	
+	/*if ( session != expectedSession && session != expectedSession )
+		{
+		// If the first item's containing session is not the expected
+		User::Leave(KErrNotFound); 
+		}
+	*/		
+	CMceSession::TState state = item.Session()->State();
+	//SessionState();
+	
+	TBool connectionActive = session->ConnectionActive();
+	
+	// -- Response creation ----------------------------------------------------	
+
+	// Add Session
+	AddIdResponseL( KSessionId, *session );
+	
+	// Add state
+	AddIntegerResponseL(KResponseState, state);
+	AddTextualSessionStateL(state);
+	
+	// Add connection state
+	AddBooleanResponseL(KResponseConnectionActive, connectionActive);	
+	
+	// Add Headers
+	AddHeadersL( item.Headers() ); 
+	
+	// Add Body
+	if (item.Body())
+		{
+		if (item.Body()->Length() > 0)
+			{	
+			AddTextResponseL(KResponseBody, *(item.Body()));	
+			}
+		}
+	
+	// Add StatusCode
+	AddIntegerResponseL(KResponseStatusCode, item.StatusCode());
+
+	// Add ReasonPhrase
+	if (item.ReasonPhrase())
+		{
+		if (item.ReasonPhrase()->Length() > 0)
+			{	
+			AddTextResponseL(KResponseReasonPhrase, 
+				 			 *(item.ReasonPhrase()));	
+			}
+		}
+	
+	// Add Error
+	if ( item.Error() != KErrNone )
+		{
+		AddIntegerResponseL( KResponseError, item.Error() );
+		}	
+	}
+
+TBool TCmdGetState::Match( const TTcIdentifier& aId )
+	{
+	return TTcMceCommandBase::Match( aId, _L8("GetState") );
+	}
+
+TTcCommandBase* TCmdGetState::CreateL( MTcTestContext& aContext )
+	{
+	return new( ELeave ) TCmdGetState( aContext );
+	}