lbs/lbsclient/src/ctlbsclientpostp254.cpp
author Maciej Seroka <maciejs@symbian.org>
Mon, 13 Sep 2010 14:50:12 +0100
branchSymbian3
changeset 64 a67132c2eb0c
parent 6 c108117318cb
permissions -rw-r--r--
Fixed smoketest.pl

// Copyright (c) 2001-2009 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:
//



// INCLUDE FILES
#include "ctlbsclientpostp254.h"
#include <f32file.h>
#include <bautils.h>
#include <LbsSatellite.h>

// CONSTANTS
_LIT(KLastPosition, "c:\\private\\101f97b2\\LastKnownPos.dat");


// ================= MEMBER FUNCTIONS =======================

// ---------------------------------------------------------
// Constructor.
// ---------------------------------------------------------
CT_LbsClientPosTp254::CT_LbsClientPosTp254(CT_LbsServer& aParent): CT_LbsPortedStepBase(aParent)
	{  
	_LIT(KTestName, "TP254 - Get last known position");
	SetTestStepName(KTestName); 
	}

// ---------------------------------------------------------
// Destructor.
// ---------------------------------------------------------
CT_LbsClientPosTp254::~CT_LbsClientPosTp254()
	{
	}

// ---------------------------------------------------------
// CT_LbsClientPosTp254::CloseTest
//
// (other items were commented in a header).
// ---------------------------------------------------------
//
void CT_LbsClientPosTp254::CloseTest()
    {
    }

