loggingservices/eventlogger/test/src/t_logcompat.cpp
author hgs
Tue, 19 Oct 2010 16:26:13 +0100
changeset 55 44f437012c90
parent 31 ba1c4f4a893f
child 45 cc28652e0254
permissions -rw-r--r--
201041_01

// Copyright (c) 2009-2010 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:
// t_logcompat.cpp - verification that old databases without SimId column in Event table can be opened
//                   and events added, viewed, etc.  
// 
//
#include <s32file.h>
#include <s32mem.h>
#include <e32math.h>
#include <bautils.h>
#include <logview.h>
#include "t_logutil2.h"

RTest TheTest(_L("t_logcompat"));

#ifdef SYMBIAN_ENABLE_EVENTLOGGER_DUALSIM	

// These values are stored in "oldLogdb.dat"
_LIT(KEventNum1, "00000");
_LIT(KEventNum2, "11111");
_LIT(KEventNum3, "22222");
_LIT(KEventNum4, "012345678901234567");
const TLogId KEventId1 = 0;
const TLogId KEventId2 = 1;
const TLogId KEventId3 = 2;
const TLogId KEventId4 = 3;

//New events, added by this test
_LIT(KEventNum5, "123411119");
_LIT(KEventNum6, "999911221");
TLogId TheEventId5 = KLogNullId;
TLogId TheEventId6 = KLogNullId;

//Stored events properties
_LIT(KTestEventDesc1, "Event Type Description");
_LIT(KTestRemoteParty1, "Remote Party");
_LIT(KTestDirection1, "Direction");
_LIT(KTestStatus1, "Status");
_LIT(KTestSubject1, "Subject");
const TUid KTestEventUid = {0x10005393};
const TLogDurationType KTestDurationType1 = 1;
const TLogDuration KTestDuration1 = 0x1234;
const TLogContactItemId KTestContact1 = 0x1234;
const TLogLink KTestLink1 = 0x1234;
_LIT8(KTestData1, "ABCDEFGH");
const TLogFlags KTestFlags1 = 0x5;

//Sim Ids used by the test
const TSimId KSimId1 = 1;
const TSimId KSimId3 = 3900100200U;

void CheckEventProperties(CLogEvent& aEvent, TLogId aEventId, const TDesC& aEventNumber, TSimId aSimId)
	{
	TEST(aEvent.Id() == aEventId);
	TEST(aEvent.Time() > TTime(0));
	TEST(aEvent.Description() == KTestEventDesc1);
	TEST(aEvent.EventType() == KTestEventUid);
	TEST(aEvent.RemoteParty() == KTestRemoteParty1);
	TEST(aEvent.Direction() == KTestDirection1);
	TEST(aEvent.DurationType() == KTestDurationType1);
	TEST(aEvent.Duration() == KTestDuration1);
	TEST(aEvent.Status() == KTestStatus1);
	TEST(aEvent.Subject() == KTestSubject1);
	TEST(aEvent.Contact() == KTestContact1);
	TEST(aEvent.Link() == KTestLink1);
	TEST(aEvent.Data() == KTestData1);
	TEST(aEvent.Flags() == KTestFlags1);
	TEST(aEvent.Number() == aEventNumber);
	TEST(aEvent.SimId() == aSimId);
	TPtrC eventStatus = aEvent.Subject();
	TPtrC eventNumber = aEvent.Number();
	TheTest.Printf(_L("Id:%d No:%S Sub:%S Contact Id:0x%x SimId:%u\n"), aEvent.Id(), &eventNumber, &eventStatus, aEvent.Contact(), aEvent.SimId());
	}

void DoGetEventTestL(TLogId aEventId, const TDesC& aEventNumber, TSimId aSimId, CTestActive& aActive, CLogClient& aLogClient)
	{
	CLogEvent* event = CLogEvent::NewL();
	CleanupStack::PushL(event);

	// set the id of the event to be fetched
	event->SetId(aEventId);

	aActive.StartL();
	aLogClient.GetEvent(*event, aActive.iStatus);
	CActiveScheduler::Start();
	TEST2(aActive.iStatus.Int(), KErrNone);
	
	CheckEventProperties(*event, aEventId, aEventNumber, aSimId);
	
	CleanupStack::PopAndDestroy(event);
	}

