diff -r a36b1e19a461 -r 989d2f495d90 serviceproviders/sapi_sysinfo/tsrc/dev/servicetests/manual/tsysinfonetworktests/src/tsysinfocellidnotify.cpp --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/serviceproviders/sapi_sysinfo/tsrc/dev/servicetests/manual/tsysinfonetworktests/src/tsysinfocellidnotify.cpp Fri Jul 03 15:51:24 2009 +0100 @@ -0,0 +1,134 @@ +/* +* Copyright (c) 2002 - 2007 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: tsysinfocellidnotify +* +*/ + + + +#include "tsysinfonetworktests.h" +#include "sysinfoservice.h" +#include "entitykeys.h" +#include "tsysinfocellidnotify.h" + +using namespace SysInfo; + +CCellidNotify* CCellidNotify::NewL(CStifLogger* aLog) + { + CCellidNotify* self = new(ELeave) CCellidNotify(aLog); + self->ConstructL(); + return self; + } + +CCellidNotify::~CCellidNotify() + { + Cancel(); + + if(iWaitSchedular->IsStarted()) + iWaitSchedular->AsyncStop(); + + delete iSysInfoService; + delete iWaitSchedular; + delete iTimer; + } + +void CCellidNotify::ConstructL() + { + iSysInfoService = CSysInfoService::NewL(); + iWaitSchedular = new(ELeave) CActiveSchedulerWait(); + iTimer = CWatchTimer::NewL(EPriorityNormal,this); + CActiveScheduler::Add(this); + } + +CCellidNotify::CCellidNotify(CStifLogger* aLog) + :CActive(EPriorityStandard), + iLog(aLog) + { + } + +void CCellidNotify::DoCancel() + { + } + +void CCellidNotify::RunL() + { + TestFuncL(); + } + +void CCellidNotify::Start() + { + SetActive(); + TRequestStatus* temp = &iStatus; + User::RequestComplete(temp, KErrNone); + iWaitSchedular->Start(); + } + +TInt CCellidNotify::Result() + { + return iResult; + } + +void CCellidNotify::TestFuncL() + { + const TTimeIntervalMicroSeconds32 OneMinute(6000000000); + iTransId = 444; + TRAPD(err,iSysInfoService->GetNotificationL(KNetwork,KCellID,iTransId,this)); + iResult = err; + iTimer->After(OneMinute); + } + +void CCellidNotify::HandleResponseL(const TDesC& /*aEntity*/,const TDesC& /*aKey*/, + CSysData* aOutput, TInt32 aTransID, TSysRequest::TRequestType /*aType*/,TInt aError) + { + + iLog->Log(_L("Signal Strength read..")); + + if(!aError) + { + TInt32 tid = aTransID; + TInt cellId = ((CStatus*)aOutput)->Status(); + + if(tid ==iTransId) + { + iResult = PASS; + iLog->Log(_L("Cell id")); + TBuf<50> buf; + buf.AppendNum(cellId); + iLog->Log(buf); + } + else + { + iResult = FAIL; + iLog->Log(_L("Cell id err..")); + } + } + else + { + iLog->Log(_L("ERROR SET")); + iResult = FAIL; + } + delete aOutput; + iWaitSchedular->AsyncStop(); + } + +void CCellidNotify::HandleTimeOut() +{ + iLog->Log(_L("TimeOut reached...")); + iSysInfoService->Cancel(1); + iResult = FAIL; + iWaitSchedular->AsyncStop(); +} + + +