cryptomgmtlibs/cryptotokenfw/tframework/t_ctframework.cpp
author Pat Downey <patd@symbian.org>
Wed, 01 Sep 2010 12:40:57 +0100
branchRCL_3
changeset 62 a71299154b21
parent 8 35751d3474b7
permissions -rw-r--r--
Revert incorrect RCL_3 drop: Revision: 201035 Kit: 201035

/*
* 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 the License "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 <e32test.h>
#include <ct.h>
#include <f32file.h>
#include "MTestInterface.h"
#include <ecom/ecom.h>

RTest test(_L("CT Framework Tests"));



TBool gLogging=ETrue;
TBool gSilent=EFalse;

const TInt gInterfaceA = 0x101f4e50;
const TInt gInterfaceB = 0x101f4e51;
const TInt gInterfaceC = 0x101f4e52;

const TInt gAttribute1 = 0x101f4e4a;
const TInt gAttribute2 = 0x101f4e4b;

const TInt gImplementation6 = 0x101f4e4c;
const TInt gImplementation5 = 0x101f4e4d;

class CTestConsole:public CConsoleBase

	{
	public:
		static CTestConsole* NewL(CConsoleBase* aCon);
		TInt Create(const TDesC16& aTitle,TSize aSize) {return iCon->Create(aTitle,aSize);};
		void Read(TRequestStatus& aStatus) {iCon->Read(aStatus);};
		void ReadCancel(void) {iCon->ReadCancel();};
		void Write(const TDesC16& aString);
		TPoint CursorPos(void) const {return iCon->CursorPos();};
		void SetCursorPosAbs(const TPoint& aPos) {iCon->SetCursorPosAbs(aPos);};
		void SetCursorPosRel(const TPoint& aPos) {iCon->SetCursorPosRel(aPos);};
		void SetCursorHeight(TInt aHeight) {iCon->SetCursorHeight(aHeight);};
		void SetTitle(const TDesC16& aTitle) {iCon->SetTitle(aTitle);};
		void ClearScreen(void) {iCon->ClearScreen();};
		void ClearToEndOfLine(void) {iCon->ClearToEndOfLine();};
		TSize ScreenSize(void) const {return iCon->ScreenSize();};
		TKeyCode KeyCode(void) const {return iCon->KeyCode();};
		TUint KeyModifiers(void) const {return iCon->KeyModifiers();};
		~CTestConsole(void);
		void SetLogFile(RFile* aFile);
	private:
		CTestConsole(void);
		CConsoleBase* iCon;
		RFile* iFile;
	};

CTestConsole* CTestConsole::NewL(CConsoleBase* aCon)

	{
	CTestConsole* self;
	self=new (ELeave) CTestConsole;
	self->iCon=aCon;
	self->iFile=NULL;
	return self;
	}

CTestConsole::CTestConsole(void):CConsoleBase()

	{
	}

CTestConsole::~CTestConsole(void)

	{
	delete iCon;
	if (iFile)
		{
		iFile->Close();
		}
	}

void CTestConsole::Write(const TDesC16& aString)

	{
	if (gSilent)
		return;
	iCon->Write(aString);
	if ((iFile)&&(gLogging))
		{
		TUint8 space[200];
		TPtr8 ptr(space,200);
		ptr.Copy(aString);
		iFile->Write(ptr);
		}
	}

void CTestConsole::SetLogFile(RFile* aFile)

	{
	iFile=aFile;
	}

template <class T> class TTestArray
	{
public:
	TTestArray(T* aArray, TInt aCount);
	TArray<T> Array();
private:
	static TInt Count(const CBase* aThat);
	static const TAny* Get(const CBase* aThat, TInt aIndex);

	T* iArray;
	TInt iCount;
	};

template <class T> TTestArray<T>::TTestArray(T* aArray, TInt aCount)
		: iArray(aArray), iCount(aCount)
	{	
	}

template <class T> TInt TTestArray<T>::Count(const CBase* aThat)
	{
	return reinterpret_cast<const TTestArray*>(aThat)->iCount;
	}

template <class T> const TAny* TTestArray<T>::Get(const CBase* aThat, TInt aIndex)
	{
	return &reinterpret_cast<const TTestArray*>(aThat)->iArray[aIndex];
	}

template <class T> TArray<T> TTestArray<T>::Array()
	{
	return TArray<T>(Count, Get, reinterpret_cast<CBase*>(this));
	}

/** A filter that includes nothing (as a random easy-to-write test filter */
class TNoTokenTypes : public MCTTokenTypeFilter
	{
 public:
	/** Always returns EFalse. */
	virtual TBool Accept(const CCTTokenTypeInfo& aTokenType) const;
	};