void DoChangeEventTestL(TLogId aEventId, const TDesC& aEventNumber, TSimId aSimId, CTestActive& aActive, CLogClient& aLogClient)
	{
	CLogEvent* event = CLogEvent::NewL();
	CleanupStack::PushL(event);

	//Retrieve the event.
	event->SetId(aEventId);
	aActive.StartL();
	aLogClient.GetEvent(*event, aActive.iStatus);
	CActiveScheduler::Start();
	TEST2(aActive.iStatus.Int(), KErrNone);
	CheckEventProperties(*event, aEventId, aEventNumber, KLogNullSimId);
	//Change event's SimId.
	event->SetSimId(aSimId);
	aActive.StartL();
	aLogClient.ChangeEvent(*event, aActive.iStatus);
	CActiveScheduler::Start();
	TEST2(aActive.iStatus.Int(), KErrNone);
	CheckEventProperties(*event, aEventId, aEventNumber, aSimId);
	
	CleanupStack::PopAndDestroy(event);
	}

TInt DoAddEventTestL(const TDesC& aEventNumber, TSimId aSimId, CTestActive& aActive, CLogClient& aLogClient)
	{
	CLogEvent* event = CLogEvent::NewL();
	CleanupStack::PushL(event);

	TTime now;
	now.UniversalTime();
	
	event->SetEventType(KTestEventUid);
	event->SetRemoteParty(KTestRemoteParty1);
	event->SetDirection(KTestDirection1);
	event->SetDurationType(KTestDurationType1);
	event->SetDuration(KTestDuration1);
	event->SetStatus(KTestStatus1);
	event->SetSubject(KTestSubject1);
	event->SetNumber(aEventNumber);
	event->SetContact(KTestContact1);
	event->SetLink(KTestLink1);
	event->SetDataL(KTestData1);
	event->SetFlags(KTestFlags1);
	if(aSimId != KLogNullSimId)
		{
		event->SetSimId(aSimId);
		}

	aActive.StartL();
	aLogClient.AddEvent(*event, aActive.iStatus);
	CActiveScheduler::Start();
	TEST(!aActive.IsActive());
	TEST2(aActive.iStatus.Int(), KErrNone);
	
	TLogId eventId = event->Id();
	TEST(eventId != KLogNullId);
	TEST(event->Time() >= now);
	
	CleanupStack::PopAndDestroy(event);
	return eventId;
	}

/**
@SYMTestCaseID			PDS-LOGENG-UT-4018
@SYMTestCaseDesc		Retrieving events from a database without "SimId" column in the "Event" table.
						The test uses the OldLogdbu.dat database, created before introducing the new 
						"SimId" column. The test checks that the events in the database can be accessed and 
						retrieved. The event's SimID property value should be 0.
@SYMTestActions			Retrieving events from a database without "SimId" column in the "Event" table.
@SYMTestExpectedResults Test must not fail
@SYMTestPriority		Medium
@SYMREQ					REQ12746
*/
void GetEventTestL()
	{
	CLogClient* client = CLogClient::NewL(theFs);
	CleanupStack::PushL(client);
	
	CTestActive* active = new(ELeave)CTestActive();
	CleanupStack::PushL(active);

	DoGetEventTestL(KEventId1, KEventNum1, KLogNullSimId, *active, *client);
	DoGetEventTestL(KEventId2, KEventNum2, KLogNullSimId, *active, *client);
	DoGetEventTestL(KEventId3, KEventNum3, KLogNullSimId, *active, *client);
	DoGetEventTestL(KEventId4, KEventNum4, KLogNullSimId, *active, *client);

	CleanupStack::PopAndDestroy(active);
	CleanupStack::PopAndDestroy(client);
	}

