messagingfw/biomsgfw/gfptsrc/t_gfp.cpp
changeset 62 db3f5fa34ec7
parent 0 8e480a14352b
child 58 6c34d0baa0b1
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/messagingfw/biomsgfw/gfptsrc/t_gfp.cpp	Wed Nov 03 22:41:46 2010 +0530
@@ -0,0 +1,414 @@
+// Copyright (c) 2000-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:
+// Test harness for Generic File Parser (ie vCard, vCalendar, Op. logo, Ringing Tones)
+// 
+//
+
+//Create a buffer containing an sms message with the relevant field
+//then pass it by reference to the parser dll
+#include <e32uid.h>
+#include <e32test.h>
+#include <e32cons.h>
+#include <s32file.h>
+#include <e32base.h>
+
+#include "Testenv.h"
+
+#include "REGPSDLL.H"
+
+#include "biotestutils.h"
+
+#define BIO_MSG_ENTRY_PARSED     1 // Set entry .iMtmData3 to 1 to indicate that the entry has store i.e parsed,externalised
+
+#define KTestEnpPriority    (1)    //Change this....
+
+#define KGenericParserTextFilePath  _L("c:\\test\\bio\\gfp\\")
+
+//
+
+//forward reference
+class CExampleScheduler;
+LOCAL_C void DisplayErrorReason(TInt& aReason);
+ 
+//global declaration
+LOCAL_D RTest test(_L("GFP Test Harness"));
+
+    //
+    // CExampleScheduler //
+    //
+
+class CExampleScheduler : public CActiveScheduler
+    {
+    public:
+    void Error (TInt aError) const;
+    };
+
+void CExampleScheduler::Error(TInt anError) const
+    {
+    CActiveScheduler::Stop();
+    test.Printf(_L("\nLeave signalled, reason=%d\n"),anError);
+    }
+// end CExampleScheduler::Error(TInt) const
+
+ //global declaration
+LOCAL_D CExampleScheduler *exampleScheduler;
+ 
+    //
+    // CTestGfp: INTERFACE //
+    //
+
+class CTestGfp : public CActive
+    {
+    public:
+        ~CTestGfp();
+        CTestGfp();
+
+        static CTestGfp* NewL();
+        void ConstructL();
+        void Start(TInt aCmd);
+        void RunL();
+        void DoCancel();
+		void RequestComplete(TRequestStatus& aStatus,TInt aCompletion);
+
+        enum TSessionState
+            {
+            EParse,
+            EProcess,
+			EReparse,
+			EDisplay,  //Display entry data
+            };
+
+    private:
+        TInt						iState;
+		TInt						iMsgCtr;
+		TInt						iMsgCount;
+
+		TInt						iTestCtr;
+
+        CBaseScriptParser2*			iParser;
+		CMsvEntrySelection*			iMsvSelection;
+
+        CArrayPtrSeg<CParsedField>* iTestParsedFieldArray;
+		CBioTestUtils*				iBioTestUtils;
+		HBufC*						iMsgBuffer;
+		TBool						iAllTestsSucessful;
+    };
+
+
+
+    //
+    // CTestGfp: IMPLEMENTATION //
+    //
+
+
+CTestGfp* CTestGfp::NewL()
+    {
+    CTestGfp* self = new (ELeave) CTestGfp();
+    CleanupStack::PushL(self);
+    self->ConstructL();
+    CleanupStack::Pop();  //self
+    return self;
+    }
+// end CTestGfp::NewL(CMsvServerEntry*)
+
+
+void CTestGfp::ConstructL()
+    {
+	// create test utilities object & go server side
+	iBioTestUtils = CBioTestUtils::NewL(test, ETuGoClientSide);
+	iBioTestUtils->GoClientSideL();
+
+	// create some messages
+	iMsvSelection = iBioTestUtils->GenerateMessagesL(KGenericParserTextFilePath);
+	iMsgCount = iMsvSelection->Count();
+	iAllTestsSucessful = ETrue;
+    CActiveScheduler::Add(this);
+    }
+// end CTestGfp::ConstructL()
+
+
+void CTestGfp::Start(TInt aCmd)
+    {
+	TInt error = KErrNone;
+	TBool finished = EFalse;
+#ifdef _DEBUG	
+	TInt failCount = 0;
+#endif	
+    iState=aCmd;
+
+    switch (iState)
+        {
+        case EParse:
+			test.Printf(_L("Parsing...\n"));
+			iBioTestUtils->TestStart(iTestCtr,_L("Parsing"));
+			delete iMsgBuffer;
+			// create the parser
+			if(iParser)
+				delete iParser;
+
+			while(!finished)
+				{
+				__UHEAP_FAILNEXT(failCount++);
+				// 
+				TRAP(error, iParser = iBioTestUtils->CreateParserL((*iMsvSelection)[iMsgCtr]););
+				if (error == KErrNone)
+					{
+					__UHEAP_RESET;
+					finished = ETrue;
+					__UHEAP_RESET;
+					}
+				// Handle error
+				else
+					{
+					// Check if error is out of memory or a specific fax rendering error
+					test(error == KErrNoMemory);
+					__UHEAP_RESET;
+					}
+				}
+
+			iMsgBuffer = iBioTestUtils->MessageBodyL((*iMsvSelection)[iMsgCtr]).AllocL();
+			finished = EFalse;
+	#ifdef _DEBUG			
+			failCount = 0;
+	#endif			
+            while(!finished)
+				{
+				__UHEAP_FAILNEXT(failCount++);
+				// 
+				TRAP(error, iParser->ParseL(iStatus,*iMsgBuffer));
+				if (error == KErrNone)
+					{
+					__UHEAP_RESET;
+					finished = ETrue;
+					SetActive();
+					}
+				// Handle error
+				else
+					{
+					// Check if error is out of memory or a specific fax rendering error
+					test(error == KErrNoMemory);
+					__UHEAP_RESET;
+					}
+				}
+            break;
+
+        case EProcess:
+			test.Printf(_L("process...(This is not supported in Generic File Parser)\n"));
+			iBioTestUtils->TestStart(iTestCtr,_L("Calling process"));
+			while(!finished)
+				{
+				__UHEAP_FAILNEXT(failCount++);
+				// 
+				TRAP(error, iParser->ProcessL(iStatus));
+				if (error == KErrNone)
+					{
+					__UHEAP_RESET;
+					finished = ETrue;
+					SetActive();
+					}
+				// Handle error
+				else
+					{
+					// Check if error is out of memory or a specific fax rendering error
+					test(error == KErrNoMemory);
+					__UHEAP_RESET;
+					}
+				}
+            break;
+
+		case EReparse:
+			test.Printf(_L("Reparsing...\n"));
+			iBioTestUtils->TestStart(iTestCtr,_L("Re-Parsing"));
+			while(!finished)
+				{
+				__UHEAP_FAILNEXT(failCount++);
+				// 
+				TRAP(error, iParser->ParseL(iStatus,*iMsgBuffer));
+				if (error == KErrNone)
+					{
+					__UHEAP_RESET;
+					finished = ETrue;
+					SetActive();
+					}
+				// Handle error
+				else
+					{
+					// Check if error is out of memory or a specific fax rendering error
+					test(error == KErrNoMemory);
+					__UHEAP_RESET;
+					}
+				}
+            break;
+		default:
+            break;
+        }
+    }
+// end CTestGfp::StartL(TInt)
+
+
+void CTestGfp::RunL()
+    {
+    TInt result=iStatus.Int();
+
+    if (result != KErrNone && result != KErrNotSupported)
+        {
+		iAllTestsSucessful = EFalse;
+        test.Console()->ClearScreen();
+        test.Console()->SetPos(0,0);
+        DisplayErrorReason(result);
+		iBioTestUtils->TestHarnessFailed(result);
+        CActiveScheduler::Stop();
+        return;
+        }
+	
+	if(iState==EProcess)
+		iBioTestUtils->WriteComment(_L("ProcessL not supported"));
+	iBioTestUtils->TestFinish(iTestCtr);
+	iTestCtr++;
+    switch (iState)
+        {
+        case EParse:
+            Start(EProcess);
+            break;
+ 
+		case EProcess:
+			Start(EReparse);
+			break;
+
+		case EReparse:
+			if(++iMsgCtr < iMsgCount)
+				Start(EParse);
+			else
+				{
+				test.Console()->ClearScreen();
+				test.Console()->SetPos(0,0);
+				DisplayErrorReason(result);
+				iParser->Cancel();
+				if(iAllTestsSucessful)
+					iBioTestUtils->TestHarnessCompleted();
+				CActiveScheduler::Stop();
+				}
+			break;
+
+        default:
+            break;
+        }
+    }
+// end CTestGfp::RunL()
+
+
+void CTestGfp::DoCancel()
+    {
+    }
+// end CTestGfp::DoCancel()
+
+CTestGfp::CTestGfp()
+:CActive(KTestEnpPriority)
+    {
+    }
+// end CTestGfp::CTestGfp()
+
+
+CTestGfp::~CTestGfp()
+    {
+    Cancel();
+
+	delete iParser;
+	delete iMsvSelection;
+	delete iBioTestUtils;
+	delete iMsgBuffer;
+
+	if(iTestParsedFieldArray)
+		{
+		iTestParsedFieldArray->ResetAndDestroy();
+		delete iTestParsedFieldArray;
+		iTestParsedFieldArray=NULL;
+		}
+    }
+// end CTestGfp::~CTestGfp()
+
+void CTestGfp::RequestComplete(TRequestStatus& aStatus,TInt aCompletion)
+	{
+	TRequestStatus* statusPtr=&aStatus;
+	User::RequestComplete(statusPtr,aCompletion);
+	}
+ 
+LOCAL_C void DisplayErrorReason(TInt& aReason)
+    {
+    switch (aReason)
+        {
+       case KErrNone:
+            test.Printf(_L("Session completed successfully"));
+            break;
+        case KErrCancel:
+            test.Printf(_L("Session cancelled"));
+            break;
+        case KErrEof:
+            test.Printf(_L("KErrEof"));
+            break;
+        case KErrNoMemory:
+            test.Printf(_L("No memory"));
+            break;
+        case KErrDisconnected:
+            test.Printf(_L(" KErrDisconnected"));
+            break;
+        case KErrAccessDenied:
+            test.Printf(_L("KErrAccessDenied"));
+            break;
+        case KErrNotSupported:
+            test.Printf(_L("Function Not Supported, Error = %d\n"), aReason);
+            break;
+        default:
+            test.Printf(_L("Error !!!= %d\n"), aReason );
+            break;
+        }
+    }
+
+LOCAL_C void doMainL()
+    {
+
+    //create a scheduler
+    exampleScheduler = new (ELeave) CExampleScheduler;
+    CleanupStack::PushL( exampleScheduler );
+    CActiveScheduler::Install( exampleScheduler );
+
+    CTestGfp* testParser = CTestGfp::NewL();
+    CleanupStack::PushL(testParser);
+
+    test(testParser != NULL);
+
+    testParser->Start(CTestGfp::EParse);
+    CActiveScheduler::Start();
+
+    CleanupStack::PopAndDestroy(2); // testParser, exampleScheduler, sEntry ,theServer
+    }
+// end doMainL()
+
+
+GLDEF_C TInt E32Main()
+    {
+    test.Title();
+    test.Start(_L("GFP Test Harness"));
+    __UHEAP_MARK;
+    CTrapCleanup* cleanup=CTrapCleanup::New();
+    test(cleanup!=NULL);
+    TRAPD(error,doMainL());
+    if (error) test.Printf(_L("Completed with return code %d"),error);
+    delete cleanup;
+    __UHEAP_MARKEND;
+    test.Close();
+    test.End();
+    return KErrNone;
+    }
+// end E32Main()