fax/faxclientandserver/Test/TE_FAX/TE_FaxTest.cpp
author Pat Downey <patd@symbian.org>
Tue, 13 Jul 2010 14:53:59 +0100
branchRCL_3
changeset 50 2ac16fe2d995
parent 0 3553901f7fa8
permissions -rw-r--r--
Re-merge addition of wapstack to fid bug 1398.

// Copyright (c) 1997-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:
// Telephony Fax Test main test code.
// 
//

/**
 @file
 @internalComponent
*/

#include "faxdefn.h"
#include "fax_reversebytes.h"
#include "FAXSET.H"
#include "CFAX32.H"
#include "etel.h"
#include "etelmm.h"
#include "faxhuff.h"

#include "TE_FaxBase.h"
#include "TE_FaxTest.h"


//
// Constants...
//
_LIT(KTEFaxTestStoreFileName, "C:\\TestStore.Fax");
_LIT(KTEFaxTestEncodeFileName, "C:\\TestEncode.Fax");
_LIT(KTEFaxTestHeaderFileName, "C:\\TestHeader.Fax");
_LIT(KTEFaxTSYName, "MM");
_LIT(KTEFaxPhoneName, "GsmPhone1");
_LIT(KTEFaxLineName, "Fax");


/**
 *  Each test step initialises it's own name
 */
CFaxTestFaxDefinition::CFaxTestFaxDefinition()
	{
	//
	// Store the name of this test case.  This is the name that is used by
	// the script file.
	//
	SetTestStepName(_L("TestFaxDefinition"));
	} // CFaxTestFaxDefinition::CFaxTestFaxDefinition


/**
 *  This tests the definition of a fax it's variables types.
 *
 *  @return Test verdict for this test.
 */	
enum TVerdict CFaxTestFaxDefinition::doTestStepL()
	{
#ifdef __EABI__
	//
	// Removed due to RVCT warnings!!!
	//
	INFO_PRINTF1(_L("Note: This test is not fully run on RVCT compiled platforms!"));
#else
	TFaxClass  faxClass = EClassAuto;
	faxClass = EClass1;

	TFaxPhase  faxPhase = ENotYetStarted;
	faxPhase = ECallEstablishment;

	TFaxResolution  faxResolution = EFaxNormal;
	faxResolution = EFaxFine;

	TFaxCompression  faxCompression = EModifiedHuffman;
	faxCompression = EModifiedRead;

	TInt  tmpValue;
	tmpValue = KFaxPixelsPerScanLine;
	tmpValue = KFaxBytesPerScanLine;
	tmpValue = KFaxCmPerScanLine;
	tmpValue = KFaxScanLinesPer10Cm;
	tmpValue = KFaxFineScanLinesPer10Cm;
	tmpValue = KFaxT4MaxDesLength;
	tmpValue = KFaxLinesPerBand;
#endif

	TFaxBufSenderId  faxBufSenderId;
	faxBufSenderId.Copy(_L8("Test"));

    TRawScanLine rawscanline;

	rawscanline.Zero();
	rawscanline.SetMax();
	rawscanline.FillZ();
	
	return TestStepResult();
	} // CFaxTestFaxDefinition::doTestStepL


/**
 *  Each test step initialises it's own name
 */
CFaxTestFaxStorage::CFaxTestFaxStorage()
	{
	//
	// Store the name of this test case.  This is the name that is used by
	// the script file.
	//
	SetTestStepName(_L("TestFaxStorage"));
	} // CFaxTestFaxStorage::CFaxTestFaxStorage


/**
 *  This tests the definition of a fax it's variables types.
 *
 *  @return Test verdict for this test.
 */	
enum TVerdict CFaxTestFaxStorage::doTestStepL()
	{
	INFO_PRINTF1(_L("Started fax store tests"));

    iWriteFaxFile = CWriteFaxFile::NewL();
	CleanupStack::PushL(iWriteFaxFile);
	iReadFaxFile = CReadFaxFile::NewL();
	CleanupStack::PushL(iReadFaxFile);

	iSenderId.Copy(_L("sender's number"));

	TBuf8<216>  scanlineBlack, scanlineWhite, scanlineAlt, scanlineCount;
	TInt  index;

	scanlineBlack.SetLength(216);
	scanlineBlack.Fill(TChar(0));
	scanlineWhite.SetLength(216);
	scanlineWhite.Fill(TChar(255));
	scanlineAlt.SetLength(216);
	scanlineAlt.Fill(TChar(255));
	
	for (index = 0;  index < 216; index += 2)
		{
		scanlineAlt[index] = 0;
		}
	scanlineCount.SetLength(216);

	for (index = 0;  index < 216;  index++)
		{
		scanlineCount[index] = TUint8(index);
		}

	TInt  numberLines, startnol(124), endnol(132);

	//
	// test 1
	//
	INFO_PRINTF3(_L("Test 1 - %d to %d repeated lines"), startnol, endnol);

	INFO_PRINTF1(_L("All black - Resolution Fine"));
	for (numberLines=startnol; numberLines<=endnol; numberLines++)
		{
		Test1L(numberLines, scanlineBlack, EFaxFine);
		}

	INFO_PRINTF1(_L("All white - Resolution Fine"));
	for (numberLines=startnol; numberLines<=endnol; numberLines++)
		{
		Test1L(numberLines, scanlineWhite, EFaxFine);
		}

	INFO_PRINTF1(_L("Black & White - Resolution Fine"));
	for (numberLines=startnol; numberLines<=endnol; numberLines++)
		{
		Test1L(numberLines, scanlineAlt, EFaxFine);
		}

	INFO_PRINTF1(_L("Counting - Resolution Fine"));
	for (numberLines=startnol; numberLines<=endnol; numberLines++)
		{
		Test1L(numberLines, scanlineCount, EFaxFine);
		}

	INFO_PRINTF1(_L("Black & White - Resolution Normal"));
	for (numberLines=startnol; numberLines<=endnol; numberLines++)
		{
		Test1L(numberLines, scanlineAlt, EFaxNormal);
		}

	INFO_PRINTF1(_L("Counting - Resolution Normal"));
	for (numberLines=startnol; numberLines<=endnol; numberLines++)
		{
		Test1L(numberLines, scanlineCount, EFaxNormal);
		}

	//
	// test 2
	//
	INFO_PRINTF3(_L("Test 2 - %d to %d alternated lines"), startnol, endnol);
	INFO_PRINTF1(_L("White and Black & White - Resolution Fine"));
	for (numberLines = startnol;  numberLines <= endnol;  numberLines++)
		{
		Test2L(numberLines, scanlineWhite, scanlineAlt, EFaxFine);
		}

	INFO_PRINTF1(_L("Black and Black & White - Resolution Fine"));
	for (numberLines = startnol;  numberLines <= endnol;  numberLines++)
		{
		Test2L(numberLines, scanlineBlack, scanlineAlt, EFaxFine);
		}

	INFO_PRINTF1(_L("Counting and Black & White - Resolution Fine"));
	for (numberLines = startnol;  numberLines <= endnol;  numberLines++)
		{
		Test2L(numberLines, scanlineCount, scanlineAlt, EFaxFine);
		}

	//
	// test 3
	//
	TInt  numberPages, maxNumberPages=5;

	INFO_PRINTF2(_L("Test 3 - 2 to %d pages"), maxNumberPages);
	for (numberPages = 2;  numberPages <= maxNumberPages;  numberPages++) 
		{
		INFO_PRINTF2(_L("%d pages"),numberPages);

		for (numberLines = startnol;  numberLines <= endnol;  numberLines++)
			{
			Test3L(numberLines, numberPages);
			}
		}

	//
	// test 4
	//
	INFO_PRINTF1(_L("Test 4 - seeking lines"));
	for (numberLines = startnol;  numberLines <= startnol;  numberLines++)
		{
		Test4L(numberLines);
		}

	//
	// test 5
	//
	TFaxBufSenderId  sd;

	INFO_PRINTF1(_L("Test 5 - writing and reading page info"));
	sd.Copy(_L8("+34345 4354"));
	Test5L(EFaxNormal,sd,EModifiedHuffman,TInt(2434));
	sd.Copy(_L8("+34345 4354"));
	Test5L(EFaxFine,sd,EModifiedHuffman,TInt(0));
	sd.Copy(_L8(""));
	Test5L(EFaxNormal,sd,EModifiedHuffman,TInt(1));
	sd.Copy(_L8(" + 4545 9"));
	Test5L(EFaxFine,sd,EModifiedHuffman,TInt(-1));

	//
	// Done!
	//
	CleanupStack::PopAndDestroy(iReadFaxFile);
	CleanupStack::PopAndDestroy(iWriteFaxFile);

	return TestStepResult();
	} // CFaxTestFaxStorage::doTestStepL


void CFaxTestFaxStorage::Test1L(TInt aNumberLines, TBuf8<216>& aScanLineWrite,
								TFaxResolution aRes)
	{
	TInt  row;
	TBuf8<216>  scanlineRead;

	iWriteFaxFile->OpenL(KTEFaxTestStoreFileName, 64);
	
	for (row = 0;  row < aNumberLines;  row++)
		{
		iWriteFaxFile->iWriteFaxPages->AddScanLineL(aScanLineWrite);
		}

	iWriteFaxFile->iWriteFaxPages->EndPageL(aRes, iSenderId);
	iWriteFaxFile->CommitL();
	iWriteFaxFile->Close();

	iReadFaxFile->OpenL(KTEFaxTestStoreFileName);

	for (row = 0;  row < aNumberLines;  row++)
		{
		iReadFaxFile->iReadFaxPages->GetScanLineL(scanlineRead);
		TESTCHECKSTR(scanlineRead, aScanLineWrite);
		}
	iReadFaxFile->Close();
	} // CFaxTestFaxStorage::Test1L


void CFaxTestFaxStorage::Test2L(TInt aNumberLines, TBuf8<216>& aScanLineWrite1,
								TBuf8<216>&  aScanLineWrite2, TFaxResolution aRes)
	{
	TInt  row;
	TBuf8<216>  scanlineRead;

	iWriteFaxFile->OpenL(KTEFaxTestStoreFileName, 64);
	for (row = 0; row < aNumberLines;  row++)
		{
		// line1
		iWriteFaxFile->iWriteFaxPages->AddScanLineL(aScanLineWrite1);
		row++;
		if (row >= aNumberLines)
			{
			break;
			}

		// line2
		iWriteFaxFile->iWriteFaxPages->AddScanLineL(aScanLineWrite2);
		}

	iWriteFaxFile->iWriteFaxPages->EndPageL(aRes, iSenderId);
	iWriteFaxFile->CommitL();
	iWriteFaxFile->Close();

	iReadFaxFile->OpenL(KTEFaxTestStoreFileName);
	for (row = 0;  row < aNumberLines;  row++)
		{
		// line1
		iReadFaxFile->iReadFaxPages->GetScanLineL(scanlineRead);
		TESTCHECKSTR(scanlineRead, aScanLineWrite1);
		row++;
		if (row >= aNumberLines)
			{
			break;
			}

		// line2
		iReadFaxFile->iReadFaxPages->GetScanLineL(scanlineRead);
		TESTCHECKSTR(scanlineRead, aScanLineWrite2);
		}
	iReadFaxFile->Close();
	} // CFaxTestFaxStorage::Test2L


