symport/e32test/buffer/t_key.cpp
author jjkang
Fri, 11 Jun 2010 15:22:09 +0800
changeset 2 806186ab5e14
parent 1 0a7b44b10206
permissions -rw-r--r--
Change SFL to EPL

// Copyright (c) 1995-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:
// e32test\buffer\t_key.cpp
// Overview:
// Test arrays keys against flat and segmented arrays of characters (8 and 16 bit) and records.
// API Information:
// TKeyArrayFix, TKeyArrayVar.
// Details:
// - Create flat and segmented array of TText8, TText16, TText. Append some text to the 
// arrays and test the functions of the TKeyArrayFix class using the Find method which 
// calls SetPtr, Set, Compare methods with ECmpNormal8, ECmpFolded8, ECmpCollated8, 
// ECmpNormal16, ECmpFolded16, ECmpCollated16, ECmpNormal, ECmpFolded, ECmpCollated key types.
// - Test the functions of the TKeyArrayVar class using the Find method which calls SetPtr, Set, 
// Compare methods with ECmpNormal8, ECmpFolded8, ECmpCollated8, ECmpNormal16, ECmpFolded16, 
// ECmpCollated16, ECmpNormal, ECmpFolded, ECmpCollated key types.
// - Create flat and segmented array of TText, append some structures with different values.
// - Test the functions of the TKeyArrayFix, TKeyArrayVar classes by searching the values using 
// sequential search technique with ECmpNormal, ECmpTInt32 key type and verifying that it is 
// found at correct position.
// - For TKeyArrayFix and TKeyArrayVar class, create a flat array of TText, append some structures 
// with different numeric values, sort the array, search the values using ECmpTInt, ECmpTUint, 
// ECmpTint8, ECmpTUint8, ECmpTint16, ECmpTUint16, ECmpTint32, ECmpTUint32 key types and verify 
// that values are found in order as expected.
// Platforms/Drives/Compatibility:
// All 
// Assumptions/Requirement/Pre-requisites:
// Failures and causes:
// Base Port information:
// 
//

#include <e32std.h>
#include <e32base.h>
#include <e32test.h>
#include <e32svr.h>
#include <e32ver.h>

#ifdef __VC32__
#pragma warning (disable:4710)	// Function not expanded
#pragma warning (disable:4702)	// Unreachable code
#endif

const TInt KTestGranularity=0x02;

LOCAL_D RTest test(_L("T_KEY"));

template <class T,TInt S>
class TArr
	{
public:
	TArr() {}
	TInt Count() const {return S;}
	T& operator[](TInt anIndex) {return iArr[anIndex];}
	const T& operator[](TInt anIndex) const {return iArr[anIndex];}
private:
	T iArr[S];
	};

//#if defined(_DEBUG)
struct Record
	{
	TBuf<0x10> name;  
	TInt32	age;
	TText8	code;
	};

struct Record2
	{
	TInt	tint;
	TUint	tuint;
	TInt8	tint8;
	TUint8	tuint8;
	TInt16  tint16;
	TUint16 tuint16;
	TInt32  tint32;
	TUint32 tuint32;
	}Rec1, Rec2, Rec3, Rec4;		
		
LOCAL_C void SetRecordData(void)
	{
	Rec1.tint=KMaxTInt;
	Rec2.tint=0;
	Rec3.tint=-KMaxTInt;
	Rec4.tint=KMinTInt;
	Rec1.tint8=KMaxTInt8;
	Rec2.tint8=0;
	Rec3.tint8=-KMaxTInt8;
	Rec4.tint8=(TInt8)KMinTInt8;
	Rec1.tint16=KMaxTInt16;
	Rec2.tint16=0;
	Rec3.tint16=-KMaxTInt16;
	Rec4.tint16=(TInt16)KMinTInt16;
	Rec1.tint32=KMaxTInt32;
	Rec2.tint32=0;
	Rec3.tint32=-KMaxTInt32;
	Rec4.tint32=(TInt32)KMinTInt32;
	Rec1.tuint=0;
	Rec2.tuint=1;
	Rec3.tuint=KMaxTUint-1;
	Rec4.tuint=KMaxTUint;
	Rec1.tuint8=0;
	Rec2.tuint8=1;
	Rec3.tuint8=(TUint8)(KMaxTUint8-1);
	Rec4.tuint8=(TUint8)KMaxTUint8;
	Rec1.tuint16=0;
	Rec2.tuint16=1;
	Rec3.tuint16=(TUint16)(KMaxTUint16-1);
	Rec4.tuint16=(TUint16)KMaxTUint16;
	Rec1.tuint32=0;
	Rec2.tuint32=1;
	Rec3.tuint32=(TUint32)(KMaxTUint32-1);
	Rec4.tuint32=KMaxTUint32;
	}

