testexecfw/tef/test/regressiontest/teststep/src/testmacrosstep.cpp
changeset 0 3e07fef1e154
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/testexecfw/tef/test/regressiontest/teststep/src/testmacrosstep.cpp	Mon Mar 08 15:03:44 2010 +0800
@@ -0,0 +1,205 @@
+/*
+* Copyright (c) 2005-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:  
+* Example CTestStep derived implementation
+*
+*/
+
+
+
+/**
+ @file WriteStringStep.cpp
+*/
+#include "TestMacrosStep.h"
+#include "Te_RegStepTestSuiteDefs.h"
+
+_LIT(KMacro, "Macro");
+_LIT(KInitState, "InitState");
+_LIT(KParameter, "Parameter");
+_LIT(KParameter2, "Parameter2");
+_LIT(KParameter3, "Parameter3");
+_LIT(KExpectedResult, "ExpectedResult");
+
+_LIT(KTest, "TEST&TESTE");
+_LIT(KTest1, "TEST1&TESTE1");
+//_LIT(KTestE, "TESTE");
+//_LIT(KTestE1, "TESTE1");
+_LIT(KTestCheckL, "TEST_CHECKL");
+
+_LIT(KPositive, "positive");
+_LIT(KNegative, "negative");
+
+#define POS_NEG_SEL (parameter?&KPositive():&KNegative())
+
+
+CTestMacrosTestStep::~CTestMacrosTestStep()
+/**
+ * Destructor
+ */
+	{
+	}
+
+CTestMacrosTestStep::CTestMacrosTestStep()
+/**
+ * Constructor
+ */
+	{
+	SetTestStepName(KMacrosTestStep);
+	}
+
+TVerdict CTestMacrosTestStep::doTestStepPreambleL()
+/**
+ * @return - TVerdict code
+ * Override of base class virtual
+ */
+	{
+	// There is no initiation work so set this result to pass.
+	SetTestStepResult(EPass);
+	return TestStepResult();
+	}
+
+
+TVerdict CTestMacrosTestStep::doTestStepL()
+/**
+ * @return - TVerdict code
+ * Override of base class pure virtual
+ * Our implementation only gets called if the base class doTestStepPreambleL() did
+ * not leave. That being the case, the current test result value will be EPass.
+ */
+	{
+	TPtrC macro;
+	GetStringFromConfig(ConfigSection(), KMacro, macro);
+	if (macro == KTest)
+		{
+		TBool parameter;
+		TInt parameter2;
+		TInt expectedResult;
+		GetBoolFromConfig(ConfigSection(), KParameter, parameter);
+		GetIntFromConfig(ConfigSection(), KParameter2, parameter2);
+		GetIntFromConfig(ConfigSection(), KExpectedResult, expectedResult);
+		_LIT(KStartInfo, "Start to run %S test of macros TEST(E) & TEST(E)L");
+		INFO_PRINTF2(KStartInfo, POS_NEG_SEL);
+		TEST(parameter);
+		TESTE(parameter, parameter2);
+		if (expectedResult != TestStepResult())
+			{
+			ERR_PRINTF2(_L("The %S test of macro TEST(E) test is failed!"), POS_NEG_SEL);
+			SetTestStepResult(EFail);
+			}
+		else
+			{
+			SetTestStepResult(EPass);
+			INFO_PRINTF3(_L("The %S test of macro TEST(E) is passed. Start to run %S test of macro TEST(E)L"), POS_NEG_SEL, POS_NEG_SEL);
+			
+			TRAPD(err, TESTL(parameter));
+			TRAPD(err1, TESTEL(parameter, parameter2));
+			if ((expectedResult==EPass && KErrNone!=err) || (expectedResult==EFail && TEST_ERROR_CODE!=err && parameter2!=err1))
+				{
+				ERR_PRINTF2(_L("The %S test of macro TEST(E)L test is failed!"), POS_NEG_SEL);
+				SetTestStepResult(EFail);
+				}
+			else
+				{
+				INFO_PRINTF2(_L("The %S test of macro TEST(E)L is passed."), POS_NEG_SEL);
+				SetTestStepResult(EPass);
+				}
+			}
+		}
+	else if (macro == KTest1)
+		{
+		TBool parameter;
+		TBool parameter2;
+		TInt parameter3;
+		TInt initState;
+		TInt expectedResult;
+		GetBoolFromConfig(ConfigSection(), KParameter, parameter);
+		GetBoolFromConfig(ConfigSection(), KParameter2, parameter2);
+		GetIntFromConfig(ConfigSection(), KParameter3, parameter3);
+		GetIntFromConfig(ConfigSection(), KInitState, initState);
+		GetIntFromConfig(ConfigSection(), KExpectedResult, expectedResult);
+		SetTestStepResult((TVerdict)initState);
+		_LIT(KStartInfo, "Start to run %S test of macros TEST(E)1 & TEST(E)1L");
+		INFO_PRINTF2(KStartInfo, POS_NEG_SEL);
+		TEST1(parameter, parameter2);
+		TESTE1(parameter, parameter3, parameter2);
+		if (expectedResult != TestStepResult())
+			{
+			ERR_PRINTF1(_L("Macro TEST(E)1 test failed!"));
+			SetTestStepResult(EFail);
+			}
+		else
+			{
+			SetTestStepResult(EPass);
+			INFO_PRINTF3(_L("The %S test of macro TEST(E)1 has passed. Start to run %S test of macro TEST(E)1L"), POS_NEG_SEL, POS_NEG_SEL);
+			
+			TRAPD(err, TEST1L(parameter, parameter2));
+			TRAP_IGNORE(TESTE1L(parameter, parameter3, parameter2));
+			if ((expectedResult==EPass && KErrNone!=err) || ((expectedResult==EFail) && (parameter && ((TEST_ERROR_CODE==err)||(parameter3==err))) || (!parameter && TEST_ERROR_CODE!=err && parameter3!=err)))
+				{
+				ERR_PRINTF1(_L("Macro TEST(E)1L test failed!"));
+				SetTestStepResult(EFail);
+				}
+			else
+				{
+				INFO_PRINTF2(_L("The %S test of macro TEST(E)1L has passed."), POS_NEG_SEL);
+				SetTestStepResult(EPass);
+				}
+			}
+		}
+
+	else if (macro == KTestCheckL)
+		{
+		TInt parameter;
+		TInt parameter1;
+		TPtrC parameter2;
+		TInt expectedResult;
+		GetIntFromConfig(ConfigSection(), KParameter, parameter1);
+		GetStringFromConfig(ConfigSection(), KParameter2, parameter2);
+		GetIntFromConfig(ConfigSection(), KExpectedResult, expectedResult);
+		
+		parameter = (parameter1==expectedResult);
+		INFO_PRINTF3(_L("Start %S test of macro %S"), POS_NEG_SEL, &KTestCheckL());
+		
+		TRAPD(err, TEST_CHECKL(parameter1, expectedResult, parameter2));
+		_LIT(KPassInfo, "This test should be passed!");
+		_LIT(KFailInfo, "This test should be failed!");
+		if ((KErrNone==err && parameter2==KPassInfo()) || (parameter1==err && parameter2==KFailInfo()))
+			{
+			INFO_PRINTF2(_L("The macro %S test is passed!"), &KTestCheckL());
+			SetTestStepResult(EPass);
+			}
+		else
+			{
+			ERR_PRINTF2(_L("The macro %S test is failed!"), &KTestCheckL());
+			SetTestStepResult(EFail);
+			}
+		}
+	else
+		{
+		WARN_PRINTF2(_L("Unrecognized Marco %S"), macro);
+		}
+	
+	return TestStepResult();
+	}
+
+
+
+TVerdict CTestMacrosTestStep::doTestStepPostambleL()
+/**
+ * @return - TVerdict code
+ * Override of base class virtual
+ */
+	{
+	return TestStepResult();
+	}