omxilcomp/omxilaudioemulator/pcmrenderer/unittest/src/tsu_omxil_component_base.cpp
author hgs
Thu, 14 Oct 2010 10:22:53 +0100
changeset 4 46e224560be8
parent 1 e0d606d6e3b1
permissions -rw-r--r--
2010wk42

// Copyright (c) 2008-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:
//

/**
 @file
 @internalComponent
*/

#include <ecom/ecom.h>
#include <openmax/il/khronos/v1_x/OMX_Component.h>
#include <openmax/il/loader/omxilcomponentif.h>

#include "log.h"
#include "tsu_omxil_component_base.h"


const TInt CCallbackHandler::KMaxMsgQueueEntries;


CAacTestFile*
CAacTestFile::NewL()
	{
    DEBUG_PRINTF(_L8("CAacTestFile::NewL"));
	CAacTestFile* self = new (ELeave) CAacTestFile();
	CleanupStack::PushL(self);
	self->ConstructL();
	CleanupStack::Pop(self);
	return self;
	}

void
CAacTestFile::ConstructL()
	{
    DEBUG_PRINTF(_L8("CAacTestFile::ConstructL"));
	}

CAacTestFile::CAacTestFile() :
	iSourceFile(0),
	iSourceFileReadPos(0),
	iFinished(EFalse)
	{
    DEBUG_PRINTF(_L8("CAacTestFile::CAacTestFile"));
	}

CAacTestFile::~CAacTestFile()
	{
    DEBUG_PRINTF(_L8("CAacTestFile::~CAacTestFile"));

	delete iSourceFile;

	}

TInt
CAacTestFile::ReadTestFileInBuffer(const TDesC& aFileName)
	{
    DEBUG_PRINTF(_L8("CAacTestFile::ReadTestFileInBuffer"));

	RFs fs;
	TInt err;
	err = fs.Connect();
	
	if (err != KErrNone)
		{
		return err;
		}
	
	RFile file;
	err = file.Open(fs, aFileName, EFileRead);
	
	if (err == KErrNone)
		{
		TInt size;
		err = file.Size(size);
		if (err == KErrNone)
			{
			iSourceFile = HBufC8::NewMax(size);
			if(!iSourceFile)
				{
				return KErrNoMemory;
				}
			TPtr8 ptr = iSourceFile->Des();
			file.Read(ptr,size);
			file.Close();
			}
		fs.Close();
		}

    return err;

	}


void
CAacTestFile::ReadNextBuffer(TDes8& aDataBuffer)
    {
    DEBUG_PRINTF(_L8("CAacTestFile::ReadNextBuffer"));

    while (ETrue)
		{
		// check if finished
		if (iFinished)
			{
			DEBUG_PRINTF(_L8("CAacTestFile::ReadNextBuffer : File finished"));
			aDataBuffer.Zero();
			return;
			}

		TInt srcLength = iSourceFile->Size();
		if (iSourceFileReadPos < srcLength)
			{
			TInt size = srcLength;
			if (size > aDataBuffer.MaxLength())
				{
				size = aDataBuffer.MaxLength();
				}
			Mem::Copy((TAny*)aDataBuffer.Ptr(), (TAny*)iSourceFile->Mid(iSourceFileReadPos).Ptr(), size);
			aDataBuffer.SetLength(size);
			iSourceFileReadPos += size;
			DEBUG_PRINTF2(_L8("CAacTestFile::ReadNextBuffer : data read = [%d] bytes"), iSourceFileReadPos);
			DEBUG_PRINTF2(_L8("CAacTestFile::ReadNextBuffer : aDataBuffer Size = [%u] bytes"), aDataBuffer.Length());
			if (iSourceFileReadPos >= srcLength)
				{
				DEBUG_PRINTF(_L8("CAacTestFile::ReadNextBuffer : end of data"));
				iFinished = ETrue;
				}
			return;

			}
		else
			{
			// no more data
			DEBUG_PRINTF(_L8("CAacTestFile::ReadNextBuffer : end of data"));
			iFinished = ETrue;
			return;
			}
		}
    }