typedef enum {eEight, eSixteen} TMode;
			
template<class KeyType, class ArrayType, class S> // S is TText8, TTExt etc. called S as _TL requires S in e32test.h
class TestTKey
	{
public:
	void Test1(TKeyCmpText, TKeyCmpText, TKeyCmpText);
	void Test2(TKeyCmpText, TKeyCmpText, TKeyCmpText);
	void Test3(void);
	void Test4(void);
	void Test5(void);
	void Test6(void);
	};

template<class KeyType, class ArrayType, class S>
GLDEF_C void TestTKey<KeyType, ArrayType, S>::Test1(TKeyCmpText N, TKeyCmpText F, TKeyCmpText C)
	{
	// This tests the functions of the TKey classes indirectly - mostly using the Find method
	// which calls SetPtr(), Set() (both trivial) and more importantly Compare(), 

	ArrayType* pArray=new ArrayType(KTestGranularity);
	pArray->AppendL(*(const TArr<S,5>*)_TL("aa cc"));
	pArray->AppendL(*(const TArr<S,5>*)_TL("bb bb"));
	pArray->AppendL(*(const TArr<S,5>*)_TL("cc aa"));

	KeyType NormalKey(0,N,5);	
	KeyType NormalKeyOffset(sizeof(S)*3,N,2) ;
	KeyType FoldedKey(0,F,5);
	KeyType FoldedKeyOffset(sizeof(S)*3,F,2);	
	KeyType CollatedKey(0,C,5);
	KeyType CollatedKeyOffset(sizeof(S)*3,C,2);

	TInt pos;
	test(pArray->Find(*(const TArr<S,5>*)_TL("aa cc"), NormalKey, pos)==0);
	test(pos==0);
	test(pArray->Find(*(const TArr<S,5>*)_TL("bb bb"), NormalKey, pos)==0);
	test(pos==1);
	test(pArray->Find(*(const TArr<S,5>*)_TL("cc aa"), NormalKey, pos)==0);
	test(pos==2);	
	test(pArray->Find(*(const TArr<S,5>*)_TL("BB BB"), NormalKey, pos)!=0);


	test(pArray->Find(*(const TArr<S,5>*)_TL("___cc"), NormalKeyOffset, pos)==0);
	test(pos==0);
	test(pArray->Find(*(const TArr<S,5>*)_TL("___bb"), NormalKeyOffset, pos)==0);
	test(pos==1);
	test(pArray->Find(*(const TArr<S,5>*)_TL("___aa"), NormalKeyOffset, pos)==0);
	test(pos==2);
	test(pArray->Find(*(const TArr<S,5>*)_TL("___ax"), NormalKeyOffset, pos)!=0);


	test(pArray->Find(*(const TArr<S,5>*)_TL("aa cc"), FoldedKey, pos)==0);
	test(pos==0);
	test(pArray->Find(*(const TArr<S,5>*)_TL("bb bb"), FoldedKey, pos)==0);
	test(pos==1);
	test(pArray->Find(*(const TArr<S,5>*)_TL("cc aa"), FoldedKey, pos)==0);
	test(pos==2);


	test(pArray->Find(*(const TArr<S,5>*)_TL("___CC"), FoldedKeyOffset, pos)==0);
	test(pos==0);
	test(pArray->Find(*(const TArr<S,5>*)_TL("___bB"), FoldedKeyOffset, pos)==0);
	test(pos==1);
	test(pArray->Find(*(const TArr<S,5>*)_TL("___Aa"), FoldedKeyOffset, pos)==0);
	test(pos==2);
	test(pArray->Find(*(const TArr<S,5>*)_TL("___ax"), FoldedKeyOffset, pos)!=0);


	test(pArray->Find(*(const TArr<S,5>*)_TL("aa cc"), CollatedKey, pos)==0);
	test(pos==0);
	test(pArray->Find(*(const TArr<S,5>*)_TL("bb bb"), CollatedKey, pos)==0);
	test(pos==1);
	test(pArray->Find(*(const TArr<S,5>*)_TL("cc aa"), CollatedKey, pos)==0);
	test(pos==2);


	test(pArray->Find(*(const TArr<S,5>*)_TL("___cc"), CollatedKeyOffset, pos)==0);
	test(pos==0);
	test(pArray->Find(*(const TArr<S,5>*)_TL("___bb"), CollatedKeyOffset, pos)==0);
	test(pos==1);
	test(pArray->Find(*(const TArr<S,5>*)_TL("___aa"), CollatedKeyOffset, pos)==0);
	test(pos==2);
	test(pArray->Find(*(const TArr<S,5>*)_TL("___ax"), CollatedKeyOffset, pos)!=0);

	delete pArray;
	}


