telephonyserverplugins/common_tsy/test/component/src/cctsyucasembms021.cpp
changeset 0 3553901f7fa8
child 24 6638e7f4bd8f
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/telephonyserverplugins/common_tsy/test/component/src/cctsyucasembms021.cpp	Tue Feb 02 01:41:59 2010 +0200
@@ -0,0 +1,283 @@
+// 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 "cctsyucasembms021.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* CCTsyUCaseMbms021::CreateSuiteL(const TDesC& aName) 
+	{
+	SUB_SUITE;        
+    ADD_TEST_STEP_ISO_CPP(CCTsyUCaseMbms021, CCtsyIntegrationTestMbms0001L );
+	END_SUITE;
+	}
+
+//
+// Actual test cases
+//
+  
+/**
+ * @SYMTestCaseID BA-CTSY-INT-MB-0037
+ * @SYMFssID BA/CTSY/MB-0037
+ * @SYMTestCaseDesc MBMS is not currently being used
+ * @SYMTestPriority High
+ * @SYMTestActions RPacketContext::InitialiseContext, RPacketContext::SetConfig, RPacketService::NotifyDynamicCapsChange, RPacketService::GetDynamicCaps, RPacketContext::Activate, RPacketService::NotifyStatusChange, RPacketService::GetStatus, RPacketContext::NotifyStatusChange, RPacketContext::GetStatus, RPacketContext::Deactivate
+ * @SYMTestExpectedResults Pass - Client gets correct capability. No MBMS contexts are in receiving state.
+ * @SYMTestType CIT
+ * @SYMTestCaseDependencies live/manual
+ *
+ * Reason for test: Verify that Context status is moved from receiving state to active state as a result of reception finishing
+ *
+ * @return - none
+ */
+void CCTsyUCaseMbms021::CCtsyIntegrationTestMbms0001L()
+    {
+        
+	//
+	// SET UP
+	//
+	        
+    OpenEtelServerL( EUseExtendedError );
+	CleanupStack::PushL( TCleanupItem( Cleanup, this ) );
+	OpenPhoneL();	
+	
+	RPacketService packetService;
+    OpenPacketServiceL( packetService );
+    CleanupClosePushL( packetService );
+              
+	TInfoName contextId;
+    RPacketMbmsContext mbmsContext;
+    mbmsContext.OpenNewContext( packetService, contextId );
+    CleanupClosePushL( mbmsContext );
+    
+    RBuf8 data;
+    CleanupClosePushL(data);
+    
+    RBuf8 expectData;
+    CleanupClosePushL(expectData);	        
+	
+	// initialisation of the context 
+	TInt status = InitMbmsContextL(mbmsContext, contextId); 
+    ASSERT_EQUALS(KErrNone, status);	
+    
+    // data for SetConfig
+    TRequestStatus requestStatus;
+    RPacketMbmsContext::TContextConfigMbmsV1 setConfig;
+    setConfig.iTmgi.SetServiceId(1); 
+    setConfig.iTmgi.SetMCC(111);
+    setConfig.iTmgi.SetMNC(111);
+    setConfig.iMbmsAccessBearer = E3GBearer;
+    setConfig.iMbmsServicePriority = EMbmsHighServicePriority;
+    setConfig.iMbmsServiceMode = KBroadcast;
+    setConfig.iMbmsSessionFlag = ETrue;
+	
+	// configure context
+    status = SetMbmsConfigL(mbmsContext, contextId, setConfig);
+	ASSERT_EQUALS(KErrNone, status);	
+
+	
+	// add sessions
+	TInt maxSessions( 1 );	
+	
+	TMockLtsyData1 <TInfoName > expData( contextId );
+	expData.SerialiseL( expectData );
+	
+ 	TMockLtsyData1 <TInfoName> outData( contextId );
+	outData.SerialiseL( data );	
+    
+    for( TInt i = 0; i < maxSessions; i++ )
+	    {
+	    TMbmsSessionId session(i);  
+	    
+	    iMockLTSY.ExpectL(EPacketContextUpdateMbmsSessionList, expectData);
+	    iMockLTSY.CompleteL(EPacketContextUpdateMbmsSessionList, KErrNone, data);            
+	    mbmsContext.UpdateMbmsSessionList(requestStatus, EAddEntries, session);    
+	    
+	    User::WaitForRequest( requestStatus );
+	    ASSERT_EQUALS( KErrNone, requestStatus.Int() ) ;	
+	    }
+    
+	// Activate MBMS context
+	status = SetMbmsActiveL(mbmsContext, setConfig, contextId);
+	ASSERT_EQUALS(KErrNone, status);
+	
+	RPacketService::TStatus sendStatus = RPacketService::EStatusActive;
+	TBool isResumed = EFalse;	
+	TInt err = SetPacketServiceStatusL(sendStatus, isResumed);	
+	ASSERT_EQUALS(KErrNone, err);
+	
+	
+	RPacketService::TStatus attachStatus;
+    TInt ret = packetService.GetStatus(attachStatus);
+    ASSERT_EQUALS(KErrNone, ret);
+    ASSERT_EQUALS(RPacketService::EStatusActive, attachStatus);
+	
+	// Ensure MBMS Context status is Active
+	RPacketContext::TContextStatus expectedStatus = RPacketContext::EStatusActive;
+	RPacketContext::TContextStatus contextStatus;
+	ret = mbmsContext.GetStatus(contextStatus);
+	ASSERT_EQUALS(KErrNone, ret);
+    ASSERT_EQUALS((TInt)expectedStatus, (TInt)contextStatus);
+	
+	// Add a session
+	CFilteringActiveScheduler scheduler;
+	CActiveScheduler::Install(&scheduler);    
+	
+    RPacketMbmsContext::CMbmsSession* session = RPacketMbmsContext::CMbmsSession::NewL();  
+    CleanupStack::PushL(session);	
+    	
+	CRetrievePcktMbmsSessionList* sessionList = CRetrievePcktMbmsSessionList::NewL(mbmsContext, *session);        
+    CleanupStack::PushL(sessionList);
+
+    CActiveRetriever::ResetRequestsNumber();
+    CActiveRetriever retriever(*sessionList);
+    
+    scheduler.AddRetrieverL(retriever);
+        
+    sessionList->Start( retriever.Status() );	 	
+	retriever.Activate();
+	scheduler.StartScheduler();
+	ASSERT_EQUALS(KErrNone, retriever.iStatus.Int());
+    
+    // ensure there is session added to a MBMS context 
+	for( TUint i = 0; i < session->iSessionIdList.Count(); i++)
+	    {
+	    TMbmsSessionId sessionId = session->iSessionIdList[i];
+	    ASSERT_EQUALS( sessionId, i);	    
+	    }
+	
+	ASSERT_EQUALS(0, CActiveRetriever::ResetRequestsNumber());	 	
+ 	AssertMockLtsyStatusL();
+    
+    mbmsContext.NotifyStatusChange(requestStatus, contextStatus);	
+    
+    TContextMisc  completeMisc;
+    completeMisc.iStatus = RPacketContext::EStatusReceiving;
+ 	TMockLtsyData2 <TInfoName, TContextMisc>ltsyData1(contextId, completeMisc);
+	ltsyData1.SerialiseL(data);
+    TRequestStatus mockLtsyStatus;
+	iMockLTSY.NotifyTerminated(mockLtsyStatus);	
+		
+	iMockLTSY.CompleteL(EPacketContextNotifyStatusChange , KErrNone, data);
+	User::WaitForRequest(mockLtsyStatus);
+    User::WaitForRequest(requestStatus);
+	
+	// Ensure RPacketContext::NotifyStatusChange completes MBMS context status RPacketContext::EStatusReceiving	
+	ASSERT_EQUALS(KErrNone, requestStatus.Int());
+	ASSERT_EQUALS(completeMisc.iStatus, contextStatus);	
+	AssertMockLtsyStatusL();
+    
+    // Check RPacketContext::GetStatus returns RPacketContext::EStatusReceiving
+	expectedStatus = RPacketContext::EStatusReceiving;
+	ret = mbmsContext.GetStatus(contextStatus);
+	ASSERT_EQUALS(KErrNone, ret);
+    ASSERT_EQUALS((TInt)expectedStatus, (TInt)contextStatus);
+    
+	//
+	// SET UP END
+	//    
+            
+	//
+	// TEST START
+	//
+	
+ 
+	// Ensure GetDynamicCaps capabilities return RPacketService::KCapsMBMS caps
+	RPacketService::TDynamicCapsFlags caps;
+	
+	packetService.GetDynamicCaps(caps);
+	ASSERT_TRUE(RPacketService::KCapsMBMS & caps);	
+
+    // post RPacketService::NotifyDynamicCapsChange
+	TRequestStatus dynamicCapsStatus;
+	packetService.NotifyDynamicCapsChange(dynamicCapsStatus, caps);
+
+    // post RPacketService::NotifyStatusChange
+	mbmsContext.NotifyStatusChange(requestStatus, contextStatus);	
+
+	// Context status is moved from receiving state to active state as a result of reception finishing.
+    completeMisc.iStatus = RPacketContext::EStatusActive;
+	ltsyData1.SerialiseL(data);
+ 	iMockLTSY.NotifyTerminated(mockLtsyStatus);	
+		
+	iMockLTSY.CompleteL(EPacketContextNotifyStatusChange , KErrNone, data);
+	User::WaitForRequest(mockLtsyStatus);
+    User::WaitForRequest(requestStatus);
+	
+	// Ensure RPacketContext::NotifyStatusChange completes MBMS context status RPacketContext::EStatusActive	
+	ASSERT_EQUALS(KErrNone, requestStatus.Int());
+	ASSERT_EQUALS(completeMisc.iStatus, contextStatus);	
+	AssertMockLtsyStatusL();
+    
+    // Check RPacketContext::GetStatus returns RPacketContext::EStatusActive
+	expectedStatus = RPacketContext::EStatusActive;
+	ret = mbmsContext.GetStatus(contextStatus);
+	ASSERT_EQUALS(KErrNone, ret);
+    ASSERT_EQUALS((TInt)expectedStatus, (TInt)contextStatus);
+
+   	// Ensure RPacketService::NotifyDynamicCapsChange doens't return RPacketService::KCapsMBMS
+   	User::WaitForRequest(dynamicCapsStatus);
+   	ASSERT_EQUALS(KErrNone, dynamicCapsStatus.Int());
+   	
+   	RPacketService::TDynamicCapsFlags expectedCaps;	
+   	expectedCaps = caps;
+   	expectedCaps &= ~RPacketService::KCapsMBMS;
+   	ASSERT_EQUALS(expectedCaps, caps );	
+	
+    // Ensure Dynamic capabilities doens't return RPacketService::KCapsMBMS
+    packetService.GetDynamicCaps(caps);
+    ASSERT_EQUALS(KErrNone, dynamicCapsStatus.Int());
+    expectedCaps = caps;
+    expectedCaps &= ~RPacketService::KCapsMBMS;
+	ASSERT_EQUALS(expectedCaps, caps );	
+	AssertMockLtsyStatusL();
+
+	// deactivate context 
+	status = SetMbmsDeactiveL(mbmsContext, contextId);
+	ASSERT_EQUALS(KErrNone, status);
+	
+	// delete context
+	status = SetMbmsDeleteL(mbmsContext, contextId);
+	ASSERT_EQUALS(KErrNone, status);
+	
+	// close context
+	mbmsContext.Close( );     
+	        
+    	
+	//
+	// TEST END
+	//	
+	
+	AssertMockLtsyStatusL();
+	CActiveScheduler::Install(NULL);    
+	CleanupStack::PopAndDestroy( 7, this ); // sessionlist, session, expectData, mbmsContext, packetService, data, this
+      }
+