locationmgmt/agpslocationmgr/test/te_man/src/man0Step.cpp
author Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
Wed, 14 Apr 2010 17:26:05 +0300
branchRCL_3
changeset 18 54d74d217042
parent 0 9cfd9a3ee49c
child 49 5f20f71a57a3
permissions -rw-r--r--
Revision: 201010 Kit: 201015

// 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();
	}