void CFaxTestFaxStorage::Test3L(TInt aNumberLines, TInt aNumberPages)
	{
	TInt  row;
	TBuf8<216>  scanlineRead, scanlineWrite;

	scanlineWrite.SetLength(216);

	iWriteFaxFile->OpenL(KTEFaxTestStoreFileName, 64);
	TInt page;
	
	for (page = 0;  page < aNumberPages;  page++)
		{
		scanlineWrite.SetLength(216);
		scanlineWrite.Fill(TChar(255));
		
		for (TInt t=0; t<216; t+=2)
			{
			scanlineWrite[t] = 0;
			}
		
		scanlineWrite[0] = TUint8(page);
		
		for (row = 0;  row < aNumberLines;  row++)
			{
			iWriteFaxFile->iWriteFaxPages->AddScanLineL(scanlineWrite);
			}

		iWriteFaxFile->iWriteFaxPages->EndPageL(EFaxFine, iSenderId);
		iWriteFaxFile->CommitL();
		}
	iWriteFaxFile->Close();

	iReadFaxFile->OpenL(KTEFaxTestStoreFileName);

	for (page = 0;  page < aNumberPages;  page++)
		{
		iReadFaxFile->iReadFaxPages->SetPageL(page);

		for (row = 0;  row < aNumberLines;  row++)
			{
			iReadFaxFile->iReadFaxPages->GetScanLineL(scanlineRead);	
			TESTCHECK(scanlineRead[0], page);
			}
		}
	iReadFaxFile->Close();
	} // CFaxTestFaxStorage::Test3L


void CFaxTestFaxStorage::Test4L(TInt aNumberLines)
	{
	TInt  row;
	TBuf8<216>  scanlineRead, scanlineWrite;

	scanlineWrite.SetLength(216);

	iWriteFaxFile->OpenL(KTEFaxTestStoreFileName, 64);

	for (row = 0;  row < aNumberLines;  row++)
		{
		scanlineWrite[0] = TUint8(row);

		iWriteFaxFile->iWriteFaxPages->AddScanLineL(scanlineWrite);
		}

	iWriteFaxFile->iWriteFaxPages->EndPageL(EFaxFine, iSenderId);
	iWriteFaxFile->CommitL();
	iWriteFaxFile->Close();

	iReadFaxFile->OpenL(KTEFaxTestStoreFileName);

	for (row = 0;  row < aNumberLines;  row++)
		{
		iReadFaxFile->iReadFaxPages->SeekScanLineL(row);
		iReadFaxFile->iReadFaxPages->GetScanLineL(scanlineRead);
		TESTCHECK(scanlineRead[0], row);
		}

	for (row = aNumberLines - 1;  row >= 0;  row--)
		{
		iReadFaxFile->iReadFaxPages->SeekScanLineL(row);
		iReadFaxFile->iReadFaxPages->GetScanLineL(scanlineRead);
		TESTCHECK(scanlineRead[0], row);
		}

	iReadFaxFile->Close();
	} // CFaxTestFaxStorage::Test4L


void CFaxTestFaxStorage::Test5L(TFaxResolution aRes, TFaxBufSenderId& aSenderId,
								TFaxCompression aF1, TInt aF2)
{
	TInt  row;
	TBuf8<216>  scanLineWrite;

	scanLineWrite.SetLength(216);

	iWriteFaxFile->OpenL(KTEFaxTestStoreFileName, 64);

	for (row=0; row<100; row++)
		{
		iWriteFaxFile->iWriteFaxPages->AddScanLineL(scanLineWrite);
		}

	iWriteFaxFile->iWriteFaxPages->EndPageL(aRes, aSenderId, aF1, aF2);
	iWriteFaxFile->CommitL();
	iWriteFaxFile->Close();

	iReadFaxFile->OpenL(KTEFaxTestStoreFileName);

	TFaxPageInfo info = iReadFaxFile->iReadFaxPages->CurrentPageInfo();

	TESTCHECK(info.iNumScanLines, 100);
	TESTCHECK(info.iResolution, aRes);
	TESTCHECKSTR(info.iSenderId, aSenderId);
	TESTCHECK(info.iCompression, aF1);
	TESTCHECK(info.iReservedFlag2, aF2);

	iReadFaxFile->Close();
}


/**
 *  Each test step initialises it's own name
 */
CFaxTestFaxCoding::CFaxTestFaxCoding()
	{
	//
	// Store the name of this test case.  This is the name that is used by
	// the script file.
	//
	SetTestStepName(_L("TestFaxCoding"));
	} // CFaxTestFaxCoding::CFaxTestFaxCoding


/**
 *  This tests the fax coding.
 *
 *  @return Test verdict for this test.
 */	
