telephonyserverplugins/common_tsy/test/component/src/cctsyucasembms009.cpp
branchopencode
changeset 24 6638e7f4bd8f
parent 0 3553901f7fa8
--- a/telephonyserverplugins/common_tsy/test/component/src/cctsyucasembms009.cpp	Mon May 03 13:37:20 2010 +0300
+++ b/telephonyserverplugins/common_tsy/test/component/src/cctsyucasembms009.cpp	Thu May 06 15:10:38 2010 +0100
@@ -1,443 +1,443 @@
-// 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 "cctsyucasembms009.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_MONITORSERVICECOUNTONE	1
-#define MBMS_MONITORSERVICECOUNTMULTIPLE 3
-
-CTestSuite* CCTsyUCaseMbms009::CreateSuiteL(const TDesC& aName) 
-	{
-	SUB_SUITE;     
-    ADD_TEST_STEP_ISO_CPP(CCTsyUCaseMbms009, CCtsyIntegrationTestMbms0001L );
-    ADD_TEST_STEP_ISO_CPP(CCTsyUCaseMbms009, CCtsyIntegrationTestMbms0002L );
-	END_SUITE;
-}
-
-//
-// Actual test cases
-//
-
-/**
- * @SYMTestCaseID BA-CTSY-INT-MB-0017
- * @SYMFssID BA/CTSY/PKTS-0017
- * @SYMTestCaseDesc Support monitor list by removing entry.
- * @SYMTestPriority High
- * @SYMTestActions RPacketService::NotifyMbmsNetworkServiceStatusChange, RPacketService::UpdateMbmsMonitorServiceListL
- * @SYMTestExpectedResults Pass - Service is removed from the monitored service list.  
- * @SYMTestType CIT
- * @SYMTestCaseDependencies live/manual
- *
- * Reason for test:  Verify that services is removed correctly to the monitored service list.
- *
- * @return - none
- */
-void CCTsyUCaseMbms009::CCtsyIntegrationTestMbms0001L()
-    {
-        
-	//
-	// SET UP
-	//
-	        
-   	OpenEtelServerL( EUseExtendedError );
-	CleanupStack::PushL( TCleanupItem( Cleanup, this ) );
-	OpenPhoneL();	
-
-	RBuf8 data;
-	CleanupClosePushL(data);
-				
-	RPacketService packetService;
-    OpenPacketServiceL( packetService );
-    CleanupClosePushL( packetService );
-
-   	TRequestStatus requestStatus;
-   	TRequestStatus requestStatus2;
-   	TRequestStatus mockLtsyStatus;
-   	 
-	//
-	// SET UP END
-	//    
-            
-	//
-	// TEST START
-	//
-	
-	TInt maxAllowed = 3; 
-	TInt maxvalue = 3;
- 	
- 	// check maximum monitored service value
- 	TMockLtsyData1<TInt> ltsyData2(maxvalue);
- 	data.Close();
-	ltsyData2.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);
-	
-	// post RPacketService::NotifyMbmsNetworkServiceAvailabilityChange
-	packetService.NotifyMbmsServiceAvailabilityChange( requestStatus );
-		
-	//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		
-	packetService.UpdateMbmsMonitorServiceListL(aReqStatus, EAddEntries, multipleEntries);	
-	
-	// wait for completion of UpdateMbmsMonitorServiceListL(	
-	User::WaitForRequest(aReqStatus);
-	// wait for completion of NotifyMbmsServiceAvailabilityChange
-	User::WaitForRequest( requestStatus );
-	AssertMockLtsyStatusL();		
-	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() );
-		
-	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 );
-	// ensure that Services is added correctly into the monitored service list		
-	ASSERT_TRUE( TComparator<CPcktMbmsMonitoredServiceList>::IsEqual( *multipleEntries, *list ) );
-	        
-  	//-------------------------------------------------------------------------
-	// Test removing one entry 
- 	//-------------------------------------------------------------------------
-
-	// post RPacketService::NotifyMbmsNetworkServiceAvailabilityChange
-	packetService.NotifyMbmsServiceAvailabilityChange( requestStatus );
-	
-	iMockLTSY.ExpectL(EPacketUpdateMbmsMonitorServiceList, expectData1);
-	
-    TInt complete = 1;
- 	TMockLtsyData1< TInt > dataForComplete(complete);
-    dataForComplete.SerialiseL(CompleteData);
-   	iMockLTSY.CompleteL(EPacketUpdateMbmsMonitorServiceList, KErrNone, CompleteData);
-	
-	CPcktMbmsMonitoredServiceList* oneEntry = CPcktMbmsMonitoredServiceList ::NewL();
-	CleanupStack::PushL(oneEntry);
-	
-	oneEntry = CPcktMbmsMonitoredServiceList ::NewL();
-	CleanupStack::PushL(oneEntry);
-	RPacketService::TMbmsServiceAvailabilityV1 param2;
-	param2.iTmgi.SetServiceId(0); 
-	oneEntry->AddEntryL( param2 );
-	packetService.UpdateMbmsMonitorServiceListL(aReqStatus, ERemoveEntries, oneEntry);	
-	// wait for completion of UpdateMbmsMonitorServiceListL(	
-	User::WaitForRequest(aReqStatus);
-	// wait for completion of NotifyMbmsServiceAvailabilityChange
-	User::WaitForRequest( requestStatus );
-	AssertMockLtsyStatusL();		
-	ASSERT_EQUALS( KErrNone, aReqStatus.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 );
-	
-	multipleEntries->DeleteEntryL(0);
-	ASSERT_EQUALS((MBMS_MONITORSERVICECOUNTMULTIPLE-1), list->Enumerate() );
-	// ensure that Services is added correctly into the monitored service list		
-	ASSERT_TRUE( TComparator<CPcktMbmsMonitoredServiceList>::IsEqual(*multipleEntries, *list) );        	
-	CleanupStack::PopAndDestroy( list );	
-	//
-	// TEST END
-	//	
-	
-	AssertMockLtsyStatusL();
-	CleanupStack::PopAndDestroy( 12, this ); // packetMbmsContext, packetService, this 
-    }
-    
-    //
-// Actual test cases
-//
-
-/**
- * @SYMTestCaseID BA-CTSY-INT-MB-0018
- * @SYMFssID BA/CTSY/PKTS-0018
- * @SYMTestCaseDesc Support monitor list by removing entry.
- * @SYMTestPriority High
- * @SYMTestActions RPacketService::NotifyMbmsNetworkServiceStatusChange, RPacketService::UpdateMbmsMonitorServiceListL
- * @SYMTestExpectedResults Pass - Service is removed from the monitored service list.  
- * @SYMTestType CIT
- * @SYMTestCaseDependencies live/manual
- *
- * Reason for test: Verify that services is removed correctly to the monitored service list.
- *
- * @return - none
- */
-void CCTsyUCaseMbms009::CCtsyIntegrationTestMbms0002L()
-    {
-        
-	//
-	// SET UP
-	//
-	        
-   	OpenEtelServerL( EUseExtendedError );
-	CleanupStack::PushL( TCleanupItem( Cleanup, this ) );
-	OpenPhoneL();	
-
-	RBuf8 data;
-	CleanupClosePushL(data);
-				
-	RPacketService packetService;
-    OpenPacketServiceL( packetService );
-    CleanupClosePushL( packetService );
-
-   	TRequestStatus requestStatus;
-   	TRequestStatus requestStatus2;
-   	TRequestStatus mockLtsyStatus;
-    
-	//
-	// SET UP END
-	//    
-            
-	//
-	// TEST START
-	//
-	
-	TInt maxAllowed = 3; 
-	TInt maxvalue = 3;
- 	
- 	// check maximum monitored service value
- 	TMockLtsyData1<TInt> ltsyData2(maxvalue);
- 	data.Close();
-	ltsyData2.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);
-	
-	// post RPacketService::NotifyMbmsNetworkServiceAvailabilityChange
-	packetService.NotifyMbmsServiceAvailabilityChange( requestStatus );
-		
-	//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);	
-	
-	// wait for completion of UpdateMbmsMonitorServiceListL(	
-	User::WaitForRequest(aReqStatus);
-	// wait for completion of NotifyMbmsServiceAvailabilityChange
-	User::WaitForRequest( requestStatus );
-	AssertMockLtsyStatusL();		
-	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() );
-	
-	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 );
-	// ensure that Services is added correctly into the monitored service list		
-	ASSERT_TRUE( TComparator<CPcktMbmsMonitoredServiceList>::IsEqual( *multipleEntries, *list ) );
-
-  	//-------------------------------------------------------------------------
-	// Test removing one entry 
- 	//-------------------------------------------------------------------------
-
-	// post RPacketService::NotifyMbmsNetworkServiceAvailabilityChange
-	packetService.NotifyMbmsServiceAvailabilityChange( requestStatus );
-	
-	iMockLTSY.ExpectL(EPacketUpdateMbmsMonitorServiceList, expectData1);
-	
-    TInt complete = 1;
- 	TMockLtsyData1< TInt > dataForComplete(complete);
-    dataForComplete.SerialiseL(CompleteData);
-   	iMockLTSY.CompleteL(EPacketUpdateMbmsMonitorServiceList, KErrNone, CompleteData);
-	
-	CPcktMbmsMonitoredServiceList* oneEntry = CPcktMbmsMonitoredServiceList ::NewL();
-	CleanupStack::PushL(oneEntry);
-	
-	RPacketService::TMbmsServiceAvailabilityV1 param2;
-	param2.iTmgi.SetServiceId(0); 
-	oneEntry->AddEntryL( param2 );
-	packetService.UpdateMbmsMonitorServiceListL(aReqStatus, ERemoveEntries, oneEntry);	
-	// wait for completion of UpdateMbmsMonitorServiceListL(	
-	User::WaitForRequest(aReqStatus);
-	// wait for completion of NotifyMbmsServiceAvailabilityChange
-	User::WaitForRequest( requestStatus );
-	AssertMockLtsyStatusL();		
-	ASSERT_EQUALS( KErrNone, aReqStatus.Int() );
-
- 	//-------------------------------------------------------------------------
-	// Try to remove same entry again 
- 	//-------------------------------------------------------------------------
-
-	// post RPacketService::NotifyMbmsNetworkServiceAvailabilityChange
-	packetService.NotifyMbmsServiceAvailabilityChange( requestStatus );
-	
-	// PacketService::UpdateMbmsMonitorServiceListL		
-	packetService.UpdateMbmsMonitorServiceListL(aReqStatus, ERemoveEntries, oneEntry);	
-	
-	// wait for completion of UpdateMbmsMonitorServiceListL(	
-	User::WaitForRequest(aReqStatus);
-	AssertMockLtsyStatusL();		
-	ASSERT_EQUALS( KErrNotFound, aReqStatus.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 );
-	
-	multipleEntries->DeleteEntryL(0);
-	ASSERT_EQUALS((MBMS_MONITORSERVICECOUNTMULTIPLE-1), list->Enumerate() );
-	ASSERT_TRUE( TComparator<CPcktMbmsMonitoredServiceList>::IsEqual(*multipleEntries, *list) );        		           	
-	
-	//
-	// TEST END
-	//	
-	
-	AssertMockLtsyStatusL();
-	CleanupStack::PopAndDestroy( 12, this ); // packetMbmsContext, packetService, this 
-      }
-    
+// 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 "cctsyucasembms009.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_MONITORSERVICECOUNTONE	1
+#define MBMS_MONITORSERVICECOUNTMULTIPLE 3
+
+CTestSuite* CCTsyUCaseMbms009::CreateSuiteL(const TDesC& aName) 
+	{
+	SUB_SUITE;     
+    ADD_TEST_STEP_ISO_CPP(CCTsyUCaseMbms009, CCtsyIntegrationTestMbms0001L );
+    ADD_TEST_STEP_ISO_CPP(CCTsyUCaseMbms009, CCtsyIntegrationTestMbms0002L );
+	END_SUITE;
+}
+
+//
+// Actual test cases
+//
+
+/**
+ * @SYMTestCaseID BA-CTSY-INT-MB-0017
+ * @SYMFssID BA/CTSY/PKTS-0017
+ * @SYMTestCaseDesc Support monitor list by removing entry.
+ * @SYMTestPriority High
+ * @SYMTestActions RPacketService::NotifyMbmsNetworkServiceStatusChange, RPacketService::UpdateMbmsMonitorServiceListL
+ * @SYMTestExpectedResults Pass - Service is removed from the monitored service list.  
+ * @SYMTestType CIT
+ * @SYMTestCaseDependencies live/manual
+ *
+ * Reason for test:  Verify that services is removed correctly to the monitored service list.
+ *
+ * @return - none
+ */
+void CCTsyUCaseMbms009::CCtsyIntegrationTestMbms0001L()
+    {
+        
+	//
+	// SET UP
+	//
+	        
+   	OpenEtelServerL( EUseExtendedError );
+	CleanupStack::PushL( TCleanupItem( Cleanup, this ) );
+	OpenPhoneL();	
+
+	RBuf8 data;
+	CleanupClosePushL(data);
+				
+	RPacketService packetService;
+    OpenPacketServiceL( packetService );
+    CleanupClosePushL( packetService );
+
+   	TRequestStatus requestStatus;
+   	TRequestStatus requestStatus2;
+   	TRequestStatus mockLtsyStatus;
+   	 
+	//
+	// SET UP END
+	//    
+            
+	//
+	// TEST START
+	//
+	
+	TInt maxAllowed = 3; 
+	TInt maxvalue = 3;
+ 	
+ 	// check maximum monitored service value
+ 	TMockLtsyData1<TInt> ltsyData2(maxvalue);
+ 	data.Close();
+	ltsyData2.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);
+	
+	// post RPacketService::NotifyMbmsNetworkServiceAvailabilityChange
+	packetService.NotifyMbmsServiceAvailabilityChange( requestStatus );
+		
+	//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		
+	packetService.UpdateMbmsMonitorServiceListL(aReqStatus, EAddEntries, multipleEntries);	
+	
+	// wait for completion of UpdateMbmsMonitorServiceListL(	
+	User::WaitForRequest(aReqStatus);
+	// wait for completion of NotifyMbmsServiceAvailabilityChange
+	User::WaitForRequest( requestStatus );
+	AssertMockLtsyStatusL();		
+	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() );
+		
+	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 );
+	// ensure that Services is added correctly into the monitored service list		
+	ASSERT_TRUE( TComparator<CPcktMbmsMonitoredServiceList>::IsEqual( *multipleEntries, *list ) );
+	        
+  	//-------------------------------------------------------------------------
+	// Test removing one entry 
+ 	//-------------------------------------------------------------------------
+
+	// post RPacketService::NotifyMbmsNetworkServiceAvailabilityChange
+	packetService.NotifyMbmsServiceAvailabilityChange( requestStatus );
+	
+	iMockLTSY.ExpectL(EPacketUpdateMbmsMonitorServiceList, expectData1);
+	
+    TInt complete = 1;
+ 	TMockLtsyData1< TInt > dataForComplete(complete);
+    dataForComplete.SerialiseL(CompleteData);
+   	iMockLTSY.CompleteL(EPacketUpdateMbmsMonitorServiceList, KErrNone, CompleteData);
+	
+	CPcktMbmsMonitoredServiceList* oneEntry = CPcktMbmsMonitoredServiceList ::NewL();
+	CleanupStack::PushL(oneEntry);
+	
+	oneEntry = CPcktMbmsMonitoredServiceList ::NewL();
+	CleanupStack::PushL(oneEntry);
+	RPacketService::TMbmsServiceAvailabilityV1 param2;
+	param2.iTmgi.SetServiceId(0); 
+	oneEntry->AddEntryL( param2 );
+	packetService.UpdateMbmsMonitorServiceListL(aReqStatus, ERemoveEntries, oneEntry);	
+	// wait for completion of UpdateMbmsMonitorServiceListL(	
+	User::WaitForRequest(aReqStatus);
+	// wait for completion of NotifyMbmsServiceAvailabilityChange
+	User::WaitForRequest( requestStatus );
+	AssertMockLtsyStatusL();		
+	ASSERT_EQUALS( KErrNone, aReqStatus.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 );
+	
+	multipleEntries->DeleteEntryL(0);
+	ASSERT_EQUALS((MBMS_MONITORSERVICECOUNTMULTIPLE-1), list->Enumerate() );
+	// ensure that Services is added correctly into the monitored service list		
+	ASSERT_TRUE( TComparator<CPcktMbmsMonitoredServiceList>::IsEqual(*multipleEntries, *list) );        	
+	CleanupStack::PopAndDestroy( list );	
+	//
+	// TEST END
+	//	
+	
+	AssertMockLtsyStatusL();
+	CleanupStack::PopAndDestroy( 12, this ); // packetMbmsContext, packetService, this 
+    }
+    
+    //
+// Actual test cases
+//
+
+/**
+ * @SYMTestCaseID BA-CTSY-INT-MB-0018
+ * @SYMFssID BA/CTSY/PKTS-0018
+ * @SYMTestCaseDesc Support monitor list by removing entry.
+ * @SYMTestPriority High
+ * @SYMTestActions RPacketService::NotifyMbmsNetworkServiceStatusChange, RPacketService::UpdateMbmsMonitorServiceListL
+ * @SYMTestExpectedResults Pass - Service is removed from the monitored service list.  
+ * @SYMTestType CIT
+ * @SYMTestCaseDependencies live/manual
+ *
+ * Reason for test: Verify that services is removed correctly to the monitored service list.
+ *
+ * @return - none
+ */
+void CCTsyUCaseMbms009::CCtsyIntegrationTestMbms0002L()
+    {
+        
+	//
+	// SET UP
+	//
+	        
+   	OpenEtelServerL( EUseExtendedError );
+	CleanupStack::PushL( TCleanupItem( Cleanup, this ) );
+	OpenPhoneL();	
+
+	RBuf8 data;
+	CleanupClosePushL(data);
+				
+	RPacketService packetService;
+    OpenPacketServiceL( packetService );
+    CleanupClosePushL( packetService );
+
+   	TRequestStatus requestStatus;
+   	TRequestStatus requestStatus2;
+   	TRequestStatus mockLtsyStatus;
+    
+	//
+	// SET UP END
+	//    
+            
+	//
+	// TEST START
+	//
+	
+	TInt maxAllowed = 3; 
+	TInt maxvalue = 3;
+ 	
+ 	// check maximum monitored service value
+ 	TMockLtsyData1<TInt> ltsyData2(maxvalue);
+ 	data.Close();
+	ltsyData2.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);
+	
+	// post RPacketService::NotifyMbmsNetworkServiceAvailabilityChange
+	packetService.NotifyMbmsServiceAvailabilityChange( requestStatus );
+		
+	//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);	
+	
+	// wait for completion of UpdateMbmsMonitorServiceListL(	
+	User::WaitForRequest(aReqStatus);
+	// wait for completion of NotifyMbmsServiceAvailabilityChange
+	User::WaitForRequest( requestStatus );
+	AssertMockLtsyStatusL();		
+	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() );
+	
+	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 );
+	// ensure that Services is added correctly into the monitored service list		
+	ASSERT_TRUE( TComparator<CPcktMbmsMonitoredServiceList>::IsEqual( *multipleEntries, *list ) );
+
+  	//-------------------------------------------------------------------------
+	// Test removing one entry 
+ 	//-------------------------------------------------------------------------
+
+	// post RPacketService::NotifyMbmsNetworkServiceAvailabilityChange
+	packetService.NotifyMbmsServiceAvailabilityChange( requestStatus );
+	
+	iMockLTSY.ExpectL(EPacketUpdateMbmsMonitorServiceList, expectData1);
+	
+    TInt complete = 1;
+ 	TMockLtsyData1< TInt > dataForComplete(complete);
+    dataForComplete.SerialiseL(CompleteData);
+   	iMockLTSY.CompleteL(EPacketUpdateMbmsMonitorServiceList, KErrNone, CompleteData);
+	
+	CPcktMbmsMonitoredServiceList* oneEntry = CPcktMbmsMonitoredServiceList ::NewL();
+	CleanupStack::PushL(oneEntry);
+	
+	RPacketService::TMbmsServiceAvailabilityV1 param2;
+	param2.iTmgi.SetServiceId(0); 
+	oneEntry->AddEntryL( param2 );
+	packetService.UpdateMbmsMonitorServiceListL(aReqStatus, ERemoveEntries, oneEntry);	
+	// wait for completion of UpdateMbmsMonitorServiceListL(	
+	User::WaitForRequest(aReqStatus);
+	// wait for completion of NotifyMbmsServiceAvailabilityChange
+	User::WaitForRequest( requestStatus );
+	AssertMockLtsyStatusL();		
+	ASSERT_EQUALS( KErrNone, aReqStatus.Int() );
+
+ 	//-------------------------------------------------------------------------
+	// Try to remove same entry again 
+ 	//-------------------------------------------------------------------------
+
+	// post RPacketService::NotifyMbmsNetworkServiceAvailabilityChange
+	packetService.NotifyMbmsServiceAvailabilityChange( requestStatus );
+	
+	// PacketService::UpdateMbmsMonitorServiceListL		
+	packetService.UpdateMbmsMonitorServiceListL(aReqStatus, ERemoveEntries, oneEntry);	
+	
+	// wait for completion of UpdateMbmsMonitorServiceListL(	
+	User::WaitForRequest(aReqStatus);
+	AssertMockLtsyStatusL();		
+	ASSERT_EQUALS( KErrNotFound, aReqStatus.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 );
+	
+	multipleEntries->DeleteEntryL(0);
+	ASSERT_EQUALS((MBMS_MONITORSERVICECOUNTMULTIPLE-1), list->Enumerate() );
+	ASSERT_TRUE( TComparator<CPcktMbmsMonitoredServiceList>::IsEqual(*multipleEntries, *list) );        		           	
+	
+	//
+	// TEST END
+	//	
+	
+	AssertMockLtsyStatusL();
+	CleanupStack::PopAndDestroy( 12, this ); // packetMbmsContext, packetService, this 
+      }
+