multimediacommsengine/mmcesrv/mmceserver/tsrc/ut_server/src/UT_CMCEStateIdle.cpp
author Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
Tue, 02 Feb 2010 01:04:58 +0200
changeset 0 1bce908db942
permissions -rw-r--r--
Revision: 201003 Kit: 201005

/*
* Copyright (c) 2004 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:  
*
*/




//  CLASS HEADER
#include "ut_cmcestateidle.h"

//  EXTERNAL INCLUDES
#include <digia/eunit/eunitmacros.h>


//  INTERNAL INCLUDES
#include "MCETestHelper.h"

#include "mcesipsession.h"
#include "mcesipstatemachine.h"
#include "mceservercore.h"
#include "mcecssession.h"
#include "mcecssessionimplementation.h"
#include "mcesipconnection.h"
#include "mcecomsession.h"
#include "mcestateidle.h"
#include "mceevent.h"
#include "mceserial.h"
#include "mcemediamanager.h"
#include "mcenatsipsession.h"



// CONSTRUCTION
UT_CMceStateIdle* UT_CMceStateIdle::NewL()
    {
    UT_CMceStateIdle* self = UT_CMceStateIdle::NewLC(); 
    CleanupStack::Pop();

    return self;
    }

UT_CMceStateIdle* UT_CMceStateIdle::NewLC()
    {
    UT_CMceStateIdle* self = new( ELeave ) UT_CMceStateIdle();
    CleanupStack::PushL( self );

	self->ConstructL(); 

    return self;
    }

// Destructor (virtual by CBase)
UT_CMceStateIdle::~UT_CMceStateIdle()
    {
    }

// Default constructor
UT_CMceStateIdle::UT_CMceStateIdle()
    {
    }

// Second phase construct
void UT_CMceStateIdle::ConstructL()
    {
    // The ConstructL from the base class CEUnitTestSuiteClass must be called.
    // It generates the test case table.
    CEUnitTestSuiteClass::ConstructL();
    }

//  METHODS

void UT_CMceStateIdle::SetupL()
    {
    CMCETls::OpenL();
    SdpCodecStringPool::OpenL();
    
    
    //TMceIds ids;
    iIds.iProfileID = 1;
    iIds.iManagerType = KMceCSSIPSession;
    iIds.iDialogType = KMceDlgTypeInvite;
    iServerCore = CMceServerCore::NewL();
    
    iStorage = CMCETls::Storage();
    
	CDesC8ArrayFlat* params = new (ELeave) CDesC8ArrayFlat( KMceArrayGranularity );
	CleanupStack::PushL( params );
	params->AppendL( _L8("User <user2@host>") );
	params->AppendL( _L8("User <user@host>") );
    
    CMceMsgTextArray* msgParams = new (ELeave) CMceMsgTextArray( *params );
    CleanupStack::PushL( msgParams );
    iStorage->StoreL( iIds, *msgParams );
    CleanupStack::PopAndDestroy( msgParams );
    CleanupStack::PopAndDestroy( params );
    
    iSession = CMceCsSession::NewL(*iServerCore);
    iSession->CreateSubSessionL(iIds, RMessage2());
    iSipSession =  static_cast<CMceSipSession*>((iSession->Implementation().SubSessions())[0]);
    iSipSession->NextState( KMceStateIdle );
    iState = static_cast<CMceStateIdle*>(&iSipSession->CurrentState());
    }

void UT_CMceStateIdle::Teardown()
    {
    CMCETls::Close();
	delete iSession;
    delete iServerCore;

    SdpCodecStringPool::Close();
    }

void UT_CMceStateIdle::UT_CMceStateIdle_AcceptLL()
    {
    TMceIds ids;
    CMceMsgBase* msg = NULL;
    
    TMceStateTransitionEvent event1( *iSipSession, EMceItcEstablishSession, ids, *msg );
    EUNIT_ASSERT ( iState->AcceptL( event1 ) );

    TMceStateTransitionEvent event2( *iSipSession, EMceInvite );
    EUNIT_ASSERT ( iState->AcceptL( event2 ) );
    
    TMceStateTransitionEvent event3( *iSipSession, EMceMediaUpdated );
    TRAPD( e1, iState->AcceptL( event3 ) );
    EUNIT_ASSERT ( e1 == KErrTotalLossOfPrecision );
    
    TMceStateTransitionEvent event4( *iSipSession, EMceItcUpdate, ids, *msg );
    TRAPD( e2, iState->AcceptL( event4 ) );
    EUNIT_ASSERT ( e2 == KErrTotalLossOfPrecision );
    
    TMceStateTransitionEvent event5( *iSipSession, EMceCancel, KErrNotFound );
    TRAPD( e3, iState->AcceptL( event5 ) );
    EUNIT_ASSERT ( e3 == KErrTotalLossOfPrecision );


    TMceStateTransitionEvent event8( *iSipSession, EMceMediaUpdated );
    TRAPD( e6, iState->AcceptL( event8 ) );
    EUNIT_ASSERT ( e6 == KErrTotalLossOfPrecision );    
    }

