telephonyserverplugins/common_tsy/test/component/src/cctsyucasembms012.cpp
author Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
Mon, 15 Mar 2010 12:45:06 +0200
branchRCL_3
changeset 15 fc69e1e37771
parent 0 3553901f7fa8
child 24 6638e7f4bd8f
permissions -rw-r--r--
Revision: 201010 Kit: 201010

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

/**
 @file The TEFUnit integration test suite for MBMS Context support in the Common TSY.
*/

#include "cctsyucasembms012.h"
#include "cctsyactiveretriever.h"
#include <etel.h>
#include <etelmm.h>
#include <et_clsvr.h>
#include <ctsy/mmtsy_names.h>
#include <ctsy/serviceapi/mmtsy_ipcdefs.h>
#include "tmockltsydata.h"
#include <ctsy/serviceapi/gsmerror.h>

#include <pcktcs.h>
#include <pcktlist.h>
#include "pcktretrieve.h"
#include "CMmCommonStaticUtility.h"
#include <ctsy/serviceapi/mmtsy_defaults.h>

#define MBMS_MONITORSERVICECOUNTMULTIPLE 3

CTestSuite* CCTsyUCaseMbms012::CreateSuiteL(const TDesC& aName) 
	{
	SUB_SUITE;        
    ADD_TEST_STEP_ISO_CPP(CCTsyUCaseMbms012, CCTsyIntegrationTestMbms0001L );
	END_SUITE;
	}

//
// Actual test cases
//

/**
 * @SYMTestCaseID BA-CTSY-INT-MB-0022
 * @SYMFssID BA/CTSY/PKTS-0022
 * @SYMTestCaseDesc Support being notified when service availability changes
 * @SYMTestPriority High
 * @SYMTestActions RPacketContext::SetConfig, RPacketContext::Activate, RPacketService::NotifyStatusChange, RPacketService::GetStatus, RPacketContext::NotifyStatusChange, RPacketContext::GetStatus, RPacketService::EnumerateNifs, RPacketService::GetContextNameInNif, RPacketService::GetNifInfo, RPacketService::EnumerateContextsInNif, RPacketContext::Deactivate, RPacketService::EnumerateContextsInNif, RPacketContext::Deactivate
 * @SYMTestExpectedResults Pass - CTSY get new service statuses and informs client.  
 * @SYMTestType CIT
 * @SYMTestCaseDependencies live/manual
 *
 * Reason for test: Verify that NotifyMbmsNetworkServiceStatusChange completes correctly.
 *
 * @return - none
 */