/**
@SYMTestCaseID			PDS-LOGENG-UT-4019
@SYMTestCaseDesc		Changing events from a database without "SimId" column in the "Event" table.
						The test uses the OldLogdbu.dat database, created before introducing the new 
						"SimId" column. The test checks that the events in the database can be accessed and 
						retrieved. After that the test changes some of the events, updating events properties
						with a non-zero SimId. The test checks that the updated event really got its SimId 
						property value changed.
@SYMTestActions			Changing events from a database without "SimId" column in the "Event" table.
@SYMTestExpectedResults Test must not fail
@SYMTestPriority		Medium
@SYMREQ					REQ12746
*/
void ChangeEventTestL()
	{
	CLogClient* client = CLogClient::NewL(theFs);
	CleanupStack::PushL(client);
	
	CTestActive* active = new(ELeave)CTestActive();
	CleanupStack::PushL(active);
	
	//Change two of the events
	DoChangeEventTestL(KEventId1, KEventNum1, KSimId1, *active, *client);
	DoChangeEventTestL(KEventId3, KEventNum3, KSimId3, *active, *client);
	//Check that the other two events are unchanged
	DoGetEventTestL(KEventId2, KEventNum2, KLogNullSimId, *active, *client);
	DoGetEventTestL(KEventId4, KEventNum4, KLogNullSimId, *active, *client);
	
	CleanupStack::PopAndDestroy(active);
	CleanupStack::PopAndDestroy(client);
	}

/**
@SYMTestCaseID			PDS-LOGENG-UT-4020
@SYMTestCaseDesc		Add events to a database without "SimId" column in the "Event" table.
						The test uses the OldLogdbu.dat database, created before introducing the new 
						"SimId" column. The test adds two events to the database, then checks that the
						events can be accessed and retrieved.
@SYMTestActions			Add events to a database without "SimId" column in the "Event" table.
@SYMTestExpectedResults Test must not fail
@SYMTestPriority		Medium
@SYMREQ					REQ12746
*/
void AddEventTestL()
	{
	CLogClient* client = CLogClient::NewL(theFs);
	CleanupStack::PushL(client);
	
	CTestActive* active = new(ELeave)CTestActive();
	CleanupStack::PushL(active);
	
	//Add an event without SimId
	TheEventId5 = DoAddEventTestL(KEventNum5, KLogNullSimId, *active, *client);
	//Add an event with SimId
	TheEventId6 = DoAddEventTestL(KEventNum6, KSimId1, *active, *client);
	//Check that the other 4 events are unchanged
	DoGetEventTestL(KEventId1, KEventNum1, KSimId1, *active, *client);//KSimId1 - set by ChangeEventTestL() 
	DoGetEventTestL(KEventId2, KEventNum2, KLogNullSimId, *active, *client);
	DoGetEventTestL(KEventId3, KEventNum3, KSimId3, *active, *client);//KSimId3 - set by ChangeEventTestL()
	DoGetEventTestL(KEventId4, KEventNum4, KLogNullSimId, *active, *client);
	//Check the first added event
	DoGetEventTestL(TheEventId5, KEventNum5, KLogNullSimId, *active, *client);
	//Check the second added event
	DoGetEventTestL(TheEventId6, KEventNum6, KSimId1, *active, *client);
	
	CleanupStack::PopAndDestroy(active);
	CleanupStack::PopAndDestroy(client);
	}

/**
@SYMTestCaseID			PDS-LOGENG-UT-4021
@SYMTestCaseDesc		Delete events from a database without "SimId" column in the "Event" table.
						The test uses the OldLogdbu.dat database, created before introducing the new 
						"SimId" column. The test deletes an event from the database and checks then that
						the other events are intact, the deleted event is really deleted.
@SYMTestActions			Delete events from a database without "SimId" column in the "Event" table.
@SYMTestExpectedResults Test must not fail
@SYMTestPriority		Medium
@SYMREQ					REQ12746
*/
void DeleteEventTestL()
	{
	CLogClient* client = CLogClient::NewL(theFs);
	CleanupStack::PushL(client);
	
	CTestActive* active = new(ELeave)CTestActive();
	CleanupStack::PushL(active);

	//Delete an event
	active->StartL();
	client->DeleteEvent(KEventId2, active->iStatus);
	CActiveScheduler::Start();
	TEST(!active->IsActive());
	TEST2(active->iStatus.Int(), KErrNone);
	
	//Check that the other 5 events are unchanged
	DoGetEventTestL(KEventId1, KEventNum1, KSimId1, *active, *client);//KSimId1 - set by ChangeEventTestL()
	DoGetEventTestL(KEventId3, KEventNum3, KSimId3, *active, *client);//KSimId3 - set by ChangeEventTestL()
	DoGetEventTestL(KEventId4, KEventNum4, KLogNullSimId, *active, *client);
	DoGetEventTestL(TheEventId5, KEventNum5, KLogNullSimId, *active, *client);
	DoGetEventTestL(TheEventId6, KEventNum6, KSimId1, *active, *client);
	
	//Check that event 2 was really deleted
	CLogEvent* event = CLogEvent::NewL();
	CleanupStack::PushL(event);
	event->SetId(KEventId2);
	active->StartL();
	client->GetEvent(*event, active->iStatus);
	CActiveScheduler::Start();
	TEST2(active->iStatus.Int(), KErrNotFound);
	
	CleanupStack::PopAndDestroy(event);
	CleanupStack::PopAndDestroy(active);
	CleanupStack::PopAndDestroy(client);
	}