void UT_CMceStateIdle::UT_CMceStateIdle_EntryLL()
    {
//Invite

    CMceComSession* clientSession = CMceComSession::NewL( CMceComSession::EOutSession );
    CleanupStack::PushL( clientSession );
    CMceMsgObject<CMceComSession>* clientSessionMsg = 
        new (ELeave) CMceMsgObject<CMceComSession>( *clientSession, EMceItcMsgTypeSession );
    CleanupStack::Pop( clientSession );
    clientSessionMsg->PushL();
    CleanupStack::PushL( clientSessionMsg );
    
    TMceIds ids;
    
    iStorage->iMediaManagerUpdateStatus = KMceAsync;
    TMceStateTransitionEvent event1( *iSipSession, EMceItcEstablishSession, ids, 
                                     *clientSessionMsg );

    iState->EntryL( event1 );
    CleanupStack::PopAndDestroy( clientSessionMsg );
   
    EUNIT_ASSERT ( iStorage->iMediaManagerAction == CMCETls::EUpdate );
    EUNIT_ASSERT ( iStorage->iMediaManagerSdpAction == CMCETls::ENone );
    EUNIT_ASSERT ( iSipSession->Body() == clientSession );
    EUNIT_ASSERT ( iSipSession->Body()->iSIPContent == NULL );
    EUNIT_ASSERT ( iSipSession->Offer() == NULL );

    delete iSipSession->iBody;
    iSipSession->iBody = NULL;

    clientSession = CMceComSession::NewL( CMceComSession::EOutSession );
    CleanupStack::PushL( clientSession );
    clientSessionMsg = 
        new (ELeave) CMceMsgObject<CMceComSession>( *clientSession, EMceItcMsgTypeSession );
    CleanupStack::Pop( clientSession );
    clientSessionMsg->PushL();
    CleanupStack::PushL( clientSessionMsg );

    iStorage->iMediaManagerUpdateStatus = KMceReady;
    TMceStateTransitionEvent event1_1( *iSipSession, EMceItcEstablishSession, ids, 
                                       *clientSessionMsg );

    iState->EntryL( event1_1 );
    CleanupStack::PopAndDestroy( clientSessionMsg );
    
    EUNIT_ASSERT ( iStorage->iMediaManagerAction == CMCETls::EUpdate );
    EUNIT_ASSERT ( iStorage->iMediaManagerSdpAction == CMCETls::EEncode );
    EUNIT_ASSERT ( iSipSession->Body() == clientSession );
    EUNIT_ASSERT ( iSipSession->Body()->iSIPContent == NULL );
    EUNIT_ASSERT ( iSipSession->Offer() != NULL );
    
    
    delete iSipSession->iOffer;
    iSipSession->iOffer = NULL;
    
    
//Invited    

    iSipSession->Body()->iType = CMceComSession::EInSession;

    RPointerArray<CSIPHeaderBase> sipHeaders;
    CSIPHeaderBase::PushLC( &sipHeaders );

    // Supported: timer 
    RStringF timerKey = SIPStrings::Pool().OpenFStringL( KMceSipTimer() );
	CleanupClosePushL( timerKey );
    
    CSIPSupportedHeader* supportedHeader = CSIPSupportedHeader::NewLC( timerKey );
    
    User::LeaveIfError( sipHeaders.Append( supportedHeader ) );
    CleanupStack::Pop( supportedHeader );
    CleanupStack::PopAndDestroy();//timerKey
    
    // Session-Expires: 10
    				
    CSIPExtensionHeader* sessionExpiresHeader = 
    						CSIPExtensionHeader::NewLC( KSessionExpires(), _L8("10") );
    User::LeaveIfError( sipHeaders.Append( sessionExpiresHeader ) );
    CleanupStack::Pop( sessionExpiresHeader );

    CSIPServerTransaction* srvtransaction = 
        MCETestHelper::ServerTransactionL( SipStrConsts::EInvite, sipHeaders, ETrue );
    CleanupStack::PopAndDestroy( &sipHeaders );
    CleanupStack::PushL( srvtransaction );
    iSipSession->iPendingReceivedRequests.AppendL( srvtransaction );
    CleanupStack::Pop( srvtransaction );
    
    TMceStateTransitionEvent event2( *iSipSession, EMceInvite );
    iState->EntryL( event2 );

    EUNIT_ASSERT ( iStorage->iMediaManagerAction == CMCETls::EUpdate );
    
    iStorage->iMediaManagerAction = CMCETls::ENone;
    iStorage->iMediaManagerDecodeStatus = KMceSipWarnMediaTypeNotAvailable;
    
    TMceStateTransitionEvent event3( *iSipSession, EMceInvite );
    iState->EntryL( event3 );


    EUNIT_ASSERT ( iStorage->iMediaManagerAction == CMCETls::ENone );
    EUNIT_ASSERT ( iStorage->iSipSentResponse->StatusCode() == KMceSipNotAcceptableHere );
    EUNIT_ASSERT ( iSipSession->Body() != NULL );
    EUNIT_ASSERT ( iSipSession->BodyCandidate() == NULL );
    EUNIT_ASSERT ( iSipSession->Body()->iType == CMceComSession::EInSession );
    EUNIT_ASSERT ( iSipSession->Body()->iSIPContent == NULL );
    

    TMceStateTransitionEvent event4( *iSipSession, EMceCancel );
    iState->EntryL( event4 );
    
    CSIPServerTransaction& request = iSipSession->Request();
    CSIPRequestElements* requestElement = const_cast<CSIPRequestElements*>(request.RequestElements());
    requestElement->MessageElements().SetContent( NULL );
    
    TMceStateTransitionEvent event2_2( *iSipSession, EMceInvite );
    iState->EntryL( event2_2 );
    }
    