enum TVerdict CFaxTestFaxCoding::doTestStepL()
	{
	TInt  result, pos;
	TInt  blackrun;
	TBool  flag(EFalse);
	RFile  enFile;
	RFs  fs;
	TRawScanLine  rawScanLine;
	TBuf8<KFaxT4MaxDesLength>  encodedScanLine;
	TBuf8<50>  leftOvers;
	TRawScanLine  decodedScanLine;
	TTime  then;
	TTime  now;
	TInt64  timetaken;

	CFaxT4* faxT4 = CFaxT4::NewL();
	CleanupStack::PushL(faxT4);

	result = fs.Connect();
	CleanupClosePushL(fs);
	TESTCHECKL(result, KErrNone);
	result = enFile.Replace(fs, KTEFaxTestEncodeFileName, EFileShareAny);
	CleanupClosePushL(enFile);
	TESTCHECKL(result, KErrNone);

	INFO_PRINTF1(_L("Testing 1D coding methods"));

	faxT4->PageInitialize(EFaxFine, EModifiedHuffman);
	rawScanLine.Fill(KFaxWhite, KFaxBytesPerScanLine);
	for (blackrun = 0;  blackrun <= 1728;  blackrun++)
		{
		Mem::Fill(&rawScanLine[0], blackrun/8, KFaxBlack);
		if (blackrun%8)
			{
			rawScanLine[(blackrun/8)] = (TUint8)(KFaxWhite << blackrun%8);
			}
		faxT4->EncodeScanLine(rawScanLine, encodedScanLine);
		encodedScanLine.Append(0);
		encodedScanLine.Append(1);
		enFile.Write(encodedScanLine);
		}
	
	enFile.Flush();
	CleanupStack::PopAndDestroy(&enFile);

	result = enFile.Open(fs, KTEFaxTestEncodeFileName, EFileShareAny);
	CleanupClosePushL(enFile);
	TESTCHECKL(result, KErrNone);

	// now encoded.fax contains the encoded RawScanLines from the jerry.fax file
	// and now we are going to decode them again

	encodedScanLine.Zero();

	then.UniversalTime();
    faxT4->PageInitialize(EFaxFine,EModifiedHuffman);
	rawScanLine.Fill(KFaxWhite, KFaxBytesPerScanLine);
	for (blackrun = 0;  blackrun <= 1728;  blackrun++)
		{
		pos = FindEndOfLine(encodedScanLine);
		if (pos == KErrNotFound)
			{
			flag = ETrue;
			if (encodedScanLine.Length() != 0)
				{
				leftOvers.Copy(encodedScanLine);
				enFile.Read(encodedScanLine, (encodedScanLine.MaxLength()-leftOvers.Length()));

				if (FindEndOfLine(encodedScanLine) == KErrNotFound)
				{
					User::Leave(KErrNotFound);
				}
			
				encodedScanLine.Insert(0, leftOvers);
				leftOvers.Zero();
				pos = FindEndOfLine(encodedScanLine);
				flag = EFalse;
				}
			
			if (flag)
				{
				enFile.Read(encodedScanLine);
				pos = FindEndOfLine(encodedScanLine);
				}
			}

		result = faxT4->DecodeScanLine(decodedScanLine, encodedScanLine.Left(pos));
		TESTCHECKL(result, KErrNone);
		
		Mem::Fill(&rawScanLine[0], blackrun/8, KFaxBlack);
		if (blackrun%8)
			{
			rawScanLine[(blackrun/8)] = (TUint8)(KFaxWhite << blackrun%8);
			}

		TEST(!rawScanLine.Compare(decodedScanLine));
		encodedScanLine.Delete(0,pos+2);	//2 is the length of the delimiter character.
		}
	now.UniversalTime();
	timetaken = now.MicroSecondsFrom(then).Int64();
	INFO_PRINTF2(_L("%dms to 1D encode all possible run lengths"), I64LOW(timetaken)/1000);

	enFile.Flush();
	CleanupStack::PopAndDestroy(&enFile);

	//
	// Again, for this test, we'll instantiate our own CFaxT4 object and generate
	// the fax file using the raw functions  - this is purely done for testing
	// and in real life we'd do a 2D fax via the StartPage() function 
	// as used in test8L
	//
	result = enFile.Replace(fs, KTEFaxTestEncodeFileName, EFileShareAny);
	CleanupClosePushL(enFile);
	TESTCHECKL(result, KErrNone);

	INFO_PRINTF1(_L("Test 2D coding methods"));

	//writeFaxFile->OpenL(_L("c:\\test.fax"),64);
	
	faxT4->PageInitialize(EFaxFine, EModifiedRead);
	rawScanLine.Fill(KFaxBlack, KFaxBytesPerScanLine);      // prepare a black reference line
	faxT4->EncodeScanLine(rawScanLine, encodedScanLine);
	
	//writeFaxFile->iWriteFaxPages->AddEncodedScanLineL(encodedScanLine);
	encodedScanLine.Append(0);
	encodedScanLine.Append(1);
	enFile.Write(encodedScanLine);

	rawScanLine[0] = KFaxWhite ;                             // start with a white run
	rawScanLine[KFaxBytesPerScanLine-1] = KFaxWhite ;        // end with a white run
	rawScanLine[(KFaxBytesPerScanLine/2)-1] = KFaxWhite ;    // with a white run halfway through
	rawScanLine[(KFaxBytesPerScanLine/2)-10] = KFaxWhite ;    // and a white run 10 before the end
	faxT4->EncodeScanLine(rawScanLine, encodedScanLine);      // horizontal mode encoding


	//writeFaxFile->iWriteFaxPages->AddEncodedScanLineL(encodedScanLine);
	encodedScanLine.Append(0);
	encodedScanLine.Append(1);
	enFile.Write(encodedScanLine);

	rawScanLine[0] = KFaxWhite;                             // first run identical for v0
	rawScanLine[(KFaxBytesPerScanLine/2)-1] = 0x1c ;         // 00011100 test v+3 v-2 
	rawScanLine[(KFaxBytesPerScanLine/2)-10] = 0x3e ;        // 00111110 test v+2 v-1 
	rawScanLine[KFaxBytesPerScanLine-1] = 0x78 ;             // 01111000 test v+1 v-3
	faxT4->EncodeScanLine(rawScanLine, encodedScanLine);      // vertical mode encoding
	encodedScanLine.Append(0);
	encodedScanLine.Append(1);
	enFile.Write(encodedScanLine);
	
	
	//writeFaxFile->iWriteFaxPages->AddEncodedScanLineL(encodedScanLine);
	rawScanLine[0] = KFaxBlack ;                             // for pass mode
	faxT4->EncodeScanLine(rawScanLine, encodedScanLine);      // pass mode encoding
	encodedScanLine.Append(0);
	encodedScanLine.Append(1);
	enFile.Write(encodedScanLine);
	//writeFaxFile->iWriteFaxPages->AddEncodedScanLineL(encodedScanLine);

	// same again in opposite colours

	faxT4->PageInitialize(EFaxFine, EModifiedRead);
	rawScanLine.Fill(KFaxWhite, KFaxBytesPerScanLine);      // prepare a white reference line
	faxT4->EncodeScanLine(rawScanLine, encodedScanLine);
	encodedScanLine.Append(0);
	encodedScanLine.Append(1);
	enFile.Write(encodedScanLine);
	//writeFaxFile->iWriteFaxPages->AddEncodedScanLineL(encodedScanLine);
	
	rawScanLine[0] = KFaxBlack ;                             // start with a black run
	rawScanLine[KFaxBytesPerScanLine-1] = KFaxBlack ;        // end with a black run
	rawScanLine[(KFaxBytesPerScanLine/2)-1] = KFaxBlack ;    // with a black run halfway through
	rawScanLine[(KFaxBytesPerScanLine/2)-10] = KFaxBlack ;    // and a blacke run 10 before the end
	faxT4->EncodeScanLine(rawScanLine, encodedScanLine);      // horizontal mode encoding
	encodedScanLine.Append(0);
	encodedScanLine.Append(1);
	enFile.Write(encodedScanLine);

	//writeFaxFile->iWriteFaxPages->AddEncodedScanLineL(encodedScanLine);
	
	rawScanLine[0] = KFaxBlack ;                             // first run identical for v0
	rawScanLine[(KFaxBytesPerScanLine/2)-1] = 0xe3 ;         // 11100011 test v+3 v-2 
	rawScanLine[(KFaxBytesPerScanLine/2)-10] = 0xc1 ;        // 11000001 test v+2 v-1 
	rawScanLine[KFaxBytesPerScanLine-1] = 0x87 ;             // 10000111 test v+1 v-3
	faxT4->EncodeScanLine(rawScanLine, encodedScanLine);      // vertical mode encoding
	encodedScanLine.Append(0);
	encodedScanLine.Append(1);
	enFile.Write(encodedScanLine);
	//writeFaxFile->iWriteFaxPages->AddEncodedScanLineL(encodedScanLine);
	
	rawScanLine[0] = KFaxWhite ;                             // for pass mode
	faxT4->EncodeScanLine(rawScanLine, encodedScanLine);      // pass mode encoding
	//writeFaxFile->iWriteFaxPages->AddEncodedScanLineL(encodedScanLine);
	encodedScanLine.Append(0);
	encodedScanLine.Append(1);
	enFile.Write(encodedScanLine);

	then.UniversalTime();
	faxT4->PageInitialize (EFaxFine, EModifiedRead);         // now start again
	rawScanLine.Fill (KFaxWhite, KFaxBytesPerScanLine);
	for (blackrun=0; blackrun <= 1728 ; blackrun++)
		{
		Mem::Fill(&rawScanLine[0], blackrun/8, KFaxBlack);
		if (blackrun%8)
			{
			rawScanLine[(blackrun/8)] = (TUint8)(KFaxWhite << blackrun%8);
			}
		faxT4->EncodeScanLine(rawScanLine, encodedScanLine);
		//writeFaxFile->iWriteFaxPages->AddEncodedScanLineL(encodedScanLine);
		encodedScanLine.Append(0);
		encodedScanLine.Append(1);
		enFile.Write(encodedScanLine);
		}
	now.UniversalTime();
	timetaken = now.MicroSecondsFrom (then).Int64 ();
	INFO_PRINTF2(_L("%dms to 2D encode all possible run lengths"), I64LOW(timetaken)/1000);

	enFile.Flush();
	CleanupStack::PopAndDestroy(&enFile);

	/*
	writeFaxFile->iWriteFaxPages->EndPageL(EFaxFine,senderId, EModifiedRead);
	writeFaxFile->CommitL();
	writeFaxFile->Close();
	*/

	//readFaxFile->OpenL(_L("c:\\test.fax"));
	//readFaxFile->iReadFaxPages->SetPageL(0);
	//TFaxPageInfo info = readFaxFile->iReadFaxPages->CurrentPageInfo();

	INFO_PRINTF1(_L("Test 2D decoding methods"));

	result = enFile.Open(fs, KTEFaxTestEncodeFileName, EFileShareAny);
	CleanupClosePushL(enFile);
	TESTCHECKL(result, KErrNone);

	rawScanLine.Fill(KFaxBlack, KFaxBytesPerScanLine);      // prepare a black line as the reference line
	//readFaxFile->iReadFaxPages->GetEncodedScanLineL(encodedScanLine);

	enFile.Read(encodedScanLine);
	pos = FindEndOfLine(encodedScanLine);

	result = faxT4->DecodeScanLine(decodedScanLine, encodedScanLine.Left(pos));
	//err = faxT4->DecodeScanLine(decodedScanLine, encodedScanLine);
	TESTCHECKL(result, KErrNone);
	result = rawScanLine.Compare(decodedScanLine);
	TESTCHECKL(result, KErrNone);
	encodedScanLine.Delete(0,pos+2);

	rawScanLine[0] = KFaxWhite ;
	rawScanLine[KFaxBytesPerScanLine-1] = KFaxWhite ;
	rawScanLine[(KFaxBytesPerScanLine/2)-1] = KFaxWhite ;    // test horizontal mode codec
	rawScanLine[(KFaxBytesPerScanLine/2)-10] = KFaxWhite ;   // and a white run 10 before the end
	
	//enFile.Read(encodedScanLine);
	pos = FindEndOfLine(encodedScanLine);

	//err = faxT4->DecodeScanLine(decodedScanLine,encodedScanLine.Left(pos));
	//readFaxFile->iReadFaxPages->GetEncodedScanLineL(encodedScanLine);
	
	result = faxT4->DecodeScanLine(decodedScanLine,encodedScanLine.Left(pos));
	TESTCHECKL(result, KErrNone);
	result = rawScanLine.Compare(decodedScanLine);
	TESTCHECKL(result, KErrNone);
	encodedScanLine.Delete(0,pos+2);

	rawScanLine[(KFaxBytesPerScanLine/2)-1] = 0x1c ;         // test v+3 v-2
	rawScanLine[(KFaxBytesPerScanLine/2)-10] = 0x3e ;        // test v+2 v-1 coded 
	rawScanLine[KFaxBytesPerScanLine-1] = 0x78 ;             // test v+1 v-3 codec

	//readFaxFile->iReadFaxPages->GetEncodedScanLineL(encodedScanLine);	
	pos=FindEndOfLine(encodedScanLine);
	result = faxT4->DecodeScanLine(decodedScanLine,encodedScanLine.Left(pos));
	TESTCHECKL(result, KErrNone);
	result = rawScanLine.Compare(decodedScanLine);
	TESTCHECKL(result, KErrNone);
	encodedScanLine.Delete(0,pos+2);
	
	rawScanLine[0] = KFaxBlack ;                      // test pass and v0 codec
	//readFaxFile->iReadFaxPages->GetEncodedScanLineL(encodedScanLine);	
	pos=FindEndOfLine(encodedScanLine);
	result = faxT4->DecodeScanLine(decodedScanLine,encodedScanLine.Left(pos));
	TESTCHECKL(result, KErrNone);
	result = rawScanLine.Compare(decodedScanLine);
	TESTCHECKL(result, KErrNone);
	encodedScanLine.Delete(0,pos+2);
	// same again in opposite colours

	rawScanLine.Fill (KFaxWhite, KFaxBytesPerScanLine);      // prepare a white line as the reference line
	pos=FindEndOfLine(encodedScanLine);
	//readFaxFile->iReadFaxPages->GetEncodedScanLineL(encodedScanLine);	
	result = faxT4->DecodeScanLine(decodedScanLine,encodedScanLine.Left(pos));
	TESTCHECKL(result, KErrNone);
	rawScanLine.Compare(decodedScanLine);
	TESTCHECKL(result, KErrNone);
	encodedScanLine.Delete(0,pos+2);


	rawScanLine[0] = KFaxBlack ;
	rawScanLine[KFaxBytesPerScanLine-1] = KFaxBlack ;
	rawScanLine[(KFaxBytesPerScanLine/2)-1] = KFaxBlack ;    // test horizontal mode codec
	rawScanLine[(KFaxBytesPerScanLine/2)-10] = KFaxBlack ;   // and a black run 10 before the end
	//readFaxFile->iReadFaxPages->GetEncodedScanLineL(encodedScanLine);
	pos=FindEndOfLine(encodedScanLine);
	result = faxT4->DecodeScanLine(decodedScanLine,encodedScanLine.Left(pos));
	TESTCHECKL(result, KErrNone);
	result = rawScanLine.Compare(decodedScanLine);
	TESTCHECKL(result, KErrNone);
	encodedScanLine.Delete(0,pos+2);
	
	rawScanLine[(KFaxBytesPerScanLine/2)-1] = 0xe3 ;         // 11100011 test v+3 v-2 
	rawScanLine[(KFaxBytesPerScanLine/2)-10] = 0xc1 ;        // 11000001 test v+2 v-1 
	rawScanLine[KFaxBytesPerScanLine-1] = 0x87 ;             // 10000111 test v+1 v-3
	//readFaxFile->iReadFaxPages->GetEncodedScanLineL(encodedScanLine);	

	pos=FindEndOfLine(encodedScanLine);
	result = faxT4->DecodeScanLine(decodedScanLine,encodedScanLine.Left(pos));
	TESTCHECKL(result, KErrNone);
	result = rawScanLine.Compare(decodedScanLine);
	TESTCHECKL(result, KErrNone);
	encodedScanLine.Delete(0,pos+2);

	rawScanLine[0] = KFaxWhite ;                             // test pass and v0 codec
	//readFaxFile->iReadFaxPages->GetEncodedScanLineL(encodedScanLine);	
	pos=FindEndOfLine(encodedScanLine);
	result = faxT4->DecodeScanLine(decodedScanLine,encodedScanLine.Left(pos));
	TESTCHECKL(result, KErrNone);
	result = rawScanLine.Compare(decodedScanLine);
	TESTCHECKL(result, KErrNone);
	encodedScanLine.Delete(0,pos+2);
	
	// now do all run lengths

	then.UniversalTime();
	//faxT4->PageInitialize (info.iResolution, info.iCompression);
//	enFile.Close();

//	err=enFile.Open(fs,_L("c:\\test.fax"),EFileShareAny);
//	if (err!=KErrNone)
//		User::Leave(err);

//	encodedScanLine.Zero();
	flag = EFalse;

    
	faxT4->PageInitialize(EFaxFine,EModifiedRead);
	rawScanLine.Fill(KFaxWhite, KFaxBytesPerScanLine);
	for (blackrun=0;  blackrun <= 1728;  blackrun++)
		{
		pos = FindEndOfLine(encodedScanLine);
		if (pos == KErrNotFound)
			{
			flag = ETrue;
			if (encodedScanLine.Length() != 0)
				{
				leftOvers.Copy(encodedScanLine);
				enFile.Read(encodedScanLine, (encodedScanLine.MaxLength()-leftOvers.Length()));
				if (FindEndOfLine(encodedScanLine) == KErrNotFound)
					{
					User::Leave(KErrNotFound);
					}
			
				encodedScanLine.Insert(0, leftOvers);
				leftOvers.Zero();
				pos = FindEndOfLine(encodedScanLine);
				flag = EFalse;
				}
			
			if (flag)
				{
				enFile.Read(encodedScanLine);
				pos = FindEndOfLine(encodedScanLine);
				}
			}

		result = faxT4->DecodeScanLine(decodedScanLine,encodedScanLine.Left(pos));
		TESTCHECKL(result, KErrNone);
		
		Mem::Fill(&rawScanLine[0], blackrun/8, KFaxBlack);
		if (blackrun%8)
			{
			rawScanLine[(blackrun/8)] = (TUint8)(KFaxWhite << blackrun%8);
			}
		result = rawScanLine.Compare(decodedScanLine);
		TESTCHECKL(result, KErrNone);
		encodedScanLine.Delete(0,pos+2);	//2 is the length of the delimiter character.
		}
	enFile.Flush();

	CleanupStack::PopAndDestroy(&enFile);
	CleanupStack::PopAndDestroy(&fs);
	CleanupStack::PopAndDestroy(faxT4);

	return TestStepResult();
	} // CFaxTestFaxCoding::doTestStepL