void
CAacTestFile::ResetPos()
	{
	iSourceFileReadPos = 0;
	iFinished = EFalse;
	}

TInt
CAacTestFile::GetPos()
	{
	return iSourceFileReadPos;
	}


CAacOutputTestFile*
CAacOutputTestFile::NewL()
	{
    DEBUG_PRINTF(_L8("CAacOutputTestFile::NewL"));
	CAacOutputTestFile* self = new (ELeave) CAacOutputTestFile();
	CleanupStack::PushL(self);
	self->ConstructL();
	CleanupStack::Pop(self);
	return self;
	}

void
CAacOutputTestFile::ConstructL()
	{
    DEBUG_PRINTF(_L8("CAacOutputTestFile::ConstructL"));
	}

CAacOutputTestFile::CAacOutputTestFile() :
	iFileServerSession(),
	iOutputFile(),
	iWrittenDataTotal(0),
	iBuffersWrittenCount(0)
	{
    DEBUG_PRINTF(_L8("CAacOutputTestFile::CAacOutputTestFile"));
	}

CAacOutputTestFile::~CAacOutputTestFile()
	{
    DEBUG_PRINTF(_L8("CAacOutputTestFile::~CAacOutputTestFile"));
	}

TInt
CAacOutputTestFile::SetUpOutputFile(const TDesC& aFileName)
	{
    DEBUG_PRINTF(_L8("CAacOutputTestFile::SetUpOutputFile"));

	TInt err;
	
	err = iFileServerSession.Connect();

	if (err != KErrNone)
		{
		return err;
		}
		
	err = iOutputFile.Create(iFileServerSession,
 			   					  aFileName,
 			   					  EFileWrite|EFileShareExclusive);
	if(err != KErrNone)
		{
		err = iOutputFile.Replace(iFileServerSession,
							aFileName,
							EFileWrite|EFileShareExclusive);
		}
	return err;

	}

TInt
CAacOutputTestFile::WriteDataToFile(const TDesC8& aDataBuffer)
	{
    DEBUG_PRINTF(_L8("CAacOutputTestFile::WriteDataToFile"));


	TInt err = KErrNone;
	err = iOutputFile.Write(aDataBuffer);
	if(err != KErrNone)
		{
		return err;
		}
	// keep record of amount of data and the number of buffers written out
	iWrittenDataTotal += aDataBuffer.Size();
	iBuffersWrittenCount++;

    DEBUG_PRINTF2(_L8("CAacOutputTestFile::WriteDataToFile : aDataBuffer.Size()[%d]"), aDataBuffer.Size());
    DEBUG_PRINTF2(_L8("CAacOutputTestFile::WriteDataToFile : iWrittenDataTotal[%d]"), iWrittenDataTotal);
	DEBUG_PRINTF2(_L8("CAacOutputTestFile::WriteDataToFile : iBuffersWrittenCount[%d]"), iBuffersWrittenCount);

	return err;

	}