/**
@SYMTestCaseID			PDS-LOGENG-UT-4022
@SYMTestCaseDesc		Event View test with an old database (without SimId).
						The test uses the OldLogdbu.dat database, created before introducing the new 
						"SimId" column. The test creates an event view and iterates over the events in the view.
						The test checks that events without SimId property set can be retrieved.
@SYMTestActions			Event View test with an old database (without SimId).
@SYMTestExpectedResults Test must not fail
@SYMTestPriority		Medium
@SYMREQ					REQ12747
*/
void EventViewTestL()
	{
	CLogClient* client = CLogClient::NewL(theFs);
	CleanupStack::PushL(client);
	
	CTestActive* active = new(ELeave)CTestActive();
	CleanupStack::PushL(active);

	CLogViewChangeObserver* observer = CLogViewChangeObserver::NewLC();
	observer->SetActive();
	
	CLogViewEvent* view = CLogViewEvent::NewL(*client, *observer);
	CleanupStack::PushL(view);

	CLogFilter* filter = CLogFilter::NewL();
	CleanupStack::PushL(filter);
	TBool res = view->SetFilterL(*filter, active->iStatus);
	TEST(res);
	
	//SimId:                      KSimId1    KSimId3    KLogNullSimId  KLogNullSimId   KSimId1 
	const TLogId KLogEventIds[] ={KEventId1, KEventId3, KEventId4,  TheEventId5, TheEventId6};
	TBool logEventVisited[] =    {EFalse,    EFalse,    EFalse,     EFalse,      EFalse};
	const TInt KLogEventCnt = sizeof(KLogEventIds)/sizeof(KLogEventIds[0]); 

	do	{
		active->StartL();
		CActiveScheduler::Start();
		TEST2(active->iStatus.Int(), KErrNone);

		const TInt viewCount = view->CountL();
		TEST2(viewCount, KLogEventCnt);
		
		TInt eventId = view->Event().Id();
		TInt i = 0;
		for(;i<KLogEventCnt;++i)
			{
			if(KLogEventIds[i] == eventId)
				{
				break;
				}
			}
		TEST(i < KLogEventCnt);
		logEventVisited[i] = ETrue;
		}
	while(view->NextL(active->iStatus));

	//Check that all events were visited. 
	for(TInt i=0;i<KLogEventCnt;++i)
		{
		TEST(logEventVisited[i]);
		}
	
	CleanupStack::PopAndDestroy(filter);
	CleanupStack::PopAndDestroy(view);
	CleanupStack::PopAndDestroy(observer);
	CleanupStack::PopAndDestroy(active);
	CleanupStack::PopAndDestroy(client);
	}

