diff -r 000000000000 -r b16258d2340f applayerpluginsandutils/bookmarksupport/test/Integration/TestBookmarksSuite/TestUpdateVisitedStep.cpp --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/applayerpluginsandutils/bookmarksupport/test/Integration/TestBookmarksSuite/TestUpdateVisitedStep.cpp Tue Feb 02 01:09:52 2010 +0200 @@ -0,0 +1,104 @@ +// 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 + +// 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 + +