locationmgmt/agpslocationmgr/test/te_man/src/man12Step.cpp
changeset 0 9cfd9a3ee49c
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/locationmgmt/agpslocationmgr/test/te_man/src/man12Step.cpp	Tue Feb 02 01:50:39 2010 +0200
@@ -0,0 +1,270 @@
+// Copyright (c) 2007-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 man12Step.cpp
+*/
+#include "man12step.h"
+#include "Te_manSuiteDefs.h"
+#include "LbsInternalInterface.h"
+#include <lbs/lbslocdatasourcegpsbase.h>
+#include "lbsassistancedatacacheapi.h"
+#include <lbs/lbsextendedsatellite.h>
+#include <lbs/lbsgpsmeasurement.h>
+
+
+Cman12Step::~Cman12Step()
+/**
+ * Destructor
+ */
+	{
+	}
+
+Cman12Step::Cman12Step()
+/**
+ * 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.
+	SetTestStepName(Kman12Step);
+	}
+
+TVerdict Cman12Step::doTestStepPreambleL()
+/**
+ * @return - TVerdict code
+ * Override of base class virtual
+ */
+	{                                  
+	SetTestStepResult(EPass);
+	return TestStepResult();
+	}
+
+
+TVerdict Cman12Step::doTestStepL()
+/**
+ * @return - TVerdict code
+ * 
+ * This test checks that when the NRH requests a hybrid location update, a measurement update
+ * is received (in addition to a location update).
+ * The test also checks that when the NRH request is cancelled, the Integration Module is reconfigured
+ * with the GPS Mode given by the corresponding admin setting and the location request is cancelled. 
+ */
+	{
+	
+	if (TestStepResult()==EPass)
+		{
+		INFO_PRINTF1(_L("Simulate NRH sending a 'hybrid' location request"));
+		INFO_PRINTF1(_L("NRH sends location update request for NOW and  MaxFixTime=5s acc=0.1"));
+			
+		const RLbsPositionUpdateRequests::TChannelIdentifer KChannelIdentifierNRH = 
+			{
+				{KLbsGpsLocManagerUidValue},{KLbsNetRequestHandlerUidValue}
+			};
+		const RLbsPositionUpdateRequests::TChannelIdentifer KChannelIdentifierLocServer = 
+			{
+				{KLbsGpsLocManagerUidValue},{KLbsLocServerUidValue}
+			};
+			
+	    RLbsPositionUpdateRequests posUpdateReqLocSrv;
+		posUpdateReqLocSrv.OpenL(KChannelIdentifierLocServer);
+		CleanupClosePushL(posUpdateReqLocSrv);
+		
+		RLbsPositionUpdateRequests posUpdateReqNRH;
+		posUpdateReqNRH.OpenL(KChannelIdentifierNRH);
+		CleanupClosePushL(posUpdateReqNRH);
+		
+		RLbsPositionUpdates posUpdates;
+		posUpdates.OpenL(KLbsGpsLocManagerUid);
+		CleanupClosePushL(posUpdates);
+		TRequestStatus locStat;
+		posUpdates.NotifyPositionUpdate(locStat);
+		
+		RLbsGpsMeasurementUpdates measurementUpdates;
+		measurementUpdates.OpenL();
+		CleanupClosePushL(measurementUpdates);
+		TRequestStatus measurementStat;
+		measurementUpdates.NotifyGpsMeasurementUpdate(measurementStat);
+		
+		RLbsModuleStatus modStatus;
+		modStatus.OpenL(KLbsGpsLocManagerUid);
+		CleanupClosePushL(modStatus);
+		
+		// Start the testcase with a cancel request both from the LocServer
+		// and the NRH to ensure the test AGPS Manager starts from scratch
+		// (previous testcases may not have cleaned up correctly)
+		TLbsPositionUpdateRequestCancel cancel;
+		
+		User::LeaveIfError(posUpdateReqLocSrv.SetPositionUpdateRequest(cancel));
+		User::LeaveIfError(posUpdateReqNRH.SetPositionUpdateRequest(cancel));
+	//	WaitAndValidateNgMsg(TLbsNetInternalMsgBase::ESelfLocationCancel);
+		User::After(1000000); // Allow one second for the cancel to take effect
+		
+		// Simulate what is done by NRH when it wants a hybrid location update
+		TLbsPositionUpdateRequest locRequestNRH;
+		TLbsLocRequestQualityInt qualityNRH;
+		qualityNRH.SetMaxFixTime(5000000);
+		qualityNRH.SetMinHorizontalAccuracy(0.5);
+		qualityNRH.SetMinVerticalAccuracy(0.5);
+    	locRequestNRH.RequestQuality() = qualityNRH;    	
+   	 	TTime targetTime;
+		targetTime.UniversalTime(); // Target time is now and try for 5 seconds
+		locRequestNRH.TargetTime() = targetTime;
+		// Make the request a 'hybrid' one
+		TLbsNetPosRequestMethodInt methods;
+		TLbsNetPosMethodInt posMethods[2];
+		posMethods[0].SetPosMethod(KLbsRootUid, (TPositionModuleInfo::ETechnologyTerminal|TPositionModuleInfo::ETechnologyAssisted));
+		posMethods[1].SetPosMethod(KLbsRootUid, (TPositionModuleInfo::ETechnologyNetwork | TPositionModuleInfo::ETechnologyAssisted));
+		methods.SetPosMethods(posMethods, 2);
+		locRequestNRH.RequestMethod() = methods;
+		
+		INFO_PRINTF1(_L("NRH sends a location request to integration module"));
+		User::LeaveIfError(posUpdateReqNRH.SetPositionUpdateRequest(locRequestNRH));
+
+		// Check first that the GPS Manager publishes a position update as provided
+		// by the test integration module (the test version of the integration module
+		// is hardwired to send a test TPositionExtendedSatelliteInfo)
+		// 
+		User::WaitForRequest(locStat);
+		
+		if(locStat.Int()!=KErrNone)
+			User::Leave(KErrGeneral);
+		
+		TInt error = 1; // something other than KErrNone
+		TTime actualTime = 0;
+		targetTime = 0;
+
+		TPositionExtendedSatelliteInfo satInfo;
+		TBool conflictControl;
+		error = posUpdates.GetPositionInfo(conflictControl, &satInfo, sizeof(satInfo),targetTime, actualTime);
+
+		if(error!=KErrNone)
+			User::Leave(KErrGeneral);
+			
+		if(targetTime!=locRequestNRH.TargetTime())
+			User::Leave(KErrGeneral);
+
+		if(satInfo.SatelliteTime()!=locRequestNRH.TargetTime())
+			User::Leave(KErrGeneral);
+
+		INFO_PRINTF1(_L("Test integration module correctly responds with location"));
+
+	
+		// Check that the GPS Manager publishes a measurement update as provided
+		// by the test integration module (the test version of the integration module
+		// is hardwired to send a measurement update with 1 measured data)
+		//
+		User::WaitForRequest(measurementStat);
+		
+		if(measurementStat.Int()!=KErrNone)
+			User::Leave(KErrGeneral);
+		
+		error = 1; // something other than KErrNone
+		actualTime = 0;
+
+		TPositionGpsMeasurementInfo measurementUpdate;
+		error = measurementUpdates.GetGpsMeasurementInfo(&measurementUpdate, sizeof(measurementUpdate), actualTime);
+		
+		
+		if (measurementUpdate.NumMeasurements() != 1)
+			User::Leave(KErrGeneral);
+		
+		if(error!=KErrNone)
+			User::Leave(KErrGeneral);
+		
+		INFO_PRINTF1(_L("Test integration module correctly responds with measurement"));
+
+
+		// The last part of the test consists of cancelling the request and check the results
+		// The test GPS Module will show those results by changes to the module status (this wouldn't
+		// happen in production code, it is just for testing). Set the module status to some initial values
+		// before cancelling.
+		TPositionModuleStatus moduleStatus;
+		moduleStatus.SetDeviceStatus(TPositionModuleStatus::EDeviceReady);
+		moduleStatus.SetDataQualityStatus(TPositionModuleStatus::EDataQualityNormal);
+
+        TPositionModuleStatusEventBase::TModuleEvent occurredEvents = 
+						TPositionModuleStatusEventBase::EEventDeviceStatus | TPositionModuleStatusEventBase::EEventDataQualityStatus;
+		User::LeaveIfError(modStatus.SetModuleStatus(&moduleStatus,sizeof(moduleStatus),occurredEvents));
+		User::After(1000000);
+		
+		// Cancel NRH's location update request.
+		// The AGPS Manager should ask the Integration Module to:
+		// 1.- Cancel the location request (because there is no outstanding request from the Location Server)
+		// 2.- Configure GPS Mode as per Admin setting.
+		//
+		User::LeaveIfError(posUpdateReqNRH.SetPositionUpdateRequest(cancel));
+		
+		//...let the cancel message do its thing for a second
+		User::After(1000000);
+		
+		occurredEvents = TPositionModuleStatusEventBase::EEventNone;
+		User::LeaveIfError(modStatus.GetModuleStatus(&moduleStatus, sizeof(moduleStatus), occurredEvents));
+
+		// Check that the cancellation has resulted in a call to CancelLocationRequest of the
+		// integration module (hack: the test integration module switches the Data Quality Status
+		// to EDataQualityPartial when CancelLocationRequest is called while in 'hybrid'mode)
+		//
+		if (moduleStatus.DataQualityStatus() != TPositionModuleStatus::EDataQualityPartial)
+			{
+			INFO_PRINTF1(_L("Incorrect DataQualityStatus: CancelLocationRequest has not been called."));
+			User::Leave(KErrNotFound);
+			}
+		
+		INFO_PRINTF1(_L("Test integration module correctly set TPositionModuleStatus::EDataQualityPartial"));
+		
+		// Check that the AGPS manager has reconfigured the Integration Module' GPS mode with the 
+		// Admin setting after leaving the hybrid mode. (NOTE: for testing purposes, the test integration 
+		// module changes the Device Status when it is configured with a new admin setting)
+		//
+		if(moduleStatus.DeviceStatus() == TPositionModuleStatus::EDeviceReady)
+			{
+			INFO_PRINTF1(_L("Incorrect DeviceStatus: GPS Mode hasn't changed."));
+			User::Leave(KErrNotFound);
+			}
+		
+		INFO_PRINTF1(_L("Checked that module status after cancelling is not EDeviceInitialising"));
+
+		WaitAndValidateNgMsg(TLbsNetInternalMsgBase::EAssistanceDataRequest);
+		
+		SendNgMsg(KSessionCompleteKErrNone);
+
+		CleanupStack::PopAndDestroy(&modStatus);
+		CleanupStack::PopAndDestroy(&measurementUpdates);
+		CleanupStack::PopAndDestroy(&posUpdates);
+		CleanupStack::PopAndDestroy(&posUpdateReqNRH);
+		CleanupStack::PopAndDestroy(&posUpdateReqLocSrv);
+
+	 		//  **************   Block end ****************
+
+		SetTestStepResult(EPass);
+		}
+	  return TestStepResult();
+	}
+
+
+
+
+TVerdict Cman12Step::doTestStepPostambleL()
+/**
+ * @return - TVerdict code
+ * Override of base class virtual
+ */
+	{
+	return TestStepResult();
+	}