template<class KeyType, class ArrayType, class S>
GLDEF_C void TestTKey<KeyType, ArrayType, S>::Test2(TKeyCmpText N, TKeyCmpText F, TKeyCmpText C)
	{
	// This tests the functions of the TKey classes indirectly - mostly using the Find method
	// which calls SetPtr(), Set() (both trivial) and more importantly Compare(), 

	ArrayType* pArray=new ArrayType(KTestGranularity);
	pArray->AppendL(*(S(*))_TL("aa cc"), 5*sizeof(S));
	pArray->AppendL(*(S(*))_TL("bb bbb"), 6*sizeof(S));
	pArray->AppendL(*(S(*))_TL("cc aaaa"), 7*sizeof(S));

	KeyType NormalKey5(0,N,5);		 
	KeyType NormalKey6(0,N,6);		
	KeyType NormalKey7(0,N,7);
	KeyType NormalKeyOffset(sizeof(S)*3,N,2); 

	KeyType FoldedKey5(0,F,5);
	KeyType FoldedKey6(0,F,6);
	KeyType FoldedKey7(0,F,7);
	KeyType FoldedKeyOffset(sizeof(S)*3,F,2);	

	KeyType CollatedKey5(0,C,5);
	KeyType CollatedKey6(0,C,6);
	KeyType CollatedKey7(0,C,7);
	KeyType CollatedKeyOffset(sizeof(S)*3,C,2);

	TInt pos;
	test(pArray->Find(*(S(*))_TL("aa cc"), NormalKey5, pos)==0);
	test(pos==0);
	test(pArray->Find(*(S(*))_TL("bb bbb"), NormalKey6, pos)==0);
	test(pos==1);
	test(pArray->Find(*(S(*))_TL("cc aaaa"), NormalKey7, pos)==0);
	test(pos==2);	
	test(pArray->Find(*(S(*))_TL("BB BB"), NormalKey5, pos)!=0);


	test(pArray->Find(*(S(*))_TL("___cc"), NormalKeyOffset, pos)==0);
	test(pos==0);
	test(pArray->Find(*(S(*))_TL("___bb"), NormalKeyOffset, pos)==0);
	test(pos==1);
	test(pArray->Find(*(S(*))_TL("___aa"), NormalKeyOffset, pos)==0);
	test(pos==2);  
	test(pArray->Find(*(S(*))_TL("___ax"), NormalKeyOffset, pos)!=0);


	test(pArray->Find(*(S(*))_TL("aa cc"), FoldedKey5, pos)==0);
	test(pos==0);
	test(pArray->Find(*(S(*))_TL("bb bbb"), FoldedKey6, pos)==0);
	test(pos==1);
	test(pArray->Find(*(S(*))_TL("cc aaaa"), FoldedKey7, pos)==0);
	test(pos==2);


	test(pArray->Find(*(S(*))_TL("___CC"), FoldedKeyOffset, pos)==0);
	test(pos==0);
	test(pArray->Find(*(S(*))_TL("___bB"), FoldedKeyOffset, pos)==0);
	test(pos==1);
	test(pArray->Find(*(S(*))_TL("___Aa"), FoldedKeyOffset, pos)==0);
	test(pos==2);
	test(pArray->Find(*(S(*))_TL("___ax"), FoldedKeyOffset, pos)!=0);


	test(pArray->Find(*(S(*))_TL("aa cc"), CollatedKey5, pos)==0);
	test(pos==0);
	test(pArray->Find(*(S(*))_TL("bb bbb"), CollatedKey6, pos)==0);
	test(pos==1);
	test(pArray->Find(*(S(*))_TL("cc aaaa"), CollatedKey7, pos)==0);
	test(pos==2);


	test(pArray->Find(*(S(*))_TL("___cc"), CollatedKeyOffset, pos)==0);
	test(pos==0);
	test(pArray->Find(*(S(*))_TL("___bb"), CollatedKeyOffset, pos)==0);
	test(pos==1);
	test(pArray->Find(*(S(*))_TL("___aa"), CollatedKeyOffset, pos)==0);
	test(pos==2);
	test(pArray->Find(*(S(*))_TL("___ax"), CollatedKeyOffset, pos)!=0);

	delete pArray;
	}


