loggingservices/eventlogger/test/src/t_logcontact.cpp
changeset 0 08ec8eefde2f
child 11 667e88a979d7
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/loggingservices/eventlogger/test/src/t_logcontact.cpp	Fri Jan 22 11:06:30 2010 +0200
@@ -0,0 +1,175 @@
+// Copyright (c) 2002-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 <logview.h>
+#include "TEST.H"
+
+
+#undef test  //there is a "test" macro which hides "RTest test" declaration.
+
+RTest test(_L("Contact Test Harness"));
+
+/**
+@SYMTestCaseID          SYSLIB-LOGENG-CT-1018
+@SYMTestCaseDesc	    Tests for backup operations
+@SYMTestPriority 	    High
+@SYMTestActions  	    Check by adding events and closing the backup file.
+                        Check for ErrNone flag. 
+@SYMTestExpectedResults Test must not fail
+@SYMREQ                 REQ0000
+*/
+static void TestBackupL(CLogClient& aClient)
+	{
+	test.Next(_L(" @SYMTestCaseID:SYSLIB-LOGENG-CT-1018 "));
+	CTestActive* active = new (ELeave) CTestActive;
+	CleanupStack::PushL(active);
+
+	CLogEvent* event = CLogEvent::NewL();
+	CleanupStack::PushL(event);
+	event->SetEventType(KLogCallEventTypeUid);
+
+   	CBaBackupSessionWrapper* backup = CBaBackupSessionWrapper::NewL();
+   	CleanupStack::PushL(backup);
+
+	// Add event
+	active->StartL();
+	aClient.AddEvent(*event, active->iStatus);
+	CActiveScheduler::Start();
+	TEST2(active->iStatus.Int(), KErrNone);
+
+	TDriveUnit driveUnit(EDriveC);
+	TDriveName name = driveUnit.Name();
+
+	TParse parse;
+	LEAVE_IF_ERROR(parse.Set(KLogDatabaseName, &name, NULL));
+
+	//Close, then delete LogEng database file. Restart backup operations monitoring
+	//on LogEng database.
+    backup->CloseFileL(parse.FullName(), MBackupObserver::EReleaseLockNoAccess);
+ 	User::After(1000000);
+	TestUtils::DeleteDatabaseL(EFalse);
+	backup->RestartFile(parse.FullName());
+ 	User::After(1000000);
+
+	// Add event
+	active->StartL();
+	aClient.AddEvent(*event, active->iStatus);
+	CActiveScheduler::Start();
+	TEST2(active->iStatus.Int(), KErrNone);
+
+	// Add event
+	active->StartL();
+	aClient.AddEvent(*event, active->iStatus);
+	CActiveScheduler::Start();
+	TEST2(active->iStatus.Int(), KErrNone);
+
+	//Close LogEng database file
+	backup->CloseFileL(parse.FullName(), MBackupObserver::EReleaseLockNoAccess);
+	//Delete LogEng database file
+ 	User::After(1000000);
+	TestUtils::DeleteDatabaseL(EFalse);
+	//Restart backup operations monitoring on LogEng database.
+	backup->RestartFile(parse.FullName());
+	User::After(1000000);
+
+	// Add event
+	active->StartL();
+	aClient.AddEvent(*event, active->iStatus);
+	CActiveScheduler::Start();
+	TEST2(active->iStatus.Int(), KErrNone);
+	
+	//Close LogEng database file.
+	backup->CloseFileL(parse.FullName(), MBackupObserver::EReleaseLockNoAccess);
+	//Delete LogEng database file.
+ 	User::After(1000000);
+	TestUtils::DeleteDatabaseL(EFalse);
+	//Restart backup operations monitoring on LogEng database.
+	backup->RestartFile(parse.FullName());
+	User::After(1000000);
+
+	// Add event
+	active->StartL();
+	aClient.AddEvent(*event, active->iStatus);
+	CActiveScheduler::Start();
+	TEST2(active->iStatus.Int(), KErrNone);
+
+	//Close LogEng database
+	backup->CloseFileL(parse.FullName(), MBackupObserver::EReleaseLockNoAccess);
+ 	User::After(1000000);
+ 	//Delete LogEng database
+	TestUtils::DeleteDatabaseL(EFalse);
+	//Restart backup operations monitoring on LogEng database.
+	backup->RestartFile(parse.FullName());
+
+	// Add event
+	active->StartL();
+	aClient.AddEvent(*event, active->iStatus);
+	CActiveScheduler::Start();
+	TEST2(active->iStatus.Int(), KErrNone);
+	//Close LogEng database
+	backup->CloseFileL(parse.FullName(), MBackupObserver::EReleaseLockNoAccess);
+	User::After(1000000);
+ 	//Delete LogEng database
+	TestUtils::DeleteDatabaseL(EFalse);
+	//Restart backup operations monitoring on LogEng database.
+	backup->RestartFile(parse.FullName());
+	User::After(1000000);
+
+	// Add event
+	active->StartL();
+	aClient.AddEvent(*event, active->iStatus);
+	CActiveScheduler::Start();
+	TEST2(active->iStatus.Int(), KErrNone);
+
+	active->StartL();
+	backup->CloseAll(MBackupObserver::EReleaseLockNoAccess, active->iStatus);
+	CActiveScheduler::Start();
+	TEST2(active->iStatus.Int(), KErrNone);
+ 	User::After(1000000);
+
+	TestUtils::DeleteDatabaseL(EFalse);
+	backup->RestartAll();
+ 	User::After(1000000);
+
+	// Add event
+	active->StartL();
+	aClient.AddEvent(*event, active->iStatus);
+	CActiveScheduler::Start();
+	TEST2(active->iStatus.Int(), KErrNone);
+
+	CleanupStack::PopAndDestroy(3); // backup, event, active
+	}
+	
+
+void doTestsL()
+	{
+	TestUtils::Initialize(_L("T_LOGCONTACT"));
+
+	test.Start(_L("Prepare the test environment"));
+	
+	// Create log client
+	CLogClient* client = CLogClient::NewL(theFs);
+	CleanupStack::PushL(client);
+
+	// Send a message to the hicap helper to delete logeng DB 
+	TestUtils::DeleteDatabaseL();
+			
+	test.Next(_L("Backup"));
+	TestBackupL(*client);
+	test.Next(_L("Backup completed ok"));
+	theLog.Write(_L8("Test 2 OK\n"));
+	
+	CleanupStack::PopAndDestroy(client);
+	}