applayerpluginsandutils/bookmarksupport/test/Integration/TestBookmarksSuite/TestUpdateVisitedStep.cpp
author Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
Mon, 15 Mar 2010 12:42:40 +0200
branchRCL_3
changeset 8 fa2fd8b2d6cc
parent 0 b16258d2340f
permissions -rw-r--r--
Revision: 201009 Kit: 201010

// Copyright (c) 2005-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:
// Contains implementation of CTestUpdateVisitedStep class
// 
//

/**
 @file
 @internalTechnology 
*/

// System Include
#include <bookmarkdatabase.h>

// User Include
#include "TestUpdateVisitedStep.h"

/**
Constructor. Sets the test step name
@internalTechnology
@test
*/
CTestUpdateVisitedStep::CTestUpdateVisitedStep(CTestBookmarksServer& aTestServer) : CTestBookmarksBaseStep(aTestServer)
	{
	//Call base class method to set human readable name for test step
	SetTestStepName(KTestUpdateVisitedStep);
	}


/**
Base class pure virtual.
@internalTechnology
@test
@param		None
@return		EPass or EFail indicating the result of the test step.
*/
TVerdict CTestUpdateVisitedStep::doTestStepL()
	{
	TInt error = KErrNone;
	RBkFolder parentFolder;
	if ((error = GetParentFolder(KMainTestFolder(), parentFolder)) != KErrNone)
		{
		ERR_PRINTF3(_L("Error %D occured while opening parent folder %S"), error, &(KMainTestFolder()));
		SetTestStepResult(EFail);
		}
	else
		{
		CleanupClosePushL(parentFolder);
		RBkBookmark bookmark = iBkDb.CreateBookmarkL(&parentFolder);
		CleanupClosePushL(bookmark);
		DoTest(bookmark);
		DoTest(bookmark);
		iBkDb.DeleteItemL(bookmark.Id());
		CleanupStack::PopAndDestroy(2, &parentFolder);
		}
	return TestStepResult();
	}	// doTestStepL

/**
Tests UpdateVisited() API
@internalTechnology
@test
@param		Reference to handle to the bookmark that is under test
@return		None
*/
void CTestUpdateVisitedStep::DoTest(RBkBookmark& aBookmark)
	{
	const TInt KOneSecond = 1000000;
	TTime initialTime;
	// Set the time to universal time
	initialTime.UniversalTime();
	INFO_PRINTF2(_L("Current time before updating = %Ld"), initialTime.Int64());
	INFO_PRINTF1(_L("Updating LastVisited..."));

	// Call updatevisited after one second
	User::After(KOneSecond);
	aBookmark.UpdateVisited();
	TTime lastVisitedTime = aBookmark.LastVisited();
	INFO_PRINTF2(_L("LastVisitedTime after updating = %Ld"), lastVisitedTime.Int64());

	// Check whether last visited is greater than the initial time
	if(lastVisitedTime <= initialTime)
		{
		INFO_PRINTF1(_L("LastVisited was not updated properly"));
		SetTestStepResult(EFail);
		}
	else
		{
		INFO_PRINTF1(_L("LastVisited was updated properly"));
		}
	}	// DoTest