template<class KeyType, class ArrayType, class S>
GLDEF_C void TestTKey<KeyType, ArrayType, S>::Test3(void)
	{
	ArrayType* pArray=new ArrayType(KTestGranularity);
	Record rec1, rec2, rec3;

	rec1.name=(_TL("fred"));
	rec1.age=5;
	rec1.code='A';

	rec2.name=(_TL("bill"));
	rec2.age=0x7fffffff;
	rec2.code='Z';

	rec3.name=(_TL("bert"));
	rec3.age=-5;
	rec3.code='X';

	pArray->AppendL(rec1);
	pArray->AppendL(rec2);
	pArray->AppendL(rec3);
	
	TInt pos;	 

	KeyType codekey(_FOFF(Record, code),ECmpNormal,1);
	test(pArray->Find(rec1, codekey, pos)==0);
	test(pos==0);
	test(pArray->Find(rec2, codekey, pos)==0);
	test(pos==1);
	test(pArray->Find(rec3, codekey, pos)==0);
	test(pos==2);

	KeyType agekey(_FOFF(Record, age), ECmpTInt32);
	test(pArray->Find(rec1, agekey, pos)==0);
	test(pos==0);
	test(pArray->Find(rec2, agekey, pos)==0);
	test(pos==1);
	test(pArray->Find(rec3, agekey, pos)==0);
	test(pos==2);

	rec1.age=-50; // march 95 - this isn't allowed , lucky that it works
	test(pArray->Find(rec1, agekey, pos)!=0);
	rec1.age=5;

	pArray->Sort(agekey);
	test(pArray->Find(rec1, agekey, pos)==0);
	test(pos==1);
	test(pArray->Find(rec2, agekey, pos)==0);
	test(pos==2);
	test(pArray->Find(rec3, agekey, pos)==0);
	test(pos==0);

	delete pArray;
	}

template<class KeyType, class ArrayType, class S>
GLDEF_C void TestTKey<KeyType, ArrayType, S>::Test4(void)
	{
	ArrayType* pArray=new ArrayType(KTestGranularity);
	Record rec1, rec2, rec3;
	
	rec1.name=(_TL("fred"));
	rec1.age=5;
	rec1.code='A';
	rec2.name=(_TL("bill"));
	rec2.age=0x7fffffff;
	rec2.code='Z';
	rec3.name=(_TL("bert"));
	rec3.age=-5;
	rec3.code='X';

	pArray->AppendL(rec1, sizeof(Record));
	pArray->AppendL(rec2, sizeof(Record));
	pArray->AppendL(rec3, sizeof(Record));

	TInt pos;
	KeyType codekey(_FOFF(Record, code),ECmpNormal,1);
	test(pArray->Find(rec1, codekey, pos)==0);
	test(pos==0);
	test(pArray->Find(rec2, codekey, pos)==0);
	test(pos==1);
	test(pArray->Find(rec3, codekey, pos)==0);
	test(pos==2);

	KeyType agekey(_FOFF(Record, age), ECmpTInt32);
	test(pArray->Find(rec1, agekey, pos)==0);
	test(pos==0);
	test(pArray->Find(rec2, agekey, pos)==0);
	test(pos==1);
	test(pArray->Find(rec3, agekey, pos)==0);
	test(pos==2);
	rec1.age=-50;					// march 95 - this isn't allowed - lucky to get away with it
	test(pArray->Find(rec1, agekey, pos)!=0);
	rec1.age=5;

	pArray->Sort(agekey);
	test(pArray->Find(rec1, agekey, pos)==0);
	test(pos==1);
	test(pArray->Find(rec2, agekey, pos)==0);
	test(pos==2);
	test(pArray->Find(rec3, agekey, pos)==0);
	test(pos==0);

	delete pArray;
	}