/**
@SYMTestCaseID			PDS-LOGENG-UT-4023
@SYMTestCaseDesc		Event View test with an old database (without SimId).
						The test uses the OldLogdbu.dat database, created before introducing the new 
						"SimId" column. The test creates an event view and iterates over the events in the view.
						The test checks that events without SimId property set can be retrieved. The test is very
						similar to the EventViewTestL() test, except the fact that the filter filters out all events
						with non-zero SimId.
@SYMTestActions			Event View test with an old database (without SimId).
@SYMTestExpectedResults Test must not fail
@SYMTestPriority		Medium
@SYMREQ					REQ12747
*/
void EventViewTest2L()
	{
	CLogClient* client = CLogClient::NewL(theFs);
	CleanupStack::PushL(client);
	
	CTestActive* active = new(ELeave)CTestActive();
	CleanupStack::PushL(active);

	CLogViewChangeObserver* observer = CLogViewChangeObserver::NewLC();
	observer->SetActive();
	
	CLogViewEvent* view = CLogViewEvent::NewL(*client, *observer);
	CleanupStack::PushL(view);

	CLogFilter* filter = CLogFilter::NewL();
	CleanupStack::PushL(filter);
	filter->SetNullFields(ELogSimIdField);
	TBool res = view->SetFilterL(*filter, active->iStatus);
	TEST(res);
	
	//Only events KEventId4 and TheEventId5 are with zero SimId.
	const TLogId KLogEventIds[] ={KEventId4,  TheEventId5};
	TBool logEventVisited[] =    {EFalse,    EFalse};
	const TInt KLogEventCnt = sizeof(KLogEventIds)/sizeof(KLogEventIds[0]); 

	do	{
		active->StartL();
		CActiveScheduler::Start();
		TEST2(active->iStatus.Int(), KErrNone);

		const TInt viewCount = view->CountL();
		TEST2(viewCount, KLogEventCnt);
		
		TInt eventId = view->Event().Id();
		TInt i = 0;
		for(;i<KLogEventCnt;++i)
			{
			if(KLogEventIds[i] == eventId)
				{
				break;
				}
			}
		TEST(i < KLogEventCnt);
		logEventVisited[i] = ETrue;
		}
	while(view->NextL(active->iStatus));

	//Check that all events were visited. 
	for(TInt i=0;i<KLogEventCnt;++i)
		{
		TEST(logEventVisited[i]);
		}
	
	CleanupStack::PopAndDestroy(filter);
	CleanupStack::PopAndDestroy(view);
	CleanupStack::PopAndDestroy(observer);
	CleanupStack::PopAndDestroy(active);
	CleanupStack::PopAndDestroy(client);
	}

/**
@SYMTestCaseID			PDS-LOGENG-UT-4024
@SYMTestCaseDesc		Event View test with an old database (without SimId).
						The test uses the OldLogdbu.dat database, created before introducing the new 
						"SimId" column. The test creates an event view, sets a filter with a non-zero SimId 
						and iterates over the events in the view. It should be possible to view events with SimId
						set, when the database was created using the old format.
@SYMTestActions			Event View test with an old database (without SimId).
@SYMTestExpectedResults Test must not fail
@SYMTestPriority		Medium
@SYMREQ					REQ12747
*/
void EventViewTest3L()
	{
	CLogClient* client = CLogClient::NewL(theFs);
	CleanupStack::PushL(client);
	
	CTestActive* active = new(ELeave)CTestActive();
	CleanupStack::PushL(active);

	CLogViewChangeObserver* observer = CLogViewChangeObserver::NewLC();
	observer->SetActive();
	
	CLogViewEvent* view = CLogViewEvent::NewL(*client, *observer);
	CleanupStack::PushL(view);

	CLogFilter* filter = CLogFilter::NewL();
	CleanupStack::PushL(filter);
	filter->SetSimId(KSimId1);
	TSimId simId = filter->SimId();
	TEST2(simId, KSimId1);
	TBool res = view->SetFilterL(*filter, active->iStatus);
	TEST(res);
	
	//Only events KEventId1 and TheEventId6 are with KSimId1.
	const TLogId KLogEventIds[] ={KEventId1,  TheEventId6};
	TBool logEventVisited[] =    {EFalse,    EFalse};
	const TInt KLogEventCnt = sizeof(KLogEventIds)/sizeof(KLogEventIds[0]); 

	do	{
		active->StartL();
		CActiveScheduler::Start();
		TEST2(active->iStatus.Int(), KErrNone);

		const TInt viewCount = view->CountL();
		TEST2(viewCount, KLogEventCnt);
		
		TInt eventId = view->Event().Id();
		TInt i = 0;
		for(;i<KLogEventCnt;++i)
			{
			if(KLogEventIds[i] == eventId)
				{
				break;
				}
			}
		TEST(i < KLogEventCnt);
		logEventVisited[i] = ETrue;
		}
	while(view->NextL(active->iStatus));

	//Check that all events were visited. 
	for(TInt i=0;i<KLogEventCnt;++i)
		{
		TEST(logEventVisited[i]);
		}
	
	CleanupStack::PopAndDestroy(filter);
	CleanupStack::PopAndDestroy(view);
	CleanupStack::PopAndDestroy(observer);
	CleanupStack::PopAndDestroy(active);
	CleanupStack::PopAndDestroy(client);
	}

