messagingfw/msgtest/testutils/sms/test/src/MsgScriptsTest.cpp
changeset 62 db3f5fa34ec7
parent 0 8e480a14352b
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/messagingfw/msgtest/testutils/sms/test/src/MsgScriptsTest.cpp	Wed Nov 03 22:41:46 2010 +0530
@@ -0,0 +1,159 @@
+// Copyright (c) 1999-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 <e32std.h>
+#include <e32test.h>
+#include <msgtestscripts.h>
+
+_LIT(KSmsConfigFile, "c:\\test\\sms\\msgscriptstest.config");
+RTest test(_L("MsgTestScripts"));
+RFs fs;
+
+_LIT(KSmsItemA, "Name");
+_LIT(KSmsItemB, "Recipients");
+_LIT(KSmsItemC, "Self");
+_LIT(KSmsItemD, "Message");
+_LIT(KSmsItemE, "Encoding");
+
+_LIT(KSmsSection1, "Group");
+_LIT(KSmsValue1A, "Anthony");
+_LIT(KSmsValue1B, "+447747065431");
+_LIT(KSmsValue1C, "+447747065499");
+_LIT(KSmsValue1D, "");
+const TInt KSmsValue1E = 0;
+
+_LIT(KSmsSection2, "NextGroup");
+_LIT(KSmsValue2A, "Bill");
+_LIT(KSmsValue2B, "+447747065445");
+_LIT(KSmsValue2C, "+447747065498");
+_LIT(KSmsValue2D, "This\nis\na\nmultiline\nmessage");
+const TInt KSmsValue2E = 7;
+
+_LIT(KSmsSection3, "LastGroup");
+_LIT(KSmsValue3A, "");
+_LIT(KSmsValue3B, "");
+_LIT(KSmsValue3C, "");
+_LIT(KSmsValue3D, "");
+const TInt KSmsValue3E = 0;
+
+void TestScriptFileL()
+	{
+	CScriptFile* scriptFile = CScriptFile::NewLC(fs, KSmsConfigFile);
+
+	TPtrC itemValue(KNullDesC);
+	TInt intValue(0);
+
+	//Test Section1
+	scriptFile->ItemValue(KSmsSection1, KSmsItemA, itemValue, KNullDesC);
+	test(itemValue == KSmsValue1A);
+
+	scriptFile->ItemValue(KSmsSection1, KSmsItemB, itemValue, KNullDesC);
+	test(itemValue == KSmsValue1B);
+
+	scriptFile->ItemValue(KSmsSection1, KSmsItemC, itemValue, KNullDesC);
+	test(itemValue == KSmsValue1C);
+
+	scriptFile->ItemValue(KSmsSection1, KSmsItemD, itemValue, KNullDesC);
+	test(itemValue == KSmsValue1D);
+
+	scriptFile->ItemValue(KSmsSection1, KSmsItemE, intValue, 0);
+	test(intValue == KSmsValue1E);
+
+	//Test Section2
+	scriptFile->ItemValue(KSmsSection2, KSmsItemA, itemValue, KNullDesC);
+	test(itemValue == KSmsValue2A);
+
+	scriptFile->ItemValue(KSmsSection2, KSmsItemB, itemValue, KNullDesC);
+	test(itemValue == KSmsValue2B);
+
+	scriptFile->ItemValue(KSmsSection2, KSmsItemC, itemValue, KNullDesC);
+	test(itemValue == KSmsValue2C);
+
+	scriptFile->ItemValue(KSmsSection2, KSmsItemD, itemValue, KNullDesC);
+	test(itemValue == KSmsValue2D);
+
+	scriptFile->ItemValue(KSmsSection2, KSmsItemE, intValue, 0);
+	test(intValue == KSmsValue2E);
+
+	//Test Section3
+	scriptFile->ItemValue(KSmsSection3, KSmsItemA, itemValue, KNullDesC);
+	test(itemValue == KSmsValue3A);
+
+	scriptFile->ItemValue(KSmsSection3, KSmsItemB, itemValue, KNullDesC);
+	test(itemValue == KSmsValue3B);
+
+	scriptFile->ItemValue(KSmsSection3, KSmsItemC, itemValue, KNullDesC);
+	test(itemValue == KSmsValue3C);
+
+	scriptFile->ItemValue(KSmsSection3, KSmsItemD, itemValue, KNullDesC);
+	test(itemValue == KSmsValue3D);
+
+	scriptFile->ItemValue(KSmsSection3, KSmsItemE, intValue, 0);
+	test(intValue == KSmsValue3E);
+
+	CleanupStack::PopAndDestroy(scriptFile);
+	}
+
+void TestHeapFailL()
+	{
+	TInt error;
+	TInt failCount = 0;
+
+	//Failure Test CSmsSettings::NewL
+	do
+		{
+		__UHEAP_FAILNEXT(failCount++);
+
+		TRAP(error, TestScriptFileL());
+
+		__UHEAP_RESET;
+
+		if (error)
+			{
+			test(error == KErrNoMemory);
+			}
+
+		}
+	while (error);
+
+	test.Printf(_L("TestScriptFileL() Fail Count %d\n"), failCount);
+
+	failCount = 0;
+	}
+
+void doMainL()
+	{
+	TestScriptFileL();
+	TestHeapFailL();
+	}
+
+GLDEF_C TInt E32Main()
+	{
+	__UHEAP_MARK;
+	test.Start(_L("Setup"));
+	CTrapCleanup* theCleanup = CTrapCleanup::New();
+	TInt ret = fs.Connect();
+	if (!ret)
+		TRAP(ret,doMainL());		
+	test(ret==KErrNone);
+	fs.Close();
+	delete theCleanup;	
+	test.Console()->SetPos(0, 13);
+	test.End();
+	test.Close();
+	__UHEAP_MARKEND;
+	return(KErrNone);
+	}
+