template<class KeyType, class ArrayType, class S>
GLDEF_C void TestTKey<KeyType, ArrayType, S>::Test5(void)
	{
	// test the numeric enumeration types
	ArrayType* pArray=new ArrayType(KTestGranularity);
	TInt pos;
	
	KeyType TIntKey(_FOFF(Record2, tint), ECmpTInt);
	KeyType TUintKey(_FOFF(Record2, tuint), ECmpTUint);
	KeyType TInt8Key(_FOFF(Record2, tint8), ECmpTInt8);
	KeyType TUint8Key(_FOFF(Record2, tuint8), ECmpTUint8);
	KeyType TInt16Key(_FOFF(Record2, tint16), ECmpTInt16);
	KeyType TUint16Key(_FOFF(Record2, tuint16), ECmpTUint16);
	KeyType TInt32Key(_FOFF(Record2, tint32), ECmpTInt32);
	KeyType TUint32Key(_FOFF(Record2, tuint32), ECmpTUint32);

	SetRecordData();

	pArray->AppendL(Rec1);
	pArray->AppendL(Rec2);
	pArray->AppendL(Rec3);
	pArray->AppendL(Rec4);

	pArray->Sort(TIntKey);
	// order should be 4,3,2,1
	test(pArray->Find(Rec4, TIntKey, pos)==0);
	test(pos==0);
	test(pArray->Find(Rec3, TIntKey, pos)==0);
	test(pos==1);
	test(pArray->Find(Rec2, TIntKey, pos)==0);
	test(pos==2);
	test(pArray->Find(Rec1, TIntKey, pos)==0);
	test(pos==3);

	pArray->Sort(TUintKey);
	// order should be 1,2,3,4
	test(pArray->Find(Rec1, TUintKey, pos)==0);
	test(pos==0);
	test(pArray->Find(Rec2, TUintKey, pos)==0);
	test(pos==1);
	test(pArray->Find(Rec3, TUintKey, pos)==0);
	test(pos==2);
	test(pArray->Find(Rec4, TUintKey, pos)==0);
	test(pos==3);

	pArray->Sort(TInt8Key);
	// order should be 4,3,2,1
	test(pArray->Find(Rec4, TInt8Key, pos)==0);
	test(pos==0);
	test(pArray->Find(Rec3, TInt8Key, pos)==0);
	test(pos==1);
	test(pArray->Find(Rec2, TInt8Key, pos)==0);
	test(pos==2);
	test(pArray->Find(Rec1, TInt8Key, pos)==0);
	test(pos==3);

	pArray->Sort(TUint8Key);
	// order should be 1,2,3,4
	test(pArray->Find(Rec1, TUint8Key, pos)==0);
	test(pos==0);
	test(pArray->Find(Rec2, TUint8Key, pos)==0);
	test(pos==1);
	test(pArray->Find(Rec3, TUint8Key, pos)==0);
	test(pos==2);
	test(pArray->Find(Rec4, TUint8Key, pos)==0);
	test(pos==3);

	pArray->Sort(TInt16Key);
	// order should be 4,3,2,1
	test(pArray->Find(Rec4, TInt16Key, pos)==0);
	test(pos==0);
	test(pArray->Find(Rec3, TInt16Key, pos)==0);
	test(pos==1);
	test(pArray->Find(Rec2, TInt16Key, pos)==0);
	test(pos==2);
	test(pArray->Find(Rec1, TInt16Key, pos)==0);
	test(pos==3);

	pArray->Sort(TUintKey);
	// order should be 1,2,3,4
	test(pArray->Find(Rec1, TUint16Key, pos)==0);
	test(pos==0);
	test(pArray->Find(Rec2, TUint16Key, pos)==0);
	test(pos==1);
	test(pArray->Find(Rec3, TUint16Key, pos)==0);
	test(pos==2);
	test(pArray->Find(Rec4, TUint16Key, pos)==0);
	test(pos==3);

	pArray->Sort(TInt32Key);
	// order should be 4,3,2,1
	test(pArray->Find(Rec4, TInt32Key, pos)==0);
	test(pos==0);
	test(pArray->Find(Rec3, TInt32Key, pos)==0);
	test(pos==1);
	test(pArray->Find(Rec2, TInt32Key, pos)==0);
	test(pos==2);
	test(pArray->Find(Rec1, TInt32Key, pos)==0);
	test(pos==3);

	pArray->Sort(TUint32Key);
	// order should be 1,2,3,4
	test(pArray->Find(Rec1, TUint32Key, pos)==0);
	test(pos==0);
	test(pArray->Find(Rec2, TUint32Key, pos)==0);
	test(pos==1);
	test(pArray->Find(Rec3, TUint32Key, pos)==0);
	test(pos==2);
	test(pArray->Find(Rec4, TUint32Key, pos)==0);
	test(pos==3);

	delete pArray;
	}