/**
@SYMTestCaseID			PDS-LOGENG-UT-4043
@SYMTestCaseDesc		CLogEvent - data compatibility test.
						The test uses data externalized from an event prior the "dual SIM support"
						changes were introduced. The test internalizes the event data and checks 
						that the data is interpreted correctly.
@SYMTestActions			CLogEvent - data compatibility test.
@SYMTestExpectedResults Test must not fail
@SYMTestPriority		Medium
@SYMREQ					REQ12746
*/
void EventDataTestL()
	{
	//Externalized to a buffer event data where the following property values have been set:
	// Id=1, Type=2, "RemoteParty", "Direction", "Data"
	//The used event format is before the "dual SIM support" changes were introduced.
	const TUint8 KEvtData1[] =
		//  0   1   2   3   4   5   6   7   8   9   A   B   C   D   E   F   
		{ 
		    1,  0,  0,  0,  2,  0,  0,  0,  0,  0,  0,  0,  0,  0,  0,  0,
		  255,  0,  0,  0,  0,255,255,255,255,  0,  0,  0,  0,  0,  0, 44,
		   82,101,109,111,116,101, 80, 97,114,116,121, 36, 68,105,114,101, 
		   99,116,105,111,110,  0,  0,  0,  4,  0,  0,  0, 18, 68, 97,116,
		   97
		};

	CLogEvent* evt1 = CLogEvent::NewL();
	CleanupStack::PushL(evt1);
	TPtrC8 ptr1(KEvtData1, sizeof(KEvtData1) / sizeof(KEvtData1[0]));
	RDesReadStream strm1(ptr1);
	strm1 >> *evt1;
	strm1.Close();
	TEST2(evt1->Id(), 1);
	TEST(evt1->EventType() == TUid::Uid(2));
	_LIT(KRemoteParty, "RemoteParty");
	TEST(evt1->RemoteParty() == KRemoteParty);
	_LIT(KDirection, "Direction");
	TEST(evt1->Direction() == KDirection);
	_LIT8(KData, "Data");
	TEST(evt1->Data() == KData);
	TEST(evt1->SimId() == KLogNullSimId);
	CleanupStack::PopAndDestroy(evt1);
	
	//Externalized to a buffer event data where the following property values have been set:
	// Id=3, Type=4, "RemoteParty2", "Direction2"
	//The used event format is before the "dual SIM support" changes were introduced.
	const TUint8 KEvtData2[] =
		//  0   1   2   3   4   5   6   7   8   9   A   B   C   D   E   F   
		{ 
		    3,  0,  0,  0,  4,  0,  0,  0,  0,  0,  0,  0,  0,  0,  0,  0,
		  255,  0,  0,  0,  0,255,255,255,255,  0,  0,  0,  0,  0,  0, 48,
		   82,101,109,111,116,101, 80, 97,114,116,121, 50, 40, 68,105,114, 
		  101, 99,116,105,111,110, 50,  0,  0,  0,  0,  0,  0,  0
		};

	CLogEvent* evt2 = CLogEvent::NewL();
	CleanupStack::PushL(evt2);
	TPtrC8 ptr2(KEvtData2, sizeof(KEvtData2) / sizeof(KEvtData2[0]));
	RDesReadStream strm2(ptr2);
	strm2 >> *evt2;
	strm2.Close();
	TEST2(evt2->Id(), 3);
	TEST(evt2->EventType() == TUid::Uid(4));
	_LIT(KRemoteParty2, "RemoteParty2");
	TEST(evt2->RemoteParty() == KRemoteParty2);
	_LIT(KDirection2, "Direction2");
	TEST(evt2->Direction() == KDirection2);
	TEST(evt2->SimId() == KLogNullSimId);
	CleanupStack::PopAndDestroy(evt2);
	}