// Accept everything
TBool TNoTokenTypes::Accept(const CCTTokenTypeInfo&) const
	{
	return EFalse;
	}

class CStopScheduler : public CActive
	{
public:
	void DoCancel() {};
	void RunL();
	CStopScheduler();
	};

void CStopScheduler::RunL()
	{
	CActiveScheduler::Stop();
	};

CStopScheduler::CStopScheduler()
		: CActive(EPriorityIdle)
	{
	CActiveScheduler::Add(this);
	SetActive();
	TRequestStatus* r = &iStatus;
	User::RequestComplete(r, KErrNone);
	}

TInt TokenTypeInfoListTestsL()
	{
	test.Printf(_L("1.1,Testing getting all token types,"));
	RCPointerArray<CCTTokenTypeInfo> myTokenTypes;
	CleanupClosePushL(myTokenTypes);

	CCTTokenTypeInfo::ListL(myTokenTypes);

	if (myTokenTypes.Count() < 6)
		{
		CleanupStack::PopAndDestroy();
		test.Printf(_L("FAILED\r\n"));
		return (1);
		}

	myTokenTypes.ResetAndDestroy();
	test.Printf(_L("PASSED\r\n"));

	test.Printf(_L("1.2,Testing user-supplied filter,"));
	TNoTokenTypes filter;
	CCTTokenTypeInfo::ListL(myTokenTypes, filter);

	if (myTokenTypes.Count() > 0)
		{
		CleanupStack::PopAndDestroy();
		test.Printf(_L("FAILED\r\n"));
		return (2);
		}

	myTokenTypes.ResetAndDestroy();
	test.Printf(_L("PASSED\r\n"));

	test.Printf(_L("1.3,Testing finding filters matching 1 interface,"));
	RArray<TUid> a;
	TUid aa = {gInterfaceA};
	User::LeaveIfError(a.Append(aa));
	CleanupClosePushL(a);
	TCTFindTokenTypesByInterface findA(a.Array());
	CCTTokenTypeInfo::ListL(myTokenTypes, findA);
	if (myTokenTypes.Count() != 4)
		{
		CleanupStack::PopAndDestroy(2);
		test.Printf(_L("FAILED\r\n"));
		return (3);
		}
	TInt findAResults[] = {1,4,5,6};
	TInt flag[] = {1,1,1,1};
	for (TInt ii = 0; ii < 4; ii++)
		{
		TInt count = 0;
		TInt iii=0;
		TBuf<20> matchString;
		_LIT(format, "Test Token Type %d");
		matchString.Format(format, findAResults[iii]);
		TBuf<20> idisplay_name= myTokenTypes[ii]->Label();
        
        if (matchString.Compare(idisplay_name))
        	count++;
        else
        	{
        	if(flag[0]==1)
        		flag[0]=0;	
        	else
        		count++;
        	}
        matchString.Format(format, findAResults[iii+1]);
        if (matchString.Compare(idisplay_name))
        	count++;
        else
        	{
        	if(flag[1]==1)
        		flag[1]=0;	
        	else
        		count++;
        	}
        matchString.Format(format, findAResults[iii+2]);
        if (matchString.Compare(idisplay_name))
        	count++;
        else
        	{
        	if(flag[2]==1)
        		flag[2]=0;	
        	else
        		count++;
        	}
        matchString.Format(format, findAResults[iii+3]);
        if (matchString.Compare(idisplay_name))
        	count++;
        else
        	{
        	if(flag[3]==1)
        		flag[3]=0;	
        	else
        		count++;
        	}
        if(count==4)
        	{
        	CleanupStack::PopAndDestroy(2);
			test.Printf(_L("FAILED\r\n"));
			return (4);
        	}
       } 
			
	myTokenTypes.ResetAndDestroy();
	test.Printf(_L("PASSED\r\n"));

	test.Printf(_L("1.5,Testing finding filters matching 2 interfaces,"));
	TUid aAndB[] = {{gInterfaceA}, {gInterfaceB}};
	TTestArray<TUid> aAndBArray(aAndB, 2);
	TCTFindTokenTypesByInterface findAAndB(aAndBArray.Array());
	CCTTokenTypeInfo::ListL(myTokenTypes, findAAndB);
	if (myTokenTypes.Count() != 2)
		{
		CleanupStack::PopAndDestroy(2);
		test.Printf(_L("FAILED\r\n"));
		return (5);
		}
	TInt findAAndBResults[] = {4,6};
	TInt flag1[] = {1,1};
	for (TInt jj = 0; jj < 2; jj++)
		{
		TInt count = 0;
		TInt jjj=0;
		TBuf<20> matchString;
		_LIT(format, "Test Token Type %d");
		matchString.Format(format, findAAndBResults[jjj]);
		TBuf<20> idisplay_name = myTokenTypes[jj]->Label();
		if (matchString.Compare(idisplay_name))
        	count++;
        else
        	{
        	if(flag1[0]==1)
        		flag1[0]=0;	
        	else
        		count++;
        	}
        matchString.Format(format, findAAndBResults[jjj+1]);
        if (matchString.Compare(idisplay_name))
        	count++;
        else
        	{
        	if(flag1[1]==1)
        		flag1[1]=0;	
        	else
        		count++;
        	}
        if(count==2)
        	{
        	CleanupStack::PopAndDestroy(2);
			test.Printf(_L("FAILED\r\n"));
			return (6);
        	}
        }
		
	// NOTE No ResetAndDestroy
	test.Printf(_L("PASSED\r\n"));

	test.Printf(_L("1.6,Testing appending interface infos,"));
	CCTTokenTypeInfo::ListL(myTokenTypes, findA);
	if (myTokenTypes.Count() != 6)
		{
		CleanupStack::PopAndDestroy(2);
		test.Printf(_L("FAILED\r\n"));
		return (7);
		}
	TInt flag2[] = {1,1,1,1};
	for (TInt kk = 0; kk < 4; kk++)
		{
		TInt count = 0;
		TInt kkk=0;
		TBuf<20> matchString;
		_LIT(format, "Test Token Type %d");
		matchString.Format(format, findAResults[kkk]);
		TBuf<20> idisplay_name = myTokenTypes[kk+2]->Label();
		if (matchString.Compare(idisplay_name))
        	count++;
        else
        	{
        	if(flag2[0]==1)
        		flag2[0]=0;	
        	else
        		count++;
        	}
        matchString.Format(format, findAResults[kkk+1]);
        if (matchString.Compare(idisplay_name))
        	count++;
        else
        	{
        	if(flag2[1]==1)
        		flag2[1]=0;	
        	else
        		count++;
        	}
        matchString.Format(format, findAResults[kkk+2]);
        if (matchString.Compare(idisplay_name))
        	count++;
        else
        	{
        	if(flag2[2]==1)
        		flag2[2]=0;	
        	else
        		count++;
        	}
        matchString.Format(format, findAResults[kkk+3]);
        if (matchString.Compare(idisplay_name))
        	count++;
        else
        	{
        	if(flag2[3]==1)
        		flag2[3]=0;	
        	else
        		count++;
        	}
        if(count==4)
        {
        	CleanupStack::PopAndDestroy(2);
			test.Printf(_L("FAILED\r\n"));
			return (8);
        }
     } 
		
	test.Printf(_L("PASSED\r\n"));

	myTokenTypes.ResetAndDestroy();
	test.Printf(_L("1.7,Testing filtering by interface and attribute,"));
	TCTTokenTypeAttribute att = {{gAttribute1}, 1};
	RArray<TCTTokenTypeAttribute> attArray(sizeof(TCTTokenTypeAttribute), &att,
										   1);
	TCTFindTokenTypesByInterfaceAndAttribute findAWithAtt1(a.Array(),
														   attArray.Array());
	CCTTokenTypeInfo::ListL(myTokenTypes, findAWithAtt1);
	if (myTokenTypes.Count() != 1)
		{
		CleanupStack::PopAndDestroy(2);
		test.Printf(_L("FAILED\r\n"));
		return (9);
		}
	_LIT(KMatch, "Test Token Type 6");
	if (myTokenTypes[0]->Label() != KMatch)
		{
		CleanupStack::PopAndDestroy(2);
		test.Printf(_L("FAILED\r\n"));
		return (10);
		}
	test.Printf(_L("PASSED\r\n"));

	CleanupStack::PopAndDestroy(2);
	return KErrNone;
	};