template<class KeyType, class ArrayType, class S>
GLDEF_C void TestTKey<KeyType, ArrayType, S>::Test6(void)
	{
	// test the numeric enumeration types
	ArrayType* pArray=new ArrayType(KTestGranularity);
	TInt pos;
	
	KeyType TIntKey(_FOFF(Record2, tint), ECmpTInt);
	KeyType TUintKey(_FOFF(Record2, tuint), ECmpTUint);
	KeyType TInt8Key(_FOFF(Record2, tint8), ECmpTInt8);
	KeyType TUint8Key(_FOFF(Record2, tuint8), ECmpTUint8);
	KeyType TInt16Key(_FOFF(Record2, tint16), ECmpTInt16);
	KeyType TUint16Key(_FOFF(Record2, tuint16), ECmpTUint16);
	KeyType TInt32Key(_FOFF(Record2, tint32), ECmpTInt32);
	KeyType TUint32Key(_FOFF(Record2, tuint32), ECmpTUint32);

	SetRecordData();

	pArray->AppendL(Rec1, sizeof(Record2));
	pArray->AppendL(Rec2, sizeof(Record2));
	pArray->AppendL(Rec3, sizeof(Record2));
	pArray->AppendL(Rec4, sizeof(Record2));

	pArray->Sort(TIntKey);
	// order should be 4,3,2,1
	test(pArray->Find(Rec4, TIntKey, pos)==0);
	test(pos==0);
	test(pArray->Find(Rec3, TIntKey, pos)==0);
	test(pos==1);
	test(pArray->Find(Rec2, TIntKey, pos)==0);
	test(pos==2);
	test(pArray->Find(Rec1, TIntKey, pos)==0);
	test(pos==3);

	pArray->Sort(TUintKey);
	// order should be 1,2,3,4
	test(pArray->Find(Rec1, TUintKey, pos)==0);
	test(pos==0);
	test(pArray->Find(Rec2, TUintKey, pos)==0);
	test(pos==1);
	test(pArray->Find(Rec3, TUintKey, pos)==0);
	test(pos==2);
	test(pArray->Find(Rec4, TUintKey, pos)==0);
	test(pos==3);

	pArray->Sort(TInt8Key);
	// order should be 4,3,2,1
	test(pArray->Find(Rec4, TInt8Key, pos)==0);
	test(pos==0);
	test(pArray->Find(Rec3, TInt8Key, pos)==0);
	test(pos==1);
	test(pArray->Find(Rec2, TInt8Key, pos)==0);
	test(pos==2);
	test(pArray->Find(Rec1, TInt8Key, pos)==0);
	test(pos==3);

	pArray->Sort(TUint8Key);
	// order should be 1,2,3,4
	test(pArray->Find(Rec1, TUint8Key, pos)==0);
	test(pos==0);
	test(pArray->Find(Rec2, TUint8Key, pos)==0);
	test(pos==1);
	test(pArray->Find(Rec3, TUint8Key, pos)==0);
	test(pos==2);
	test(pArray->Find(Rec4, TUint8Key, pos)==0);
	test(pos==3);

	pArray->Sort(TInt16Key);
	// order should be 4,3,2,1
	test(pArray->Find(Rec4, TInt16Key, pos)==0);
	test(pos==0);
	test(pArray->Find(Rec3, TInt16Key, pos)==0);
	test(pos==1);
	test(pArray->Find(Rec2, TInt16Key, pos)==0);
	test(pos==2);
	test(pArray->Find(Rec1, TInt16Key, pos)==0);
	test(pos==3);

	pArray->Sort(TUintKey);
	// order should be 1,2,3,4
	test(pArray->Find(Rec1, TUint16Key, pos)==0);
	test(pos==0);
	test(pArray->Find(Rec2, TUint16Key, pos)==0);
	test(pos==1);
	test(pArray->Find(Rec3, TUint16Key, pos)==0);
	test(pos==2);
	test(pArray->Find(Rec4, TUint16Key, pos)==0);
	test(pos==3);

	pArray->Sort(TInt32Key);
	// order should be 4,3,2,1
	test(pArray->Find(Rec4, TInt32Key, pos)==0);
	test(pos==0);
	test(pArray->Find(Rec3, TInt32Key, pos)==0);
	test(pos==1);
	test(pArray->Find(Rec2, TInt32Key, pos)==0);
	test(pos==2);
	test(pArray->Find(Rec1, TInt32Key, pos)==0);
	test(pos==3);

	pArray->Sort(TUint32Key);
	// order should be 1,2,3,4
	test(pArray->Find(Rec1, TUint32Key, pos)==0);
	test(pos==0);
	test(pArray->Find(Rec2, TUint32Key, pos)==0);
	test(pos==1);
	test(pArray->Find(Rec3, TUint32Key, pos)==0);
	test(pos==2);
	test(pArray->Find(Rec4, TUint32Key, pos)==0);
	test(pos==3);

	delete pArray;
	}

