telephonyserverplugins/common_tsy/test/component/src/cctsyucasembms022.cpp
changeset 0 3553901f7fa8
child 24 6638e7f4bd8f
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/telephonyserverplugins/common_tsy/test/component/src/cctsyucasembms022.cpp	Tue Feb 02 01:41:59 2010 +0200
@@ -0,0 +1,346 @@
+// 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 "cctsyucasembms022.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>
+
+CTestSuite* CCTsyUCaseMbms022::CreateSuiteL(const TDesC& aName) 
+	{
+	SUB_SUITE;        
+    ADD_TEST_STEP_ISO_CPP(CCTsyUCaseMbms022, CCtsyIntegrationTestMbms0001L );
+    ADD_TEST_STEP_ISO_CPP(CCTsyUCaseMbms022, CCtsyIntegrationTestMbms0002L );
+	END_SUITE;
+	}
+
+//
+// Actual test cases
+//
+  
+/**
+ * @SYMTestCaseID BA-CTSY-INT-MB-0038
+ * @SYMFssID BA/CTSY/MB-0038
+ * @SYMTestCaseDesc MBMS local context Deactivation
+ * @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 - MBMS context deactivation succeeded.  
+ * @SYMTestType CIT
+ * @SYMTestCaseDependencies live/manual
+ *
+ * Reason for test: Verify that MBMS context deactivation succeeded.
+ *
+ * @return - none
+ */
+void CCTsyUCaseMbms022::CCtsyIntegrationTestMbms0001L()
+    {
+        
+	//
+	// SET UP
+	//
+	        
+    OpenEtelServerL( EUseExtendedError );
+	CleanupStack::PushL( TCleanupItem( Cleanup, this ) );
+	OpenPhoneL();
+			
+	RPacketService packetService;
+	OpenPacketServiceL( packetService );
+	CleanupClosePushL( packetService );
+	
+	RBuf8 expectData;
+    CleanupClosePushL(expectData);
+    
+    RBuf8 data;
+    CleanupClosePushL(data);    	        
+	
+	// Open new context
+	TInfoName contextId;	
+	TInfoName hostCid;
+	RPacketMbmsContext packetMbmsContext;	
+	packetMbmsContext.OpenNewContext( packetService, contextId );	
+	CleanupClosePushL( packetMbmsContext );
+	
+	// post RPacketMbmsContext::NotifyStatusChange
+	TRequestStatus requestStatus;
+    RPacketContext::TContextStatus contextStatus; 
+	packetMbmsContext.NotifyStatusChange(requestStatus, contextStatus);
+	
+    TInt status = InitMbmsContextL(packetMbmsContext, contextId);	
+	ASSERT_EQUALS( KErrNone, status );
+	
+	// Ensure RPacketContext::NotifyStatusChange completes MBMS context status RPacketContext::EStatusInactive
+    User::WaitForRequest(requestStatus);	
+	ASSERT_EQUALS(KErrNone, requestStatus.Int());
+	ASSERT_EQUALS(RPacketContext::EStatusInactive, contextStatus);	
+  	
+  	AssertMockLtsyStatusL();    
+    
+    // Ensure RPacketContext::GetStatus returns status RPacketContext::EStatusInactive
+	packetMbmsContext.GetStatus(contextStatus);
+	ASSERT_EQUALS( RPacketContext::EStatusInactive, contextStatus );     
+	
+	// set configuration
+	RPacketMbmsContext::TContextConfigMbmsV1 setConfig;
+    setConfig.iMbmsAccessBearer = E2GBearer;
+    setConfig.iMbmsServiceMode = KBroadcast;
+    setConfig.iMbmsServicePriority = EMbmsLowServicePriority;
+    setConfig.iMbmsSessionFlag = EFalse;
+    
+    status = SetMbmsConfigL(packetMbmsContext,contextId, setConfig);
+  	ASSERT_EQUALS( KErrNone, status );
+
+ 	TMockLtsyData1 <TInfoName > expData( contextId );
+	expData.SerialiseL( expectData );
+	
+	// re-post notify
+	packetMbmsContext.NotifyStatusChange(requestStatus, contextStatus);
+        	
+  	// activate context
+  	status = SetMbmsActiveL(packetMbmsContext, setConfig, contextId );
+	ASSERT_EQUALS( KErrNone, status );
+ 	
+ 	// Ensure RPacketContext::NotifyStatusChange completes MBMS context status RPacketContext::EStatusActivating
+    User::WaitForRequest(requestStatus);	
+	ASSERT_EQUALS(KErrNone, requestStatus.Int());
+	ASSERT_EQUALS(RPacketContext::EStatusActivating, contextStatus);	
+ 	
+ 	// Ensure RPacketContext::NotifyStatusChange completes MBMS context status RPacketContext::EStatusActive
+ 	packetMbmsContext.NotifyStatusChange(requestStatus, contextStatus);
+ 	User::WaitForRequest(requestStatus);	
+	ASSERT_EQUALS(KErrNone, requestStatus.Int());
+	ASSERT_EQUALS(RPacketContext::EStatusActive, contextStatus);
+	
+	// Ensure RPacketContext::GetStatus returns status RPacketContext::EStatusActive
+	packetMbmsContext.GetStatus(contextStatus);
+	ASSERT_EQUALS( RPacketContext::EStatusActive, contextStatus );
+	
+	// Ensure MBMS context count is greater than 0
+	TInt count;
+	TInt maxAllowed;
+	
+	packetService.EnumerateMbmsActiveServiceList(requestStatus, count, maxAllowed); 
+    User::WaitForRequest( requestStatus );	
+	ASSERT_EQUALS(KErrNone, status);
+	ASSERT_TRUE(0 < count);
+	
+	
+	//
+	// SET UP END
+	//    
+            
+	//
+	// TEST START
+	//
+
+	packetMbmsContext.NotifyStatusChange(requestStatus, contextStatus);
+	
+	// The Client requests Deactivate MBMS context (via RPacketContext) from ETEL API.
+	// Deactivate context
+	TMockLtsyData1< TInfoName > ltsyData1(contextId);
+	ltsyData1.SerialiseL(data);	
+	TRequestStatus deactivateStatus;
+	
+ 	iMockLTSY.ExpectL( EPacketContextDeactivate, data );
+ 	iMockLTSY.CompleteL(EPacketContextDeactivate, KErrNone, data);
+ 	
+ 	packetMbmsContext.Deactivate( deactivateStatus );
+	User::WaitForRequest( deactivateStatus );
+	ASSERT_EQUALS(KErrNone, deactivateStatus.Int());
+
+	// CTSY completes pending NotifyStatusChange with status = EStatusDeactivating.
+	User::WaitForRequest(requestStatus);	
+	ASSERT_EQUALS(KErrNone, requestStatus.Int());
+	ASSERT_EQUALS(RPacketContext::EStatusDeactivating, contextStatus);	
+	
+	// re-post notify
+	packetMbmsContext.NotifyStatusChange(requestStatus, contextStatus);
+	
+	// Ensure RPacketContext::NotifyStatusChange completes MBMS context status RPacketContext::EStatusInactive
+    User::WaitForRequest(requestStatus);	
+	ASSERT_EQUALS(KErrNone, requestStatus.Int());
+	ASSERT_EQUALS(RPacketContext::EStatusInactive, contextStatus);	
+ 	
+	// Ensure RPacketContext::GetStatus returns status RPacketContext::EStatusInactive
+	packetMbmsContext.GetStatus(contextStatus);
+	ASSERT_EQUALS( RPacketContext::EStatusInactive, contextStatus );
+            
+	AssertMockLtsyStatusL();
+	ASSERT_EQUALS(KErrNone, status);	
+	
+	//
+	// TEST END
+	//	
+	
+	AssertMockLtsyStatusL();
+	CleanupStack::PopAndDestroy( 5, this ); // packetMbmsContext, packetService, expectData, data, this
+    }
+    
+    
+/**
+ * @SYMTestCaseID BA-CTSY-INT-MB-0039
+ * @SYMFssID BA/CTSY/MB-0039
+ * @SYMTestCaseDesc MBMS local context Deactivation
+ * @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 - MBMS context deactivation fails.  
+ * @SYMTestType CIT
+ * @SYMTestCaseDependencies live/manual
+ *
+ * Reason for test:  Verify that MBMS context deactivation failed.
+ *
+ * @return - none
+ */
+void CCTsyUCaseMbms022::CCtsyIntegrationTestMbms0002L()
+    {
+        
+	//
+	// SET UP
+	//
+	        
+    OpenEtelServerL( EUseExtendedError );
+	CleanupStack::PushL( TCleanupItem( Cleanup, this ) );
+	OpenPhoneL();
+			
+	RPacketService packetService;
+	OpenPacketServiceL( packetService );
+	CleanupClosePushL( packetService );
+	
+	RBuf8 expectData;
+    CleanupClosePushL(expectData);
+    
+    RBuf8 data;
+    CleanupClosePushL(data);    	        
+	
+	// Open new context
+	TInfoName contextId;	
+	TInfoName hostCid;
+	RPacketMbmsContext packetMbmsContext;	
+	packetMbmsContext.OpenNewContext( packetService, contextId );	
+	CleanupClosePushL( packetMbmsContext );
+	
+	// post RPacketMbmsContext::NotifyStatusChange
+	TRequestStatus requestStatus;
+    RPacketContext::TContextStatus contextStatus; 
+	packetMbmsContext.NotifyStatusChange(requestStatus, contextStatus);
+	
+    TInt status = InitMbmsContextL(packetMbmsContext, contextId);	
+	ASSERT_EQUALS( KErrNone, status );
+	
+	// Ensure RPacketContext::NotifyStatusChange completes MBMS context status RPacketContext::EStatusInactive
+    User::WaitForRequest(requestStatus);	
+	ASSERT_EQUALS(KErrNone, requestStatus.Int());
+	ASSERT_EQUALS(RPacketContext::EStatusInactive, contextStatus);	
+  	
+  	AssertMockLtsyStatusL();    
+    
+    // Ensure RPacketContext::GetStatus returns status RPacketContext::EStatusInactive
+	packetMbmsContext.GetStatus(contextStatus);
+	ASSERT_EQUALS( RPacketContext::EStatusInactive, contextStatus );     
+	
+	// set configuration
+	RPacketMbmsContext::TContextConfigMbmsV1 setConfig;
+    setConfig.iMbmsAccessBearer = E2GBearer;
+    setConfig.iMbmsServiceMode = KBroadcast;
+    setConfig.iMbmsServicePriority = EMbmsLowServicePriority;
+    setConfig.iMbmsSessionFlag = EFalse;
+    
+    status = SetMbmsConfigL(packetMbmsContext,contextId, setConfig);
+  	ASSERT_EQUALS( KErrNone, status );
+
+ 	TMockLtsyData1 <TInfoName > expData( contextId );
+	expData.SerialiseL( expectData );
+	
+	// re-post notify
+	packetMbmsContext.NotifyStatusChange(requestStatus, contextStatus);
+        	
+  	// activate context
+  	status = SetMbmsActiveL(packetMbmsContext, setConfig, contextId );
+	ASSERT_EQUALS( KErrNone, status );
+ 	
+ 	// Ensure RPacketContext::NotifyStatusChange completes MBMS context status RPacketContext::EStatusActivating
+    User::WaitForRequest(requestStatus);	
+	ASSERT_EQUALS(KErrNone, requestStatus.Int());
+	ASSERT_EQUALS(RPacketContext::EStatusActivating, contextStatus);	
+ 	
+ 	// Ensure RPacketContext::NotifyStatusChange completes MBMS context status RPacketContext::EStatusActive
+ 	packetMbmsContext.NotifyStatusChange(requestStatus, contextStatus);
+ 	User::WaitForRequest(requestStatus);	
+	ASSERT_EQUALS(KErrNone, requestStatus.Int());
+	ASSERT_EQUALS(RPacketContext::EStatusActive, contextStatus);
+	
+	// Ensure RPacketContext::GetStatus returns status RPacketContext::EStatusActive
+	packetMbmsContext.GetStatus(contextStatus);
+	ASSERT_EQUALS( RPacketContext::EStatusActive, contextStatus );
+	
+	// Ensure MBMS context count is greater than 0
+	TInt count;
+	TInt maxAllowed;
+	
+	packetService.EnumerateMbmsActiveServiceList(requestStatus, count, maxAllowed); 
+    User::WaitForRequest( requestStatus );	
+	ASSERT_EQUALS(KErrNone, status);
+	ASSERT_TRUE(0 < count);
+    
+	//
+	// SET UP END
+	//    
+            
+	//
+	// TEST START
+	//
+	
+	
+	// The Client requests Deactivate MBMS context (via RPacketContext) from ETEL API.
+	// Deactivate context
+	TMockLtsyData1< TInfoName > ltsyData1(contextId);
+	ltsyData1.SerialiseL(data);	
+	TRequestStatus deactivateStatus;
+	
+ 	iMockLTSY.ExpectL( EPacketContextDeactivate, data );
+ 	iMockLTSY.CompleteL(EPacketContextDeactivate, KErrGeneral, data);
+ 	
+ 	packetMbmsContext.Deactivate( deactivateStatus );
+	User::WaitForRequest( deactivateStatus );
+	ASSERT_EQUALS(KErrGeneral, deactivateStatus.Int());
+
+	// Ensure RPacketContext::GetStatus returns status RPacketContext::EStatusActive
+	packetMbmsContext.GetStatus(contextStatus);
+	ASSERT_EQUALS( RPacketContext::EStatusActive, contextStatus );
+            
+	AssertMockLtsyStatusL();
+	
+	//
+	// TEST END
+	//	
+	
+	AssertMockLtsyStatusL();
+	CleanupStack::PopAndDestroy( 5, this ); // packetMbmsContext, packetService, expectData, data, this
+   }
+