TInt
CAacOutputTestFile::AddWavHeader()
	{
    DEBUG_PRINTF(_L8("CAacOutputTestFile::AddWavHeader"));

	TInt err;
	RFs fs;
	err = fs.Connect();
	
	if (err != KErrNone)
		{
		return err;
		}
		
	RFile file;
	err = file.Open(fs, KAacDecoderOutputTestFile, EFileRead);
	if (err != KErrNone)
		{
		return err;
		}

	TInt size;
	err = file.Size(size);
	if (err != KErrNone)
		{
		return err;
		}

	HBufC8* rawDecFile = HBufC8::NewMax(size);
	if(!rawDecFile)
		{
		return KErrNoMemory;
		}

	TPtr8 ptr = rawDecFile->Des();
	file.Read(ptr,size);
	file.Close();

	// add headers
	err = file.Replace(fs, KAacDecoderOutputTestFile, EFileWrite);
	if (err != KErrNone)
		{
		return err;
		}

	// this is canonical WAV file format header
	TInt32 chunkSize = size + KTestWavFormatPCMChunkHeaderSize;
	TInt32 subchunk1size = KTestWavFormatPCMSubchunk1Size;
	TInt16 audioFormat = KTestAudioFormatPCM;
	TInt16 numChannels = KTestNumChannels;
	TInt32 sampleRate = KTestSampleRate;
	TInt16 bitsPerSample = KTestBitsPerSample;
	TInt32 byteRate = sampleRate * numChannels * (bitsPerSample / 8);
	TInt16 blockAlign = numChannels * (bitsPerSample / 8);
	TInt32 subchunk2size = size;

	file.Write(_L8("RIFF"));
	{ TPtrC8 buf((TText8*)&chunkSize,sizeof(TInt32)); file.Write(buf); }
	file.Write(_L8("WAVEfmt "));
	{ TPtrC8 buf((TText8*)&subchunk1size,sizeof(TInt32)); file.Write(buf); }
	{ TPtrC8 buf((TText8*)&audioFormat,sizeof(TInt16)); file.Write(buf); }
	{ TPtrC8 buf((TText8*)&numChannels,sizeof(TInt16)); file.Write(buf); }
	{ TPtrC8 buf((TText8*)&sampleRate,sizeof(TInt32)); file.Write(buf); }
	{ TPtrC8 buf((TText8*)&byteRate,sizeof(TInt32)); file.Write(buf); }
	{ TPtrC8 buf((TText8*)&blockAlign,sizeof(TInt16)); file.Write(buf); }
	{ TPtrC8 buf((TText8*)&bitsPerSample,sizeof(TInt16)); file.Write(buf); }
	file.Write(_L8("data"));
	{ TPtrC8 buf((TText8*)&subchunk2size,sizeof(TInt32)); file.Write(buf); }
	file.Write(ptr,size);

	// store file size
	file.Size(iWrittenDataTotal);

	file.Close();
	fs.Close();

	delete rawDecFile;

	return KErrNone;

	}

void
CAacOutputTestFile::CloseOutputFile()
	{
    DEBUG_PRINTF(_L8("CAacOutputTestFile::CloseOutputFile"));

	iOutputFile.Close();
	iFileServerSession.Close();

	}

//
// CUtilityTimer
//
CUtilityTimer*
CUtilityTimer::NewL(TTimeIntervalMicroSeconds32& aDelay,
					MTimerObserver& aObserver)
    {
    CUtilityTimer* self = new (ELeave) CUtilityTimer(aObserver);
    CleanupStack::PushL(self);
    self->ConstructL(aDelay);
    CleanupStack::Pop(self);
    return self;
    }

void
CUtilityTimer::ConstructL(TTimeIntervalMicroSeconds32& aDelay)
    {
    CTimer::ConstructL();

    iDelay = aDelay;
    CActiveScheduler::Add(this);
    }

CUtilityTimer::~CUtilityTimer()
    {
    Cancel();
    }

void
CUtilityTimer::InitializeTimer()
    {
	// Request another wait - assume not active
	CTimer::After(iDelay);
    }

void
CUtilityTimer::RunL()
    {
	if (iStatus.Int() == KErrNone)
		iObserver.TimerExpired();
    }

void
CUtilityTimer::DoCancel()
	{
	}


CUtilityTimer::CUtilityTimer(MTimerObserver& aObserver) :
	CTimer(CActive::EPriorityUserInput),
    iObserver(aObserver)
	{
    }

//
// CCallbackHandler
//
CCallbackHandler*
CCallbackHandler::NewL(RAsyncTestStepOmxILComponentBase& aDecoderTest)
	{
    DEBUG_PRINTF(_L8("CCallbackHandler::NewL"));

	CCallbackHandler* self = new (ELeave) CCallbackHandler(aDecoderTest);
	CleanupStack::PushL(self);
	self->ConstructL();
	CleanupStack::Pop(self);
	return self;

	}


