diff -r 1972d8c2e329 -r 510c70acdbf6 adaptationlayer/tsy/nokiatsy_dll/internal/test/nokiatsy_test_tool/cbs/src/cbsblocks.cpp --- a/adaptationlayer/tsy/nokiatsy_dll/internal/test/nokiatsy_test_tool/cbs/src/cbsblocks.cpp Mon Nov 09 10:31:01 2009 +0000 +++ /dev/null Thu Jan 01 00:00:00 1970 +0000 @@ -1,402 +0,0 @@ -/* -* Copyright (c) 2002-2008 Nokia Corporation and/or its subsidiary(-ies). -* All rights reserved. -* This component and the accompanying materials are made available -* under the terms of the License "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: Specific class for Cell Broadcast tests -* -*/ - - - - -// INCLUDE FILES -#include -#include -#include -#include "cbs.h" -#include -#include - -// CONSTANTS - -// ============================ MEMBER FUNCTIONS =============================== - -// ----------------------------------------------------------------------------- -// CCbs::Delete -// Delete here all resources allocated and opened from test methods. -// Called from destructor. -// ----------------------------------------------------------------------------- -// -void CCbs::Delete() - { - } - -// ----------------------------------------------------------------------------- -// CCbs::RunMethodL -// Run specified method. Contains also table of test mothods and their names. -// ----------------------------------------------------------------------------- -// -TInt CCbs::RunMethodL( - CStifItemParser& aItem ) - { - iCbsLog->Log(_L8("CCbs::RunMethodL")); - - static TStifFunctionInfo const KFunctions[] = - { - ENTRY( "RunIscTestCase", CCore::RunIscTestCase), - ENTRY( "SyncIscTestCase", CCore::SyncIscTestCase), - ENTRY( "ActivateCbsReception", CCbs::ActivateCbsReceptionL ), - ENTRY( "DeactivateCbsReception", CCbs::DeactivateCbsReceptionL ), - ENTRY( "ReceiveCbs", CCbs::ReceiveCbsL ), - ENTRY( "ReadCBSSimTopics", CCbs::ReadCBSSimTopicsL ), - ENTRY( "DeleteCBSSimTopic", CCbs::DeleteCBSSimTopicL ), - ENTRY( "HandleSpecifiedRequests", CCore::HandleSpecifiedRequests), - ENTRY( "InitializeIPCRequestTable", CCore::InitializeIPCRequestTable), - ENTRY( "SetExpectedCompleteIPC", CCore::SetExpectedCompleteIPC), - }; - - const TInt count = sizeof( KFunctions ) / - sizeof( TStifFunctionInfo ); - - return RunInternalL( KFunctions, count, aItem ); - - } - -// ----------------------------------------------------------------------------- -// CCbs::ActivateCbsReceptionL -// ----------------------------------------------------------------------------- -// -TInt CCbs::ActivateCbsReceptionL(CStifItemParser& /*aItem*/) - { - iCbsLog->Log(_L8("CBS::ActivateCbsReception")); - - TInt ret = KErrGeneral; - - TCbsCbmiAndLangAndFilter filter; - filter.iSetting = RMobileBroadcastMessaging::EBroadcastAcceptAll; - CMmDataPackage package; - package.PackData(&filter); - ret = HandleRequestL( EMobileBroadcastMessagingReceiveMessage, &package ); - if ( KErrNone != ret ) - { - iCbsLog->Log(_L8("Error in activating CBS reception: %d"), ret ); - } - else - { - iActivateCbsReceptionPending = ETrue; - } - return ret; - } - -// ----------------------------------------------------------------------------- -// CCbs::CompleteActivateCbsReception -// ----------------------------------------------------------------------------- -// -void CCbs::CompleteActivateCbsReception(TInt aErr) - { - iCbsLog->Log(_L8("CBS::CompleteActivateCbsReception, err=%d"),aErr); - if (iActivateCbsReceptionPending) - { - iActivateCbsReceptionPending = EFalse; - Signal( aErr ); - } - } - -// ----------------------------------------------------------------------------- -// CCbs::DeactivateCbsReceptionL -// ----------------------------------------------------------------------------- -// -TInt CCbs::DeactivateCbsReceptionL(CStifItemParser& /*aItem*/) - { - iCbsLog->Log(_L8("CBS::DeactivateCbsReception")); - - TInt ret = KErrGeneral; - - TCbsCbmiAndLangAndFilter filter; - filter.iSetting = RMobileBroadcastMessaging::EBroadcastAcceptNone; - CMmDataPackage package; - package.PackData(&filter); - ret = HandleRequestL( EMobileBroadcastMessagingReceiveMessageCancel, &package ); - if ( KErrNone != ret ) - { - iCbsLog->Log(_L8("Error in deactivating CBS reception: %d"), ret ); - } - else - { - iDeactivateCbsReceptionPending = ETrue; - } - - return ret; - } - -// ----------------------------------------------------------------------------- -// CCbs::CompleteDeactivateCbsReception -// ----------------------------------------------------------------------------- -// -void CCbs::CompleteDeactivateCbsReception(TInt aErr) - { - iCbsLog->Log(_L8("CBS::CompleteDeactivateCbsReception, err=%d"),aErr); - if (iDeactivateCbsReceptionPending) - { - iDeactivateCbsReceptionPending = EFalse; - Signal( aErr ); - } - } - -// ----------------------------------------------------------------------------- -// CCbs::ReceiveCbsL -// ----------------------------------------------------------------------------- -// -TInt CCbs::ReceiveCbsL(CStifItemParser& aItem) - { - iCbsLog->Log(_L8("CBS::ReceiveCbsL. Waiting for CBS message (be patient, please).")); - - // Set reference parameters for parameter checking - TInt temp( 0 ); - aItem.GetNextInt( temp ); - iSbNumber = temp; - - aItem.GetNextInt( temp ); - iNumberOfPages = temp; - - aItem.GetNextInt( temp ); - iMessageType = temp; - - aItem.GetNextInt( temp ); - iMessageId = temp; - - aItem.GetNextInt( temp ); - iSerialNum = temp; - - aItem.GetNextInt( temp ); - iDCS = temp; - - aItem.GetNextInt( temp ); - iInfoLength = temp; - - // do nothing but waiting ... - iReceiveCbsPending = ETrue; - return KErrNone; - } - -// ----------------------------------------------------------------------------- -// CCbs::CompleteReceiveCbs, GSM only -// ----------------------------------------------------------------------------- -// -void CCbs::CompleteReceiveGsmCbs(TInt aErr, CMmDataPackage& aData) - { - iCbsLog->Log(_L8("CBS::CompleteReceiveGsmCbs, err=%d"),aErr); - if (iReceiveCbsPending) - { - if ( KErrNone == aErr ) - { - _LIT8( KReceiveCbsOk, "CBS receiving ok" ); - iCbsLog->Log((TDesC8)KReceiveCbsOk ); - - TGsmCbsMsg cbsMsg; - aData.UnPackData( cbsMsg ); - // CBS message starts with: - // - serial nr MSB - // - serial nr LSB - // - message id MSB - // - message id LSB - // - data coding scheme (DCS) - iCbsLog->Log(_L8("Received msg has serial nr=%d, cbmi=%d, dcs=%d"), - ((cbsMsg.iCbsMsg[0]<<8)+cbsMsg.iCbsMsg[1]), - ((cbsMsg.iCbsMsg[2]<<8)+cbsMsg.iCbsMsg[3]), - cbsMsg.iCbsMsg[4]); - - // Check received data - if ( iHandleSpecifiedRequests ) - { - if ( cbsMsg.iCbsMsg != iCbsMsgGSM ) - { - aErr = KErrGeneral; - } - } - } - else - { - _LIT8( KReceiveCbsFailed, "CBS receiving failed: %d" ); - iCbsLog->Log((TDesC8)KReceiveCbsFailed, aErr ); - } - iReceiveCbsPending = EFalse; - Signal( aErr ); - } - } - -// ----------------------------------------------------------------------------- -// CCbs::CompleteReceiveWcdmaCbs, WCDMA only -// ----------------------------------------------------------------------------- -// -void CCbs::CompleteReceiveWcdmaCbs( TInt aErr, CMmDataPackage& aData ) - { - iCbsLog->Log(_L8("CBS::CompleteReceiveWcdmaCbs.")); - if ( iReceiveCbsPending ) - { - if ( KErrNone == aErr ) - { - _LIT8( KReceiveCbsOk, "CBS WCDMA receiving ok" ); - iCbsLog->Log((TDesC8)KReceiveCbsOk ); - CArrayPtrFlat* cbsMsg; - TInt sbNumber; - aData.UnPackData( cbsMsg, sbNumber ); - TWcdmaCbsMsg* wcdmaCbsMsg( cbsMsg->At( 0 ) ); - iCbsLog->Log(_L8("Received msg has serial nr=%d, cbmessage id=%d, dcs=%d"), - wcdmaCbsMsg->iSerialNum, wcdmaCbsMsg->iMessageId,wcdmaCbsMsg->iDCS ); - - // Check received data - if ( iHandleSpecifiedRequests ) - { - TBuf8 - iWcdmaCbsDataTemp; - iWcdmaCbsDataTemp.Append( - wcdmaCbsMsg->iWcdmaCbsData.Mid ( 0 , wcdmaCbsMsg->iInfoLength ) ); - - if ( iWcdmaCbsDataTemp != iCbsMsgWCDMA ) - { - aErr = KErrGeneral; - } - if ( wcdmaCbsMsg->iSbNumber != iSbNumber ) - { - aErr = KErrGeneral; - } - if ( wcdmaCbsMsg->iNumberOfPages != iNumberOfPages ) - { - aErr = KErrGeneral; - } - if ( wcdmaCbsMsg->iMessageType != iMessageType ) - { - aErr = KErrGeneral; - } - if ( wcdmaCbsMsg->iMessageId != iMessageId ) - { - aErr = KErrGeneral; - } - if ( wcdmaCbsMsg->iSerialNum != iSerialNum ) - { - aErr = KErrGeneral; - } - if ( wcdmaCbsMsg->iDCS != iDCS ) - { - aErr = KErrGeneral; - } - if ( wcdmaCbsMsg->iInfoLength != iInfoLength ) - { - aErr = KErrGeneral; - } - } - } - else - { - _LIT8( KReceiveCbsFailed, "CBS WCDMA receiving failed: %d" ); - iCbsLog->Log((TDesC8)KReceiveCbsFailed, aErr ); - } - iReceiveCbsPending = EFalse; - Signal( aErr ); - } - } - - -// ----------------------------------------------------------------------------- -// CCbs::ReadCBSSimTopicsL -// ----------------------------------------------------------------------------- -// -TInt CCbs::ReadCBSSimTopicsL(CStifItemParser& /*aItem*/) - { - iCbsLog->Log(_L8("CBS::ReadCBSSimTopicsL")); - TInt ret = KErrGeneral; - ret = HandleRequestL( ECustomStartSimCbTopicBrowsingIPC ); - if ( KErrNone != ret ) - { - iCbsLog->Log(_L8("Error in reading CBS SIM topics: %d"), ret ); - } - else - { - iReadCBSSimTopicsPending = ETrue; - } - return ret; - } - -// ----------------------------------------------------------------------------- -// CCbs::CompleteReadCBSSimTopics -// ----------------------------------------------------------------------------- -// -void CCbs::CompleteReadCBSSimTopics(TInt aErr, CMmDataPackage& aData) - { - iCbsLog->Log(_L8("CBS::CompleteReadCBSSimTopics, err=%d"),aErr); - if (iReadCBSSimTopicsPending) - { - if ( KErrNone == aErr ) - { - CArrayFixFlat* topics; - aData.UnPackData( topics ); - TInt count = topics->Count(); - if ( 0 < count ) - { - iCbsLog->Log(_L8("%d topics read."), count); - for ( TInt i = 0; i < count; i++ ) - { - iCbsLog->Log(_L8(" topic[%d]=%d."),i,topics->At( i ).iNumber); - } - } - } - iReadCBSSimTopicsPending = EFalse; - Signal(aErr); - } - } - -// ----------------------------------------------------------------------------- -// CCbs::DeleteCBSSimTopicL -// ----------------------------------------------------------------------------- -// -TInt CCbs::DeleteCBSSimTopicL(CStifItemParser& aItem) - { - TInt nbr; - aItem.GetNextInt(nbr); - iCbsLog->Log(_L8("CBS::DeleteCBSSimTopicL, deleting topic %d."),nbr); - - TInt ret = KErrGeneral; - TBool deleteTopic = ETrue; - CMmDataPackage package; - package.PackData(&nbr, &deleteTopic); - ret = HandleRequestL( ECustomDeleteSimCbTopicIPC, &package ); - if ( KErrNone != ret ) - { - iCbsLog->Log(_L8("Error in deleting CBS SIM topic: %d"), ret ); - } - else - { - iDeleteCBSSimTopicPending = ETrue; - } - return ret; - } - -// ----------------------------------------------------------------------------- -// CCbs::CompleteDeleteCBSSimTopic -// ----------------------------------------------------------------------------- -// -void CCbs::CompleteDeleteCBSSimTopic(TInt aErr) - { - iCbsLog->Log(_L8("CBS::CompleteDeleteCBSSimTopic, err=%d"),aErr); - if (iDeleteCBSSimTopicPending) - { - iDeleteCBSSimTopicPending = EFalse; - Signal(aErr); - } - } - - -// ========================== OTHER EXPORTED FUNCTIONS ========================= -// None - -// End of File