void UT_CMceStateIdle::UT_CMceStateIdle_ExitLL()
    {
    TMceIds ids;
    CMceMsgBase* msg = NULL;
    
    iSipSession->iBody = CMceComSession::NewL( CMceComSession::EOutSession );
    
    TMceStateTransitionEvent event1( *iSipSession, EMceItcEstablishSession, ids, *msg );
    event1.ParamStatus() = KMceAsync;
    
    iState->ExitL( event1 );
    EUNIT_ASSERT ( iSipSession->CurrentState().Id() == KMceStateClientEstablishing );
    EUNIT_ASSERT ( iSipSession->iBody->iState == CMceSession::EOffering );
    EUNIT_ASSERT ( ids.iState == CMceSession::EOffering );
    MCE_SET_STATES( iSipSession /*session*/, 
                    CMceSession::EIdle /*clientState*/, 
                    KMceStateIdle /*serverState*/ );
    
    
    TMceStateTransitionEvent event1_1( *iSipSession, EMceItcEstablishSession, ids, *msg );
    event1_1.ParamStatus() = KMceReady;
    
    iState->ExitL( event1_1 );
    EUNIT_ASSERT ( iSipSession->CurrentState().Id() == KMceStateOffering );
    EUNIT_ASSERT ( iSipSession->iBody->iState == CMceSession::EOffering );
    EUNIT_ASSERT ( ids.iState == CMceSession::EOffering );
    MCE_SET_STATES( iSipSession /*session*/, 
                    CMceSession::EIdle /*clientState*/, 
                    KMceStateIdle /*serverState*/ );
    
    EUNIT_ASSERT ( iSipSession->CurrentState().Id() == KMceStateIdle );
    MCE_TH_SET( iSipSession->iBody, NULL );
    iSipSession->iBody = CMceComSession::NewL( CMceComSession::EInSession );
    
    TMceStateTransitionEvent event2( *iSipSession, EMceInvite );
    iState->ExitL( event2 );
    EUNIT_ASSERT ( iSipSession->CurrentState().Id() == KMceStateServerEstablishing );
    EUNIT_ASSERT ( iSipSession->iBody->iState == CMceSession::EIncoming );

    MCE_SET_STATES( iSipSession /*session*/, 
                    CMceSession::EIdle /*clientState*/, 
                    KMceStateIdle /*serverState*/ );
    
    TMceStateTransitionEvent event3( *iSipSession, EMceCancel );
    iState->ExitL( event3 );

    MCE_SET_STATES( iSipSession /*session*/, 
                    CMceSession::EIdle /*clientState*/, 
                    KMceStateIdle /*serverState*/ );
    }