void CCTsyUCaseMbms012::CCTsyIntegrationTestMbms0001L()
    {
        
	//
	// SET UP
	//
	        
    OpenEtelServerL( EUseExtendedError );
	CleanupStack::PushL( TCleanupItem( Cleanup, this ) );
	OpenPhoneL();	
	
	RPacketService packetService;
    OpenPacketServiceL( packetService );
    CleanupClosePushL( packetService );
              
	TInfoName contextId;
    RPacketMbmsContext packetMbmsContext;
    packetMbmsContext.OpenNewContext( packetService, contextId );
    CleanupClosePushL( packetMbmsContext );
    
	//
	// SET UP END
	//    
            
	//
	// TEST START
	//
	
	RBuf8 data;
	CleanupClosePushL( data );
	TRequestStatus requestStatus;
	TRequestStatus mockLtsyStatus;
 
   	TInt maxAllowed( 10 ); 
	TInt maxvalue( 10 );
 	
 	// check maximum monitored service value.
 	TMockLtsyData1<TInt> ltsyData( maxvalue );
 	data.Close();
	ltsyData.SerialiseL( data );
 	iMockLTSY.NotifyTerminated( mockLtsyStatus );	
	iMockLTSY.CompleteL( EPacketEnumerateMbmsMonitorServiceList, KErrNone, data );
	User::WaitForRequest( mockLtsyStatus );	
	ASSERT_EQUALS( KErrNone, mockLtsyStatus.Int() );
		
	ASSERT_EQUALS( maxvalue, maxAllowed );

 	CFilteringActiveScheduler scheduler;
	CActiveScheduler::Install( &scheduler );
	
	//List retriever
	CRetrievePcktMbmsMonitoredServices* monitorList = CRetrievePcktMbmsMonitoredServices::NewL( packetService );	 
	CleanupStack::PushL( monitorList );

	CActiveRetriever::ResetRequestsNumber();
	CActiveRetriever* activeRetriever = CActiveRetriever::NewL( *monitorList );
	CleanupStack::PushL( activeRetriever );
	scheduler.AddRetrieverL( *activeRetriever );
		
	RBuf8 expectData1;
	CleanupClosePushL( expectData1 );
	TInt i;
    TMockLtsyData1<TInt> expExpect1( i );
    expExpect1.SerialiseL( expectData1 );
    
	RBuf8 completeData;
	CleanupClosePushL( completeData );
	
	TRequestStatus aReqStatus;
    RPacketService::TMbmsServiceAvailabilityV1 existingParams;
    
    
    CPcktMbmsMonitoredServiceList* multipleEntries = CPcktMbmsMonitoredServiceList ::NewL();
	CleanupStack::PushL( multipleEntries );
	
	for( TInt i = 0; i < MBMS_MONITORSERVICECOUNTMULTIPLE; i++ )
		{
		existingParams.iTmgi.SetServiceId( i ); 
	    existingParams.iTmgi.SetMCC( i );
	    existingParams.iTmgi.SetMNC( i );
	    existingParams.iMbmsServiceMode = KBroadcast;
	    existingParams.iMbmsAccessBearer = E2GBearer;
	   	existingParams.iMbmsAvailabilityStatus = EMbmsUnavailable;
		multipleEntries->AddEntryL( existingParams );
		}
	
	iMockLTSY.ExpectL( EPacketUpdateMbmsMonitorServiceList, expectData1 );
	iMockLTSY.CompleteL( EPacketUpdateMbmsMonitorServiceList, KErrNone, completeData );
	
	packetService.UpdateMbmsMonitorServiceListL(aReqStatus, EAddEntries, multipleEntries );	
	User::WaitForRequest( aReqStatus );
	ASSERT_EQUALS( KErrNone, aReqStatus.Int() );
		
	monitorList->Start( activeRetriever->Status() );
	activeRetriever->Activate();
	scheduler.StartScheduler();

	ASSERT_EQUALS( 0, CActiveRetriever::ResetRequestsNumber() );
	ASSERT_EQUALS( KErrNone, activeRetriever->iStatus.Int() );

	CPcktMbmsMonitoredServiceList* list = monitorList->RetrieveListL();
	CleanupStack::PushL( list );
	
	ASSERT_EQUALS(MBMS_MONITORSERVICECOUNTMULTIPLE, list->Enumerate() );
	
   	RBuf8 expectData2;
	CleanupClosePushL( expectData2 );
	TInt j;
    TMockLtsyData1<TInt> expExpect2( j );
    expExpect2.SerialiseL( expectData2 );
    
	RBuf8 completeData2;
	CleanupClosePushL( completeData2 );
	
    RPacketService::TMbmsServiceAvailabilityV1 updatedParams;
    
    CPcktMbmsMonitoredServiceList* multipleEntries2 = CPcktMbmsMonitoredServiceList ::NewL();
	CleanupStack::PushL( multipleEntries2 );
	
	for( TInt i = 0; i < MBMS_MONITORSERVICECOUNTMULTIPLE; i++ )
		{
		updatedParams.iTmgi.SetServiceId( i ); 
	    updatedParams.iTmgi.SetMCC( i );
	    updatedParams.iTmgi.SetMNC( i );
	    updatedParams.iMbmsServiceMode = KBroadcast;
	    updatedParams.iMbmsAccessBearer = E2GBearer;
	   	updatedParams.iMbmsAvailabilityStatus = EMbmsAvailable;
		multipleEntries2->AddEntryL( updatedParams );
		}


 	//-------------------------------------------------------------------------
	// TEST: Successful completion request of
	// RPacketService::NotifyMbmsServiceAvailabilityChange.
 	//-------------------------------------------------------------------------
  
	// RPacketService::NotifyMbmsServiceAvailabilityListChange
	packetService.NotifyMbmsServiceAvailabilityChange( requestStatus );
	
	TInt complete2 = 0;
 	TMockLtsyData1< TInt > dataForComplete2( complete2 );
    dataForComplete2.SerialiseL( completeData2 );
    
    iMockLTSY.NotifyTerminated( mockLtsyStatus );
   	iMockLTSY.CompleteL( EPacketNotifyMbmsServiceAvailabilityChange, KErrNone, completeData2 );
			
	User::WaitForRequest( mockLtsyStatus );
	AssertMockLtsyStatusL();
	// ensure that RPacketService::NotifyMbmsServiceAvailabilityListChange completes with status KErrNone
	ASSERT_EQUALS( KErrNone, mockLtsyStatus.Int() );	 
	User::WaitForRequest( requestStatus );	
	AssertMockLtsyStatusL();
	ASSERT_EQUALS( KErrNone, requestStatus.Int() );
	
	monitorList->Start( activeRetriever->Status() );
	activeRetriever->Activate();
	scheduler.StartScheduler();

	ASSERT_EQUALS( 0, CActiveRetriever::ResetRequestsNumber() );
	ASSERT_EQUALS( KErrNone, activeRetriever->iStatus.Int() );
	
	list = monitorList->RetrieveListL();
	CleanupStack::PushL( list );
	// check that monitored list has been updated correctly.		
	ASSERT_TRUE( TComparator<CPcktMbmsMonitoredServiceList>::IsEqual( *multipleEntries2, *list ) );

	//
	// TEST END
	//	

	AssertMockLtsyStatusL();
	CleanupStack::PopAndDestroy( 14, this ); // multipleEntries2, expectData2, list, multipleEntries, completeData, expectData1, activeRetriever, monitorList, data, packetMbmsContext, packetService, this
   }