void
CCallbackHandler::ConstructL()
	{
    DEBUG_PRINTF(_L8("CCallbackHandler::ConstructL"));

	OMX_CALLBACKTYPE h =
		{
		CCallbackHandler::EventHandler,
		CCallbackHandler::EmptyBufferDone,
		CCallbackHandler::FillBufferDone
		};

	iHandle = h;
	CActiveScheduler::Add(this);

	User::LeaveIfError(iMsgQueue.CreateLocal(KMaxMsgQueueEntries));
	iMsgQueue.NotifyDataAvailable(iStatus);
	SetActive();

	}

CCallbackHandler::CCallbackHandler(RAsyncTestStepOmxILComponentBase& aDecoderTest)
	: CActive(EPriorityNormal),
	  iDecoderTest(aDecoderTest)
	{
    DEBUG_PRINTF(_L8("CCallbackHandler::CCallbackHandler"));
	}


CCallbackHandler::operator OMX_CALLBACKTYPE*()
	{
    DEBUG_PRINTF(_L8("CCallbackHandler::operator OMX_CALLBACKTYPE*"));

	return &iHandle;

	}


void
CCallbackHandler::RunL()
	{
    DEBUG_PRINTF(_L8("CCallbackHandler::RunL"));

	TOmxMessage msg;
	while (iMsgQueue.Receive(msg)==KErrNone)
		{
		switch (msg.iType)
			{
		case EEmptyBufferCallback:
			{
			iDecoderTest.DoEmptyBufferDoneL(msg.iComponent,
											msg.iBuffer);
			}
			break;
		case EFillBufferCallback:
			{
			iDecoderTest.DoFillBufferDoneL(msg.iComponent,
										   msg.iBuffer);
			}
			break;
		case EEventCallback:
			{
			iDecoderTest.DoEventHandlerL(msg.iComponent,
										 msg.iEventParams.iEvent,
										 msg.iEventParams.iData1,
										 msg.iEventParams.iData2,
										 msg.iEventParams.iExtra);
			}
			break;
		default:
			{
			// This is an invalid state
			ASSERT(EFalse);
			}
			};
		}

	// setup for next callbacks
	iStatus = KRequestPending;
	iMsgQueue.NotifyDataAvailable(iStatus);
	SetActive();

	}

CCallbackHandler::~CCallbackHandler()
	{
    DEBUG_PRINTF(_L8("CCallbackHandler::~CCallbackHandler"));

	Cancel();
	iMsgQueue.Close();

	}


void
CCallbackHandler::DoCancel()
	{
    DEBUG_PRINTF(_L8("CCallbackHandler::DoCancel"));

	if (iMsgQueue.Handle())
		{
		iMsgQueue.CancelDataAvailable();
		}

	}

OMX_ERRORTYPE
CCallbackHandler::FillBufferDone(OMX_HANDLETYPE aComponent,
								 TAny* aAppData,
								 OMX_BUFFERHEADERTYPE* aBuffer)
	{
    DEBUG_PRINTF(_L8("CCallbackHandler::FillBufferDone"));

	return static_cast<CCallbackHandler*>(aAppData)->DoFillBufferDone(aComponent, aBuffer);

	}

OMX_ERRORTYPE
CCallbackHandler::EmptyBufferDone(OMX_HANDLETYPE aComponent,
								  TAny* aAppData,
								  OMX_BUFFERHEADERTYPE* aBuffer)
	{
    DEBUG_PRINTF(_L8("CCallbackHandler::EmptyBufferDone"));

	return static_cast<CCallbackHandler*>(aAppData)->DoEmptyBufferDone(aComponent, aBuffer);

	}