/**
@SYMTestCaseID			PDS-LOGENG-UT-4046
@SYMTestCaseDesc		CLogClient::ClearLog() - data compatibility test.
						The test uses the OldLogdbu.dat database, created before introducing the new 
						"SimId" column. The test verifies that CLogClient::ClearLog() can work with 
						database with the old format. 
@SYMTestActions			CLogClient::ClearLog() - data compatibility test.
@SYMTestExpectedResults Test must not fail
@SYMTestPriority		Medium
@SYMREQ					REQ12748
*/
void ClearLogTestL()
	{
	CLogClient* client = CLogClient::NewL(theFs);
	CleanupStack::PushL(client);
	
	CTestActive* active = new(ELeave)CTestActive();
	CleanupStack::PushL(active);

	//Get one of the events
	CLogEvent* event = CLogEvent::NewL();
	CleanupStack::PushL(event);
	event->SetId(KEventId1);
	active->StartL();
	client->GetEvent(*event, active->iStatus);
	CActiveScheduler::Start();
	TEST2(active->iStatus.Int(), KErrNone);
	TTime evtTime = event->Time();
	CleanupStack::PopAndDestroy(event);
	event = NULL;
	
	//Delete all events with time < (evtTime + 1s). 
	evtTime += TTimeIntervalSeconds(1);
	active->StartL();
	client->ClearLog(evtTime, active->iStatus);
	CActiveScheduler::Start();
	TEST2(active->iStatus.Int(), KErrNone);

	//The event with time "evtTime" should not be in the log anymore.
	event = CLogEvent::NewL();
	CleanupStack::PushL(event);
	event->SetId(KEventId1);
	active->StartL();
	client->GetEvent(*event, active->iStatus);
	CActiveScheduler::Start();
	TEST2(active->iStatus.Int(), KErrNotFound);
	CleanupStack::PopAndDestroy(event);
	
	CleanupStack::PopAndDestroy(active);
	CleanupStack::PopAndDestroy(client);
	}

void doTestsL()
	{
    TestUtils::Initialize(_L("t_logcompat"));
	
#ifdef _DEBUG	
	TheTest.Start(_L("Copy the old LogEng database"));
	TestUtils::CopyOldDbL();
	//
	TheTest.Next(_L(" @SYMTestCaseID:PDS-LOGENG-UT-4018: \"Get Event\" compatibility test"));
	GetEventTestL();
	TheTest.Next(_L(" @SYMTestCaseID:PDS-LOGENG-UT-4019: \"Change Event\" compatibility test"));
	ChangeEventTestL();
	TheTest.Next(_L(" @SYMTestCaseID:PDS-LOGENG-UT-4020: \"Add Event\" compatibility test"));
	AddEventTestL();
	TheTest.Next(_L(" @SYMTestCaseID:PDS-LOGENG-UT-4021: \"Delete Event\" compatibility test"));
	DeleteEventTestL();
	TheTest.Next(_L(" @SYMTestCaseID:PDS-LOGENG-UT-4022: \"Event View\" compatibility test"));
	EventViewTestL();
	TheTest.Next(_L(" @SYMTestCaseID:PDS-LOGENG-UT-4023: \"Event View 2\" compatibility test"));
	EventViewTest2L();
	TheTest.Next(_L(" @SYMTestCaseID:PDS-LOGENG-UT-4024: \"Event View 3\" compatibility test"));
	EventViewTest3L();
	TheTest.Next(_L(" @SYMTestCaseID:PDS-LOGENG-UT-4043: \"CLogEvent data\" compatibility test"));
	EventDataTestL();
	TheTest.Next(_L(" @SYMTestCaseID:PDS-LOGENG-UT-4046: \"CLogClient::ClearLog()\" compatibility test"));
	ClearLogTestL();
	//
	TestUtils::DeleteDatabaseL();
#else
	TheTest.Start(_L("This test works only in debug mode, otherwise the LogEng server cannot be stopped. See TestUtils::CopyOldDbL()"));
#endif
	}

#else//SYMBIAN_ENABLE_EVENTLOGGER_DUALSIM

void doTestsL()
	{
	TestUtils::Initialize(_L("t_logcompat"));
	TheTest.Start(_L("The LogEng compatibility test cases are compiled only when SYMBIAN_ENABLE_EVENTLOGGER_DUALSIM macro is defined!"));
	}

#endif//SYMBIAN_ENABLE_EVENTLOGGER_DUALSIM