TInt CFaxTestFaxCoding::FindEndOfLine(TDes8& aEncodedDes)
	{
	TInt  maxlength;
	TUint  compareWord(0);

	maxlength = aEncodedDes.Length();
	if (aEncodedDes.Length() == 0)
		{
		return KErrNotFound;
		}

	TInt  index;

	for (index = 0;  index <= maxlength - 2;  index++)
		{
		compareWord = aEncodedDes[index];
		if (compareWord == 0)
			{
			compareWord = aEncodedDes[index + 1];
			if (compareWord == 1)
				{
				return index;
				}
			}
		}		
		
	return KErrNotFound;
	}

	
/**
 *  Each test step initialises it's own name
 */
CFaxTestFaxHeaderDefinition::CFaxTestFaxHeaderDefinition()
	{
	//
	// Store the name of this test case.  This is the name that is used by
	// the script file.
	//
	SetTestStepName(_L("TestFaxHeaderDefinition"));
	} // CFaxTestFaxHeaderDefinition::CFaxTestFaxHeaderDefinition


/**
 *  This tests the fax header definition...
 *
 *  @return Test verdict for this test.
 */	
enum TVerdict CFaxTestFaxHeaderDefinition::doTestStepL()
	{
	//
    // this test is in two halves
	//
    // firstly we generate a header file - we don't do this via an Epoc print, but
    // directly using one of the test fonts in testfont.h.  However, the functions
    // we need are all exercised (writing font information and writing series of
    // TRawScanLines.  (Getting epoc printing to generate the correct data is not
    // part of this test.)  The test function here takes a pointer to the font
    // together with its dimensions as paramters, so that fonts 1 2 and 3 bytes
    // wide can be tested out all at te same time.  The fonts are in testfont.h
    //
    // secondly we use the header file we've just generate to create encoded scan lines
    // for a header, which we'll write to TEST.FAX as a fax file.  Naturally, in
    // real use, we'd send our encodes scan lines as part of the T.4 image at the start
    // of each pages, but generating a fax image (which is just a series of encoded scan
    // lines) is just as good a test.  So, we pass a pointer to the fax store as a parameters.
    // Again, we run this once for each font we test.
	//
	RFs  fs;
	TInt  result;
	RFile  file;

	result = fs.Connect();
	CleanupClosePushL(fs);
	TESTCHECKL(result, KErrNone);
	
	result = file.Replace(fs, KTEFaxTestHeaderFileName, EFileShareAny);
	CleanupClosePushL(file);
	TESTCHECKL(result, KErrNone);

	INFO_PRINTF1(_L("Generating header file using one byte wide font"));
    GenerateHeaderFileL(*font8x16, 1, 16);
	INFO_PRINTF1(_L("Writing fax header to TestHeader.Fax using current time and date")) ;
    GenerateFaxFileL(file);

	INFO_PRINTF1(_L("Generating header file using two bytes wide font"));
    GenerateHeaderFileL(*font16x16, 2, 16);
	INFO_PRINTF1(_L("Writing fax header to TestHeader.Fax using current time and date"));
	GenerateFaxFileL(file);

	INFO_PRINTF1(_L("Generating header file using three bytes wide font")) ;
    GenerateHeaderFileL(*font24x16, 3, 16);
	INFO_PRINTF1(_L("Writing fax header to TestHeader.Fax using current time and date")) ;
	GenerateFaxFileL(file);
	
	file.Flush();

	CleanupStack::PopAndDestroy(&file);
	CleanupStack::PopAndDestroy(&fs);

	return TestStepResult();
	} // CFaxTestFaxHeaderDefinition::doTestStepL


void CFaxTestFaxHeaderDefinition::GenerateFaxFileL(RFile& aFile)
   {
    // use the header to generate a *.FAX file
    TFaxHeaderInfo faxHeader;

	CFaxT4*  faxT4 = CFaxT4::NewL();
	CleanupStack::PushL(faxT4);
    CFaxHeaderLines*  testheader = CFaxHeaderLines::NewL();
	CleanupStack::PushL(testheader);

    testheader->ReadFaxHeaderInfoL(faxHeader);

    TRawScanLine  headline;
    TRawScanLine  fontline;
    TBuf8<KFaxT4MaxDesLength>  encodedHeadLine;

    TTime  timeOfTransmission;
    TBuf<12>  timeText;

	timeOfTransmission.HomeTime ();
    timeOfTransmission.FormatL(timeText, _L("%F%D%M%Y%H%T"));

	for (TInt index = 0;  index < 12;  index++)
		{
        timeText[index] -= '0';
		}

    // Forces 2 digit day - 2 digit month - 4 digit year - 2 digit hour - 2 digit minute

	for (TInt scanline = 0;  scanline < faxHeader.iHeaderFontHeightInLines;  scanline++)
		{
        testheader->ReadRawHeaderLineL(scanline, headline);
        testheader->ReadRawFontLineL(scanline, fontline);

        for (TInt fontByte = 0; fontByte < faxHeader.iHeaderFontWidthInBytes; fontByte++)
			{
			headline[((faxHeader.iOffsetToDay) * faxHeader.iHeaderFontWidthInBytes) + fontByte] = fontline[(timeText[0] * faxHeader.iHeaderFontWidthInBytes) + fontByte];
            headline[((faxHeader.iOffsetToDay + 1) * faxHeader.iHeaderFontWidthInBytes) + fontByte] = fontline[(timeText[1] * faxHeader.iHeaderFontWidthInBytes) + fontByte];
            headline[((faxHeader.iOffsetToMonth) * faxHeader.iHeaderFontWidthInBytes) + fontByte] = fontline[(timeText[2] * faxHeader.iHeaderFontWidthInBytes) + fontByte];
            headline[((faxHeader.iOffsetToMonth + 1) * faxHeader.iHeaderFontWidthInBytes) + fontByte] = fontline[(timeText[3] * faxHeader.iHeaderFontWidthInBytes) + fontByte];
            headline[((faxHeader.iOffsetToYear) * faxHeader.iHeaderFontWidthInBytes) + fontByte] = fontline[(timeText[4] * faxHeader.iHeaderFontWidthInBytes) + fontByte];
            headline[((faxHeader.iOffsetToYear + 1) * faxHeader.iHeaderFontWidthInBytes) + fontByte] = fontline[(timeText[5] * faxHeader.iHeaderFontWidthInBytes) + fontByte];
            headline[((faxHeader.iOffsetToYear + 2) * faxHeader.iHeaderFontWidthInBytes) + fontByte] = fontline[(timeText[6] * faxHeader.iHeaderFontWidthInBytes) + fontByte];
            headline[((faxHeader.iOffsetToYear + 3) * faxHeader.iHeaderFontWidthInBytes) + fontByte] = fontline[(timeText[7] * faxHeader.iHeaderFontWidthInBytes) + fontByte];
            headline[((faxHeader.iOffsetToHour) * faxHeader.iHeaderFontWidthInBytes) + fontByte] = fontline[(timeText[8] * faxHeader.iHeaderFontWidthInBytes) + fontByte];
            headline[((faxHeader.iOffsetToHour + 1) * faxHeader.iHeaderFontWidthInBytes) + fontByte] = fontline[(timeText[9] * faxHeader.iHeaderFontWidthInBytes) + fontByte];
            headline[((faxHeader.iOffsetToMinute) * faxHeader.iHeaderFontWidthInBytes) + fontByte] = fontline[(timeText[10] * faxHeader.iHeaderFontWidthInBytes) + fontByte];
            headline[((faxHeader.iOffsetToMinute + 1) * faxHeader.iHeaderFontWidthInBytes) + fontByte] = fontline[(timeText[11] * faxHeader.iHeaderFontWidthInBytes) + fontByte];

            // put the page info in as 12/34

            headline[((faxHeader.iOffsetToCurrentPage) * faxHeader.iHeaderFontWidthInBytes) + fontByte] = fontline[(1 * faxHeader.iHeaderFontWidthInBytes) + fontByte];
            headline[((faxHeader.iOffsetToCurrentPage + 1) * faxHeader.iHeaderFontWidthInBytes) + fontByte] = fontline[(2 * faxHeader.iHeaderFontWidthInBytes) + fontByte];
            headline[((faxHeader.iOffsetToTotalPages) * faxHeader.iHeaderFontWidthInBytes) + fontByte] = fontline[(3 * faxHeader.iHeaderFontWidthInBytes) + fontByte];
            headline[((faxHeader.iOffsetToTotalPages + 1) * faxHeader.iHeaderFontWidthInBytes) + fontByte] = fontline[(4 * faxHeader.iHeaderFontWidthInBytes) + fontByte];
			}

      faxT4->EncodeScanLine(headline, encodedHeadLine);
	  aFile.Write(encodedHeadLine);
      }

	CleanupStack::PopAndDestroy(testheader);
	CleanupStack::PopAndDestroy(faxT4);
	} // CFaxTestFaxHeaderDefinition::GenerateFaxFileL


