diff -r 000000000000 -r dfb7c4ff071f datacommsserver/esockserver/test/TE_SocketServer/TE_TestStepSocketServer.h --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/datacommsserver/esockserver/test/TE_SocketServer/TE_TestStepSocketServer.h Thu Dec 17 09:22:25 2009 +0200 @@ -0,0 +1,107 @@ +// Copyright (c) 2004-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: +// + +#if (!defined __TESTSTEPSOCKET_H__) +#define __TESTSTEPSOCKET_H__ +#include +#include +#include + +const TInt KLargeNumSockets = 60; + + +class CTestStepSocketServer : public CTestStep + { + public: + // virtual TDesC GetTestName() = 0; + CTestStepSocketServer(); + ~CTestStepSocketServer(); + + // CTestSuiteSocket * iEsockSuite;// Pointer to the suite which owns this test + enum TVerdict doTestStepPreambleL( void ); + enum TVerdict doTestStepL( void ); + enum TVerdict doTestStepPostambleL( void ); + + protected: + virtual enum TVerdict InternalDoTestStepL( void ) = 0; + + const TPtrC& EpocErrorToText(const TInt aErrCode); + + + static TInt OptimalConnect(RSocketServ &aSrv); + static TInt IllegalOptimalConnect(RSocketServ &aSrv); + static TInt PanicProtocolModule(RSocket &aSock); + static void NonCompletingIoclt(RSocket &aSock, TRequestStatus &aStat); + static TInt PanicDealer(RSocketServ &aSockServ); + static TInt BlockHardOnClose(RSocket &aSock); + static void SlowIoctlReturn(RSocket &aSock, TRequestStatus &aStat, TBool aBlockPermanently); + TInt CheckForModuleL(const TDesC8 &aModuleName); + TInt OpenSocketProtocolStarted(); + void OpenMultipleSocketsL(RSocketServ &aSS,RSocket *aSockets,TInt aNumSockets); + + private: + TPtrC iErrText; + TBuf<16> iErrBuff; // size must at least satisfy the number of digits used to represent a TInt + RProperty iHangingModuleFlag; + //This use as a kind of semaphore describing the number of prt that have been put + //into a hanging state and need to be unlocked before they can unload and the next + //test can begin + }; + +class CSocketServerTestStep_OOMCapable : public CTestStepSocketServer + { +public: + ~CSocketServerTestStep_OOMCapable() + { + iOOMSess.Close(); + } + + void SetHeapFailNext(TInt aFailureIndex) + { + if(iOOMSess.Handle() == KNullHandle) + { + iOOMSess.Connect(); + } + if(iOOMSess.Handle() != KNullHandle) + { + iOOMSess.__DbgFailNext(aFailureIndex - 1); // want to start with 0th + } + } + + void ResetHeapFailNext() + { + if(iOOMSess.Handle() != KNullHandle) + { + iOOMSess.__DbgFailNext(-1); + } + } + + TBool CheckForHeapFailNext() + { + if(iOOMSess.Handle() != KNullHandle) + { + // If ESOCK heaps are still in FailNext mode then we try to flag the termination + // of the loop to TEF by setting the local heap to fail. Because this might get + // "eaten" inside TEF before it checks we walk a failure point here too + return iOOMSess.__DbgCheckFailNext(); + } + return ETrue; + } + virtual enum TVerdict InternalDoTestStepL() =0; +private: + RSocketServ iOOMSess; + }; +#endif /* __TESTSTEPSOCKET_H__ */ +