TInt TokenTypeInfoTestsL()
	{
	test.Printf(_L("2.1,Testing token type for tests,"));
	RCPointerArray<CCTTokenTypeInfo> myTokenTypes;
	CleanupClosePushL(myTokenTypes);
	TUid aABndC[] = {{gInterfaceA}, {gInterfaceB}, {gInterfaceC}};
	TTestArray<TUid> aABndCArray(aABndC, 3);
	TCTFindTokenTypesByInterface findABAndC(aABndCArray.Array());
	CCTTokenTypeInfo::ListL(myTokenTypes, findABAndC);
	if (myTokenTypes.Count() != 1)
		{
		CleanupStack::PopAndDestroy();
		test.Printf(_L("FAILED\r\n"));
		return (1);
		}
	test.Printf(_L("PASSED\r\n"));

	test.Printf(_L("2.2,Test UID function,"));
	CCTTokenTypeInfo* info = myTokenTypes[0];	
	if (info->Type().iUid != gImplementation6)
		{
		CleanupStack::PopAndDestroy();
		test.Printf(_L("FAILED\r\n"));
		return (1);
		}
	test.Printf(_L("PASSED\r\n"));

	test.Printf(_L("2.3,Test getting an array of interfaces,"));
	RArray<TUid> interfaces = info->Interfaces();
	if (interfaces.Count() != 3)
		{
		CleanupStack::PopAndDestroy();
		test.Printf(_L("FAILED\r\n"));
		return (4);
		}
	TUid refInterfaces[] = {{gInterfaceA}, {gInterfaceB}, {gInterfaceC}};
	for (TInt ii = 0; ii < 3; ii++)
		{
		if (interfaces[ii] != refInterfaces[ii])
			{
			CleanupStack::PopAndDestroy();
			test.Printf(_L("FAILED\r\n"));
			return (5);
			}
		}
	test.Printf(_L("PASSED\r\n"));

	test.Printf(_L("2.4,Test getting an array of attributes,"));
	RArray<TCTTokenTypeAttribute> attributes = info->Attributes();
	if (attributes.Count() != 2)
		{
		CleanupStack::PopAndDestroy();
		test.Printf(_L("FAILED\r\n"));
		return (8);
		}
	TCTTokenTypeAttribute refAttributes[] =
		{{{gAttribute2}, 2}, {{gAttribute1}, 1}};
	for (TInt jj = 0; jj < 2; jj++)
		{
		if (attributes[jj].iUID != refAttributes[jj].iUID ||
			attributes[jj].iVal != refAttributes[jj].iVal)
			{
			CleanupStack::PopAndDestroy();
			test.Printf(_L("FAILED\r\n"));
			return (9);
			}
		}
	test.Printf(_L("PASSED\r\n"));

	test.Printf(_L("2.5,Test getting the label,"));
	_LIT(KLabel, "Test Token Type 6");
	if (info->Label() != KLabel)
		{
		CleanupStack::PopAndDestroy();
		test.Printf(_L("FAILED\r\n"));
		return (10);
		}
	test.Printf(_L("PASSED\r\n"));

	test.Printf(_L("2.6,Test getting the type of the token type,"));
	TUid impl6 = {gImplementation6};
	if (info->Type() != impl6)
		{
		CleanupStack::PopAndDestroy();
		test.Printf(_L("FAILED\r\n"));
		return (11);
		}
	test.Printf(_L("PASSED\r\n"));

	CleanupStack::PopAndDestroy();
	return KErrNone;
	}