OMX_ERRORTYPE
CCallbackHandler::EventHandler(OMX_HANDLETYPE aComponent,
							   TAny* aAppData,
							   OMX_EVENTTYPE aEvent,
							   TUint32 aData1,
							   TUint32 aData2,
							   TAny* aExtra)
	{
    DEBUG_PRINTF4(_L8("CCallbackHandler::EventHandler : EVENT[%d] Data1[%d] Data2[%d]"), aExtra, aData1, aData2);

	CCallbackHandler::TEventParams eventParams;
	eventParams.iEvent = aEvent;
	eventParams.iData1 = aData1;
	eventParams.iData2 = aData2;
	eventParams.iExtra = aExtra;
	return static_cast<CCallbackHandler*>(aAppData)->DoEventHandler(aComponent, eventParams);

	}

OMX_ERRORTYPE
CCallbackHandler::DoFillBufferDone(OMX_HANDLETYPE aComponent,
								   OMX_BUFFERHEADERTYPE* aBuffer)
	{
    DEBUG_PRINTF(_L8("CCallbackHandler::DoFillBufferDone"));

	TOmxMessage message;
	message.iType = EFillBufferCallback;
	message.iComponent = aComponent;
	message.iBuffer = aBuffer;
	return RAsyncTestStepOmxILComponentBase::ConvertSymbianErrorType(
		iMsgQueue.Send(message));

	}

OMX_ERRORTYPE
CCallbackHandler::DoEmptyBufferDone(OMX_HANDLETYPE aComponent,
									OMX_BUFFERHEADERTYPE* aBuffer)
	{
    DEBUG_PRINTF(_L8("CCallbackHandler::DoEmptyBufferDone"));

	TOmxMessage message;
	message.iType = EEmptyBufferCallback;
	message.iComponent = aComponent;
	message.iBuffer = aBuffer;
	return RAsyncTestStepOmxILComponentBase::ConvertSymbianErrorType(
		iMsgQueue.Send(message));

	}

OMX_ERRORTYPE
CCallbackHandler::DoEventHandler(OMX_HANDLETYPE aComponent,
								 TEventParams aEventParams)
	{
    DEBUG_PRINTF(_L8("CCallbackHandler::DoEventHandler"));

	TOmxMessage message;
	message.iType = EEventCallback;
	message.iComponent = aComponent;
	message.iEventParams = aEventParams;
	return RAsyncTestStepOmxILComponentBase::ConvertSymbianErrorType(
		iMsgQueue.Send(message));

	}

//
// RAsyncTestStepOmxILComponentBase
//
RAsyncTestStepOmxILComponentBase::RAsyncTestStepOmxILComponentBase(const TDesC& aTestName, TInt aComponentUid)
	:
	iComponentUid(),
	ipKickoffAOp(0),
	ipKickoffStop(0),
	ipCOmxILComponent(0),
	ipCallbackHandler(0),
	ipTestFile(0),
	iTestFileName(KAacDecoderTestFile()),
	ipCompHandle(0)
	{
    DEBUG_PRINTF2(_L8("RAsyncTestStepOmxILComponentBase::RAsyncTestStepOmxILComponentBase: UID[%X]"), aComponentUid);
	iTestStepName = aTestName;
	iComponentUid = aComponentUid;
	// Default heap size is 32K. Increased to avoid the KErrNoMemory for this test step.
	iHeapSize = KTestHeapSize;

	}

RAsyncTestStepOmxILComponentBase::~RAsyncTestStepOmxILComponentBase()
	{
    DEBUG_PRINTF(_L8("RAsyncTestStepOmxILComponentBase::~RAsyncTestStepOmxILComponentBase"));
	// nothing here just yet
	}