void CFaxTestFaxHeaderDefinition::GenerateHeaderFileL(const TUint8* aFont,
													  TInt aWidth, TInt aHeight)
	{
    TFaxHeaderInfo  faxHeader;

    //
	// declare the font size
	//
    faxHeader.iHeaderFontWidthInBytes  = aWidth;
    faxHeader.iHeaderFontHeightInLines = aHeight;

    //
	// Work out the number of characters we can get in the scan line, so that we can
    // create a modifiable buffer to hold the header line and fill it with spaces
    //
	TInt  charactersPerLine = KFaxBytesPerScanLine / faxHeader.iHeaderFontWidthInBytes;
    HBufC8*  textBuff = HBufC8::NewL(charactersPerLine);
	CleanupStack::PushL(textBuff);

    TPtr8  textLine = textBuff->Des();
    textLine.Fill(0x20, charactersPerLine);

    //
	// Work out the margin we leave on each side of the page in characters
    // this is specified as 74 pixels in T.4
	//
	TInt  margin = (74 / (8 * faxHeader.iHeaderFontWidthInBytes));

	//
	// THE FOLLOWING LAYOUT IS PURELY FOR TEST PURPOSES AND SHOULDN'T
    // BE TAKEN TO BE A DEFINITIVE HEADER LAYOUT
	//
    // assume we have the date and time on the lefthand side as dd/mm/yyyy hh:mm
    // 0000000001111111
    // 1234567890123456
    // fill in the separators
	textLine.Replace(margin + 3, 1, _L8 ("/"));
    textLine.Replace(margin + 6, 1, _L8 ("/"));
    textLine.Replace(margin + 14, 1, _L8 (":"));

    //
	// set up the offsets to the data
	//
	faxHeader.iOffsetToDay = margin + 1;
    faxHeader.iOffsetToMonth = margin + 4;
    faxHeader.iOffsetToYear = margin + 7;
    faxHeader.iOffsetToHour = margin + 12;
    faxHeader.iOffsetToMinute = margin + 15;

    //
	// assume we have the page info on the righthand side as pp/tt
    // 54321
    // fill in the separator
	//
    textLine.Replace (charactersPerLine - margin - 3, 1, _L8 ("/"));

    //
	// set up the offsets to the data
	//
    faxHeader.iOffsetToTotalPages = charactersPerLine - margin - 2;
    faxHeader.iOffsetToCurrentPage = charactersPerLine - margin - 5;

    //
    // read in the fax settings, because we want the fax ID and the user ID
    //
    TFaxSettings  ourFaxSettings;
    TBuf8<20>  userName;
   
    ourFaxSettings.iFaxId.Copy(_L("+++01234 56789+++"));
    userName.Copy(_L("Symbian Test Header"));

    TInt  lenID = ourFaxSettings.iFaxId.Length ();
    TInt  lenUser = userName.Length ();

    //
    // Fill the header line with appropriate information
	//
    textLine.Replace (faxHeader.iOffsetToMinute + 4, lenID, ourFaxSettings.iFaxId);
    textLine.Replace (faxHeader.iOffsetToCurrentPage - lenUser -2, lenUser, userName);

    //
	// HEADER LAYOUT NOW FINISHED
	//
    // now we can write the fax header info to the header info file
    //
    CFaxHeaderLines*  testheader = CFaxHeaderLines::NewL();
	CleanupStack::PushL(testheader);
    testheader->WriteFaxHeaderInfoL(faxHeader);

	//
    // Now we generate the scan line and write the header line bitmap
    // via a loop for each rowInFont in the font
	//
    TInt rowInFont;

	for (rowInFont = 0;  rowInFont < faxHeader.iHeaderFontHeightInLines;  rowInFont++)
		{
		TRawScanLine  image;
        image.SetMax();
        image.FillZ();
        TInt  offsetInImage = 0;
 
        offsetInImage = 0;
        for (TInt characterPosition = 0;  characterPosition < charactersPerLine;  characterPosition++)
			{
            for (TInt fontByte = 0;  fontByte < faxHeader.iHeaderFontWidthInBytes;  fontByte++)
				{
				image[offsetInImage++] = (TUint8)~KReverseByte[*(aFont + ((textLine[characterPosition] - 32) * faxHeader.iHeaderFontHeightInLines * faxHeader.iHeaderFontWidthInBytes) + (rowInFont * faxHeader.iHeaderFontWidthInBytes) + fontByte)];
				}
			}
        testheader->WriteRawHeaderLineL (rowInFont, image);
		}

	//
    // now we replace the first ten characters in the header text line with digits
	//
    textLine.Replace(0, 10, _L8("0123456789"));

	//
    // and write out the font line
	//
	for (rowInFont = 0; rowInFont < faxHeader.iHeaderFontHeightInLines; rowInFont++)
		{
		TRawScanLine  image;
		image.SetMax();
		image.FillZ();
		TInt  offsetInImage = 0;

		offsetInImage = 0;
		for (TInt characterPosition = 0;  characterPosition < charactersPerLine;  characterPosition++)
			{
			for (TInt fontByte = 0;  fontByte < faxHeader.iHeaderFontWidthInBytes;  fontByte++)
				{
				image[offsetInImage++] = (TUint8)~KReverseByte[*(aFont + ((textLine[characterPosition] - 32) * faxHeader.iHeaderFontHeightInLines * faxHeader.iHeaderFontWidthInBytes) + (rowInFont * faxHeader.iHeaderFontWidthInBytes) + fontByte)];
				}
			}
		testheader->WriteRawFontLineL (rowInFont, image);
		// we can add the test code to generate the panic here
		}

	CleanupStack::PopAndDestroy(testheader);
	CleanupStack::PopAndDestroy(textBuff);
	} // CFaxTestFaxHeaderDefinition::GenerateHeaderFileL


/**
 *  Each test step initialises it's own name
 */
CFaxTestTransmitFax01::CFaxTestTransmitFax01()
	{
	//
	// Store the name of this test case.  This is the name that is used by
	// the script file.
	//
	SetTestStepName(_L("TestTransmitFax01"));
	} // CFaxTestTransmitFax01::CFaxTestTransmitFax01


/**
 *  This tests the transmission of a straight forward test fax.
 *
 *  @return Test verdict for this test.
 */	
enum TVerdict CFaxTestTransmitFax01::doTestStepL()
	{
	TFaxSettings  faxSettings;

	//
	// Before instantiating CFaxTransfer we have to have a valid set of
	// TFaxSettings to pass in to it - so our first step must always be
	// to read the fax settings or set up suitable defaults.
	//
	TRAPD(leaveCode, ReadFaxCommDBSettingsL(faxSettings));
	if (leaveCode != KErrNone)
		{
		INFO_PRINTF2(_L("ReadFaxCommDBSettingsL() error %d!"), leaveCode);
		}
	TESTCHECKL(leaveCode, KErrNone);

	//
	// Set the Fax parameters...
	//
	faxSettings.iFaxClass             = EClassAuto;
	faxSettings.iPreferredECM         = 0;
	faxSettings.iMaxSpeed             = 14400;
	faxSettings.iMinSpeed             = 2400;
	faxSettings.iPreferredResolution  = EFaxNormal;
	faxSettings.iPreferredCompression = EModifiedHuffman;
	faxSettings.iFaxId.Copy(_L8("+441632960000"));

	//
	// Start the Fax session...
	//
	CFaxTransfer*  faxSession = NULL;

	TRAPD(startSessionResult, faxSession = CFaxTransfer::NewL(faxSettings));
	TESTCHECKL(startSessionResult, KErrNone);
	TESTL(faxSession != NULL);

	faxSession->SetMode(EDialAndTransmit);

	//
	// Generate a Fax header for transmitting...
	//
	TFaxHeaderInfo  faxHeader;

	faxHeader.iHeaderFontWidthInBytes = 0;
	
	CFaxHeaderLines*  testheader = CFaxHeaderLines::NewL();
	TRAP_IGNORE(testheader->ReadFaxHeaderInfoL(faxHeader));
	delete testheader;

	GenerateHeaderFileL(faxSettings, *font8x16, 1, 16);

	//
	// Add the source file to the session...
	//
	faxSession->AddSourceL(_L("C:\\TEST.FAX"), Prefer1D);

	//
	// Set the destination phone number if needed...
	//
	if ((faxSession->iMode & KFaxNoDial) == 0)
		{
		TBuf8<32>  phoneNumber;

		ReadDestPhoneNumberFromIniFileL(phoneNumber);
		faxSession->SetPhoneNumberL(phoneNumber);
		}
	
	//
	// Begin transfering the fax...
	//
	INFO_PRINTF1(_L("Starting fax transmission of TEST.FAX a simple test fax..."));
	TInt  transferResult = BeginFaxTransfer(faxSession);
	INFO_PRINTF2(_L("Fax transmission completed with return code %d"), transferResult);
	TESTCHECK(transferResult, KErrNone);

	//
	// Clean up the Fax session...
	//
	faxSession->RemoveAllSources();
	delete faxSession;
	faxSession = NULL;

	return TestStepResult();
	} // CFaxTestTransmitFax01::doTestStepL


/**
 *  Each test step initialises it's own name
 */
CFaxTestTransmitFax02::CFaxTestTransmitFax02()
	{
	//
	// Store the name of this test case.  This is the name that is used by
	// the script file.
	//
	SetTestStepName(_L("TestTransmitFax02"));
	} // CFaxTestTransmitFax02::CFaxTestTransmitFax02


/**
 *  This tests the transmission of a straight forward test fax.
 *
 *  @return Test verdict for this test.
 */	
enum TVerdict CFaxTestTransmitFax02::doTestStepL()
	{
	TFaxSettings  faxSettings;

	//
	// Before instantiating CFaxTransfer we have to have a valid set of
	// TFaxSettings to pass in to it - so our first step must always be
	// to read the fax settings or set up suitable defaults.
	//
	TRAPD(leaveCode, ReadFaxCommDBSettingsL(faxSettings));
	if (leaveCode != KErrNone)
		{
		INFO_PRINTF2(_L("ReadFaxCommDBSettingsL() error %d!"), leaveCode);
		}
	TESTCHECKL(leaveCode, KErrNone);

	//
	// Set the Fax parameters...
	//
	faxSettings.iFaxClass             = EClassAuto;
	faxSettings.iPreferredECM         = 0;
	faxSettings.iMaxSpeed             = 9600;
	faxSettings.iMinSpeed             = 2400;
	faxSettings.iPreferredResolution  = EFaxFine;
	faxSettings.iPreferredCompression = EModifiedRead;
	faxSettings.iFaxId.Copy(_L8("+441632960000"));

	//
	// Start the Fax session...
	//
	CFaxTransfer*  faxSession = NULL;

	TRAPD(startSessionResult, faxSession = CFaxTransfer::NewL(faxSettings));
	TESTCHECKL(startSessionResult, KErrNone);
	TESTL(faxSession != NULL);

	faxSession->SetMode(EDialAndTransmit); // Or EImmediateTransmit

	//
	// Generate a Fax header for transmitting...
	//
	TFaxHeaderInfo  faxHeader;

	faxHeader.iHeaderFontWidthInBytes = 0;
	
	CFaxHeaderLines*  testheader = CFaxHeaderLines::NewL();
	TRAP_IGNORE(testheader->ReadFaxHeaderInfoL(faxHeader));
	delete testheader;

	GenerateHeaderFileL(faxSettings, *font16x16, 2, 16);

	//
	// Add the source file to the session. "CHART4.FAX" is an ITU test chart.
	//
	faxSession->AddSourceL(_L("C:\\CHART4.FAX"), Prefer2D);

	//
	// Set the destination phone number if needed...
	//
	if ((faxSession->iMode & KFaxNoDial) == 0)
		{
		TBuf8<32>  phoneNumber;

		ReadDestPhoneNumberFromIniFileL(phoneNumber);
		faxSession->SetPhoneNumberL(phoneNumber);
		}
	
	//
	// Begin transfering the fax...
	//
	INFO_PRINTF1(_L("Starting fax transmission of CHART4.FAX an ITU test chart..."));
	TInt  transferResult = BeginFaxTransfer(faxSession);
	INFO_PRINTF2(_L("Fax transmission completed with return code %d"), transferResult);
	TESTCHECK(transferResult, KErrNone);

	//
	// Clean up the Fax session...
	//
	faxSession->RemoveAllSources();
	delete faxSession;
	faxSession = NULL;

	return TestStepResult();
	} // CFaxTestTransmitFax02::doTestStepL


/**
 *  Each test step initialises it's own name
 */
CFaxTestTransmitFax03::CFaxTestTransmitFax03()
	{
	//
	// Store the name of this test case.  This is the name that is used by
	// the script file.
	//
	SetTestStepName(_L("TestTransmitFax03"));
	} // CFaxTestTransmitFax03::CFaxTestTransmitFax03


/**
 *  This tests the transmission of a straight forward test fax.
 *
 *  @return Test verdict for this test.
 */	