TInt TestTokenTypeL(MCTTokenType* aTokenType, TInt aNum)
	{
	test.Printf(_L("3.4.1,Getting token info,"));
	RCPointerArray<HBufC> tokenInfo;
	CleanupClosePushL(tokenInfo);
	TRequestStatus status = KRequestPending;
	aTokenType->List(tokenInfo, status);
	// Cancel call is pointelss as it does nothing in the test
	// plugin. But it won't do any harm to check it doesn't explode.
	aTokenType->CancelList();
	User::WaitForRequest(status);
	if (status.Int() != KErrNone || tokenInfo.Count() != 1)
		{
		CleanupStack::PopAndDestroy();
		test.Printf(_L("FAILED\r\n"));
		return (100);
		}
	test.Printf(_L("PASSED\r\n"));

	test.Printf(_L("3.4.1,Checking token type name,"));
	TBuf<20> buf;
	_LIT(KLabelFormat, "Test Token Type %d");
	buf.Format(KLabelFormat, aNum);
	if (aTokenType->Label().Compare(buf))
		{
		CleanupStack::PopAndDestroy();
		test.Printf(_L("FAILED\r\n"));
		return (105);
		}
	test.Printf(_L("PASSED\r\n"));

	test.Printf(_L("3.4.2,Checking token type Type UID,"));
	TUid uid = {gImplementation5 + 5 - aNum};
	if (aTokenType->Type() != uid)
		{
		CleanupStack::PopAndDestroy();
		test.Printf(_L("FAILED\r\n"));
		return (105);
		}
	test.Printf(_L("PASSED\r\n"));

	test.Printf(_L("3.4.3,Checking token name,"));
	_LIT(KFormat, "Test Token %d");
	buf.Format(KFormat, aNum);
	if (buf.Compare(*tokenInfo[0]))
		{
		CleanupStack::PopAndDestroy();
		test.Printf(_L("FAILED\r\n"));
		return (101);
		}
	test.Printf(_L("PASSED\r\n"));

	test.Printf(_L("3.4.4,Opening token,"));
	status = KRequestPending;
	MCTToken* token;
	aTokenType->OpenToken(*tokenInfo[0], token, status);
	// Cancel call will fail as token isn't opened asynchronous. Check
	// that the reference counting still works.
	aTokenType->CancelOpenToken();
	User::WaitForRequest(status);
	if (status.Int() != KErrNone)
		{
		CleanupStack::PopAndDestroy();
		test.Printf(_L("FAILED\r\n"));
		return (102);
		}
	token->Release();
	test.Printf(_L("PASSED\r\n"));

	test.Printf(_L("3.4.5,Opening token by handle,"));
	status = KRequestPending;
	TCTTokenHandle handle(aTokenType->Type(), 1);
	aTokenType->OpenToken(handle, token, status);
	User::WaitForRequest(status);
	if (status.Int() != KErrNone)
		{
		CleanupStack::PopAndDestroy();
		test.Printf(_L("FAILED\r\n"));
		return (102);
		}
	test.Printf(_L("PASSED\r\n"));

	test.Printf(_L("3.4.6,Checking token's TokenType() function,"));
	if (&token->TokenType() != aTokenType)
		{
		CleanupStack::PopAndDestroy();
		test.Printf(_L("FAILED\r\n"));
		return (102);
		}
	test.Printf(_L("PASSED\r\n"));

	_LIT(KVersion, "The Ultimate Version");
	_LIT(KSerial, "Serial No. 1");
	_LIT(KManufacturer, "ACME Corporation");

	test.Printf(_L("3.4.6.1,Checking token's Information() function,"));
	if (token->Information(MCTToken::EVersion) != KVersion ||
		token->Information(MCTToken::ESerialNo) != KSerial ||
		token->Information(MCTToken::EManufacturer)  != KManufacturer)
		{
		CleanupStack::PopAndDestroy();
		test.Printf(_L("FAILED\r\n"));
		return (102);
		}
	test.Printf(_L("PASSED\r\n"));

	test.Printf(_L("3.4.7,Registering for removal notification,"));
	// This is another test to check that an API doesn't crash. We
	// call the base NotifyOnRemoval/CancelNotify functions and check
	// they do nothing! There's no point in creating derived versions
	// that do something as that would be testing the test plugin, not
	// the framework.
	TRequestStatus removalStatus;
	token->NotifyOnRemoval(removalStatus);
	token->CancelNotify();
	test.Printf(_L("PASSED\r\n"));

	test.Printf(_L("3.4.9,Testing cancellation of async interface opening,"));
	MTestInterface* interface;
	MCTTokenInterface* temp;
	TUid intB = {gInterfaceB};
	token->GetInterface(intB, temp, status);
	token->CancelGetInterface();
	test.Printf(_L("PASSED\r\n"));

	test.Printf(_L("3.4.10,Opening an interface,"));
	status = KRequestPending;
	TUid intC = {gInterfaceC};
	token->GetInterface(intC, temp, status);
	interface = static_cast<MTestInterface*>(temp);
	// Cancel call is pointelss as it does nothing in the test
	// plugin. But it won't do any harm to check it doesn't explode.
	token->CancelGetInterface();
	CleanupReleasePushL(*interface);
	token->Release();
	User::WaitForRequest(status);
	if (status.Int() != KErrNone)
		{
		CleanupStack::PopAndDestroy(2);
		test.Printf(_L("FAILED\r\n"));
		return (103);
		}
	test.Printf(_L("PASSED\r\n"));

	test.Printf(_L("3.4.11,Checking interface name,"));
	if (buf.Compare(interface->Label()))
		{
		CleanupStack::PopAndDestroy(2);
		test.Printf(_L("FAILED\r\n"));
		return (104);
		}
	test.Printf(_L("PASSED\r\n"));

	test.Printf(_L("3.4.12,Getting an object,"));
	MTestObject* object = interface->ObjectL();
	object->Release();
	test.Printf(_L("PASSED\r\n"));

	CleanupStack::PopAndDestroy(2);
	return KErrNone;
	}