void
RAsyncTestStepOmxILComponentBase::PrintOmxState(OMX_STATETYPE aOmxState)
	{
    DEBUG_PRINTF(_L8("RAsyncTestStepOmxILComponentBase::PrintOmxState"));

	switch(aOmxState)
		{
    case OMX_StateInvalid:
		{
		INFO_PRINTF1(_L("OMX STATE : OMX_StateInvalid"));
		}
		break;
    case OMX_StateLoaded:
		{
		INFO_PRINTF1(_L("OMX STATE : OMX_StateLoaded"));
		}
		break;
    case OMX_StateIdle:
		{
		INFO_PRINTF1(_L("OMX STATE : OMX_StateIdle"));
		}
		break;
    case OMX_StateExecuting:
		{
		INFO_PRINTF1(_L("OMX STATE : OMX_StateExecuting"));
		}
		break;
    case OMX_StatePause:
		{
		INFO_PRINTF1(_L("OMX STATE : OMX_StatePause"));
		}
		break;
    case OMX_StateWaitForResources:
		{
		INFO_PRINTF1(_L("OMX STATE : OMX_StateWaitForResources"));
		}
		break;
	default:
		{
		INFO_PRINTF1(_L("OMX STATE : Wrong state found"));
		}
		};

	}

OMX_ERRORTYPE
RAsyncTestStepOmxILComponentBase::ConvertSymbianErrorType(TInt aError)
	{
    DEBUG_PRINTF(_L8("RAsyncTestStepOmxILComponentBase::ConvertSymbianErrorType"));

	OMX_ERRORTYPE err = OMX_ErrorNone;
	switch (aError)
		{
	case KErrNone:
		err = OMX_ErrorNone;
		break;
	case KErrNoMemory:
		err = OMX_ErrorInsufficientResources;
		break;
	case KErrGeneral:
		break;
	default:
		err = OMX_ErrorUndefined;
		}
	return err;

	}


/**
   This method is used at the beginning of the test, and initialises the
   asynchronous calls that will be activated once the call returns. The
   ActiveScheduler is active at this point.  If this test leaves, then
   StopTest() will be called with the leave value, so implicitly the test
   stops.

*/
void
RAsyncTestStepOmxILComponentBase::KickoffTestL()
	{
    DEBUG_PRINTF(_L8("RAsyncTestStepOmxILComponentBase::KickoffTestL"));

	__MM_HEAP_MARK;

	// Set up an asynchronous call
	TCallBack callback (ComponentBaseCallBack, this);
	delete ipKickoffAOp;
	ipKickoffAOp = NULL;
	ipKickoffAOp =
		new (ELeave) CAsyncCallBack (callback, CActive::EPriorityLow);
	// Queues this active object to be run once.
	ipKickoffAOp->Call();

	}

TInt
RAsyncTestStepOmxILComponentBase::ComponentBaseCallBack(TAny* aPtr)
	{
    DEBUG_PRINTF(_L8("RAsyncTestStepOmxILComponentBase::ComponentBaseCallBack"));

	RAsyncTestStepOmxILComponentBase* self = static_cast<RAsyncTestStepOmxILComponentBase*> (aPtr);
	self->DoComponentBaseCallBack();
	return KErrNone;

	}