enum TVerdict CFaxTestTransmitFax03::doTestStepL()
	{
	TFaxSettings  faxSettings;

	//
	// Before instantiating CFaxTransfer we have to have a valid set of
	// TFaxSettings to pass in to it - so our first step must always be
	// to read the fax settings or set up suitable defaults.
	//
	TRAPD(leaveCode, ReadFaxCommDBSettingsL(faxSettings));
	if (leaveCode != KErrNone)
		{
		INFO_PRINTF2(_L("ReadFaxCommDBSettingsL() error %d!"), leaveCode);
		}
	TESTCHECKL(leaveCode, KErrNone);

	//
	// Set the Fax parameters...
	//
	faxSettings.iFaxClass             = EClass2;
	faxSettings.iMaxSpeed             = 9600;
	faxSettings.iMinSpeed             = 14400;
	faxSettings.iPreferredResolution  = EFaxNormal;
	faxSettings.iPreferredCompression = EModifiedRead;
	faxSettings.iFaxId.Copy(_L8("+441632960000"));

	//
	// Start the Fax session...
	//
	CFaxTransfer*  faxSession = NULL;

	TRAPD(startSessionResult, faxSession = CFaxTransfer::NewL(faxSettings));
	TESTCHECKL(startSessionResult, KErrNone);
	TESTL(faxSession != NULL);

	faxSession->SetMode(EDialAndTransmit); // Or EImmediateTransmit

	//
	// Generate a Fax header for transmitting...
	//
	TFaxHeaderInfo  faxHeader;

	faxHeader.iHeaderFontWidthInBytes = 0;
	
	CFaxHeaderLines*  testheader = CFaxHeaderLines::NewL();
	TRAP_IGNORE(testheader->ReadFaxHeaderInfoL(faxHeader));
	delete testheader;

	GenerateHeaderFileL(faxSettings, *font24x16, 3, 16);

	//
	// Add the source file to the session. The "BLANK.FAX" all-white short run
	// length file.
	//
	faxSession->AddSourceL(_L("C:\\BLANK.FAX"), Prefer2D);

	//
	// Set the destination phone number if needed...
	//
	if ((faxSession->iMode & KFaxNoDial) == 0)
		{
		TBuf8<32>  phoneNumber;

		ReadDestPhoneNumberFromIniFileL(phoneNumber);
		faxSession->SetPhoneNumberL(phoneNumber);
		}
	
	//
	// Begin transfering the fax...
	//
	INFO_PRINTF1(_L("Starting fax transmission of BLANK.FAX an all-white short run length file..."));
	TInt  transferResult = BeginFaxTransfer(faxSession);
	INFO_PRINTF2(_L("Fax transmission completed with return code %d"), transferResult);
	TESTCHECK(transferResult, KErrNone);

	//
	// Clean up the Fax session...
	//
	faxSession->RemoveAllSources();
	delete faxSession;
	faxSession = NULL;

	return TestStepResult();
	} // CFaxTestTransmitFax03::doTestStepL


/**
 *  Each test step initialises it's own name
 */
CFaxTestTransmitFax04::CFaxTestTransmitFax04()
	{
	//
	// Store the name of this test case.  This is the name that is used by
	// the script file.
	//
	SetTestStepName(_L("TestTransmitFax04"));
	} // CFaxTestTransmitFax04::CFaxTestTransmitFax04


/**
 *  This tests the transmission of a straight forward test fax.
 *
 *  @return Test verdict for this test.
 */	
enum TVerdict CFaxTestTransmitFax04::doTestStepL()
	{
	TFaxSettings  faxSettings;

	//
	// Before instantiating CFaxTransfer we have to have a valid set of
	// TFaxSettings to pass in to it - so our first step must always be
	// to read the fax settings or set up suitable defaults.
	//
	TRAPD(leaveCode, ReadFaxCommDBSettingsL(faxSettings));
	if (leaveCode != KErrNone)
		{
		INFO_PRINTF2(_L("ReadFaxCommDBSettingsL() error %d!"), leaveCode);
		}
	TESTCHECKL(leaveCode, KErrNone);

	//
	// Set the Fax parameters...
	//
	faxSettings.iFaxClass             = EClass2point0;
	faxSettings.iPreferredECM         = 1;
	faxSettings.iMaxSpeed             = 2400;
	faxSettings.iMinSpeed             = 2400;
	faxSettings.iPreferredResolution  = EFaxNormal;
	faxSettings.iPreferredCompression = EModifiedHuffman;
	faxSettings.iFaxId.Copy(_L8("+441632960000"));

	//
	// Start the Fax session...
	//
	CFaxTransfer*  faxSession = NULL;

	TRAPD(startSessionResult, faxSession = CFaxTransfer::NewL(faxSettings));
	TESTCHECKL(startSessionResult, KErrNone);
	TESTL(faxSession != NULL);

	faxSession->SetMode(EDialAndTransmit); // Or EImmediateTransmit

	//
	// Generate a Fax header for transmitting...
	//
	TFaxHeaderInfo  faxHeader;

	faxHeader.iHeaderFontWidthInBytes = 0;
	
	CFaxHeaderLines*  testheader = CFaxHeaderLines::NewL();
	TRAP_IGNORE(testheader->ReadFaxHeaderInfoL(faxHeader));
	delete testheader;

	GenerateHeaderFileL(faxSettings, *font8x16, 1, 16);

	//
	// Add the source file to the session...
	//
	faxSession->AddSourceL(_L("C:\\TWO.FAX"), Prefer2D);

	//
	// Set the destination phone number if needed...
	//
	if ((faxSession->iMode & KFaxNoDial) == 0)
		{
		TBuf8<32>  phoneNumber;

		ReadDestPhoneNumberFromIniFileL(phoneNumber);
		faxSession->SetPhoneNumberL(phoneNumber);
		}

	//
	// Begin transfering the fax...
	//
	INFO_PRINTF1(_L("Starting fax transmission of TWO.FAX a two page fax..."));
	TInt  transferResult = BeginFaxTransfer(faxSession);
	INFO_PRINTF2(_L("Fax transmission completed with return code %d"), transferResult);
	TESTCHECK(transferResult, KErrNone);

	//
	// Clean up the Fax session...
	//
	faxSession->RemoveAllSources();
	delete faxSession;
	faxSession = NULL;

	return TestStepResult();
	} // CFaxTestTransmitFax04::doTestStepL


/**
 *  Each test step initialises it's own name
 */
CFaxTestTransmitFax05::CFaxTestTransmitFax05()
	{
	//
	// Store the name of this test case.  This is the name that is used by
	// the script file.
	//
	SetTestStepName(_L("TestTransmitFax05"));
	} // CFaxTestTransmitFax05::CFaxTestTransmitFax05


/**
 *  This tests the transmission of a straight forward test fax.
 *
 *  @return Test verdict for this test.
 */	
enum TVerdict CFaxTestTransmitFax05::doTestStepL()
	{
	TFaxSettings  faxSettings;

	//
	// Before instantiating CFaxTransfer we have to have a valid set of
	// TFaxSettings to pass in to it - so our first step must always be
	// to read the fax settings or set up suitable defaults.
	//
	TRAPD(leaveCode, ReadFaxCommDBSettingsL(faxSettings));
	if (leaveCode != KErrNone)
		{
		INFO_PRINTF2(_L("ReadFaxCommDBSettingsL() error %d!"), leaveCode);
		}
	TESTCHECKL(leaveCode, KErrNone);

	//
	// Set the Fax parameters...
	//
	faxSettings.iFaxClass             = EClassAuto;
	faxSettings.iPreferredECM         = 1;
	faxSettings.iMaxSpeed             = 14400;
	faxSettings.iMinSpeed             = 2400;
	faxSettings.iPreferredResolution  = EFaxNormal;
	faxSettings.iPreferredCompression = EModifiedRead;
	faxSettings.iFaxId.Copy(_L8("+441632960000"));

	//
	// Start the Fax session...
	//
	CFaxTransfer*  faxSession = NULL;

	TRAPD(startSessionResult, faxSession = CFaxTransfer::NewL(faxSettings));
	TESTCHECKL(startSessionResult, KErrNone);
	TESTL(faxSession != NULL);

	faxSession->SetMode(EDialAndTransmit); // Or EImmediateTransmit

	//
	// Generate a Fax header for transmitting...
	//
	TFaxHeaderInfo  faxHeader;

	faxHeader.iHeaderFontWidthInBytes = 0;
	
	CFaxHeaderLines*  testheader = CFaxHeaderLines::NewL();
	TRAP_IGNORE(testheader->ReadFaxHeaderInfoL(faxHeader));
	delete testheader;

	GenerateHeaderFileL(faxSettings, *font24x16, 3, 16);

	//
	// Add the source files to the session. This will test out the multi page
	// sends and also the overall sending of large complex fax images
	// by sending whole of CHART4.FAX, pages 3 to 5 from SIX.FAX, followed by
	// TWO.FAX starting from page 2 and followed by page 1 of BLANK.FAX.
	//
	faxSession->AddSourceL(_L("C:\\chart4.fax"), Prefer2D);
	faxSession->AddSourceL(_L("C:\\SIX.FAX"), 3, 5);
	faxSession->AddSourceL(_L("C:\\TWO.FAX"), 2);
	faxSession->AddSourceL(_L("C:\\BLANK.FAX"), 1, 1);

	//
	// Set the destination phone number if needed...
	//
	if ((faxSession->iMode & KFaxNoDial) == 0)
		{
		TBuf8<32>  phoneNumber;

		ReadDestPhoneNumberFromIniFileL(phoneNumber);
		faxSession->SetPhoneNumberL(phoneNumber);
		}
	
	//
	// Begin transfering the fax...
	//
	INFO_PRINTF1(_L("Starting fax transmission of a large complex fax set..."));
	TInt  transferResult = BeginFaxTransfer(faxSession);
	INFO_PRINTF2(_L("Fax transmission completed with return code %d"), transferResult);
	TESTCHECK(transferResult, KErrNone);

	//
	// Clean up the Fax session...
	//
	faxSession->RemoveAllSources();
	delete faxSession;
	faxSession = NULL;

	return TestStepResult();
	} // CFaxTestTransmitFax05::doTestStepL


/**
 *  Each test step initialises it's own name
 */
CFaxTestTransmitFax06::CFaxTestTransmitFax06()
	{
	//
	// Store the name of this test case.  This is the name that is used by
	// the script file.
	//
	SetTestStepName(_L("TestTransmitFax06"));
	} // CFaxTestTransmitFax06::CFaxTestTransmitFax06


/**
 *  This tests the transmission of a straight forward test fax.
 *
 *  @return Test verdict for this test.
 */	
