diff -r 000000000000 -r dfb7c4ff071f commsconfig/commsdatabaseshim/ts_commdb/Step_003_xx.cpp --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/commsconfig/commsdatabaseshim/ts_commdb/Step_003_xx.cpp Thu Dec 17 09:22:25 2009 +0200 @@ -0,0 +1,565 @@ +// Copyright (c) 2001-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: +// This contains CommDb Unit Test Cases 003.01 - 003.07 +// +// + +// EPOC includes +#include +#include + + +// Test system includes +#include +#include +#include "Teststepcommdb.h" +#include "TestSuiteCommdb.h" +#include "Step_003_xx.h" + + + + +// +// Test step 003.001 +// + +// constructor +CCommDbTest003_01::CCommDbTest003_01() + { + // store the name of this test case + iTestStepName = _L("step_003_01"); + } + +// destructor +CCommDbTest003_01::~CCommDbTest003_01() + { + } + + +TVerdict CCommDbTest003_01::doTestStepPreambleL() + { + openDbL(); + return EPass; + } + +TInt CCommDbTest003_01::myOpenTableL() + { + + // Because OpenTableLC puts an object on the cleanup stack, + // we cant use TRAP() on it as this causes a Panic during the + // UnTrap cleanup, so we write our own leaving wrapper function. + iTheView=iTheDb->OpenTableLC(TPtrC(DIAL_OUT_ISP)); + CleanupStack::Pop(); + + //if this test does not trap, it can only ever return KErrNone + return KErrNone; + + } + +TInt CCommDbTest003_01::executeStepL() + { + TInt ret=KErrNone; + + TRAPD(r, ret = myOpenTableL() ); + + if ( r==KErrNone ) + { + //if there were no traps, return the value call to the api + r=ret; + } + + return r; + } + + +TVerdict CCommDbTest003_01::doTestStepL( ) + { + + Log(_L("Step 003.01 called ")); + + if ( executeStepL() == KErrNone ) + iTestStepResult = EPass; + else + iTestStepResult = EFail; + + + return iTestStepResult; + } + + + +// +// Test step 003.002 +// + +// constructor +CCommDbTest003_02::CCommDbTest003_02() + { + // store the name of this test case + iTestStepName = _L("step_003_02"); + } + +// destructor +CCommDbTest003_02::~CCommDbTest003_02() + { + } + + +TVerdict CCommDbTest003_02::doTestStepPreambleL() + { + openDbL(); + return EPass; + } + +#define INVALID_TABLE_NAME _S("Inval") + + +TInt CCommDbTest003_02::myOpenTableL() + { + + // Because OpenTableLC puts an object on the cleanup stack, + // we cant use TRAP() on it as this causes a Panic during the + // UnTrap cleanup, so we write our own leaving wrapper function. + iTheView=iTheDb->OpenTableLC(TPtrC(INVALID_TABLE_NAME)); + CleanupStack::Pop(); + + //This test should trap, if it gets here then something has gone wrong + return KErrGeneral; + + } + + +TInt CCommDbTest003_02::executeStepL() + { + TInt ret=KErrNone; + + TRAPD(r, ret = myOpenTableL() ); + + if ( r==KErrNone ) + { + //if there were no traps, return the value call to the api + r=ret; + } + + return r; + } + + + +TVerdict CCommDbTest003_02::doTestStepL( ) + { + Log(_L("Step 003.02 called ")); + + + //Test for the expected return value + if ( executeStepL() == KErrNotFound ) + iTestStepResult = EPass; + else + iTestStepResult = EFail; + + + return iTestStepResult; + } + + + +// +// Test step 003.003 +// + +// constructor +CCommDbTest003_03::CCommDbTest003_03() + { + // store the name of this test case + iTestStepName = _L("step_003_03"); + } + +// destructor +CCommDbTest003_03::~CCommDbTest003_03() + { + } + + +TVerdict CCommDbTest003_03::doTestStepPreambleL() + { + openDbL(); + return EPass; + } + +#define ZERO_LENGTH_TABLE_NAME _S("") + +TInt CCommDbTest003_03::myOpenTableL() + { + + // Because OpenTableLC puts an object on the cleanup stack, + // we cant use TRAP() on it as this causes a Panic during the + // UnTrap cleanup, so we write our own leaving wrapper function. + + iTheView = iTheDb->OpenTableLC(TPtrC(ZERO_LENGTH_TABLE_NAME)); + CleanupStack::Pop(); + + //This test should trap, if we get here something has gone wrong + return KErrGeneral; + } + + +TInt CCommDbTest003_03::executeStepL() + { + TInt ret=KErrNone; + + TRAPD(r, ret = myOpenTableL() ); + + if ( r==KErrNone ) + { + //if there were no traps, return the value call to the api + r=ret; + } + + return r; + } + + +TVerdict CCommDbTest003_03::doTestStepL( ) + { + Log(_L("Step 003.03 called ")); + + + //Test for the expected return value + if ( executeStepL() == KErrArgument ) + iTestStepResult = EPass; + else + iTestStepResult = EFail; + + + return iTestStepResult; + } + +// +// Test step 003.04 +// + +// constructor +CCommDbTest003_04::CCommDbTest003_04() + { + // store the name of this test case + iTestStepName = _L("step_003_04"); + } + +// destructor +CCommDbTest003_04::~CCommDbTest003_04() + { + } + +TVerdict CCommDbTest003_04::doTestStepPreambleL() + { + openDbL(); + return EPass; + } + +#define LONG_TABLE_NAME _S("aVeryVeryLongTableNameThatIsLongerThanFiftyCharacters") + + +TInt CCommDbTest003_04::myOpenTableL() + { + + // Because OpenTableLC puts an object on the cleanup stack, + // we cant use TRAP() on it as this causes a Panic during the + // UnTrap cleanup, so we write our own leaving wrapper function. + iTheView=iTheDb->OpenTableLC(TPtrC(LONG_TABLE_NAME)); + CleanupStack::Pop(); + + //This test will cause a PANIC, so we will never get here + return KErrGeneral; + } + + +TInt CCommDbTest003_04::executeStepL() + { + TInt ret=KErrNone; + + TRAPD(r, myOpenTableL() ); + + if ( r==KErrNone ) + { + //if there were no traps, return the value call to the api + r=ret; + } + + return r; +} + + +TVerdict CCommDbTest003_04::doTestStepL( ) + { + + User::SetJustInTime(EFalse); + + if ( executeStepL() == KErrArgument ) + iTestStepResult = EPass; + else + iTestStepResult = EFail; + + return iTestStepResult; + } +// +// Test step 003.05 +// + +// constructor +CCommDbTest003_05::CCommDbTest003_05() + { + // store the name of this test case + iTestStepName = _L("step_003_05"); + } + +// destructor +CCommDbTest003_05::~CCommDbTest003_05() + { + } + + +TVerdict CCommDbTest003_05::doTestStepPreambleL() + { + openDbL(); + return EPass; + } + +//The CONNECTION_PREFERENCES table isn't really a public table, +//but someone still could try to open it. +#define CONNECTION_PREFERENCES _S("ConnectionPreferences") + +TInt CCommDbTest003_05::myOpenTableL() + { + + // Because OpenTableLC puts an object on the cleanup stack, + // we cant use TRAP() on it as this causes a Panic during the + // UnTrap cleanup, so we write our own leaving wrapper function. + iTheView=iTheDb->OpenTableLC(TPtrC( CONNECTION_PREFERENCES )); + CleanupStack::Pop(); + + //This test should leave, so we will never reach here + return KErrGeneral; + } + +TInt CCommDbTest003_05::executeStepL() +{ + TInt ret=KErrNone; + + TRAPD(r, ret = myOpenTableL() ); + + if ( r==KErrNone ) + { + //if there were no traps, return the value call to the api + r=ret; + } + + return r; +} + + + +TVerdict CCommDbTest003_05::doTestStepL( ) + { + Log(_L("Step 003.05 called ")); + + + if ( executeStepL() == KErrAccessDenied ) + iTestStepResult = EPass; + else + iTestStepResult = EFail; + + return iTestStepResult; + } + +// +// Test step 003.006 +// + +// constructor +CCommDbTest003_06::CCommDbTest003_06() + { + // store the name of this test case + iTestStepName = _L("step_003_06"); + } + +// destructor +CCommDbTest003_06::~CCommDbTest003_06() + { + } + + +TVerdict CCommDbTest003_06::doTestStepPreambleL() + { + openDbL(); + return EPass; + } + +#define GLOBAL_SETTINGS _S("GlobalSettings") + +TInt CCommDbTest003_06::myOpenTableL() + { + + // Because OpenTableLC puts an object on the cleanup stack, + // we cant use TRAP() on it as this causes a Panic during the + // UnTrap cleanup, so we write our own leaving wrapper function. + iTheView=iTheDb->OpenTableLC(TPtrC( GLOBAL_SETTINGS )); + CleanupStack::Pop(); + + //This test should leave, so we will never reach here + return KErrGeneral; + } + +TInt CCommDbTest003_06::executeStepL() +{ + TInt ret=KErrNone; + + + TRAPD(r, ret = myOpenTableL() ); + + if ( r==KErrNone ) + { + //if there were no traps, return the value call to the api + r=ret; + } + + return r; +} + + +TVerdict CCommDbTest003_06::doTestStepL( ) + { + Log(_L("Step 003.06 called ")); + + + if ( executeStepL() == KErrNotFound ) + iTestStepResult = EPass; + else + iTestStepResult = EFail; + + return iTestStepResult; + } + +// +// Test step 003.07 +// + +// constructor +CCommDbTest003_07::CCommDbTest003_07() + { + // store the name of this test case + iTestStepName = _L("step_003_07"); + } + +// destructor +CCommDbTest003_07::~CCommDbTest003_07() + { + } + +TVerdict CCommDbTest003_07::doTestStepL( ) + { + Log(_L("Step 003.07 called ")); + + iTestStepResult = EPass; + + //Heap test for 003.01 + + CCommDbTest003_01* step003_01 = new CCommDbTest003_01; + CleanupStack::PushL(step003_01); + step003_01->iSuite = iSuite; + doTestStepWithHeapFailureL( *step003_01, KErrNone); + if( step003_01->iTestStepResult == EFail ) + iTestStepResult = EFail; + CleanupStack::PopAndDestroy(step003_01); + + + //Heap test for 003.02 + + CCommDbTest003_02* step003_02 = new CCommDbTest003_02; + CleanupStack::PushL(step003_02); + step003_02->iSuite = iSuite; + doTestStepWithHeapFailureL( *step003_02, KErrNotFound); + if( step003_02->iTestStepResult == EFail ) + iTestStepResult = EFail; + CleanupStack::PopAndDestroy(step003_02); + + + //Heap test for 003.03 + + CCommDbTest003_03* step003_03 = new CCommDbTest003_03; + CleanupStack::PushL(step003_03); + step003_03->iSuite = iSuite; + doTestStepWithHeapFailureL( *step003_03, KErrArgument); + if( step003_03->iTestStepResult == EFail ) + iTestStepResult = EFail; + CleanupStack::PopAndDestroy(step003_03); + + //Heap test for 003.04 - see test step 3.08 + + //Heap test for 003.05 + + CCommDbTest003_05* step003_05 = new CCommDbTest003_05; + CleanupStack::PushL(step003_05); + step003_05->iSuite = iSuite; + doTestStepWithHeapFailureL( *step003_05, KErrAccessDenied); + if( step003_05->iTestStepResult == EFail ) + iTestStepResult = EFail; + CleanupStack::PopAndDestroy(step003_05); + + + //Heap test for 003.06 + + CCommDbTest003_06* step003_06 = new CCommDbTest003_06; + CleanupStack::PushL(step003_06); + step003_06->iSuite = iSuite; + doTestStepWithHeapFailureL( *step003_06, KErrNotFound); + if( step003_06->iTestStepResult == EFail ) + iTestStepResult = EFail; + CleanupStack::PopAndDestroy(step003_06); + + + return iTestStepResult; + } + +// +// Test step 003.08 +// + +// constructor +CCommDbTest003_08::CCommDbTest003_08() + { + // store the name of this test case + iTestStepName = _L("step_003_08"); + } + +// destructor +CCommDbTest003_08::~CCommDbTest003_08() + { + } + +TVerdict CCommDbTest003_08::doTestStepL( ) + { + + iTestStepResult = EPass; + + //Heap test for 003.04 - a panic test + + CCommDbTest003_04* step003_04 = new CCommDbTest003_04; + CleanupStack::PushL(step003_04); + step003_04->iSuite = iSuite; + if ( doTestStepWithHeapFailureL( *step003_04, KErrNotFound) == EFail ) + iTestStepResult = EFail; + CleanupStack::PopAndDestroy(step003_04); + + return iTestStepResult; + }