void
RAsyncTestStepOmxILComponentBase::DoComponentBaseCallBack()
	{
    DEBUG_PRINTF(_L8("RAsyncTestStepOmxILComponentBase::DoComponentBaseCallBack"));

	TRAPD(err, ipCOmxILComponent =
		  COmxILComponentIf::CreateImplementationL(TUid::Uid(iComponentUid)));

	//return StopTest(err, EFail);
	if (err != KErrNone)
		{
		INFO_PRINTF2(_L("RAsyncTestStepOmxILComponentBase::DoComponentBaseCallBack : err [%d]"), err);
		if (KErrNotFound == err)
			{
			INFO_PRINTF1(_L("DoComponentBaseCallBack : CreateImplementationL returned KErrNotFound"));
// PacketVideo's AAC decoder libraries only provided for UDEB
#ifndef _DEBUG
			INFO_PRINTF1(_L("IMPORTANT NOTE : THIS SUITE CAN ONLY BE RUN IN UDEB MODE"));
			INFO_PRINTF1(_L("IMPORTANT NOTE : PACKETVIDEO'S AAC DECODER LIBRARY ONLY AVAILABLE IN UDEB MODE"));
#endif
			}
		return StopTest(err, EFail);
		}

	ipCompHandle = static_cast<OMX_COMPONENTTYPE*>(ipCOmxILComponent->Handle());
	if (!ipCompHandle)
		{
		return StopTest(KErrGeneral, EFail);
		}

	TRAP(err, ipCallbackHandler = CCallbackHandler::NewL(*this));
	if (err != KErrNone)
		{
		return StopTest(err, EFail);
		}

	TRAP(err, ipTestFile = CAacTestFile::NewL());
	if (err != KErrNone)
		{
		return StopTest(err, EFail);
		}

	err = ipTestFile->ReadTestFileInBuffer(iTestFileName);
	if (err != KErrNone)
		{
		return StopTest(err, EFail);
		}

	TRAP(err, ipOutputTestFile = CAacOutputTestFile::NewL());
	if (err != KErrNone)
		{
		return StopTest(err, EFail);
		}

	err = ipOutputTestFile->SetUpOutputFile(KAacDecoderOutputTestFile);
	if (err != KErrNone)
		{
		return StopTest(err, EFail);
		}


	}

TInt
RAsyncTestStepOmxILComponentBase::StopTestCallBack(TAny* aPtr)
	{
    DEBUG_PRINTF(_L8("RAsyncTestStepOmxILComponentBase::StopTestCallBack"));
	RAsyncTestStepOmxILComponentBase* self =
		static_cast<RAsyncTestStepOmxILComponentBase*> (aPtr);
	self->DoStopTestCallBack();
	return KErrNone;
	}

void
RAsyncTestStepOmxILComponentBase::DoStopTestCallBack()
	{
    DEBUG_PRINTF(_L8("RAsyncTestStepOmxILComponentBase::DoStopTestCallBack"));

	StopTest();

	}


void
RAsyncTestStepOmxILComponentBase::CloseTest()
	{
    DEBUG_PRINTF(_L8("RAsyncTestStepOmxILComponentBase::CloseTest"));

    if (ipCompHandle)
    	{
    	ipCompHandle->ComponentDeInit(ipCompHandle);
    	}
	delete ipCOmxILComponent;
	ipCOmxILComponent = 0;
	ipCompHandle = 0;

	delete ipKickoffAOp; // no need to Cancel
	ipKickoffAOp = 0;

	delete ipCallbackHandler;
	ipCallbackHandler = 0;

	delete ipTestFile;
	ipTestFile = 0;

	if (ipOutputTestFile)
		{
		ipOutputTestFile->CloseOutputFile();
		// We ignore here this error...
		TInt err = ipOutputTestFile->AddWavHeader();
		delete ipOutputTestFile;
		ipOutputTestFile = 0;
		}

	REComSession::FinalClose();
	__MM_HEAP_MARKEND;

	}

void
RAsyncTestStepOmxILComponentBase::DoFillBufferDoneL(OMX_HANDLETYPE /* aComponent */,
												   OMX_BUFFERHEADERTYPE* /* aBuffer */)
	{
    DEBUG_PRINTF(_L8("RAsyncTestStepOmxILComponentBase::DoFillBufferDoneL"));
	// By default, no callback expected here...
	return StopTest(KErrGeneral, EFail);
	}

void
RAsyncTestStepOmxILComponentBase::DoEmptyBufferDoneL(OMX_HANDLETYPE /* aComponent */,
													OMX_BUFFERHEADERTYPE* /* aBuffer */)
	{
    DEBUG_PRINTF(_L8("RAsyncTestStepOmxILComponentBase::DoEmptyBufferDoneL"));
	// By default, no callback expected here...
	return StopTest(KErrGeneral, EFail);
	}