enum TVerdict CFaxTestTransmitFax06::doTestStepL()
	{
	TFaxSettings  faxSettings;

	//
	// Before instantiating CFaxTransfer we have to have a valid set of
	// TFaxSettings to pass in to it - so our first step must always be
	// to read the fax settings or set up suitable defaults.
	//
	TRAPD(leaveCode, ReadFaxCommDBSettingsL(faxSettings));
	if (leaveCode != KErrNone)
		{
		INFO_PRINTF2(_L("ReadFaxCommDBSettingsL() error %d!"), leaveCode);
		}
	TESTCHECKL(leaveCode, KErrNone);

	//
	// Set the Fax parameters...
	//
	faxSettings.iFaxClass             = EClassAuto;
	faxSettings.iPreferredECM         = 0;
	faxSettings.iMaxSpeed             = 14400;
	faxSettings.iMinSpeed             = 2400;
	faxSettings.iPreferredResolution  = EFaxFine;
	faxSettings.iPreferredCompression = EModifiedHuffman;
	faxSettings.iFaxId.Copy(_L8("+441632960000"));

	//
	// Start the Fax session...
	//
	CFaxTransfer*  faxSession = NULL;

	TRAPD(startSessionResult, faxSession = CFaxTransfer::NewL(faxSettings));
	TESTCHECKL(startSessionResult, KErrNone);
	TESTL(faxSession != NULL);

	faxSession->SetMode(EDialAndTransmit); // Or EImmediateTransmit

	//
	// Generate a Fax header for transmitting...
	//
	TFaxHeaderInfo  faxHeader;

	faxHeader.iHeaderFontWidthInBytes = 0;
	
	CFaxHeaderLines*  testheader = CFaxHeaderLines::NewL();
	TRAP_IGNORE(testheader->ReadFaxHeaderInfoL(faxHeader));
	delete testheader;

	GenerateHeaderFileL(faxSettings, *font24x16, 3, 16);

	//
	// Add the source files to the session. This tests a bad page fax.
	//
	faxSession->AddSourceL(_L("C:\\BADPAGE.FAX"), Prefer1D);

	//
	// Set the destination phone number if needed...
	//
	if ((faxSession->iMode & KFaxNoDial) == 0)
		{
		TBuf8<32>  phoneNumber;

		ReadDestPhoneNumberFromIniFileL(phoneNumber);
		faxSession->SetPhoneNumberL(phoneNumber);
		}
	
	//
	// Begin transfering the fax...
	//
	INFO_PRINTF1(_L("Starting fax transmission of a bad page fax..."));
	TInt  transferResult = BeginFaxTransfer(faxSession);
	INFO_PRINTF2(_L("Fax transmission completed with return code %d"), transferResult);
	TESTCHECK(transferResult, KErrNone);

	//
	// Clean up the Fax session...
	//
	faxSession->RemoveAllSources();
	delete faxSession;
	faxSession = NULL;

	return TestStepResult();
	} // CFaxTestTransmitFax06::doTestStepL


/**
 *  Each test step initialises it's own name
 */
CFaxTestReceiveFax01::CFaxTestReceiveFax01()
	{
	//
	// Store the name of this test case.  This is the name that is used by
	// the script file.
	//
	SetTestStepName(_L("TestReceiveFax01"));
	} // CFaxTestReceiveFax01::CFaxTestReceiveFax01


/**
 *  This tests the reception of a straight forward test fax.
 *
 *  @return Test verdict for this test.
 */	
enum TVerdict CFaxTestReceiveFax01::doTestStepL()
	{
	TFaxSettings  faxSettings;

	//
	// Before instantiating CFaxTransfer we have to have a valid set of
	// TFaxSettings to pass in to it - so our first step must always be
	// to read the fax settings or set up suitable defaults.
	//
	TRAPD(leaveCode, ReadFaxCommDBSettingsL(faxSettings));
	if (leaveCode != KErrNone)
		{
		INFO_PRINTF2(_L("ReadFaxCommDBSettingsL() error %d!"), leaveCode);
		}
	TESTCHECKL(leaveCode, KErrNone);

	//
	// Set the Fax parameters...
	//
	faxSettings.iFaxClass = EClassAuto;  // Or EClass1, EClass2, EClass2point0
	if (faxSettings.iFaxClass == EClass2point0  ||
		faxSettings.iFaxClass == EClassAuto)
		{
		faxSettings.iPreferredECM = 0; // Or 1
		}

	faxSettings.iMaxSpeed = 14400; // 2400 to 14400 % 2400
	faxSettings.iMinSpeed = 2400; // 2400 to 14400 % 2400
	faxSettings.iPreferredResolution = EFaxNormal; // Or EFaxFine
	faxSettings.iPreferredCompression = EModifiedHuffman;
	faxSettings.iFaxId.Copy(_L8("+441632960000"));

	//
	// Start the Fax session...
	//
	CFaxTransfer*  faxSession = NULL;

	TRAPD(startSessionResult, faxSession = CFaxTransfer::NewL(faxSettings));
	TESTCHECKL(startSessionResult, KErrNone);
	TESTL(faxSession != NULL);

	faxSession->SetMode(EWaitForRingAndReceive); // Or EDialAndReceiveFaxBack, EDialAndReceivePoll, EImmediateReceive
	faxSession->SetReceiveFileName(_L("C:\\RECEIVE01.FAX"));

	//
	// Set the destination phone number if needed...
	//
	if ((faxSession->iMode & KFaxNoDial) == 0)
		{
		TBuf8<32>  phoneNumber;

		ReadDestPhoneNumberFromIniFileL(phoneNumber);
		faxSession->SetPhoneNumberL(phoneNumber);
		}

	//
	// Begin transfering the fax...
	//
	INFO_PRINTF1(_L("Starting fax reception..."));
	TInt  transferResult = BeginFaxTransfer(faxSession);
	INFO_PRINTF2(_L("Fax reception completed with return code %d"), transferResult);
	TESTCHECK(transferResult, KErrNone);

	//
	// Clean up the Fax session...
	//
	faxSession->RemoveAllSources();
	delete faxSession;
	faxSession = NULL;

	return TestStepResult();
	} // CFaxTestReceiveFax01::doTestStepL


/**
 *  Each test step initialises it's own name
 */
CFaxTestReceiveFax02::CFaxTestReceiveFax02()
	{
	//
	// Store the name of this test case.  This is the name that is used by
	// the script file.
	//
	SetTestStepName(_L("TestTransmitFax02"));
	} // CFaxTestReceiveFax02::CFaxTestReceiveFax02


/**
 *  This tests the reception of a fax, specifying the call object name first.
 *
 *  @return Test verdict for this test.
 */	
enum TVerdict CFaxTestReceiveFax02::doTestStepL()
	{
	TFaxSettings  faxSettings;

	//
	// Before instantiating CFaxTransfer we have to have a valid set of
	// TFaxSettings to pass in to it - so our first step must always be
	// to read the fax settings or set up suitable defaults.
	//
	TRAPD(leaveCode, ReadFaxCommDBSettingsL(faxSettings));
	if (leaveCode != KErrNone)
		{
		INFO_PRINTF2(_L("ReadFaxCommDBSettingsL() error %d!"), leaveCode);
		}
	TESTCHECKL(leaveCode, KErrNone);

	//
	// Set the Fax parameters...
	//
	faxSettings.iFaxClass = EClassAuto;  // Or EClass1, EClass2, EClass2point0
	if (faxSettings.iFaxClass == EClass2point0  ||
		faxSettings.iFaxClass == EClassAuto)
		{
		faxSettings.iPreferredECM = 0; // Or 1
		}

	faxSettings.iMaxSpeed = 14400; // 2400 to 14400 % 2400
	faxSettings.iMinSpeed = 2400; // 2400 to 14400 % 2400
	faxSettings.iPreferredResolution = EFaxNormal; // Or EFaxFine
	faxSettings.iPreferredCompression = EModifiedHuffman;
	faxSettings.iFaxId.Copy(_L8("+441632960000"));

	//
	// Start the Fax session...
	//
	CFaxTransfer*  faxSession = NULL;

	TRAPD(startSessionResult, faxSession = CFaxTransfer::NewL(faxSettings));
	TESTCHECKL(startSessionResult, KErrNone);
	TESTL(faxSession != NULL);


	faxSession->SetMode(EWaitForRingAndReceive); // Or EDialAndReceiveFaxBack, EDialAndReceivePoll, EImmediateReceive
	faxSession->SetReceiveFileName(_L("C:\\RECEIVE02.FAX"));

	//
	// For this test, find the name of the incoming call and request the fax
	// session to open that call...
	//
	RTelServer  telServer;
	RMobilePhone  phone;
	RLine  line;
	RCall  call;
	TName  incomingCallName;
	RCall::TStatus  callStatus;

	TInt  result = telServer.Connect();
	TESTCHECKL(result, KErrNone);
	CleanupClosePushL(telServer);

	result = telServer.LoadPhoneModule(KTEFaxTSYName);
	TESTCHECKL(result, KErrNone);

	result = phone.Open(telServer, KTEFaxPhoneName);
	TESTCHECKL(result, KErrNone);
	CleanupClosePushL(phone);

	result = line.Open(phone, KTEFaxLineName);
	TESTCHECKL(result, KErrNone);
	CleanupClosePushL(line);

	TRequestStatus  status;

	line.NotifyIncomingCall(status, incomingCallName);
	User::WaitForRequest(status);
	TESTCHECKL(status.Int(), KErrNone);
	INFO_PRINTF2(_L("Incoming fax call is \"%S\"..."), &incomingCallName);

	faxSession->SetCallObjectName(incomingCallName);

	//
	// Open the incoming call and request a notification of state change. If
	// the Fax Server were to open a different RCall object then this would
	// not work - thus it is a good test of SetCallObjectName()...
	//
	result = call.OpenExistingCall(line, incomingCallName);
	TESTCHECKL(result, KErrNone);
	CleanupClosePushL(call);

	callStatus = RCall::EStatusUnknown;
	call.NotifyStatusChange(status, callStatus);
	TESTCHECK(status.Int(), KRequestPending);

	//
	// Set the destination phone number if needed...
	//
	if ((faxSession->iMode & KFaxNoDial) == 0)
		{
		TBuf8<32>  phoneNumber;

		ReadDestPhoneNumberFromIniFileL(phoneNumber);
		faxSession->SetPhoneNumberL(phoneNumber);
		}
	
	//
	// Begin transfering the fax...
	//
	INFO_PRINTF1(_L("Starting fax reception..."));
	TInt  transferResult = BeginFaxTransfer(faxSession);
	INFO_PRINTF2(_L("Fax reception completed with return code %d"), transferResult);
	TESTCHECK(transferResult, KErrNone);

	//
	// Check that the notify operation returned as the fax server answered the
	// call...
	//
	User::WaitForRequest(status);
	TESTCHECK(status.Int(), KErrNone);
	TESTCHECK(callStatus, RCall::EStatusAnswering);

	//
	// Clean up Etel handles...
	//
	CleanupStack::PopAndDestroy(&call);
	CleanupStack::PopAndDestroy(&line);
	CleanupStack::PopAndDestroy(&phone);
	CleanupStack::PopAndDestroy(&telServer);

	//
	// Clean up the Fax session...
	//
	faxSession->RemoveAllSources();
	delete faxSession;
	faxSession = NULL;

	return TestStepResult();
	} // CFaxTestReceiveFax02::doTestStepL


/**
 *  Each test step initialises it's own name
 */
CFaxTestReceiveFax03::CFaxTestReceiveFax03()
	{
	//
	// Store the name of this test case.  This is the name that is used by
	// the script file.
	//
	SetTestStepName(_L("TestReceiveFax03"));
	} // CFaxTestReceiveFax03::CFaxTestReceiveFax03


/**
 *  This tests the reception of a straight forward test fax.
 *
 *  @return Test verdict for this test.
 */	
