diff -r 000000000000 -r 9cfd9a3ee49c datasourcemodules/defaultpositioningmodule/test/te_defproxy/src/psyvisiblestep.cpp --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/datasourcemodules/defaultpositioningmodule/test/te_defproxy/src/psyvisiblestep.cpp Tue Feb 02 01:50:39 2010 +0200 @@ -0,0 +1,129 @@ +// Copyright (c) 2008-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 PsyVisibleStep.cpp + @internalTechnology +*/ +#include "PsyVisibleStep.h" +#include "Te_defproxySuiteDefs.h" + +CPsyVisibleStep::~CPsyVisibleStep() +/** + * Destructor + */ + { + } + +CPsyVisibleStep::CPsyVisibleStep() +/** + * Constructor + */ + { + SetTestStepName(KPsyVisibleStep); + } + +TVerdict CPsyVisibleStep::doTestStepPreambleL() +/** + * @return - TVerdict code + * Override of base class virtual + */ + { + CTe_defproxySuiteStepBase::doTestStepPreambleL(); + SetTestStepResult(EPass); + return TestStepResult(); + } + + +TVerdict CPsyVisibleStep::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. + */ + { + StandardPrepareL(); + InitPsySettingsL(3, KNetworkPsy1, 1, KIntGpsPsy1, 1, KNetworkPsy2, 1); + + ConfigPsyL(KIntGpsPsy1, 3, + KConfigLRNoError5s, //Step 1. no error in 5s + KConfigLRErrGeneral1s, //Step 2. error in 1s + KConfigLRErrGeneral1s //Step 3. error in 1s + ); + + User::After(KSecond*7); + + TRequestStatus status; + TPositionInfo posInfo; + TPositionUpdateOptions options; + + ToggleModuleVisibleL(KNetworkPsy1, EFalse); + //1. Set PSY1 visible shall not affect location request + SET_TIME + iPositioner.NotifyPositionUpdate(posInfo, status); + User::After(KTinyDelay); + ToggleModuleVisibleL(KNetworkPsy1, ETrue); + User::WaitForRequest(status); + CHECK_TIME(5) + CheckExpectedResult(status.Int(), KErrNone, KFailedPositionRequest); + CheckExpectedResult(posInfo.ModuleId(), KIntGpsPsy1, KWrongModuleIdReturned); + + + ToggleModuleVisibleL(KNetworkPsy2, EFalse); + + + ConfigPsyL(KNetworkPsy1, 2, + KConfigLRNoError35s, //Step2. no error in 35s + KConfigLRErrNoMemory //Step 3. error in 1s + ); + + User::After(KSecond*7); + + //2. Set PSY3 visible during fallback shall has no effect + SET_TIME + iPositioner.NotifyPositionUpdate(posInfo, status); + User::After(KSecond*5); + ToggleModuleVisibleL(KNetworkPsy2, ETrue); + User::WaitForRequest(status); + CHECK_TIME(35) //PSY1 response time + CheckExpectedResult(status.Int(), KErrNone, KFailedPositionRequest); + CheckExpectedResult(posInfo.ModuleId(), KNetworkPsy1, KWrongModuleIdReturned); + + //3. PSY3 shall be used in next LR + SET_TIME + iPositioner.NotifyPositionUpdate(posInfo, status); + User::WaitForRequest(status); + CheckExpectedResult(status.Int(), KErrNone, KFailedPositionRequest); + CheckExpectedResult(posInfo.ModuleId(), KNetworkPsy2, KWrongModuleIdReturned); + + // cleanup + StandardCleanup(); + return TestStepResult(); + } + + + +TVerdict CPsyVisibleStep::doTestStepPostambleL() +/** + * @return - TVerdict code + * Override of base class virtual + */ + { + CTe_defproxySuiteStepBase::doTestStepPostambleL(); + return TestStepResult(); + }