tzservices/tzserver/test/component/t_databaseupdate.cpp
changeset 0 2e3d3ce01487
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/tzservices/tzserver/test/component/t_databaseupdate.cpp	Tue Feb 02 10:12:00 2010 +0200
@@ -0,0 +1,217 @@
+// 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:
+//
+
+#include <e32test.h>
+#include "testserver.h"
+#include <vtzrules.h>
+
+_LIT8(KEuropeLondon, "Europe/London");
+_LIT8(KEuropeParis, "Europe/Paris");
+_LIT(KTzDatabaseToBeCopied, "z:\\testresourcefiles\\tzdb.dbz");
+_LIT(KTzDatabaseCopiedToFlash, "c:\\private\\1020383e\\tzdb.dbz");
+_LIT(KTzDatabaseToBeDeleted, "c:\\private\\1020383e\\tzdb.dbz");
+
+RTest test (_L("t_databaseupdate"));
+
+/**
+@SYMTestCaseID      PIM-APPSERV-TZ-TZS-ECL-0001
+@SYMTestCaseDesc    The purpose of this test is to verify the use of eclipsed system
+					TZ rules database.  
+@SYMTestActions     1.	Use the RTz API to obtain a copy of the first TZ rule (preUpdateRule)
+						for a given time zone.
+					2.	Copy a system TZ rules database that modifies the TZ rule obtained in 
+						action 1 to the appropriate location the C: drive.
+					3.	Use the RTz API to obtain a copy of the first TZ rule (postUpdateRule) 
+						for the same time zone used in action 2.
+
+@SYMTestExpectedResults     The preUpdateRule object is not the same as the postUpdateRule object.
+@SYMREQ                     REQ9952
+@SYMTestType                CT
+@SYMTestPriority            1
+*/
+LOCAL_C void TestRulesInTzDatabaseL()
+    {
+   	RTz tz;
+  	CleanupClosePushL(tz);
+  	User::LeaveIfError(tz.Connect());
+    	
+  	CTzId* tzId = CTzId::NewL(KEuropeLondon);
+  	CleanupStack::PushL(tzId);
+  	tz.SetTimeZoneL(*tzId);
+  	
+  	TDateTime startDateTime(2008,EJanuary,0,0,0,0,0);
+	TDateTime endDateTime(2008,EDecember,30,23,59,59,0);
+   	CTzRules* tzRules = tz.GetTimeZoneRulesL(*tzId,startDateTime,endDateTime,ETzUtcTimeReference);
+  	CleanupStack::PushL(tzRules);
+    	
+   	TInt count = tzRules->Count();
+	test.Printf(_L(" @SYMTestCaseID PIM-APPSERV-TZ-TZS-ECL-0001"));
+   	test.Printf(_L("The number of rules found in default database are %d\n"), count);
+  	
+   	CleanupStack::PopAndDestroy(tzRules);
+    tz.Close();
+  	
+   	RPIMTestServer serv;	
+	CleanupClosePushL(serv);
+	TInt err = serv.Connect();
+	if (err != KErrNone)
+		{
+		_LIT(KErrTestServerConnection, "Couldn't connect to PIMTestServer\n");
+		test.Printf(KErrTestServerConnection);
+		User::Leave(err);
+		}
+	TRAP(err, serv.CopyFileL(KTzDatabaseToBeCopied, KTzDatabaseCopiedToFlash));
+	if (err != KErrNone)
+		{
+		_LIT(KErrCopyFiles, "Couldn't copy database file\n");
+		test.Printf(KErrCopyFiles);
+		User::Leave(err);
+		}
+
+	User::LeaveIfError(tz.Connect());
+	
+	CTzId* parisId = CTzId::NewL(KEuropeParis);
+	CleanupStack::PushL(parisId);
+	tz.SetTimeZoneL(*parisId);
+	CleanupStack::PopAndDestroy(parisId);
+  	
+ 	tz.SetTimeZoneL(*tzId);
+  	CTzRules* tzRulesFlash = tz.GetTimeZoneRulesL(*tzId,startDateTime,endDateTime,ETzUtcTimeReference);
+  	CleanupStack::PushL(tzRulesFlash);
+   	  	
+   	TInt countFlash = tzRulesFlash->Count();
+  	test.Printf(_L("The number of rules found in the database on flash are %d\n"), countFlash);
+  		
+  	test(count != countFlash);
+	
+	serv.DeleteFileL(KTzDatabaseToBeDeleted);
+	tz.SwiObsBeginL();
+	tz.SwiObsFileChangedL(RTz::EFilterTzPrivate);
+	tz.SwiObsEndL();
+	
+	CleanupStack::PopAndDestroy(tzRulesFlash);
+	CleanupStack::PopAndDestroy(&serv);   	
+  	CleanupStack::PopAndDestroy(tzId);
+   	CleanupStack::PopAndDestroy(&tz);    	   	
+	}
+
+/**
+@SYMTestCaseID      PIM-DATABASEUPDATE-0001
+@SYMTestCaseDesc    The purpose of this test is to verify that eclipsing is taken into account
+					even if the time zone server is running.  
+@SYMTestActions     1.	Use the RTz API to obtain a copy of the first TZ rule (preUpdateRule)
+						for a given time zone.
+					2.	Copy a system TZ rules database that modifies the TZ rule obtained in 
+						action 1 to the appropriate location the C: drive. The server is still
+						running when this happens.
+					3.	Use the RTz API to obtain a copy of the first TZ rule (postUpdateRule) 
+						for the same time zone used in action 2.
+
+@SYMTestExpectedResults     The preUpdateRule object is not the same as the postUpdateRule object.
+@SYMREQ                     REQ9952
+@SYMTestType                CT
+@SYMTestPriority            1
+*/
+LOCAL_C void TestRulesInTzDatabaseLiveUpdateL()
+    {
+    RTz tz;
+  	CleanupClosePushL(tz);
+  	User::LeaveIfError(tz.Connect());
+  	
+  	CTzId* tzId = CTzId::NewL(KEuropeLondon);
+  	CleanupStack::PushL(tzId);
+  	tz.SetTimeZoneL(*tzId);
+  	
+  	TDateTime startDateTime(2008,EJanuary,0,0,0,0,0);
+	TDateTime endDateTime(2008,EDecember,30,23,59,59,0);
+   	CTzRules* tzRules = tz.GetTimeZoneRulesL(*tzId,startDateTime,endDateTime,ETzUtcTimeReference);
+  	CleanupStack::PushL(tzRules);
+    TInt count = tzRules->Count();
+   	test.Printf(_L("The number of rules found in default database are %d\n"), count);
+  	CleanupStack::PopAndDestroy(tzRules);
+  	
+  	RPIMTestServer serv;	
+	CleanupClosePushL(serv);
+	TInt err = serv.Connect();
+	if (err != KErrNone)
+		{
+		_LIT(KErrTestServerConnection, "Couldn't connect to PIMTestServer\n");
+		test.Printf(KErrTestServerConnection);
+		User::Leave(err);
+		}
+	TRAP(err, serv.CopyFileL(KTzDatabaseToBeCopied, KTzDatabaseCopiedToFlash));
+	if (err != KErrNone)
+		{
+		_LIT(KErrCopyFiles, "Couldn't copy database file\n");
+		test.Printf(KErrCopyFiles);
+		User::Leave(err);
+		}
+	tz.SwiObsBeginL();
+	tz.SwiObsFileChangedL(RTz::EFilterTzPrivate);
+	tz.SwiObsEndL();
+   	
+	CTzRules* tzRulesFlash = tz.GetTimeZoneRulesL(*tzId,startDateTime,endDateTime,ETzUtcTimeReference);
+  	CleanupStack::PushL(tzRulesFlash);
+   	  	
+   	TInt countFlash = tzRulesFlash->Count();
+	test.Printf(_L(" @SYMTestCaseID PIM-DATABASEUPDATE-0001 "));
+  	test.Printf(_L("The number of rules found in the database on flash are %d\n"), countFlash);
+  		
+  	test(count != countFlash);
+	
+	serv.DeleteFileL(KTzDatabaseToBeDeleted);
+	
+	CleanupStack::PopAndDestroy(tzRulesFlash);
+	CleanupStack::PopAndDestroy(&serv);   	
+  	CleanupStack::PopAndDestroy(tzId);
+	CleanupStack::PopAndDestroy(&tz);    	
+    }
+
+LOCAL_C void DoStartL()
+	{
+	CActiveScheduler* scheduler = new (ELeave) CActiveScheduler();
+	CleanupStack::PushL(scheduler);
+	
+	CActiveScheduler::Install(scheduler);
+
+	TestRulesInTzDatabaseL();
+	TestRulesInTzDatabaseLiveUpdateL();
+	
+	// Delete active scheduler
+	CleanupStack::PopAndDestroy(scheduler);	
+	}
+
+//  Global Functions
+	
+	
+GLDEF_C TInt E32Main()
+	{
+	// Create cleanup stack
+	__UHEAP_MARK;
+	test.Start(_L("Starting Test t_databaseupdate"));
+	CTrapCleanup* cleanup = CTrapCleanup::New();
+
+	// Run application code inside TRAP harness.
+	TRAPD(mainError, DoStartL());
+	
+	test(mainError == KErrNone);
+	
+	delete cleanup;
+	test.End();
+	test.Close();
+	__UHEAP_MARKEND;
+	return KErrNone;
+	}
+