// ---------------------------------------------------------
// CT_LbsClientPosTp254::StartL
//
// (other items were commented in a header).
// ---------------------------------------------------------
//
void CT_LbsClientPosTp254::StartL()
    {
    User::After(2000000);
    DeleteFileL(KLastPosition);
	SetupPsyL(iUidTestPsy11);

    RPositionServer	posServer;
    CleanupClosePushL(posServer);
    RPositioner positioner;
    CleanupClosePushL(positioner);
    TPositionInfo positionInfo = TPositionInfo();
    TPositionInfo positionInfoLast = TPositionInfo();

	_LIT(KConnectErr, "Error when connecing to EPos server,  %d");
	TInt err = posServer.Connect();
	AssertTrueL(err == KErrNone, KConnectErr, err);

	_LIT(KOpenErr, "Error when opening positioner,  %d");
    err = positioner.Open(posServer,iUidTestPsy11 ); //use defalut psy
	AssertTrueL(err == KErrNone, KOpenErr, err);


    _LIT(KService ,"Service");
	positioner.SetRequestor(CRequestor::ERequestorService,
							 CRequestor::EFormatApplication, KService);

    TRequestStatus status;
    status = KRequestPending;

    positionInfoLast.SetUpdateType(EPositionUpdateUnknown); // just to make a difference
    
    positioner.GetLastKnownPosition(positionInfoLast, status);
    User::WaitForRequest(status);
    err = status.Int();
    _LIT(KErrorRequest, "Get last known position did not return with KErrUnKnown %d");
    AssertTrueL(err == KErrUnknown, KErrorRequest, err);

    //Verification of TR SBUY-5WHGS3 i.e even if the psy has a really fast
    //responce time a last known position should be saved.
    status = KRequestPending;

    positioner.NotifyPositionUpdate(positionInfo, status);
    User::WaitForRequest(status);
    err = status.Int();
    _LIT(KErrPosition, "Not possible to make a request");
    AssertTrueL(err == KErrNone, KErrPosition, err);

    positioner.GetLastKnownPosition(positionInfoLast, status);
    User::WaitForRequest(status);
    err = status.Int();
    _LIT(KErrorFast, "Get last known position after fast psy did not work %d");
    AssertTrueL(err == KErrNone, KErrorFast, err);

    positioner.Close();
    posServer.Close();

    const TTimeIntervalMicroSeconds32 KPosWaitServerShutDown( 6000000 );
    User::After(KPosWaitServerShutDown);
    DeleteFileL(KLastPosition);
    SetupPsyL(iUidTestPsyMaxAge);
	err = posServer.Connect();
	AssertTrueL(err == KErrNone, KConnectErr, err);
    err = positioner.Open(posServer); //use defalut psy
	AssertTrueL(err == KErrNone, KOpenErr, err);
	positioner.SetRequestor(CRequestor::ERequestorService,
							 CRequestor::EFormatApplication, KService);

    
    status = KRequestPending;

    positioner.NotifyPositionUpdate(positionInfo, status);
    User::WaitForRequest(status);
    err = status.Int();
    AssertTrueL(err == KErrNone, KErrPosition, err);

    //Now there should exist a last known position
    positioner.GetLastKnownPosition(positionInfoLast, status);
    User::WaitForRequest(status);
    err = status.Int();
    _LIT(KErrorRequestLast, "Get last known position did not return with KErrNone %d");
    AssertTrueL(err == KErrNone, KErrorRequestLast, err);

    CheckPositionInfoL(positionInfo, positionInfoLast);

	TPositionSatelliteInfo satelliteInfoLast = TPositionSatelliteInfo();
    positioner.GetLastKnownPosition(satelliteInfoLast, status);
    User::WaitForRequest(status);
    err = status.Int();
    
    AssertTrueL(err == KErrArgument, KErrorRequest, err);

    positioner.NotifyPositionUpdate(positionInfo, status);
    User::WaitForRequest(status);
    err = status.Int();
    AssertTrueL(err == KErrNone, KErrPosition, err);

    positioner.GetLastKnownPosition(positionInfoLast, status);
    User::WaitForRequest(status);
    err = status.Int();
    AssertTrueL(err == KErrNone, KErrorRequest, err);

    CheckPositionInfoL(positionInfo, positionInfoLast);

    positioner.Close();
    posServer.Close();

    //connect again
	err = posServer.Connect();
	AssertTrueL(err == KErrNone, KConnectErr, err);
    err = positioner.Open(posServer); //use defalut psy
	AssertTrueL(err == KErrNone, KOpenErr, err);
	positioner.SetRequestor(CRequestor::ERequestorService,
							 CRequestor::EFormatApplication, KService);


    TPositionInfo positionInfoLast1 = TPositionInfo();
    positioner.GetLastKnownPosition(positionInfoLast1, status);
    User::WaitForRequest(status);
    err = status.Int();
    AssertTrueL(err == KErrNone, KErrorRequest, err);    
    CheckPositionInfoL(positionInfoLast, positionInfoLast1);

    positioner.Close();
    posServer.Close();
	User::After(6000000);

    //The position is written to persistant storeage since TEF is shutdown.
    if (!FileExistsL(KLastPosition))
        {
        _LIT(KErrStore, "The dat file not created");
        LogErrorAndLeaveL(KErrStore);
        }

    //Connect again
	err = posServer.Connect();
	AssertTrueL(err == KErrNone, KConnectErr, err);
    err = positioner.Open(posServer); //use defalut psy
	AssertTrueL(err == KErrNone, KOpenErr, err);
	positioner.SetRequestor(CRequestor::ERequestorService,
							 CRequestor::EFormatApplication, KService);


    TPositionInfo positionInfoLast2 = TPositionInfo();
    positioner.GetLastKnownPosition(positionInfoLast2, status);
    User::WaitForRequest(status);
    err = status.Int();
    AssertTrueL(err == KErrNone, KErrorRequest, err);    
    CheckPositionInfoL(positionInfoLast, positionInfoLast2);

    RPositionServer	posServer1;
    CleanupClosePushL(posServer1);
    RPositioner positioner1;
    CleanupClosePushL(positioner1);
    SetupPsyL(iUidMultiPsy);
	_LIT(KConnect1Err, "Error when connecing to EPos server,  %d");
	err = posServer1.Connect();
	AssertTrueL(err == KErrNone, KConnect1Err, err);

	_LIT(KOpen1Err, "Error when opening positioner,  %d");
    err = positioner1.Open(posServer); //use defalut psy
	AssertTrueL(err == KErrNone, KOpen1Err, err);
	positioner1.SetRequestor(CRequestor::ERequestorService,
							 CRequestor::EFormatApplication, KService);

    positioner1.NotifyPositionUpdate(positionInfo, status);
    User::WaitForRequest(status);
    err = status.Int();
    AssertTrueL(err == KErrNone, KErrPosition, err);

    positioner.GetLastKnownPosition(positionInfoLast, status);
    User::WaitForRequest(status);
    err = status.Int();
    AssertTrueL(err == KErrNone, KErrorRequest, err);
    CheckPositionInfoL(positionInfo, positionInfoLast);

    //just to make sure that positioner1 also gets the correct position
    positioner1.GetLastKnownPosition(positionInfoLast, status);
    User::WaitForRequest(status);
    err = status.Int();
    AssertTrueL(err == KErrNone, KErrorRequest, err);
    CheckPositionInfoL(positionInfo, positionInfoLast);

    SetupPsyL(iUidTestPsyPartialUpdate);
    User::After(1000000);
    TPositionInfo positionInfoPartial = TPositionInfo();
    TPositionUpdateOptions updateOption = TPositionUpdateOptions();
    updateOption.SetAcceptPartialUpdates(ETrue);
    positioner1.SetUpdateOptions(updateOption);

    positioner1.NotifyPositionUpdate(positionInfoPartial, status);
    User::WaitForRequest(status);
    err = status.Int();
    _LIT(KErrPositionPartial, "no partial position returned %d");
    AssertTrueL(err == KPositionPartialUpdate, KErrPositionPartial, err);

    positioner.GetLastKnownPosition(positionInfoLast, status);
    User::WaitForRequest(status);
    err = status.Int();
    AssertTrueL(err == KErrNone, KErrorRequest, err);
    
    TPosition pos;
    TPosition lastPos;
	positionInfoPartial.GetPosition(pos);
    positionInfoLast.GetPosition(lastPos);
    
    if (pos.Time() == lastPos.Time())
		{
		_LIT(KErrPosition, "Partial position was cached");
		LogErrorAndLeaveL(KErrPosition);
		}

    CleanupStack::PopAndDestroy(&positioner1);
    CleanupStack::PopAndDestroy(&posServer1);
    CleanupStack::PopAndDestroy(&positioner);
    CleanupStack::PopAndDestroy(&posServer);

    }