// INVITE received for a NAT session
void UT_CMceStateIdle::UT_CMceStateIdle_ExitL_NatSessionL()
	{
	
	CMceSipManager& manager = iServerCore->Manager();
    TUint32 profileId = 1;
    CSIPProfile& profile = manager.ProfileL( profileId );
	
	// Syncronous case
	CMceNatSipSession* natSession =
		CMceNatSipSession::NewLC( *iSession,
								  iSipSession->SIPConnection(),
								  *iSipSession->iStateMachine,
								  profile,
								  NULL );
									  
	natSession->iBody = CMceComSession::NewL( CMceComSession::EInSession );
    
    TMceIds ids;
    CMceMsgBase* msg = NULL;
  
    CSIPServerTransaction* trx = 
        MCETestHelper::ServerTransactionL( SipStrConsts::EInvite, ETrue );
    CleanupStack::PushL(trx);
    EUNIT_ASSERT( &natSession->Request() == NULL );
    natSession->iPendingReceivedRequests.AppendL( trx );
    CleanupStack::Pop(trx);
    EUNIT_ASSERT( &natSession->Request() == trx );
        
    // TODO: remove natSession->iComSession = natSession->iBody;
    natSession->iType = CMceCsSubSession::EInSession; // make this MT case
									  
								  
	TMceStateTransitionEvent event( *natSession, EMceInvite );
	event.ParamStatus() = KMceReady;

	iState->ExitL( event );

	EUNIT_ASSERT( natSession->CurrentState().Id() ==
				  KMceStateServerInitializing );


	// Asyncronous case
	natSession->NextState( KMceStateIdle );
    event.ParamStatus() = KMceAsync;

    iState->ExitL( event );
	EUNIT_ASSERT( natSession->CurrentState().Id() ==
				  KMceStateServerInitializing );


	// Error case
	natSession->NextState( KMceStateIdle );
    event.ParamStatus() = KErrGeneral;

    iState->ExitL( event );

	EUNIT_ASSERT( natSession->CurrentState().Id() == KMceStateTerminated );
	       
	CleanupStack::PopAndDestroy( natSession );
	}
	

// Pull mode INVITE received for a NAT session
void UT_CMceStateIdle::UT_CMceStateIdle_ExitL_NatSession1L()
	{
	CMceSipManager& manager = iServerCore->Manager();
    TUint32 profileId = 1;
    CSIPProfile& profile = manager.ProfileL( profileId );
    
	// Syncronous case
	CMceNatSipSession* natSession =
		CMceNatSipSession::NewLC( *iSession,
								  iSipSession->SIPConnection(),
								  *iSipSession->iStateMachine,
								  profile,
								  NULL );
	TMceStateTransitionEvent event( *natSession, EMceInvite );
	event.ParamStatus() = KMceReady;

	iState->ExitL( event );

	EUNIT_ASSERT( natSession->CurrentState().Id() ==
				  KMceStateServerEstablishing );

	// Error case
	natSession->NextState( KMceStateIdle );
    event.ParamStatus() = KErrGeneral;

    iState->ExitL( event );

	EUNIT_ASSERT( natSession->CurrentState().Id() == KMceStateTerminated );
	       
	CleanupStack::PopAndDestroy( natSession );
	}

	
	
        
//  TEST TABLE

EUNIT_BEGIN_TEST_TABLE( 
    UT_CMceStateIdle,
    "UT_CMceStateIdle",
    "UNIT" )

EUNIT_TEST(
    "AcceptL - test ",
    "CMceStateIdle",
    "AcceptL",
    "FUNCTIONALITY",
    SetupL, UT_CMceStateIdle_AcceptLL, Teardown)

EUNIT_TEST(
    "EntryL - test ",
    "CMceStateIdle",
    "EntryL",
    "FUNCTIONALITY",
    SetupL, UT_CMceStateIdle_EntryLL, Teardown)

EUNIT_TEST(
    "ExitL - test ",
    "CMceStateIdle",
    "ExitL",
    "FUNCTIONALITY",
    SetupL, UT_CMceStateIdle_ExitLL, Teardown)

EUNIT_TEST(
    "ExitL - NAT session",
    "CMceStateIdle",
    "ExitL",
    "FUNCTIONALITY",
    SetupL, UT_CMceStateIdle_ExitL_NatSessionL, Teardown)
    
EUNIT_TEST(
    "ExitL - NAT Pull Mode",
    "CMceStateIdle",
    "ExitL",
    "FUNCTIONALITY",
    SetupL, UT_CMceStateIdle_ExitL_NatSession1L, Teardown)
        

EUNIT_END_TEST_TABLE

//  END OF FILE