TInt TokenTypeTestsL()
	{
	test.Printf(_L("3.1,Getting token types for tests,"));
	RFs fs;
	RCPointerArray<CCTTokenTypeInfo> myTokenTypes;
	CleanupClosePushL(myTokenTypes);
	TUid aABndC[] = {{gInterfaceA}, {gInterfaceB}, {gInterfaceC}};
	TTestArray<TUid> aABandCArray(aABndC, 3);
	TCTFindTokenTypesByInterface findABAndC(aABandCArray.Array());
	CCTTokenTypeInfo::ListL(myTokenTypes, findABAndC);
	if (myTokenTypes.Count() != 1)
		{
		CleanupStack::PopAndDestroy();
		test.Printf(_L("FAILED\r\n"));
		return (1);
		}
	test.Printf(_L("PASSED\r\n"));

	test.Printf(_L("3.2,Loading token type 6,"));
	MCTTokenType* token6 = MCTTokenType::NewL(*myTokenTypes[0], fs);
	if (!token6)
		{
		CleanupStack::PopAndDestroy();
		test.Printf(_L("FAILED\r\n"));
		return (1);
		}
	CleanupReleasePushL(*token6);
	test.Printf(_L("PASSED\r\n"));

	TInt ret = TestTokenTypeL(token6, 6);
	if (ret)
		{
		CleanupStack::PopAndDestroy(2);
		return ret;
		}

	test.Printf(_L("3.3,Loading token type 5,"));
	TUid UID5 = {gImplementation5};
	MCTTokenType* token5 = MCTTokenType::NewL(UID5, fs);
	if (!token5)
		{
		CleanupStack::PopAndDestroy(2);
		test.Printf(_L("FAILED\r\n"));
		return (2);
		}
	CleanupReleasePushL(*token5);
	test.Printf(_L("PASSED\r\n"));

	ret = TestTokenTypeL(token5, 5);
	CleanupStack::PopAndDestroy(3);

	return ret;
	}

