diff -r 000000000000 -r 71ca22bcf22a mmfenh/advancedaudiocontroller/tsrc/advancedaudiocontrollertestmodule/AudioPlaybackTestModule/inc/MmfTsPlay.h --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/mmfenh/advancedaudiocontroller/tsrc/advancedaudiocontrollertestmodule/AudioPlaybackTestModule/inc/MmfTsPlay.h Tue Feb 02 01:08:46 2010 +0200 @@ -0,0 +1,452 @@ +/* +* Copyright (c) 2002 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: MmfTsPlay test module. +* +*/ + + + +#ifndef MMFTSPLAY_H +#define MMFTSPLAY_H + +// INCLUDES +#include "StifTestModule.h" +#include + +// CONSTANTS +//const ?type ?constant_var = ?constant; + +//#include "badesca.h" +//#include "ecom.h" +#include +#include +#include "SimpleSoundPlayer.h" +#include "MediaEvent.h" +#include "FileNameParameters.h" +#include "Des8Parameters.h" +#include "UrlParameters.h" +#include +#include +#include // Binh + + + const TInt KErrConfigInvalid = KErrNone; //-1100; + const TInt KErrExpectedValueDifferent = -1502; //-1101 + const TInt KErrSkippedEvents = -1102; + const TInt KErrNotExecuted = -1003; + const TInt KErrExecuted = KErrNone; + const TInt KErrLeft = -1503; + + const TInt KNumMetaDataField = 19; // Binh + + _LIT(KSectionStart, "[general]"); + _LIT(KSectionEnd, "[general_end]"); + + _LIT(KTestCaseConfigStart, "[TestCase]"); + _LIT(KTestCaseConfigEnd, "[End_TestCase]"); + + _LIT(KTagId, "id"); + _LIT(KTagTitle, "Title"); + + _LIT(KTagSoundFile, "SoundFile"); + _LIT(KTagSoundUrl, "SoundUrl"); + _LIT(KTagSoundDes, "SoundDes"); + + _LIT(KTagRepeatTimes, "RepeatTimes"); + _LIT(KTagSilenceDuration, "SilenceDuration"); + + _LIT(KTagRampDuration, "RampDuration"); + + _LIT(KTagPosition, "Position"); + _LIT(KTagErrorRange, "ErrorRange"); + + _LIT(KTagDelay, "Delay"); + _LIT(KTagBalance, "Balance"); + + _LIT(KTagPauseDelay, "PauseDelay"); + _LIT(KTagPlayDelay, "PlayDelay"); + + _LIT(KTagExpectedDuration, "ExpectedDuration"); + _LIT(KTagWindowStart, "StartPosition"); + _LIT(KTagWindowEnd, "EndPosition"); + + _LIT(KTagMime, "MimeType"); + _LIT(KTagIapId, "IapId"); + + _LIT(KTagInterfaceId, "InterfaceId"); + + _LIT(KTagPriority, "Priority"); + _LIT(KTagPriorityPreference, "PriorityPreference"); + + // Binh + _LIT(KTagMetaDataData, "MetaDataData"); + _LIT(KTagMetaDataName, "MetaDataName"); + _LIT(KTagDontPlayAudioClip, "DontPlayAudioClip"); + _LIT(KTagEntriesCount, "EntryCount"); + + _LIT(KLogFileTag, "logFileName"); + _LIT(KLogPathTag, "logPath"); + + _LIT(KDefLogFile, "tmmftsPlayDefault.log"); + _LIT(KDefLogPath, ""); + + //Log literals + //_LIT(KTestCaseTitleFormat, "MMFTS.PLAY.%d-%S"); + _LIT(KTestCaseTitleFormat, "%$2$S - %$1$d"); + //_LIT(KDefaultLogger, "Using Default Logger"); + _LIT(KLoggerStarted, "Started logger for INI file [%S]"); + _LIT(KOpeningConfig, "Opening configuration file [%S]"); + _LIT(KOpeningLogFilepath, "Opening logfile path [%S]"); + _LIT(KConfigRequired, "TestCases need to be configured in file"); + _LIT(KConfigInvalid, "TestCases need to be configured properly (file might have change between GetTestCases and RunTestCase)"); + + //Resultados + _LIT(KTestCaseResultNotImplemented, "TestCase not implemented"); + _LIT(KTestCaseResultSuccess, "successful"); + _LIT(KTestCaseResultFail, "Failed"); + _LIT(KTestCaseResultLeft, "A LEAVE occurred"); + + _LIT(KTestCaseResultFailExpectedValueDifferent, "Expected result is different from actual result"); + _LIT(KTestCaseResultFailSkippedEvents, "Not enough events took place to complete test"); + + _LIT(KTestCaseNotFound, "The TestCase id is invalid"); +// MACROS +//#define ?macro ?macro_def + +// Logging path +//_LIT( KMmfTsPlayLogPath, "\\logs\\testframework\\MmfTsPlay\\" ); +// Log file +//_LIT( KMmfTsPlayLogFile, "MmfTsPlay.txt" ); + +// DATA TYPES +//enum ?declaration +//typedef ?declaration +//extern ?data_type; + +// FUNCTION PROTOTYPES +//?type ?function_name(?arg_list); + +// FORWARD DECLARATIONS +//class ?FORWARD_CLASSNAME; + +// CLASS DECLARATION + +/** +* This a MmfTsPlay class. +* ?other_description_lines +* +* @lib ?library +* @since ?Series60_version +*/ +NONSHARABLE_CLASS(CMmfTsPlay) : public CTestModuleBase + { + public: // Constructors and destructor + + /** + * Two-phased constructor. + */ + static CMmfTsPlay* NewL(); + + /** + * Destructor. + */ + virtual ~CMmfTsPlay(); + + public: // New functions + + /** + * ?member_description. + * @since ?Series60_version + * @param ?arg1 ?description + * @return ?description + */ + //?type ?member_function( ?type ?arg1 ); + + public: // Functions from base classes + + /** + * From CTestModuleBase InitL is used to initialize the MmfTsPlay. + * It is called once for every instance of MmfTsPlay after + * its creation. + * @since ?Series60_version + * @param aIniFile Initialization file for the test module (optional) + * @param aFirstTime Flag is true when InitL is executed for first + * created instance of MmfTsPlay. + * @return Symbian OS error code + */ + TInt InitL( TFileName& aIniFile, TBool aFirstTime ); + + /** + * From CTestModuleBase GetTestCasesL is used to inquiry test cases + * from MmfTsPlay. + * @since ?Series60_version + * @param aTestCaseFile Test case file (optional) + * @param aTestCases Array of TestCases returned to test framework + * @return Symbian OS error code + */ + TInt GetTestCasesL( const TFileName& aTestCaseFile, + RPointerArray& aTestCases ); + + /** + * From CTestModuleBase RunTestCaseL is used to run an individual + * test case. + * @since ?Series60_version + * @param aCaseNumber Test case number + * @param aTestCaseFile Test case file (optional) + * @param aResult Test case result returned to test framework (PASS/FAIL) + * @return Symbian OS error code (test case execution error, which is + * not reported in aResult parameter as test case failure). + */ + TInt RunTestCaseL( const TInt aCaseNumber, + const TFileName& aTestCaseFile, + TTestResult& aResult ); + + /** + * From CTestModuleBase; OOMTestQueryL is used to specify is particular + * test case going to be executed using OOM conditions + * @param aTestCaseFile Test case file (optional) + * @param aCaseNumber Test case number (optional) + * @param aFailureType OOM failure type (optional) + * @param aFirstMemFailure The first heap memory allocation failure value (optional) + * @param aLastMemFailure The last heap memory allocation failure value (optional) + * @return TBool + */ + virtual TBool OOMTestQueryL( const TFileName& /* aTestCaseFile */, + const TInt /* aCaseNumber */, + TOOMFailureType& /* aFailureType */, + TInt& /* aFirstMemFailure */, + TInt& /* aLastMemFailure */ ); + + /** + * From CTestModuleBase; User may add implementation for OOM test + * environment initialization. Usually no implementation is required. + * @param aTestCaseFile Test case file (optional) + * @param aCaseNumber Test case number (optional) + * @return None + */ + virtual void OOMTestInitializeL( const TFileName& /* aTestCaseFile */, + const TInt /* aCaseNumber */ ); + + /** + * From CTestModuleBase; OOMHandleWarningL. User may add implementation + * for OOM test warning handling. Usually no implementation is required. + * @param aTestCaseFile Test case file (optional) + * @param aCaseNumber Test case number (optional) + * @param aFailNextValue FailNextValue for OOM test execution (optional) + * @return None + */ + virtual void OOMHandleWarningL( const TFileName& /* aTestCaseFile */, + const TInt /* aCaseNumber */, + TInt& /* aFailNextValue */); + + /** + * From CTestModuleBase; OOMTestFinalizeL may be used to finalize OOM + * test environment. Usually no implementation is required. + * @param aTestCaseFile Test case file (optional) + * @param aCaseNumber Test case number (optional) + * @return None + */ + virtual void OOMTestFinalizeL( const TFileName& /* aTestCaseFile */, + const TInt /* aCaseNumber */ ); + + protected: // New functions + + void InitLoggerL( const TFileName& aLogPath , const TFileName& aLogFile ); + void InitLoggerL(); + TInt RunTestCaseFunctionL(TInt id, CStifSectionParser *section, TTestResult &aResult) ; + TBool IsDurationInRange(TInt aRepeatTimes, TTimeIntervalMicroSeconds aToneDuration, TTimeIntervalMicroSeconds aRepeatSilence, TTimeIntervalMicroSeconds aErrorRange , TTime aStartTime , TTime aEndTime ) ; + + TInt TestCasePlayFileL(CStifSectionParser *section , TTestResult &aResult) ; + TInt TestCaseGetBitRateL(CStifSectionParser *section , TTestResult &aResult) ; + TInt TestCaseGetDRMCmdL(CStifSectionParser *section , TTestResult &aResult) ; + TInt TestCaseCancelNotificationL(CStifSectionParser *section , TTestResult &aResult) ; + TInt TestCaseCtrImpInfoL(CStifSectionParser *section , TTestResult &aResult) ; + TInt TestCaseSet_PriorityL(CStifSectionParser *section , TTestResult &aResult) ; + TInt TestCasePlayFileWithVolumeRampL(CStifSectionParser *section , TTestResult &aResult) ; + TInt TestCasePlayFileWithRepeatsL(CStifSectionParser *section , TTestResult &aResult) ; + TInt TestCasePlayFileWithPositionL(CStifSectionParser *section , TTestResult &aResult) ; + TInt TestCasePlayFileWithBalanceL(CStifSectionParser *section , TTestResult &aResult) ; + TInt TestCasePlayFileWithPauseL(CStifSectionParser *section , TTestResult &aResult) ; + TInt TestCasePlayFileStopOpenL(CStifSectionParser *section , TTestResult &aResult) ; + TInt TestCaseNewFilePlayerL(CStifSectionParser *section , TTestResult &aResult) ; + TInt TestCaseNewDesPlayerL(CStifSectionParser *section , TTestResult &aResult) ; + TInt TestCaseNewDesReadOnlyPlayerL(CStifSectionParser *section , TTestResult &aResult) ; + TInt TestCaseGetLoadPercentageL(CStifSectionParser *section , TTestResult &aResult) ; + TInt TestCasePlayFileReportPositionL(CStifSectionParser *section , TTestResult &aResult) ; + TInt TestCasePlayFileReportDurationL(CStifSectionParser *section , TTestResult &aResult) ; + TInt TestCasePlayFileWindowL(CStifSectionParser *section , TTestResult &aResult) ; + TInt TestCasePlayFileWindowClearL(CStifSectionParser *section , TTestResult &aResult) ; + TInt TestCasePlayFilesWithPrioritiesL(CStifSectionParser *section , TTestResult &aResult) ; + TInt TestCasePlayFilesWithVolumesL(CStifSectionParser *section , TTestResult &aResult) ; + TInt TestCasePlayDesL(CStifSectionParser *section , TTestResult &aResult) ; + TInt TestCasePlayDesStopOpenL(CStifSectionParser *section , TTestResult &aResult) ; + TInt TestCasePlayUrlL(CStifSectionParser *section , TTestResult &aResult) ; + TInt TestCasePlayUrlStopOpenL(CStifSectionParser *section , TTestResult &aResult) ; + TInt TestCasePlayFileMetaInfoL(CStifSectionParser *section , TTestResult &aResult, TBool aFileHandler=EFalse) ; + TInt TestCasePlayFileFormatsL(CStifSectionParser *section , TTestResult &aResult) ; + TInt TestCasePlayHandlerL(CStifSectionParser *section , TTestResult &aResult) ; + TInt TestCasePlayHandlerStopOpenL(CStifSectionParser *section , TTestResult &aResult) ; + TInt TestCasePlayHandlerWithPauseL(CStifSectionParser *section , TTestResult &aResult) ; + TInt TestCasePlayHandlerWithRampL(CStifSectionParser *section , TTestResult &aResult) ; + TInt TestCasePlayHandlerWithSetPositionL(CStifSectionParser *section , TTestResult &aResult) ; + TInt TestCasePlayHandlerWithGetPositionL(CStifSectionParser *section , TTestResult &aResult) ; + TInt TestCasePlayHandlerWithDurationL(CStifSectionParser *section , TTestResult &aResult) ; + TInt TestCasePlayHandlerWithWindowL(CStifSectionParser *section , TTestResult &aResult) ; + TInt TestCasePlayHandlerWithClearWindowL(CStifSectionParser *section , TTestResult &aResult) ; + TInt TestCasePlayHandlerWithPrioritiesL(CStifSectionParser *section , TTestResult &aResult) ; + TInt TestMetaDataDataL(CStifSectionParser *section , TTestResult &aResult, TBool aFileHandler=EFalse); + TInt TestMetaDataCountL(CStifSectionParser *section , TTestResult &aResult, TBool aFileHandler=EFalse); + TInt TestCaseOpenFileL(CStifSectionParser *section , TTestResult &aResult); + TInt TestCasePlayFileL(CStifSectionParser *section , TTestResult &aResult, TInt aSubCase) ; + TInt TestCasePlayFileHandlerL(CStifSectionParser *section , TTestResult &aResult, TInt aSubCase) ; + TInt TestCasePlayFileSourceL(CStifSectionParser *section , TTestResult &aResult, TInt aSubCase) ; + TInt TestCasePlayDescL(CStifSectionParser *section , TTestResult &aResult, TInt aSubCase) ; + TInt TestCaseRegNotificationL(CStifSectionParser *section , TTestResult &aResult) ; + TInt TestCaseRegLoadNotificationL(CStifSectionParser *section , TTestResult &aResult) ; + TInt TestCasePlayFileWithRepeatForeverL(CStifSectionParser *section , TTestResult &aResult); + TInt TestCasePlayFileWithRepeatsWithPauseL(CStifSectionParser *section , TTestResult &aResult); + TInt TestCasePlayFileWithRepeatsInPlaywindowL(CStifSectionParser *section , TTestResult &aResult); + TInt TestCasePlayFileWithRepeatsInPlaywindowPauseL(CStifSectionParser *section , TTestResult &aResult); + TInt TestCasePlayFileWithRepeatForeverInPlaywindowL(CStifSectionParser *section , TTestResult &aResult); + + TInt TestAudioOutputL(CStifSectionParser *section , TTestResult &aResult); + TInt TestLoopPlayL(CStifSectionParser *section , TTestResult &aResult); + + protected: // Functions from base classes + + private: + + /** + * C++ default constructor. + */ + CMmfTsPlay(); + + /** + * By default Symbian 2nd phase constructor is private. + */ + void ConstructL(); + + //TTimeIntervalMicroSeconds GetDelayL(CStifSectionParser *aSection, const TDesC &aTag=KTagDelay); + TTimeIntervalMicroSeconds32 GetTimeIntervalL(CStifSectionParser *aSection, const TDesC &aTag, TBool &aUsingDefault, const TTimeIntervalMicroSeconds32 &aDefaultInterval); + TTimeIntervalMicroSeconds GetTimeIntervalL(CStifSectionParser *aSection, const TDesC &aTag, TBool &aUsingDefault, const TTimeIntervalMicroSeconds &aDefaultInterval=TTimeIntervalMicroSeconds(-1) ); + + HBufC8 *GetDescriptor8LC(const TFileName &aFileName,CStifSectionParser *aSection ); + + TInt GetIntL(CStifSectionParser *aSection, const TDesC &aTag, TBool &aUsingDefault, const TInt &aDefaultInt, TBool aContinue=EFalse) ; + + // Binh + TInt CMmfTsPlay::DisplayFields(TInt aEntryCount, CSimpleSoundPlayer* aSndPlayer, TBool aDisplay); + TInt CMmfTsPlay::GetFieldId(const TDesC& aString); + void CMmfTsPlay::DeleteMetaDataFields(); + + public: // Data + static const TInt MAX_TESTCASE_ID; + static const TInt KDefaultRepeats; + static const TInt KDefaultRepeatForever; + +#define KDefaultSilenceDuration (TTimeIntervalMicroSeconds ((TInt64)500000)) +#define KDefaultRampDuration (TTimeIntervalMicroSeconds ((TInt64)2000000)) +#define KDefaultPosition (TTimeIntervalMicroSeconds ((TInt64) 2000000)) +#define KDefaultErrorRange (TTimeIntervalMicroSeconds ((TInt64) 250000)) + static const TInt KDefaultPauseDelay; + static const TInt KDefaultPlayDelay; + static const TInt KDefaultStopOpenPlayDelay; + static const TInt KDefaultReportDelay; + //Cases + static const TInt KCasePlayFile; + static const TInt KCasePlayFileWithRepeats; + static const TInt KCasePlayFileWithRamp; + static const TInt KCasePlayFileWithPause; + static const TInt KCasePlayFileWithPosition; + static const TInt KCaseGetLoadPercentage; + static const TInt KCasePlayFileWithBalance; + static const TInt KCasePlayFileStopOpen; + static const TInt KCasePlayFileReportPosition; + static const TInt KCasePlayFileReportDuration; + static const TInt KCasePlayFileWindow; + static const TInt KCasePlayFileClearWindow; + static const TInt KCasePlayFilesWithPriorities; + static const TInt KCasePlayFilesWithVolumes; + static const TInt KCasePlayDes; + static const TInt KCasePlayDesStopOpen ; + static const TInt KCasePlayUrl; + static const TInt KCasePlayUrlStopOpen ; + static const TInt KCasePlayFileMetaInfo; + static const TInt KCaseImplementationInformation; + static const TInt KCasePlayHandler; + static const TInt KCasePlayHandlerStopOpen; + static const TInt KCasePlayHandlerWithPause; + static const TInt KCasePlayHandlerWithRamp; + static const TInt KCasePlayHandlerWithSetPosition; + static const TInt KCasePlayHandlerWithGetPosition; + static const TInt KCasePlayHandlerWithDuration; + static const TInt KCasePlayHandlerWithWindow; + static const TInt KCasePlayHandlerWithClearWindow; + static const TInt KCasePlayHandlerWithPriorities; + static const TInt KCaseNewFilePlayer; + static const TInt KCaseNewDesPlayer; + static const TInt KCaseNewDesReadOnlyPlayer; + static const TInt KCaseGetBitRate; + static const TInt KCaseGetDRMCmd; + static const TInt KCaseCancelNotification; + static const TInt KCaseCtrImpInfo; + static const TInt KCaseSet_Priority; + static const TInt KCaseMetaDataData; + static const TInt KCaseMetaDataCount; + static const TInt KCaseMetaDataDataFileHandler; + static const TInt KCasePlayFileMetaInfoFileHandler; + static const TInt KCaseMetaDataCountFileHandler; + static const TInt KCaseOpenFile ; + static const TInt KCasePlayFileHandler ; + static const TInt KCasePlayFileSource ; + static const TInt KCasePlayDesc ; + static const TInt KCaseOpenUrl ; + static const TInt KCase_PlayFile ; + static const TInt KCaseRegNotification; + static const TInt KCaseRegLoadNotification; + static const TInt KCasePlayFileWithRepeatForever; + static const TInt KCasePlayFileWithRepeatsWithPause; + static const TInt KCasePlayFileWithRepeatsInPlaywindow; + static const TInt KCasePlayFileWithRepeatsInPlaywindowPause; + static const TInt KCasePlayFileWithRepeatForeverInPlaywindow; + + static const TInt KCaseAudioOutput; + static const TInt KCaseLoopPlayTest; + + protected: // Data + + private: // Data + + CStifLogger *iLogger; + CActiveScheduler* iScheduler; + + //Binh + HBufC* iMetaDataField[KNumMetaDataField]; + TBuf<50> iMetaDataFieldName[KNumMetaDataField]; + TMetaDataFieldId iMetaDataFieldID[KNumMetaDataField]; + + public: // Friend classes + RFs iFs; + // RFs iFs2; + RFile iFile; + // RFile iFile2; + + protected: // Friend classes + private: // Friend classes + + }; + +#endif // MMFTSPLAY_H + +// End of File