// ---------------------------------------------------------
// CT_LbsClientPosTp254::DeleteFileL
//
// (other items were commented in a header).
// ---------------------------------------------------------
//
void CT_LbsClientPosTp254::DeleteFileL(const TDesC& aFile)
    {
    RFs fs;
    TInt err = fs.Connect();

    err = fs.Delete(aFile);
    fs.Close();
    if (err == KErrNone)
        {
        _LIT(KDebugText, "TP254: The specified file deleted");
        INFO_PRINTF1(KDebugText);
        }
    else
        {
        if (err == KErrInUse)
            {
            _LIT(KErrText, "TP254: The specified file could not be deleted it is already in use, errorcode %d");
            INFO_PRINTF1(aFile);
            TBuf<100> buf;
            buf.Format(KErrText, err);
            AssertTrueL(err==0, KErrText, err);
            }
        else if (err == KErrNotFound)
            {
            _LIT(KDebugText, "TP254: The specified file could not be found ,errorcode %d");
            TBuf<100> buf;
            buf.Format(KDebugText, err);
            INFO_PRINTF1(buf);
            }
        else
            {
            _LIT(KErrText, "TP254: The specified file could not be deleted, errorcode %d");
            TBuf<100> buf;
            buf.Format(KErrText, err);
            AssertTrueL(err==0, KErrText, err);
            }
        }
    }

// ---------------------------------------------------------
// CT_LbsClientPosTp254::FileExistsL
//
// (other items were commented in a header).
// ---------------------------------------------------------
//
TBool CT_LbsClientPosTp254::FileExistsL(const TDesC& aFile)
    {
    RFs fs;
    TInt err = fs.Connect();
    TBool exists = EFalse;
    
    if(KErrNone==err)
    	{
    	exists = BaflUtils::FileExists(fs, aFile);
    	if (exists)
    		{
    		_LIT(KErrText, "TP254: The specified file does not exist");
    		INFO_PRINTF1(KErrText);
    		}
    	else
    		{
    		_LIT(KErrText, "TP254: The specified file exists");
    		INFO_PRINTF1(KErrText);
    		}
    	}
    
    fs.Close();
    return exists;
    }

void CT_LbsClientPosTp254::CheckPositionInfoL(TPositionInfo& aInfo, TPositionInfo& aLastInfo)
	{
    if (aInfo.UpdateType() != aLastInfo.UpdateType())
        {
        _LIT(KErrUpdateType, "Update type not stored correctly");
        LogErrorAndLeaveL(KErrUpdateType);
        }
    if (aLastInfo.ModuleId().iUid != 0)
		{
		_LIT(KIncorrectPsyError,
           "Uid not reseted");
		LogErrorAndLeaveL(KIncorrectPsyError);
		}
	TPosition pos;
    TPosition lastPos;
	aInfo.GetPosition(pos);
    aLastInfo.GetPosition(lastPos);
	CheckPositionL(pos, lastPos);
	}

void CT_LbsClientPosTp254::CheckPositionL(TPosition& aPos, TPosition& aLastPos)
	{
	if (aPos.Time() != aLastPos.Time() ||
		aPos.HorizontalAccuracy() != aLastPos.HorizontalAccuracy() ||
		aPos.VerticalAccuracy() != aLastPos.VerticalAccuracy() ||
		aPos.Latitude() != aLastPos.Latitude() ||
		aPos.Longitude() != aLastPos.Longitude() ||
		aPos.Altitude() != aLastPos.Altitude())
		{
		_LIT(KErrPosition, "Wrong position returned");
		LogErrorAndLeaveL(KErrPosition);
		}
	}

// End of File