TInt MemoryTestL(TInt (*aFnToTest)())
	{
	gLogging = EFalse;
	for (TInt ii = 1; ; ii++)
		{
		if (ii % 10)
			test.Printf(_L("."));
		else
			test.Printf(_L("*"));
		if (!(ii % 50))
			test.Printf(_L("\r\n"));
		gSilent = ETrue;
		__UHEAP_MARK;
		__UHEAP_FAILNEXT(ii);
		TRAPD(err,aFnToTest());
		__UHEAP_RESET;
		REComSession::FinalClose();
		__UHEAP_MARKEND;
		User::Heap().Check();
		gSilent = EFalse;
		if (err != KErrNoMemory)
			{
			test.Printf(_L("\r\n"));
			gLogging = ETrue;
			return err;
			}
		}
	}

void TestsL(void)
	{
	CActiveScheduler* as = new(ELeave) CActiveScheduler;
	CActiveScheduler::Install(as);

	TInt errors = 0;
	TInt ret;
	__UHEAP_MARK;
	ret = TokenTypeInfoListTestsL();
	REComSession::FinalClose();
	__UHEAP_MARKEND;
	if (ret)
		{
		test.Printf(_L("1.9,ERROR %d in Info List test,FAILED\r\n"),ret);
		errors++;
		}
	else
		{
		test.Printf(_L("1.9,Info List test,PASSED\r\n"),ret);
		}
	__UHEAP_MARK;
	ret = TokenTypeInfoTestsL();
	REComSession::FinalClose();
	__UHEAP_MARKEND;
	if (ret)
		{
		test.Printf(_L("2.9,ERROR %d in Info test,FAILED\r\n"),ret);
		errors++;
		}
	else
		{
		test.Printf(_L("2.9,Info test,PASSED\r\n"),ret);
		}

	__UHEAP_MARK;
	ret = TokenTypeTestsL();
	REComSession::FinalClose();
	__UHEAP_MARKEND;
	if (ret)
		{
		test.Printf(_L("3.9,ERROR %d in token test,FAILED\r\n"),ret);
		errors++;
		}
	else
		{
		test.Printf(_L("3.9,token test,PASSED\r\n"),ret);
		}

	ret = MemoryTestL(TokenTypeInfoListTestsL);
	if (ret)
		{
		test.Printf(_L("4.9,ERROR %d in Info List memory test,FAILED\r\n"),ret);
		errors++;
		}
	else
		{
		test.Printf(_L("4.9,Info List memory test,PASSED\r\n"),ret);
		}
	ret = MemoryTestL(TokenTypeTestsL);
	if (ret)
		{
		test.Printf(_L("5.9,ERROR %d in Token Type memory test,FAILED\r\n"),ret);
		errors++;
		}
	else
		{
		test.Printf(_L("5.9,Token Type memory test,PASSED\r\n"),ret);
		}

	test.Printf(_L("%d tests failed out of 44 hardcoded\r\n"), errors);


	if (errors)
		{
		test.Printf(_L("%d TESTS FAILED\r\n"),errors);
		}
	else
		{
		test.Printf(_L("ALL TESTS PASSED\r\n"));
		}

	delete as;
	}

GLDEF_C TInt E32Main(void)

	{
	CTrapCleanup* cleanup;
	cleanup=CTrapCleanup::New();
	test.Start(_L(" @SYMTestCaseID:SEC-CRYPTOTOKENS-CTFRAMEWORK-0001 Starting token framework tests\r\n"));		 
	CTestConsole* con=NULL;
	TRAPD(ret,con=CTestConsole::NewL(test.Console()));
	RFs fs;
	if (gLogging)
		{
		User::LeaveIfError(fs.Connect());
		RFile* file;
		file=new (ELeave) RFile;
		TDriveUnit sysDrive (fs.GetSystemDrive());
		TDriveName driveName(sysDrive.Name());
		TBuf<64> logFile (driveName);
		logFile.Append(_L("\\T_CTFrameworkLog.txt"));
		User::LeaveIfError(file->Replace(fs, logFile, EFileShareAny|EFileWrite));
		con->SetLogFile(file);
		}
	test.SetConsole(con);
	TRAP(ret,TestsL());
	if (ret)
		{
		test.Printf(_L("Unexpected leave\r\n"));
		}
	gLogging=EFalse;
	test.Close();
	delete cleanup;
	return(KErrNone);
	}