diff -r 000000000000 -r 3553901f7fa8 telephonyserverplugins/common_tsy/test/component/src/cctsyucasembms024.cpp --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/telephonyserverplugins/common_tsy/test/component/src/cctsyucasembms024.cpp Tue Feb 02 01:41:59 2010 +0200 @@ -0,0 +1,203 @@ +// 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 "cctsyucasembms024.h" +#include "cctsyactiveretriever.h" +#include +#include +#include +#include +#include +#include "tmockltsydata.h" +#include + +#include +#include +#include "pcktretrieve.h" +#include "CMmCommonStaticUtility.h" +#include + +CTestSuite* CCTsyUCaseMbms024::CreateSuiteL(const TDesC& aName) + { + SUB_SUITE; + ADD_TEST_STEP_ISO_CPP(CCTsyUCaseMbms024, CCtsyIntegrationTestMbms0001L ); + END_SUITE; + } + +// +// Actual test cases +// + +/** + * @SYMTestCaseID BA-CTSY-INT-MB-0042 + * @SYMFssID BA/CTSY/MB-0042 + * @SYMTestCaseDesc MBMS local context Closure. + * @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 is Closed. + * @SYMTestType CIT + * @SYMTestCaseDependencies live/manual + * + * Reason for test: Verify that MBMS context is closed successfully. + * + * @return - none + */ +void CCTsyUCaseMbms024::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 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); + + // re-post notify + packetMbmsContext.NotifyStatusChange(requestStatus, contextStatus); + // Deactivate context + status = SetMbmsDeactiveL(packetMbmsContext, contextId); + ASSERT_EQUALS(KErrNone, status); + + // Ensure RPacketContext::GetStatus returns status RPacketContext::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 ); + + + // + // SET UP END + // + + // + // TEST START + // + + // The Client requests Close MBMS context from ETEL API. + packetMbmsContext.Close( ); + + // Ensure MBMS context count is 0 + packetService.EnumerateMbmsActiveServiceList(requestStatus, count, maxAllowed); + + User::WaitForRequest( requestStatus ); + ASSERT_EQUALS(KErrNone, status); + ASSERT_EQUALS(0 , count); + + + // + // TEST END + // + + AssertMockLtsyStatusL(); + + CleanupStack::PopAndDestroy( 5 ); // packetMbmsContext, packetService, expectData, data, this + } +