--- /dev/null Thu Jan 01 00:00:00 1970 +0000
+++ b/locationmgmt/agpslocationmgr/test/te_man/src/man0Step.cpp Fri Jun 04 10:34:15 2010 +0100
@@ -0,0 +1,234 @@
+// Copyright (c) 2006-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:
+// Example CTestStep derived implementation
+//
+//
+
+/**
+ @file man0Step.cpp
+*/
+#include "man0Step.h"
+#include "Te_manSuiteDefs.h"
+#include "LbsInternalInterface.h"
+#include "cprocesslaunch.h"
+#include "tprocessstartparams.h"
+#include "lbsassistancedatacacheapi.h"
+#include "lbsnetinternalapi.h"
+#include "lbsnetregstatusint.h"
+#include "LbsLocSourceTestChannel.h"
+#include "lbsprocesssupervisor.h"
+
+#include <lbs/lbsextendedsatellite.h>
+
+Cman0Step::~Cman0Step()
+/**
+ * Destructor
+ */
+ {
+ }
+
+Cman0Step::Cman0Step()
+/**
+ * Constructor
+ */
+ {
+ // **MUST** call SetTestStepName in the constructor as the controlling
+ // framework uses the test step name immediately following construction to set
+ // up the step's unique logging ID.
+ iStepCount = 0;
+ SetTestStepName(Kman0Step);
+ }
+
+TVerdict Cman0Step::doTestStepPreambleL()
+/**
+ * @return - TVerdict code
+ * Override of base class virtual
+ */
+ {
+ //INFO_PRINTF1(_L("Please delete this line or modify it. I am in Test Step Preamble in Class Cman0Step"));
+ // uncomment the following 3 lines if you have common pre setting to all the test steps in there
+ CTe_manSuiteStepBase::doTestStepPreambleL();
+ // if (TestStepResult()!=EPass)
+ // return TestStepResult();
+ // process some pre setting to this test step then set SetTestStepResult to EFail or Epass.
+ SetTestStepResult(EPass);
+ return TestStepResult();
+ }
+
+
+TVerdict Cman0Step::doTestStepL()
+/**
+ * @return - TVerdict code
+ * Override of base class pure virtual
+ * Our implementation only gets called if the base class doTestStepPreambleL() did
+ * not leave. That being the case, the current test result value will be EPass.
+ */
+ {
+ if (TestStepResult()==EPass)
+ {
+
+ // Start test version of AGPS manager and use a test version if integration module
+ // The test version of AGPS manager is same as actual but does not use the
+ // ECOM plugin interface.
+
+ // for real thing this is done by route (lbs startup) process
+ TPositionExtendedSatelliteInfo posSatInfo;
+ RLbsPositionUpdates::InitializeL(posSatInfo); // used to publish position
+
+ TPositionModuleStatus defaultPositionModuleStatus;
+ RLbsModuleStatus::InitializeL(defaultPositionModuleStatus);
+
+ RLbsPositionUpdateRequests::InitializeL();
+ RLbsNetworkRegistrationStatus::InitializeL();
+ RLbsNetChannel::InitializeL(RLbsNetChannel::EChannelAGPS2NG);
+ RLbsNetChannel::InitializeL(RLbsNetChannel::EChannelNG2AGPS);
+ RAssistanceDataCache::InitializeL();
+ RAgpsModuleTestChannel::InitialiseL();
+
+ RLbsGpsMeasurementUpdates::InitializeL();
+
+ /*
+ * Define the properties used by the Root Process API
+ */
+ RLbsProcessSupervisor::InitializeL();
+
+ TProcessStartParams params;
+ _LIT(KDummyFileName, "\\sys\\bin\\testlbsgpslocmanager.exe");
+ _LIT(KDummyProcessName, "testlbsgpslocmanager");
+ params.SetProcessFileName(KDummyFileName);
+ params.SetProcessName(KDummyProcessName);
+ params.SetRendezvousRequired(ETrue);
+ TInt r = CProcessLaunch::ProcessLaunch(params);
+ User::LeaveIfError(r);
+
+ INFO_PRINTF1(_L("AGPSManagerProcess started in the file man0Step.cpp")); //Block start
+ INFO_PRINTF1(_L("Advise test integration module EPowerModeStandby"));
+ TLbsPositionUpdateRequestStatus request;
+ request.Tracking() = ETrue;
+ request.SetPowerAdvice(TLbsPositionUpdateRequestBase::EPowerAdviceStandby);
+ RLbsPositionUpdateRequests posReqs;
+ posReqs.OpenL(KChannelArray[0]);
+ CleanupClosePushL(posReqs);
+
+ const TUint KLbsGpsLocManagerUidValue = 0x10281D44;
+ const TUid KLbsGpsLocManagerUid = {KLbsGpsLocManagerUidValue};
+
+ RLbsModuleStatus modStatus;
+ modStatus.OpenL(KLbsGpsLocManagerUid);
+ CleanupClosePushL(modStatus);
+ TRequestStatus stat;
+ modStatus.NotifyModuleStatusChange(stat);
+
+ User::LeaveIfError(posReqs.SetPositionUpdateRequest(request));
+ /* now enable active scheduler and wait for call bacl to be called which exits sceduler */
+
+
+ User::WaitForRequest(stat);
+ if(stat.Int()!=KErrNone) User::Leave(KErrGeneral);
+
+ TPositionModuleStatus status;
+ TPositionModuleStatusEventBase::TModuleEvent occurredEvents =
+ TPositionModuleStatusEventBase::EEventNone;
+ User::LeaveIfError(modStatus.GetModuleStatus(&status, sizeof(TPositionModuleStatus), occurredEvents));
+
+ if(status.DeviceStatus() != TPositionModuleStatus::EDeviceStandBy)
+ {
+ User::Leave(KErrNotFound);
+ }
+ INFO_PRINTF1(_L("Test integration module correctly responds with EDeviceStandBy"));
+
+ // now iterate around all eight values for TDeviceStatus and
+ // check correct publishing to CPosIntGpsHwStatus
+
+
+ CPosIntGpsHwStatus* posIntGpsHwStatus = CPosIntGpsHwStatus::NewL(*this);
+ CleanupStack::PushL(posIntGpsHwStatus);
+
+ CActiveScheduler* temp = CActiveScheduler::Current();
+
+ // this test checks that the correct hardware status is
+ // sent to the OnStatusUpdateEvent (see MPosIntGpsHwStatusObserver)
+ // The strategy is for the test to send eight EPowerAdviceClosed
+ // messages to the AGPS manager which then passes each in turn
+ // to a test agps module which responds to each with one of an 8 ordered list
+ // of hw status updates to the agps manager.
+ // The manager publishes each value onto the api and
+ // this test checks that the correct values are oberved on OnStatusUpdateEvent.
+ for (TUint i= 0; i < 8; i++)
+ {
+ request.SetPowerAdvice(TLbsPositionUpdateRequestBase::EPowerAdviceClosed);
+ //request.SetPowerAdvice((TLbsPositionUpdateRequestBase::TPowerAdvice)(TInt)(TLbsPositionUpdateRequestBase::EPowerAdviceClosed+1));
+ User::LeaveIfError(posReqs.SetPositionUpdateRequest(request));
+ temp->Start();
+
+ }
+
+ CleanupStack::PopAndDestroy(posIntGpsHwStatus);
+ CleanupStack::PopAndDestroy(&modStatus);
+ CleanupStack::PopAndDestroy(&posReqs);
+ // Set the network registration status to 'home network' - as this is what most of
+ // the tests expect
+ RLbsNetworkRegistrationStatus netRegStatus;
+ netRegStatus.OpenL();
+ CleanupClosePushL(netRegStatus);
+ netRegStatus.SetNetworkRegistrationStatus(RLbsNetworkRegistrationStatus::ERegisteredHomeNetwork);
+
+ CleanupStack::PopAndDestroy(&netRegStatus);
+
+ // ************** Block end ****************
+
+ SetTestStepResult(EPass);
+ }
+ return TestStepResult();
+ }
+
+
+
+
+static const CPosIntGpsHwStatus::TIntGpsHwStatus KResultStatusTable[8] =
+ {
+ CPosIntGpsHwStatus::EStatusOff, // EDeviceUnknown -> EStatusOff
+ CPosIntGpsHwStatus::EStatusOn, // EDeviceInitialising -> EStatusOn
+ CPosIntGpsHwStatus::EStatusOff, // EDeviceError -> EStatusOff
+ CPosIntGpsHwStatus::EStatusOn, // EDeviceStandBy -> EStatusOn
+ CPosIntGpsHwStatus::EStatusOff, // EDeviceDisabled -> EStatusOff
+ CPosIntGpsHwStatus::EStatusOn, // EDeviceReady -> EStatusOn
+ CPosIntGpsHwStatus::EStatusOff, // EDeviceInactive -> EStatusOff
+ CPosIntGpsHwStatus::EStatusActive // EDeviceActive -> EStatusActive
+ };
+
+void Cman0Step::OnStatusUpdateEvent(CPosIntGpsHwStatus::TIntGpsHwStatus aStatus, TInt /*aError*/)
+{
+ INFO_PRINTF3(_L("Received TIntGpsHwStatus %d and expected %d"), aStatus , KResultStatusTable[iStepCount]);
+
+ if (KResultStatusTable[iStepCount] != aStatus)
+ {
+ INFO_PRINTF1(_L("Test Failed"));
+ }
+
+ TESTL(aStatus == KResultStatusTable[iStepCount]);
+ iStepCount++;
+
+ CActiveScheduler::Stop();
+}
+
+TVerdict Cman0Step::doTestStepPostambleL()
+/**
+ * @return - TVerdict code
+ * Override of base class virtual
+ */
+ {
+ CTe_manSuiteStepBase::doTestStepPostambleL();
+ return TestStepResult();
+ }