GLDEF_C TInt E32Main()
    {

	test.Title();	
	test.Start(_L("Fixed key class with a flat array of TText8"));
	typedef CArrayFixFlat<TArr<TText8,5> >  aFixedFlatArrayOfTText8;		
	TestTKey<TKeyArrayFix, aFixedFlatArrayOfTText8, TText8> T1;
	T1.Test1(ECmpNormal8, ECmpFolded8, ECmpCollated8);
  
	test.Next(_L("Fixed key class with a flat array of TText16"));
	typedef CArrayFixFlat<TArr<TText16,5> >  aFixedFlatArrayOfTText16;		
	TestTKey<TKeyArrayFix, aFixedFlatArrayOfTText16, TText16> T2;
	T2.Test1(ECmpNormal16, ECmpFolded16, ECmpCollated16);

	test.Next(_L("Fixed key class with a flat array of TText"));
	typedef CArrayFixFlat<TArr<TText,5> >  aFixedFlatArrayOfTText;		
	TestTKey<TKeyArrayFix, aFixedFlatArrayOfTText, TText> T3;
	T3.Test1(ECmpNormal, ECmpFolded, ECmpCollated);

	test.Next(_L("Fixed key class with a segmented array of TText8"));
	typedef CArrayFixSeg<TArr<TText8,5> >  aFixedSegmentedArrayOfTText8;		
	TestTKey<TKeyArrayFix, aFixedSegmentedArrayOfTText8, TText8> T4;
	T4.Test1(ECmpNormal8, ECmpFolded8, ECmpCollated8);
						   
	test.Next(_L("Fixed key class with a segmented array of TText16"));
	typedef CArrayFixSeg<TArr<TText16,5> >  aFixedSegmentedArrayOfTText16;		
	TestTKey<TKeyArrayFix, aFixedSegmentedArrayOfTText16, TText16> T5;
	T5.Test1(ECmpNormal16, ECmpFolded16, ECmpCollated16);

	test.Next(_L("Fixed key class with a segmented array of TText"));
	typedef CArrayFixSeg<TArr<TText,5> >  aFixedSegmentedArrayOfTText;		
	TestTKey<TKeyArrayFix, aFixedSegmentedArrayOfTText, TText> T6;
	T6.Test1(ECmpNormal, ECmpFolded, ECmpCollated);

	test.Next(_L("Var key with a flat array of TText8"));
	typedef CArrayVarFlat<TText8> aVarFlatArrayOfTText8;
	TestTKey<TKeyArrayVar, aVarFlatArrayOfTText8, TText8> T7;
	T7.Test2(ECmpNormal8, ECmpFolded8, ECmpCollated8);

	test.Next(_L("Var key with a flat array of TText16"));
	typedef CArrayVarFlat<TText16> aVarFlatArrayOfTText16;
	TestTKey<TKeyArrayVar, aVarFlatArrayOfTText16, TText16> T8;
	T8.Test2(ECmpNormal16, ECmpFolded16, ECmpCollated16);

	test.Next(_L("Var key with a flat array of TText"));
	typedef CArrayVarFlat<TText> aVarFlatArrayOfTText;
	TestTKey<TKeyArrayVar, aVarFlatArrayOfTText, TText> T9;
	T9.Test2(ECmpNormal, ECmpFolded, ECmpCollated);

	test.Next(_L("Var key with a segmented array of TText8"));
	typedef CArrayVarSeg<TText8> aVarSegmentedArrayOfTText8;
	TestTKey<TKeyArrayVar, aVarSegmentedArrayOfTText8, TText8> T10;
	T10.Test2(ECmpNormal8, ECmpFolded8, ECmpCollated8);	

	test.Next(_L("Var key with a segmented array of TText16"));
	typedef CArrayVarSeg<TText16> aVarSegmentedArrayOfTText16;
	TestTKey<TKeyArrayVar, aVarSegmentedArrayOfTText16, TText16> T11;
	T11.Test2(ECmpNormal16, ECmpFolded16, ECmpCollated16);

	test.Next(_L("Var key with a segmented array of TText"));
	typedef CArrayVarSeg<TText> aVarSegmentedArrayOfTText;
	TestTKey<TKeyArrayVar, aVarSegmentedArrayOfTText, TText> T12;
	T12.Test2(ECmpNormal, ECmpFolded, ECmpCollated);

	test.Next(_L("Fixed key with a flat array of structs"));
	typedef CArrayFixFlat<Record> aFixedFlatArrayOfRecord;
	TestTKey<TKeyArrayFix, aFixedFlatArrayOfRecord, TText> T13;
	T13.Test3();

	test.Next(_L("Fixed key with a segmented array of structs"));
	typedef CArrayFixSeg<Record> aFixedSegmentedArrayOfRecord;
	TestTKey<TKeyArrayFix, aFixedSegmentedArrayOfRecord, TText> T14;
	T14.Test3();
  
	test.Next(_L("Var key with a flat array of structs"));
	typedef CArrayVarFlat<Record> aVarFlatArrayOfRecord;
	TestTKey<TKeyArrayVar, aVarFlatArrayOfRecord, TText> T15;
	T15.Test4();

	test.Next(_L("Var key with a segmented array of structs"));
	typedef CArrayVarSeg<Record> aVarSegmentedArrayOfRecord;
	TestTKey<TKeyArrayVar, aVarSegmentedArrayOfRecord, TText> T16;
	T16.Test4();

	test.Next(_L("Fixed key with a flat array of structs testing numeric types"));
	typedef CArrayFixFlat<Record2> aFixedFlatArrayOfRecord2;
	TestTKey<TKeyArrayFix, aFixedFlatArrayOfRecord2, TText> T17;
	T17.Test5();   

	test.Next(_L("Var key with a flat array of structs testing numeric types"));
	typedef CArrayVarFlat<Record2> aVarFlatArrayOfRecord2;
	TestTKey<TKeyArrayVar, aVarFlatArrayOfRecord2, TText> T18;
	T18.Test6();
	test.End();
	return(KErrNone);
    }

/*#else
GLDEF_C TInt E32Main()
//
// Test unavailable in release build.
//
    {

	test.Title();	
	test.Start(_L("No tests for release builds"));
	test.End();
	return(0);
    }
#endif

*/