enum TVerdict CFaxTestReceiveFax03::doTestStepL()
	{
	TFaxSettings  faxSettings;

	//
	// Before instantiating CFaxTransfer we have to have a valid set of
	// TFaxSettings to pass in to it - so our first step must always be
	// to read the fax settings or set up suitable defaults.
	//
	TRAPD(leaveCode, ReadFaxCommDBSettingsL(faxSettings));
	if (leaveCode != KErrNone)
		{
		INFO_PRINTF2(_L("ReadFaxCommDBSettingsL() error %d!"), leaveCode);
		}
	TESTCHECKL(leaveCode, KErrNone);

	//
	// Set the Fax parameters...
	//
	faxSettings.iFaxClass = EClassAuto;  // Or EClass1, EClass2, EClass2point0
	if (faxSettings.iFaxClass == EClass2point0  ||
		faxSettings.iFaxClass == EClassAuto)
		{
		faxSettings.iPreferredECM = 0; // Or 1
		}

	faxSettings.iMaxSpeed = 14400; // 2400 to 14400 % 2400
	faxSettings.iMinSpeed = 2400; // 2400 to 14400 % 2400
	faxSettings.iPreferredResolution = EFaxNormal; // Or EFaxFine
	faxSettings.iPreferredCompression = EModifiedHuffman;
	faxSettings.iFaxId.Copy(_L8("+441632960000"));

	//
	// Start the Fax session...
	//
	CFaxTransfer*  faxSession = NULL;

	TRAPD(startSessionResult, faxSession = CFaxTransfer::NewL(faxSettings));
	TESTCHECKL(startSessionResult, KErrNone);
	TESTL(faxSession != NULL);

	faxSession->SetMode(EWaitForRingAndReceive); // Or EDialAndReceiveFaxBack, EDialAndReceivePoll, EImmediateReceive
	faxSession->SetReceiveFileName(_L("C:\\RECEIVE03.FAX"));

	//
	// Set the destination phone number if needed...
	//
	if ((faxSession->iMode & KFaxNoDial) == 0)
		{
		TBuf8<32>  phoneNumber;

		ReadDestPhoneNumberFromIniFileL(phoneNumber);
		faxSession->SetPhoneNumberL(phoneNumber);
		}
	
	//
	// Begin transfering the fax...
	//
	INFO_PRINTF1(_L("Starting fax reception..."));
	TInt  transferResult = BeginFaxTransfer(faxSession);
	INFO_PRINTF2(_L("Fax reception completed with return code %d"), transferResult);
	TESTCHECK(transferResult, KErrNone);

	//
	// Clean up the Fax session...
	//
	faxSession->RemoveAllSources();
	delete faxSession;
	faxSession = NULL;

	return TestStepResult();
	} // CFaxTestReceiveFax03::doTestStepL


/**
 *  Each test step initialises it's own name
 */
CFaxTestReceiveFax04::CFaxTestReceiveFax04()
	{
	//
	// Store the name of this test case.  This is the name that is used by
	// the script file.
	//
	SetTestStepName(_L("TestReceiveFax04"));
	} // CFaxTestReceiveFax04::CFaxTestReceiveFax04


/**
 *  This tests the reception of a straight forward test fax.
 *
 *  @return Test verdict for this test.
 */	
enum TVerdict CFaxTestReceiveFax04::doTestStepL()
	{
	TFaxSettings  faxSettings;

	//
	// Before instantiating CFaxTransfer we have to have a valid set of
	// TFaxSettings to pass in to it - so our first step must always be
	// to read the fax settings or set up suitable defaults.
	//
	TRAPD(leaveCode, ReadFaxCommDBSettingsL(faxSettings));
	if (leaveCode != KErrNone)
		{
		INFO_PRINTF2(_L("ReadFaxCommDBSettingsL() error %d!"), leaveCode);
		}
	TESTCHECKL(leaveCode, KErrNone);

	//
	// Set the Fax parameters...
	//
	faxSettings.iFaxClass = EClassAuto;  // Or EClass1, EClass2, EClass2point0
	if (faxSettings.iFaxClass == EClass2point0  ||
		faxSettings.iFaxClass == EClassAuto)
		{
		faxSettings.iPreferredECM = 0; // Or 1
		}

	faxSettings.iMaxSpeed = 14400; // 2400 to 14400 % 2400
	faxSettings.iMinSpeed = 2400; // 2400 to 14400 % 2400
	faxSettings.iPreferredResolution = EFaxNormal; // Or EFaxFine
	faxSettings.iPreferredCompression = EModifiedHuffman;
	faxSettings.iFaxId.Copy(_L8("+441632960000"));

	//
	// Start the Fax session...
	//
	CFaxTransfer*  faxSession = NULL;

	TRAPD(startSessionResult, faxSession = CFaxTransfer::NewL(faxSettings));
	TESTCHECKL(startSessionResult, KErrNone);
	TESTL(faxSession != NULL);


	faxSession->SetMode(EWaitForRingAndReceive); // Or EDialAndReceiveFaxBack, EDialAndReceivePoll, EImmediateReceive
	faxSession->SetReceiveFileName(_L("C:\\RECEIVE04.FAX"));

	//
	// Set the destination phone number if needed...
	//
	if ((faxSession->iMode & KFaxNoDial) == 0)
		{
		TBuf8<32>  phoneNumber;

		ReadDestPhoneNumberFromIniFileL(phoneNumber);
		faxSession->SetPhoneNumberL(phoneNumber);
		}
	
	//
	// Begin transfering the fax...
	//
	INFO_PRINTF1(_L("Starting fax reception..."));
	TInt  transferResult = BeginFaxTransfer(faxSession);
	INFO_PRINTF2(_L("Fax reception completed with return code %d"), transferResult);
	TESTCHECK(transferResult, KErrNone);

	//
	// Clean up the Fax session...
	//
	faxSession->RemoveAllSources();
	delete faxSession;
	faxSession = NULL;

	return TestStepResult();
	} // CFaxTestReceiveFax04::doTestStepL


/**
 *  Each test step initialises it's own name
 */
CFaxTestReceiveFax05::CFaxTestReceiveFax05()
	{
	//
	// Store the name of this test case.  This is the name that is used by
	// the script file.
	//
	SetTestStepName(_L("TestReceiveFax05"));
	} // CFaxTestReceiveFax05::CFaxTestReceiveFax05


/**
 *  This tests the reception of a straight forward test fax.
 *
 *  @return Test verdict for this test.
 */	
enum TVerdict CFaxTestReceiveFax05::doTestStepL()
	{
	TFaxSettings  faxSettings;

	//
	// Before instantiating CFaxTransfer we have to have a valid set of
	// TFaxSettings to pass in to it - so our first step must always be
	// to read the fax settings or set up suitable defaults.
	//
	TRAPD(leaveCode, ReadFaxCommDBSettingsL(faxSettings));
	if (leaveCode != KErrNone)
		{
		INFO_PRINTF2(_L("ReadFaxCommDBSettingsL() error %d!"), leaveCode);
		}
	TESTCHECKL(leaveCode, KErrNone);

	//
	// Set the Fax parameters...
	//
	faxSettings.iFaxClass = EClassAuto;  // Or EClass1, EClass2, EClass2point0
	if (faxSettings.iFaxClass == EClass2point0  ||
		faxSettings.iFaxClass == EClassAuto)
		{
		faxSettings.iPreferredECM = 0; // Or 1
		}

	faxSettings.iMaxSpeed = 14400; // 2400 to 14400 % 2400
	faxSettings.iMinSpeed = 2400; // 2400 to 14400 % 2400
	faxSettings.iPreferredResolution = EFaxNormal; // Or EFaxFine
	faxSettings.iPreferredCompression = EModifiedHuffman;
	faxSettings.iFaxId.Copy(_L8("+441632960000"));

	//
	// Start the Fax session...
	//
	CFaxTransfer*  faxSession = NULL;

	TRAPD(startSessionResult, faxSession = CFaxTransfer::NewL(faxSettings));
	TESTCHECKL(startSessionResult, KErrNone);
	TESTL(faxSession != NULL);


	faxSession->SetMode(EWaitForRingAndReceive); // Or EDialAndReceiveFaxBack, EDialAndReceivePoll, EImmediateReceive
	faxSession->SetReceiveFileName(_L("C:\\RECEIVE05.FAX"));

	//
	// Set the destination phone number if needed...
	//
	if ((faxSession->iMode & KFaxNoDial) == 0)
		{
		TBuf8<32>  phoneNumber;

		ReadDestPhoneNumberFromIniFileL(phoneNumber);
		faxSession->SetPhoneNumberL(phoneNumber);
		}

	//
	// Begin transfering the fax...
	//
	INFO_PRINTF1(_L("Starting fax reception..."));
	TInt  transferResult = BeginFaxTransfer(faxSession);
	INFO_PRINTF2(_L("Fax reception completed with return code %d"), transferResult);
	TESTCHECK(transferResult, KErrNone);

	//
	// Clean up the Fax session...
	//
	faxSession->RemoveAllSources();
	delete faxSession;
	faxSession = NULL;

	return TestStepResult();
	} // CFaxTestReceiveFax05::doTestStepL


/**
 *  Each test step initialises it's own name
 */
CFaxTestReceiveFax06::CFaxTestReceiveFax06()
	{
	//
	// Store the name of this test case.  This is the name that is used by
	// the script file.
	//
	SetTestStepName(_L("TestReceiveFax06"));
	} // CFaxTestReceiveFax06::CFaxTestReceiveFax06


/**
 *  This tests the reception of a straight forward test fax.
 *
 *  @return Test verdict for this test.
 */	
enum TVerdict CFaxTestReceiveFax06::doTestStepL()
	{
	TFaxSettings  faxSettings;

	//
	// Before instantiating CFaxTransfer we have to have a valid set of
	// TFaxSettings to pass in to it - so our first step must always be
	// to read the fax settings or set up suitable defaults.
	//
	TRAPD(leaveCode, ReadFaxCommDBSettingsL(faxSettings));
	if (leaveCode != KErrNone)
		{
		INFO_PRINTF2(_L("ReadFaxCommDBSettingsL() error %d!"), leaveCode);
		}
	TESTCHECKL(leaveCode, KErrNone);

	//
	// Set the Fax parameters...
	//
	faxSettings.iFaxClass = EClassAuto;  // Or EClass1, EClass2, EClass2point0
	if (faxSettings.iFaxClass == EClass2point0  ||
		faxSettings.iFaxClass == EClassAuto)
		{
		faxSettings.iPreferredECM = 0; // Or 1
		}

	faxSettings.iMaxSpeed = 14400; // 2400 to 14400 % 2400
	faxSettings.iMinSpeed = 2400; // 2400 to 14400 % 2400
	faxSettings.iPreferredResolution = EFaxNormal; // Or EFaxFine
	faxSettings.iPreferredCompression = EModifiedHuffman;
	faxSettings.iFaxId.Copy(_L8("+441632960000"));

	//
	// Start the Fax session...
	//
	CFaxTransfer*  faxSession = NULL;

	TRAPD(startSessionResult, faxSession = CFaxTransfer::NewL(faxSettings));
	TESTCHECKL(startSessionResult, KErrNone);
	TESTL(faxSession != NULL);


	faxSession->SetMode(EWaitForRingAndReceive); // Or EDialAndReceiveFaxBack, EDialAndReceivePoll, EImmediateReceive
	faxSession->SetReceiveFileName(_L("C:\\RECEIVE06.FAX"));

	//
	// Set the destination phone number if needed...
	//
	if ((faxSession->iMode & KFaxNoDial) == 0)
		{
		TBuf8<32>  phoneNumber;

		ReadDestPhoneNumberFromIniFileL(phoneNumber);
		faxSession->SetPhoneNumberL(phoneNumber);
		}

	//
	// Begin transfering the fax...
	//
	INFO_PRINTF1(_L("Starting fax reception..."));
	TInt  transferResult = BeginFaxTransfer(faxSession);
	INFO_PRINTF2(_L("Fax reception completed with return code %d"), transferResult);
	TESTCHECK(transferResult, KErrNone);

	//
	// Clean up the Fax session...
	//
	faxSession->RemoveAllSources();
	delete faxSession;
	faxSession = NULL;

	return TestStepResult();
	} // CFaxTestReceiveFax06::doTestStepL