mmaudio_pub/drm_audio_player_api/tsrc/DRMAudioPlay/src/DRMAudioPlay_core.cpp
author hgs
Wed, 13 Oct 2010 12:45:32 +0100
changeset 2 5c1df44f2eed
parent 0 b8ed18f6c07b
child 5 b220a9341636
permissions -rw-r--r--
2010wk42_01
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
0
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
     1
/*
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
     2
* Copyright (c) 2002 Nokia Corporation and/or its subsidiary(-ies).
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
     3
* All rights reserved.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
     4
* This component and the accompanying materials are made available
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
     5
* under the terms of "Eclipse Public License v1.0"
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
     6
* which accompanies this distribution, and is available
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
     7
* at the URL "http://www.eclipse.org/legal/epl-v10.html".
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
     8
*
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
     9
* Initial Contributors:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    10
* Nokia Corporation - initial contribution.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    11
*
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    12
* Contributors:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    13
*
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    14
* Description: DRM Player
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    15
*
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    16
*/
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    17
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    18
// INCLUDE FILES
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    19
#include <StifTestInterface.h>
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    20
#include "DRMAudioPlay.h"
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    21
#include <caf.h>
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    22
#include <caf/supplier.h>
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    23
#include <caf/importfile.h>
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    24
#include <BAUTILS.H>
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    25
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    26
using namespace ContentAccess;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    27
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    28
	// Constants
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    29
	const TInt CDRMAudioPlay::MAX_TESTCASE_ID = 1046;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    30
	const TInt CDRMAudioPlay::KDefaultRepeats = 5;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    31
	const TInt CDRMAudioPlay::KDefaultRepeatForever = -2;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    32
	const TInt CDRMAudioPlay::KDefaultPauseDelay = 1000000;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    33
	const TInt CDRMAudioPlay::KDefaultPlayDelay = 3000000;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    34
	const TInt CDRMAudioPlay::KDefaultStopOpenPlayDelay = 1000000;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    35
	const TInt CDRMAudioPlay::KDefaultReportDelay = 500000;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    36
	
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    37
	// Taken from Oma2Agent.h
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    38
	_LIT8(KOma1XmlRoContentType, "application/vnd.oma.drm.rights+xml");
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    39
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    40
	//Cases
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    41
	const TInt CDRMAudioPlay::KCaseImplementationInformation                        = 1001;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    42
	const TInt CDRMAudioPlay::KCasePlayFile                                         = 1002;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    43
	const TInt CDRMAudioPlay::KCasePlayFileStopOpen                                 = 1003;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    44
    const TInt CDRMAudioPlay::KCasePlayDes                                          = 1004;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    45
    const TInt CDRMAudioPlay::KCasePlayDesStopOpen                                  = 1005;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    46
    const TInt CDRMAudioPlay::KCasePlayUrl                                          = 1006;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    47
    const TInt CDRMAudioPlay::KCasePlayUrlStopOpen                                  = 1007;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    48
	const TInt CDRMAudioPlay::KCasePlayFileWithPause                                = 1008;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    49
	const TInt CDRMAudioPlay::KCasePlayFileWithPosition                             = 1009;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    50
	const TInt CDRMAudioPlay::KCasePlayFileReportPosition                           = 1010;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    51
	const TInt CDRMAudioPlay::KCasePlayFileReportDuration                           = 1011;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    52
    const TInt CDRMAudioPlay::KCasePlayFilesWithVolumes                             = 1012;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    53
    const TInt CDRMAudioPlay::KCasePlayFileWithRamp                                 = 1013;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    54
    const TInt CDRMAudioPlay::KCasePlayFileMetaInfo                                 = 1014;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    55
    const TInt CDRMAudioPlay::KCasePlayFileWindow                                   = 1015;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    56
    const TInt CDRMAudioPlay::KCasePlayFileClearWindow                              = 1016;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    57
    const TInt CDRMAudioPlay::KCasePlayFileWithRepeats                              = 1017;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    58
    const TInt CDRMAudioPlay::KCasePlayFileWithBalance                              = 1018;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    59
    const TInt CDRMAudioPlay::KCasePlayFilesWithPriorities                          = 1019;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    60
    const TInt CDRMAudioPlay::KCasePlayHandler                                      = 1020;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    61
    const TInt CDRMAudioPlay::KCasePlayHandlerStopOpen                              = 1021;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    62
    const TInt CDRMAudioPlay::KCasePlayHandlerWithPause                             = 1022;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    63
    const TInt CDRMAudioPlay::KCasePlayFileHandlerWithRamp                          = 1023;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    64
    const TInt CDRMAudioPlay::KCasePlayFileHandlerWithSetPosition                   = 1024;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    65
    const TInt CDRMAudioPlay::KCasePlayFileHandlerWithGetPosition                   = 1025;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    66
    const TInt CDRMAudioPlay::KCasePlayFileHandlerWithDuration                      = 1026;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    67
    const TInt CDRMAudioPlay::KCasePlayFileHandlerWithWindow                        = 1027;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    68
    const TInt CDRMAudioPlay::KCasePlayFileHandlerWithClearWindow                   = 1028;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    69
    const TInt CDRMAudioPlay::KCasePlayFileSetVolume                                = 1029;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    70
    const TInt CDRMAudioPlay::KCasePlayFileGetBalance                               = 1030;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    71
    const TInt CDRMAudioPlay::KCasePlayFileGetBitRate                               = 1031;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    72
    const TInt CDRMAudioPlay::KCasePlayFileGetAudioLoadingProgress                  = 1032;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    73
    const TInt CDRMAudioPlay::KCasePlayFileRegisterForAudioLoadingNotification      = 1033;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    74
    const TInt CDRMAudioPlay::KCasePlayFileImplementationInformation                = 1034;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    75
    const TInt CDRMAudioPlay::KCasePlayFileMaxVolume                                = 1035;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    76
    const TInt CDRMAudioPlay::KCasePlayFileSetBalance                               = 1036;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    77
    const TInt CDRMAudioPlay::KCasePlayFileSetPriority                              = 1037;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    78
    const TInt CDRMAudioPlay::KCasePlayFileSetRepeats                               = 1038;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    79
	const TInt CDRMAudioPlay::KCasePlayFilesGetMetaDataEntry                        = 1039;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    80
	const TInt CDRMAudioPlay::KCasePlayFilesGetNumberOfMetaDataEntries              = 1040;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    81
    const TInt CDRMAudioPlay::KCasePlayRepeatDRMFile                                = 1041;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    82
    const TInt CDRMAudioPlay::KCasePlayPauseRepeatDRMFile                           = 1042;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    83
    const TInt CDRMAudioPlay::KCasePlayRepeatDRMFileForever                         = 1043;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    84
    const TInt CDRMAudioPlay::KCasePlayRepeatDRMFileWithPlayWindow                  = 1044;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    85
    const TInt CDRMAudioPlay::KCasePlayPauseRepeatDRMFileWithPlayWindow             = 1045;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    86
    const TInt CDRMAudioPlay::KCasePlayRepeatForeverDRMFileWithPlayWindow           = 1046;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    87
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    88
// ** FilePlay *******************************************************
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    89
TInt CDRMAudioPlay::TestCasePlayFileWithPauseL(CStifSectionParser *section , TTestResult &aResult)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    90
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    91
	TPtrC FileNamePtr;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    92
	TTimeIntervalMicroSeconds32 PauseDelay=KDefaultPauseDelay;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    93
	TTimeIntervalMicroSeconds32 PlayDelay=KDefaultPlayDelay;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    94
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    95
	if ( !section->GetLine(KTagSoundFile, FileNamePtr, ENoTag) )
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    96
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    97
		TFileName FileName = FileNamePtr;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    98
		iLogger->Log(_L("Creating simple player with file [%S]"), &FileNamePtr);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    99
		CSimpleSoundPlayer *sndPlayer = CSimpleSoundPlayer::NewL( FileName, TestModuleIf() , *iLogger);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   100
		CleanupStack::PushL(sndPlayer);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   101
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   102
		//*********************************************
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   103
		TBool UsingDefault;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   104
		PauseDelay = GetTimeIntervalL(section, KTagPauseDelay, UsingDefault, (TTimeIntervalMicroSeconds32)KDefaultPauseDelay);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   105
		if (UsingDefault) {iLogger->Log(_L("Error retrieving pause delay, using default"));}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   106
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   107
		PlayDelay = GetTimeIntervalL(section, KTagPlayDelay, UsingDefault, (TTimeIntervalMicroSeconds32)KDefaultPlayDelay);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   108
		if (UsingDefault) {iLogger->Log(_L("Error retrieving play delay, using default"));}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   109
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   110
		if (PauseDelay > PlayDelay)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   111
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   112
			//Pause delay longer than play delay. Switching
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   113
			TTimeIntervalMicroSeconds32 TempDelay = PlayDelay;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   114
			PlayDelay = PauseDelay;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   115
			PauseDelay = TempDelay;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   116
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   117
		iLogger->Log(_L("Setting Pause and Play delays to [%d] and [%d]"), PauseDelay.Int(), PlayDelay.Int());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   118
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   119
		TTimeIntervalMicroSeconds ErrorRange = GetTimeIntervalL(section, KTagErrorRange, UsingDefault, KDefaultErrorRange);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   120
		if (UsingDefault) {iLogger->Log(_L("Using default error range"));}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   121
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   122
		//*********************************************
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   123
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   124
		CParameters *pauseParams = new (ELeave) CParameters( CSimpleSoundPlayer::KPlayerActionPause );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   125
		CleanupStack::PushL(pauseParams);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   126
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   127
		CParameters *playParams = new (ELeave) CParameters( CSimpleSoundPlayer::KPlayerActionPlay );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   128
		CleanupStack::PushL(playParams);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   129
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   130
		CMediaEvent *mEventPlay = CMediaEvent::NewLC(TestModuleIf() , *iLogger, PlayDelay, PlayDelay, sndPlayer, playParams);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   131
		CMediaEvent *mEventPause = CMediaEvent::NewLC(TestModuleIf() , *iLogger, PauseDelay, PauseDelay, sndPlayer, pauseParams, CActive::EPriorityStandard+1);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   132
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   133
		iLogger->Log(_L("Starting scheduler"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   134
		TTime StartTime, EndTime;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   135
		StartTime.HomeTime();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   136
		CActiveScheduler::Start();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   137
		EndTime.HomeTime();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   138
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   139
		iLogger->Log(_L("Returned from player, errorcode: %d"), sndPlayer->iFinalError );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   140
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   141
		TTimeIntervalMicroSeconds PerceivedDuration = EndTime.MicroSecondsFrom( StartTime );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   142
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   143
		TTime ExpectedEnd = StartTime + sndPlayer->GetDuration() + PlayDelay - PauseDelay;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   144
		TTime Range1 = ExpectedEnd - ErrorRange;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   145
		TTime Range2 = ExpectedEnd + ErrorRange;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   146
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   147
		TTimeIntervalMicroSeconds ExpectedDuration = ExpectedEnd.MicroSecondsFrom( StartTime );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   148
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   149
		iLogger->Log(_L("Perceived duration (%d)") , PerceivedDuration.Int64() );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   150
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   151
		iLogger->Log(_L("Expected duration  (%d)"), ExpectedDuration.Int64() );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   152
	//	iLogger->Log(_L("Difference = (%d)") , ExpectedEnd.MicroSecondsFrom(EndTime) );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   153
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   154
		if (mEventPlay->GetCount()<=0 || mEventPause->GetCount()<=0)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   155
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   156
			iLogger->Log( KTestCaseResultFailSkippedEvents() );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   157
			aResult.iResultDes.Copy( KTestCaseResultFailSkippedEvents() );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   158
			aResult.iResult = KErrSkippedEvents;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   159
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   160
		else if (EndTime < Range1 || Range2 < EndTime)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   161
			{	//Durations too different
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   162
			iLogger->Log(_L("The clips duration + silence duration (%d) is too different from the actual duration (%d)") , ExpectedDuration.Int64() , PerceivedDuration.Int64() );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   163
			aResult.iResult = KErrExpectedValueDifferent;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   164
			aResult.iResultDes.Copy(KTestCaseResultFailExpectedValueDifferent());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   165
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   166
		else if (sndPlayer->iFinalError)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   167
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   168
			aResult.iResult = sndPlayer->iFinalError;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   169
			iLogger->Log(_L("Test failed, error code %d"), aResult.iResult);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   170
			aResult.iResultDes.Copy(KTestCaseResultFail());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   171
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   172
		else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   173
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   174
			iLogger->Log(_L("Test was successful"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   175
			aResult.iResultDes.Copy(KTestCaseResultSuccess());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   176
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   177
		CleanupStack::PopAndDestroy(mEventPause);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   178
		CleanupStack::PopAndDestroy(mEventPlay);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   179
		CleanupStack::Pop(playParams);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   180
		CleanupStack::Pop(pauseParams);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   181
		CleanupStack::PopAndDestroy(sndPlayer);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   182
		return KErrExecuted;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   183
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   184
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   185
	else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   186
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   187
		//The file name of the clip to play is missing
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   188
		aResult.iResultDes.Copy(KConfigInvalid());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   189
		aResult.iResult = KErrNotExecuted;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   190
		return KErrConfigInvalid;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   191
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   192
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   193
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   194
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   195
TInt CDRMAudioPlay::TestCasePlayHandlerWithPauseL(CStifSectionParser *section , TTestResult &aResult)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   196
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   197
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   198
	TPtrC FileNamePtr;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   199
	User::LeaveIfError(iFs.Connect());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   200
	iFs.ShareProtected();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   201
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   202
	TTimeIntervalMicroSeconds32 PauseDelay = KDefaultPauseDelay;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   203
	TTimeIntervalMicroSeconds32 PlayDelay = KDefaultPlayDelay;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   204
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   205
	if ( !section->GetLine(KTagSoundFile, FileNamePtr, ENoTag) )
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   206
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   207
		TFileName FileName = FileNamePtr;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   208
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   209
		iLogger->Log(_L("Creating simple player with file handler [%S]"), &FileNamePtr);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   210
		User::LeaveIfError(iFile.Open( iFs, FileName, EFileRead));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   211
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   212
		CSimpleSoundPlayer *sndPlayer = CSimpleSoundPlayer::NewL( iFile, TestModuleIf() , *iLogger);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   213
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   214
		iFile.Close();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   215
	//	iFs.Close();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   216
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   217
		CleanupStack::PushL(sndPlayer);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   218
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   219
		//*********************************************
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   220
		TBool UsingDefault;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   221
		PauseDelay = GetTimeIntervalL(section, KTagPauseDelay, UsingDefault, (TTimeIntervalMicroSeconds32)KDefaultPauseDelay);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   222
		if (UsingDefault) {iLogger->Log(_L("Error retrieving pause delay, using default"));}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   223
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   224
		PlayDelay = GetTimeIntervalL(section, KTagPlayDelay, UsingDefault, (TTimeIntervalMicroSeconds32)KDefaultPlayDelay);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   225
		if (UsingDefault) {iLogger->Log(_L("Error retrieving play delay, using default"));}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   226
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   227
		if (PauseDelay > PlayDelay)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   228
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   229
			//Pause delay longer than play delay. Switching
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   230
			TTimeIntervalMicroSeconds32 TempDelay = PlayDelay;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   231
			PlayDelay = PauseDelay;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   232
			PauseDelay = TempDelay;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   233
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   234
		iLogger->Log(_L("Setting Pause and Play delays to [%d] and [%d]"), PauseDelay.Int(), PlayDelay.Int());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   235
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   236
		TTimeIntervalMicroSeconds ErrorRange = GetTimeIntervalL(section, KTagErrorRange, UsingDefault, KDefaultErrorRange);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   237
		if (UsingDefault) {iLogger->Log(_L("Using default error range"));}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   238
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   239
		//*********************************************
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   240
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   241
		CParameters *pauseParams = new (ELeave) CParameters( CSimpleSoundPlayer::KPlayerActionPause );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   242
		CleanupStack::PushL(pauseParams);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   243
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   244
		CParameters *playParams = new (ELeave) CParameters( CSimpleSoundPlayer::KPlayerActionPlay );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   245
		CleanupStack::PushL(playParams);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   246
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   247
		CMediaEvent *mEventPlay = CMediaEvent::NewLC(TestModuleIf() , *iLogger, PlayDelay, PlayDelay, sndPlayer, playParams);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   248
		CMediaEvent *mEventPause = CMediaEvent::NewLC(TestModuleIf() , *iLogger, PauseDelay, PauseDelay, sndPlayer, pauseParams, CActive::EPriorityStandard+1);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   249
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   250
		iLogger->Log(_L("Starting scheduler"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   251
		TTime StartTime, EndTime;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   252
		StartTime.HomeTime();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   253
		CActiveScheduler::Start();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   254
		EndTime.HomeTime();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   255
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   256
		iFs.Close();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   257
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   258
		iLogger->Log(_L("Returned from player, errorcode: %d"), sndPlayer->iFinalError );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   259
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   260
		TTimeIntervalMicroSeconds PerceivedDuration = EndTime.MicroSecondsFrom( StartTime );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   261
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   262
		TTime ExpectedEnd = StartTime + sndPlayer->GetDuration() + PlayDelay - PauseDelay;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   263
		TTime Range1 = ExpectedEnd - ErrorRange;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   264
		TTime Range2 = ExpectedEnd + ErrorRange;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   265
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   266
		TTimeIntervalMicroSeconds ExpectedDuration = ExpectedEnd.MicroSecondsFrom( StartTime );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   267
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   268
		iLogger->Log(_L("Perceived duration (%d)") , PerceivedDuration.Int64() );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   269
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   270
		iLogger->Log(_L("Expected duration  (%d)"), ExpectedDuration.Int64() );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   271
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   272
	//	iLogger->Log(_L("Difference = (%d)") , ExpectedEnd.MicroSecondsFrom(EndTime) );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   273
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   274
		if (mEventPlay->GetCount()<=0 || mEventPause->GetCount()<=0)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   275
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   276
			iLogger->Log( KTestCaseResultFailSkippedEvents() );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   277
			aResult.iResultDes.Copy( KTestCaseResultFailSkippedEvents() );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   278
			aResult.iResult = KErrSkippedEvents;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   279
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   280
		else if (EndTime < Range1 || Range2 < EndTime)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   281
			{	//Durations too different
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   282
			iLogger->Log(_L("The clips duration + silence duration (%d) is too different from the actual duration (%d)") , ExpectedDuration.Int64() , PerceivedDuration.Int64() );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   283
			aResult.iResult = KErrExpectedValueDifferent;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   284
			aResult.iResultDes.Copy(KTestCaseResultFailExpectedValueDifferent());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   285
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   286
		else if (sndPlayer->iFinalError)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   287
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   288
			aResult.iResult = sndPlayer->iFinalError;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   289
			iLogger->Log(_L("Test failed, error code %d"), aResult.iResult);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   290
			aResult.iResultDes.Copy(KTestCaseResultFail());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   291
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   292
		else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   293
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   294
			iLogger->Log(_L("Test was successful"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   295
			aResult.iResultDes.Copy(KTestCaseResultSuccess());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   296
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   297
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   298
		CleanupStack::PopAndDestroy(mEventPause);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   299
		CleanupStack::PopAndDestroy(mEventPlay);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   300
		CleanupStack::Pop(playParams);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   301
		CleanupStack::Pop(pauseParams);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   302
		CleanupStack::PopAndDestroy(sndPlayer);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   303
		return KErrExecuted;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   304
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   305
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   306
	else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   307
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   308
		//The file name of the clip to play is missing
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   309
		aResult.iResultDes.Copy(KConfigInvalid());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   310
		aResult.iResult = KErrNotExecuted;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   311
		return KErrConfigInvalid;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   312
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   313
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   314
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   315
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   316
TInt CDRMAudioPlay::TestCasePlayFileL(CStifSectionParser *section , TTestResult &aResult)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   317
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   318
	TPtrC FileNamePtr;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   319
    CStifItemParser *item;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   320
    TInt parseError = KErrNone;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   321
    TBool Immediate = 0;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   322
	if ( !section->GetLine(KTagSoundFile, FileNamePtr, ENoTag) )
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   323
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   324
		TFileName FileName = FileNamePtr;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   325
		iLogger->Log(_L("Creating simple player with file [%S]"), &FileNamePtr);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   326
        item = section->GetItemLineL(KTagImmediate);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   327
        if (item)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   328
            {
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   329
            CleanupStack::PushL(item);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   330
            parseError = item->GetInt(KTagImmediate, Immediate);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   331
            CleanupStack::PopAndDestroy(item);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   332
            }
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   333
        item = NULL;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   334
        TBool FileType = EFalse;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   335
        item = section->GetItemLineL(KTagFileType);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   336
        if (item)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   337
        	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   338
        	CleanupStack::PushL(item);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   339
        	parseError = item->GetInt(KTagFileType, FileType);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   340
        	CleanupStack::PopAndDestroy(item);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   341
        	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   342
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   343
        CSimpleSoundPlayer *sndPlayer = CSimpleSoundPlayer::NewL( FileName, TestModuleIf() , *iLogger, Immediate, FileType);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   344
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   345
		CleanupStack::PushL(sndPlayer);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   346
		iLogger->Log(_L("Starting scheduler"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   347
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   348
		CActiveScheduler::Start();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   349
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   350
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   351
		iLogger->Log(_L("Returned from player, errorcode: %d"), sndPlayer->iFinalError );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   352
		aResult.iResult = sndPlayer->iFinalError ;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   353
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   354
		TBool DontCheckExpectedDuration;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   355
		TTimeIntervalMicroSeconds ErrorRange=GetTimeIntervalL(section, KTagErrorRange, DontCheckExpectedDuration);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   356
		if (!DontCheckExpectedDuration && !aResult.iResult)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   357
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   358
			TBool DontUseExpectedDuration;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   359
			TTimeIntervalMicroSeconds ExpectedDuration=GetTimeIntervalL(section, KTagExpectedDuration, DontUseExpectedDuration);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   360
			if (!IsDurationInRange(0, (DontUseExpectedDuration ? sndPlayer->GetDuration() : ExpectedDuration), TTimeIntervalMicroSeconds(0), ErrorRange, sndPlayer->GetPlayStartTime(), sndPlayer->GetPlayStopTime() ) )
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   361
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   362
				iLogger->Log(_L("Duration too different"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   363
				aResult.iResult = KErrExpectedValueDifferent;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   364
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   365
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   366
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   367
		if (aResult.iResult)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   368
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   369
			iLogger->Log(_L("Test failed, error code %d"), aResult.iResult);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   370
			aResult.iResultDes.Copy(KTestCaseResultFail());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   371
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   372
		else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   373
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   374
			iLogger->Log(_L("Test was successful"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   375
			aResult.iResultDes.Copy(KTestCaseResultSuccess());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   376
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   377
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   378
		CleanupStack::PopAndDestroy(sndPlayer);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   379
		return KErrExecuted;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   380
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   381
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   382
	else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   383
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   384
		//The file name of the clip to play is missing
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   385
		aResult.iResultDes.Copy(KConfigInvalid());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   386
		aResult.iResult = KErrNotExecuted;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   387
		return KErrConfigInvalid;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   388
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   389
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   390
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   391
TInt CDRMAudioPlay::TestCasePlayHandlerL(CStifSectionParser *section , TTestResult &aResult)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   392
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   393
	TPtrC FileNamePtr;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   394
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   395
	User::LeaveIfError(iFs.Connect());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   396
	iFs.ShareProtected();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   397
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   398
	if ( !section->GetLine(KTagSoundFile, FileNamePtr, ENoTag) )
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   399
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   400
		TFileName FileName = FileNamePtr;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   401
		iLogger->Log(_L("Creating simple player with file [%S]"), &FileNamePtr);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   402
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   403
		User::LeaveIfError(iFile.Open( iFs, FileName, EFileRead));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   404
	//	TRAP(err, iAudioPlayer->OpenFileL( iFile ));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   405
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   406
	//	CSimpleSoundPlayer *sndPlayer = CSimpleSoundPlayer::NewL( FileName, TestModuleIf() , *iLogger);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   407
		CSimpleSoundPlayer *sndPlayer = CSimpleSoundPlayer::NewL( iFile, TestModuleIf() , *iLogger);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   408
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   409
		iFile.Close();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   410
	//	iFs.Close();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   411
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   412
		CleanupStack::PushL(sndPlayer);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   413
		iLogger->Log(_L("Starting scheduler"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   414
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   415
		CActiveScheduler::Start();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   416
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   417
		iFs.Close();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   418
		iLogger->Log(_L("Returned from player, errorcode: %d"), sndPlayer->iFinalError );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   419
		aResult.iResult = sndPlayer->iFinalError ;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   420
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   421
		TBool DontCheckExpectedDuration;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   422
		TTimeIntervalMicroSeconds ErrorRange=GetTimeIntervalL(section, KTagErrorRange, DontCheckExpectedDuration);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   423
		if (!DontCheckExpectedDuration && !aResult.iResult)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   424
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   425
			TBool DontUseExpectedDuration;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   426
			TTimeIntervalMicroSeconds ExpectedDuration=GetTimeIntervalL(section, KTagExpectedDuration, DontUseExpectedDuration);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   427
			if (!IsDurationInRange(0, (DontUseExpectedDuration ? sndPlayer->GetDuration() : ExpectedDuration), TTimeIntervalMicroSeconds(0), ErrorRange, sndPlayer->GetPlayStartTime(), sndPlayer->GetPlayStopTime() ) )
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   428
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   429
				iLogger->Log(_L("Duration too different"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   430
				aResult.iResult = KErrExpectedValueDifferent;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   431
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   432
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   433
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   434
		if (aResult.iResult)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   435
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   436
			iLogger->Log(_L("Test failed, error code %d"), aResult.iResult);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   437
			aResult.iResultDes.Copy(KTestCaseResultFail());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   438
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   439
		else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   440
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   441
			iLogger->Log(_L("Test was successful"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   442
			aResult.iResultDes.Copy(KTestCaseResultSuccess());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   443
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   444
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   445
		CleanupStack::PopAndDestroy(sndPlayer);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   446
		return KErrExecuted;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   447
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   448
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   449
	else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   450
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   451
		//The file name of the clip to play is missing
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   452
		aResult.iResultDes.Copy(KConfigInvalid());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   453
		aResult.iResult = KErrNotExecuted;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   454
		return KErrConfigInvalid;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   455
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   456
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   457
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   458
TInt CDRMAudioPlay::TestCasePlayFileWithRepeatsL(CStifSectionParser *section , TTestResult &aResult)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   459
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   460
	TPtrC FileNamePtr;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   461
	TInt Repeats = KDefaultRepeats;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   462
	TTimeIntervalMicroSeconds SilenceDuration = KDefaultSilenceDuration;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   463
	TInt ParseError=KErrNone;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   464
	CStifItemParser *item;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   465
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   466
	if ( !section->GetLine(KTagSoundFile, FileNamePtr, ENoTag) )
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   467
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   468
		TFileName FileName = FileNamePtr;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   469
		TBool DontCheckExpectedDuration;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   470
		TTimeIntervalMicroSeconds ErrorRange=GetTimeIntervalL(section, KTagErrorRange, DontCheckExpectedDuration);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   471
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   472
		iLogger->Log(_L("Creating simple player with file [%S]"), &FileNamePtr);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   473
		CSimpleSoundPlayer *sndPlayer = CSimpleSoundPlayer::NewL( FileName, TestModuleIf() , *iLogger);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   474
		CleanupStack::PushL(sndPlayer);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   475
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   476
		//Setup repeat count
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   477
		ParseError=KErrNotFound;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   478
		item = section->GetItemLineL(KTagRepeatTimes);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   479
		if (item)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   480
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   481
			CleanupStack::PushL(item);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   482
			ParseError = item->GetInt(KTagRepeatTimes, Repeats);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   483
			CleanupStack::PopAndDestroy(item);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   484
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   485
		iLogger->Log(_L("Setting up repeat count to %d"), Repeats);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   486
		if (ParseError)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   487
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   488
			iLogger->Log(_L("Using default value of %d"), KDefaultRepeats); Repeats=KDefaultRepeats;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   489
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   490
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   491
		TBool UsingDefault;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   492
		SilenceDuration = GetTimeIntervalL(section, KTagSilenceDuration, UsingDefault, KDefaultSilenceDuration);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   493
		// * ****************************************************
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   494
		iLogger->Log(_L("Setting interval to %d"), SilenceDuration.Int64());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   495
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   496
		if (UsingDefault) { iLogger->Log(_L("Using default of %d"), KDefaultSilenceDuration.Int64()) ; }
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   497
		sndPlayer->SetRepeats(Repeats, SilenceDuration);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   498
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   499
		iLogger->Log(_L("Starting scheduler"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   500
		CActiveScheduler::Start();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   501
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   502
		iLogger->Log(_L("Returned from player, errorcode: %d"), sndPlayer->iFinalError );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   503
		aResult.iResult = sndPlayer->iFinalError;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   504
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   505
		if (!DontCheckExpectedDuration && !aResult.iResult)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   506
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   507
			TBool DontUseExpectedDuration;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   508
			TTimeIntervalMicroSeconds ExpectedDuration=GetTimeIntervalL(section, KTagExpectedDuration, DontUseExpectedDuration);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   509
			if (!IsDurationInRange(Repeats, ( DontUseExpectedDuration ? sndPlayer->GetDuration() : ExpectedDuration), SilenceDuration, ErrorRange, sndPlayer->GetPlayStartTime(), sndPlayer->GetPlayStopTime() ) )
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   510
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   511
				iLogger->Log(_L("Duration too different"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   512
				aResult.iResult = KErrExpectedValueDifferent;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   513
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   514
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   515
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   516
		CleanupStack::PopAndDestroy(sndPlayer);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   517
		if (aResult.iResult)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   518
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   519
			iLogger->Log(_L("Test failed, error code %d"), aResult.iResult);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   520
			aResult.iResultDes.Copy(KTestCaseResultFail());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   521
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   522
		else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   523
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   524
			iLogger->Log(_L("Test was successful"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   525
			aResult.iResultDes.Copy(KTestCaseResultSuccess());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   526
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   527
		return KErrExecuted;	//aResult.iResult;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   528
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   529
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   530
	else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   531
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   532
		//The file name of the clip to play is missing
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   533
		aResult.iResultDes.Copy(KConfigInvalid());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   534
		aResult.iResult = KErrNotExecuted;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   535
		return KErrConfigInvalid;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   536
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   537
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   538
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   539
TInt CDRMAudioPlay::TestCasePlayFileWithPositionL(CStifSectionParser *section, TTestResult & aResult)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   540
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   541
	TPtrC FileNamePtr;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   542
	TTimeIntervalMicroSeconds Position = KDefaultPosition;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   543
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   544
	if ( !section->GetLine(KTagSoundFile, FileNamePtr, ENoTag) )
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   545
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   546
		TFileName FileName = FileNamePtr;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   547
		iLogger->Log(_L("Creating simple player with file [%S]"), &FileNamePtr);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   548
		CSimpleSoundPlayer *sndPlayer = CSimpleSoundPlayer::NewL( FileName, TestModuleIf() , *iLogger);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   549
		CleanupStack::PushL(sndPlayer);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   550
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   551
		TBool UsingDefault;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   552
		Position = GetTimeIntervalL(section, KTagPosition, UsingDefault, KDefaultPosition);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   553
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   554
		iLogger->Log(_L("Seting position to: %d"), Position.Int64());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   555
		if (UsingDefault) {iLogger->Log(_L("Using default position duration of: (%d)") , KDefaultPosition.Int64());}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   556
		sndPlayer->iPosition = Position;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   557
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   558
		TTimeIntervalMicroSeconds ErrorRange = GetTimeIntervalL(section, KTagErrorRange, UsingDefault, KDefaultErrorRange);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   559
		if (UsingDefault) {iLogger->Log(_L("Using default error range"));}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   560
		// * **************************************************************
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   561
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   562
		iLogger->Log(_L("Starting scheduler"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   563
		TTime StartTime,EndTime;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   564
		StartTime.HomeTime();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   565
		CActiveScheduler::Start();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   566
		EndTime.HomeTime();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   567
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   568
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   569
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   570
		TTimeIntervalMicroSeconds PerceivedDuration = EndTime.MicroSecondsFrom( StartTime );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   571
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   572
		iLogger->Log(_L("Returned from player, errorcode: %d"), sndPlayer->iFinalError );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   573
		iLogger->Log(_L("Perceived duration: %d") , PerceivedDuration.Int64() );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   574
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   575
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   576
		TTimeIntervalMicroSeconds ExpectedDuration = TTimeIntervalMicroSeconds(I64INT(sndPlayer->GetDuration().Int64()) - I64INT(Position.Int64()));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   577
		iLogger->Log(_L("ExpectedDuration: %d") ,ExpectedDuration.Int64() );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   578
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   579
		if (  Abs(ExpectedDuration.Int64() - PerceivedDuration.Int64()) > ErrorRange.Int64() )
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   580
			{	//Durations too different
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   581
			iLogger->Log(_L("The clips duration is too different from the actual duration + position") );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   582
			aResult.iResult = KErrExpectedValueDifferent;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   583
			aResult.iResultDes.Copy(KTestCaseResultFailExpectedValueDifferent());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   584
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   585
		else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   586
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   587
			aResult.iResult = sndPlayer->iFinalError;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   588
			if (aResult.iResult)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   589
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   590
				iLogger->Log(_L("Test failed, error code %d"), aResult.iResult);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   591
				aResult.iResultDes.Copy(KTestCaseResultFail());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   592
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   593
			else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   594
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   595
				iLogger->Log(_L("Test was successful"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   596
				aResult.iResultDes.Copy(KTestCaseResultSuccess());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   597
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   598
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   599
		CleanupStack::PopAndDestroy(sndPlayer);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   600
		return KErrExecuted;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   601
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   602
	else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   603
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   604
		aResult.iResultDes.Copy(KConfigInvalid());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   605
		aResult.iResult = KErrNotExecuted;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   606
		return KErrConfigInvalid;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   607
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   608
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   609
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   610
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   611
//FH
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   612
TInt CDRMAudioPlay::TestCasePlayHandlerWithSetPositionL(CStifSectionParser *section, TTestResult & aResult)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   613
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   614
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   615
	TPtrC FileNamePtr;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   616
	User::LeaveIfError(iFs.Connect());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   617
	iFs.ShareProtected();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   618
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   619
	TTimeIntervalMicroSeconds Position = KDefaultPosition;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   620
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   621
	if ( !section->GetLine(KTagSoundFile, FileNamePtr, ENoTag) )
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   622
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   623
		TFileName FileName = FileNamePtr;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   624
		iLogger->Log(_L("Creating simple player with file [%S]"), &FileNamePtr);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   625
		User::LeaveIfError(iFile.Open( iFs, FileName, EFileRead));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   626
	//	CSimpleSoundPlayer *sndPlayer = CSimpleSoundPlayer::NewL( FileName, TestModuleIf() , *iLogger);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   627
		CSimpleSoundPlayer *sndPlayer = CSimpleSoundPlayer::NewL( iFile, TestModuleIf() , *iLogger);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   628
		iFile.Close();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   629
		CleanupStack::PushL(sndPlayer);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   630
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   631
		TBool UsingDefault;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   632
		Position = GetTimeIntervalL(section, KTagPosition, UsingDefault, KDefaultPosition);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   633
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   634
		iLogger->Log(_L("Seting position to: %d"), Position.Int64());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   635
		if (UsingDefault) {iLogger->Log(_L("Using default position duration of: (%d)") , KDefaultPosition.Int64());}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   636
		sndPlayer->iPosition = Position;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   637
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   638
		TTimeIntervalMicroSeconds ErrorRange = GetTimeIntervalL(section, KTagErrorRange, UsingDefault, KDefaultErrorRange);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   639
		if (UsingDefault) {iLogger->Log(_L("Using default error range"));}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   640
		// * **************************************************************
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   641
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   642
		iLogger->Log(_L("Starting scheduler"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   643
		TTime StartTime,EndTime;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   644
		StartTime.HomeTime();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   645
		CActiveScheduler::Start();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   646
		EndTime.HomeTime();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   647
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   648
		iFs.Close();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   649
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   650
		TTimeIntervalMicroSeconds PerceivedDuration = EndTime.MicroSecondsFrom( StartTime );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   651
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   652
		iLogger->Log(_L("Returned from player, errorcode: %d"), sndPlayer->iFinalError );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   653
		iLogger->Log(_L("Perceived duration: %d") , PerceivedDuration.Int64() );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   654
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   655
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   656
		TTimeIntervalMicroSeconds ExpectedDuration = TTimeIntervalMicroSeconds(I64INT(sndPlayer->GetDuration().Int64()) - I64INT(Position.Int64()));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   657
		iLogger->Log(_L("ExpectedDuration: %d") ,ExpectedDuration.Int64() );
2
5c1df44f2eed 2010wk42_01
hgs
parents: 0
diff changeset
   658
		
5c1df44f2eed 2010wk42_01
hgs
parents: 0
diff changeset
   659
		//if total duration less than the setposition value, set the expected duration to zero
5c1df44f2eed 2010wk42_01
hgs
parents: 0
diff changeset
   660
		//to handle test cases with setposition >   total duration.
5c1df44f2eed 2010wk42_01
hgs
parents: 0
diff changeset
   661
		if(ExpectedDuration.Int64() < 0)
5c1df44f2eed 2010wk42_01
hgs
parents: 0
diff changeset
   662
		    ExpectedDuration = TTimeIntervalMicroSeconds(I64INT(0));
0
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   663
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   664
		if (  Abs(ExpectedDuration.Int64() - PerceivedDuration.Int64()) > ErrorRange.Int64() )
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   665
			{	//Durations too different
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   666
			iLogger->Log(_L("The clips duration is too different from the actual duration + position") );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   667
			aResult.iResult = KErrExpectedValueDifferent;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   668
			aResult.iResultDes.Copy(KTestCaseResultFailExpectedValueDifferent());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   669
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   670
		else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   671
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   672
			aResult.iResult = sndPlayer->iFinalError;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   673
			if (aResult.iResult)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   674
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   675
				iLogger->Log(_L("Test failed, error code %d"), aResult.iResult);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   676
				aResult.iResultDes.Copy(KTestCaseResultFail());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   677
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   678
			else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   679
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   680
				iLogger->Log(_L("Test was successful"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   681
				aResult.iResultDes.Copy(KTestCaseResultSuccess());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   682
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   683
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   684
		CleanupStack::PopAndDestroy(sndPlayer);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   685
		return KErrExecuted;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   686
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   687
	else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   688
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   689
		aResult.iResultDes.Copy(KConfigInvalid());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   690
		aResult.iResult = KErrNotExecuted;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   691
		return KErrConfigInvalid;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   692
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   693
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   694
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   695
TInt CDRMAudioPlay::TestCasePlayFileStopOpenL(CStifSectionParser *section , TTestResult &aResult)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   696
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   697
		TPtrC FileNamePtr;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   698
		TTimeIntervalMicroSeconds32 StopDelay=KDefaultPauseDelay;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   699
		TTimeIntervalMicroSeconds32 PlayDelay=KDefaultPlayDelay;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   700
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   701
		if ( !section->GetLine(KTagSoundFile, FileNamePtr, ENoTag) )
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   702
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   703
			TFileName FileName = FileNamePtr;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   704
			iLogger->Log(_L("Creating simple player with file [%S]"), &FileNamePtr);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   705
			CSimpleSoundPlayer *sndPlayer = CSimpleSoundPlayer::NewL( FileName, TestModuleIf() , *iLogger);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   706
			CleanupStack::PushL(sndPlayer);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   707
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   708
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   709
			CParameters *playParams;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   710
			if ( section->GetNextLine(KTagSoundFile, FileNamePtr, ENoTag) )
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   711
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   712
				playParams = CFileNameParameters::NewLC(CSimpleSoundPlayer::KPlayerActionOpen, FileName );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   713
				iLogger->Log(_L("Second filename not found, using the same file twice"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   714
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   715
			else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   716
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   717
				playParams = CFileNameParameters::NewLC(CSimpleSoundPlayer::KPlayerActionOpen, FileNamePtr );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   718
				iLogger->Log(_L("Second filename set to [%S]") , &FileNamePtr );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   719
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   720
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   721
			//*********************************************
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   722
			TBool UsingDefault;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   723
			StopDelay = GetTimeIntervalL(section, KTagStopDelay, UsingDefault, (TTimeIntervalMicroSeconds32)KDefaultPauseDelay);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   724
			if (UsingDefault)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   725
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   726
				iLogger->Log(_L("Error retrieving pause delay, using default"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   727
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   728
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   729
			PlayDelay = GetTimeIntervalL(section, KTagPlayDelay, UsingDefault, (TTimeIntervalMicroSeconds32)KDefaultPlayDelay);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   730
			if (UsingDefault) {iLogger->Log(_L("Error retrieving play delay, using default"));}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   731
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   732
			if (StopDelay > PlayDelay)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   733
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   734
				//Pause delay longer than play delay. Switching
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   735
				TTimeIntervalMicroSeconds32 TempDelay = PlayDelay;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   736
				PlayDelay = StopDelay;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   737
				StopDelay = TempDelay;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   738
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   739
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   740
			TTimeIntervalMicroSeconds ErrorRange = GetTimeIntervalL(section, KTagErrorRange, UsingDefault, KDefaultErrorRange);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   741
			if (UsingDefault) {iLogger->Log(_L("Using default error range"));}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   742
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   743
			//*********************************************
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   744
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   745
			CParameters *stopParams = new (ELeave) CParameters( CSimpleSoundPlayer::KPlayerActionStopPlayFile );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   746
			CleanupStack::PushL(stopParams);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   747
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   748
			CMediaEvent *mEventPlay = CMediaEvent::NewLC(TestModuleIf() , *iLogger, PlayDelay, PlayDelay, sndPlayer, playParams);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   749
			CMediaEvent *mEventStop = CMediaEvent::NewLC(TestModuleIf() , *iLogger, StopDelay, StopDelay, sndPlayer, stopParams, CActive::EPriorityStandard+1);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   750
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   751
			iLogger->Log(_L("Starting scheduler"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   752
			TTime StartTime, EndTime;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   753
			StartTime.HomeTime();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   754
			CActiveScheduler::Start();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   755
			EndTime.HomeTime();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   756
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   757
			iLogger->Log(_L("Returned from player, errorcode: %d"), sndPlayer->iFinalError );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   758
			aResult.iResult = sndPlayer->iFinalError;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   759
			iLogger->Log(_L("Playcount: (%d)") , mEventStop->GetCount() );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   760
			if (mEventStop->GetCount() <= 0)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   761
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   762
				aResult.iResult = KErrSkippedEvents;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   763
				iLogger->Log(_L("Test failed, error code %d"), aResult.iResult);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   764
				aResult.iResultDes.Copy(KTestCaseResultFailSkippedEvents());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   765
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   766
			else if (sndPlayer->iFinalError)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   767
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   768
					iLogger->Log(_L("Test failed, error code %d"), aResult.iResult);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   769
					aResult.iResultDes.Copy(KTestCaseResultFail());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   770
					aResult.iResult = sndPlayer->iFinalError;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   771
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   772
				else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   773
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   774
					iLogger->Log(_L("Test was successful"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   775
					aResult.iResultDes.Copy(KTestCaseResultSuccess());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   776
					aResult.iResult = sndPlayer->iFinalError;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   777
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   778
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   779
			CleanupStack::PopAndDestroy(mEventStop);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   780
			CleanupStack::PopAndDestroy(mEventPlay);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   781
			CleanupStack::Pop(stopParams);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   782
			CleanupStack::Pop(playParams);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   783
			CleanupStack::PopAndDestroy(sndPlayer);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   784
			return KErrExecuted;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   785
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   786
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   787
		else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   788
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   789
		aResult.iResultDes.Copy(KConfigInvalid());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   790
		aResult.iResult = KErrNotExecuted;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   791
		return KErrConfigInvalid;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   792
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   793
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   794
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   795
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   796
TInt CDRMAudioPlay::TestCasePlayHandlerStopOpenL(CStifSectionParser *section , TTestResult &aResult)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   797
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   798
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   799
	TPtrC FileNamePtr;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   800
	User::LeaveIfError(iFs.Connect());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   801
	iFs.ShareProtected();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   802
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   803
	TTimeIntervalMicroSeconds32 StopDelay=KDefaultStopOpenPlayDelay;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   804
	TTimeIntervalMicroSeconds32 PlayDelay=KDefaultPlayDelay;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   805
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   806
	if ( !section->GetLine(KTagSoundFile, FileNamePtr, ENoTag) )
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   807
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   808
		TFileName FileName = FileNamePtr;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   809
		iLogger->Log(_L("Creating simple player with file [%S]"), &FileNamePtr);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   810
		User::LeaveIfError(iFile.Open( iFs, FileName, EFileRead));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   811
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   812
		CSimpleSoundPlayer *sndPlayer = CSimpleSoundPlayer::NewL( iFile, TestModuleIf() , *iLogger);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   813
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   814
		iFile.Close();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   815
		CleanupStack::PushL(sndPlayer);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   816
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   817
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   818
		CParameters *playParams;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   819
		if ( section->GetNextLine(KTagSoundFile, FileNamePtr, ENoTag) )
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   820
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   821
			playParams = CFileNameParameters::NewLC(CSimpleSoundPlayer::KPlayerActionOpenFileHandler, FileName );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   822
			iLogger->Log(_L("Second filename not found, using the same file twice"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   823
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   824
		else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   825
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   826
			playParams = CFileNameParameters::NewLC(CSimpleSoundPlayer::KPlayerActionOpenFileHandler, FileNamePtr );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   827
			iLogger->Log(_L("Second filename set to [%S]") , &FileNamePtr );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   828
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   829
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   830
		//*********************************************
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   831
		TBool UsingDefault;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   832
		StopDelay = GetTimeIntervalL(section, KTagStopDelay, UsingDefault, (TTimeIntervalMicroSeconds32)KDefaultPauseDelay);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   833
		if (UsingDefault) {iLogger->Log(_L("Error retrieving pause delay, using default"));}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   834
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   835
		PlayDelay = GetTimeIntervalL(section, KTagPlayDelay, UsingDefault, (TTimeIntervalMicroSeconds32)KDefaultPlayDelay);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   836
		if (UsingDefault) {iLogger->Log(_L("Error retrieving play delay, using default"));}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   837
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   838
		if (StopDelay > PlayDelay)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   839
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   840
			//Pause delay longer than play delay. Switching
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   841
			TTimeIntervalMicroSeconds32 TempDelay = PlayDelay;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   842
			PlayDelay = StopDelay;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   843
			StopDelay = TempDelay;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   844
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   845
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   846
		TTimeIntervalMicroSeconds ErrorRange = GetTimeIntervalL(section, KTagErrorRange, UsingDefault, KDefaultErrorRange);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   847
		if (UsingDefault) {iLogger->Log(_L("Using default error range"));}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   848
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   849
		//*********************************************
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   850
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   851
		CParameters *stopParams = new (ELeave) CParameters( CSimpleSoundPlayer::KPlayerActionStopPlayFileHandler );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   852
		CleanupStack::PushL(stopParams);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   853
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   854
		CMediaEvent *mEventPlay = CMediaEvent::NewLC(TestModuleIf() , *iLogger, PlayDelay, PlayDelay, sndPlayer, playParams);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   855
		CMediaEvent *mEventStop = CMediaEvent::NewLC(TestModuleIf() , *iLogger, StopDelay, StopDelay, sndPlayer, stopParams, CActive::EPriorityStandard+1);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   856
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   857
		iLogger->Log(_L("Starting scheduler"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   858
		TTime StartTime, EndTime;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   859
		StartTime.HomeTime();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   860
		CActiveScheduler::Start();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   861
		EndTime.HomeTime();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   862
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   863
		iFs.Close();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   864
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   865
		iLogger->Log(_L("Returned from player, errorcode: %d"), sndPlayer->iFinalError );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   866
		aResult.iResult = sndPlayer->iFinalError;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   867
		iLogger->Log(_L("Playcount: (%d)") , mEventStop->GetCount() );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   868
		if (mEventStop->GetCount() <= 0)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   869
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   870
			aResult.iResult = KErrSkippedEvents;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   871
			iLogger->Log(_L("Test failed, error code %d"), aResult.iResult);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   872
			aResult.iResultDes.Copy(KTestCaseResultFailSkippedEvents());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   873
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   874
		else if (sndPlayer->iFinalError)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   875
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   876
				iLogger->Log(_L("Test failed, error code %d"), aResult.iResult);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   877
				aResult.iResultDes.Copy(KTestCaseResultFail());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   878
				aResult.iResult = sndPlayer->iFinalError;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   879
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   880
			else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   881
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   882
				iLogger->Log(_L("Test was successful"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   883
				aResult.iResultDes.Copy(KTestCaseResultSuccess());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   884
				aResult.iResult = sndPlayer->iFinalError;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   885
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   886
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   887
		CleanupStack::PopAndDestroy(mEventStop);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   888
		CleanupStack::PopAndDestroy(mEventPlay);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   889
		CleanupStack::Pop(stopParams);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   890
		CleanupStack::Pop(playParams);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   891
		CleanupStack::PopAndDestroy(sndPlayer);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   892
		return KErrExecuted;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   893
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   894
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   895
	else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   896
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   897
	aResult.iResultDes.Copy(KConfigInvalid());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   898
	aResult.iResult = KErrNotExecuted;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   899
	return KErrConfigInvalid;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   900
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   901
}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   902
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   903
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   904
TInt CDRMAudioPlay::TestCasePlayFileWithBalanceL(CStifSectionParser *section , TTestResult &aResult)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   905
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   906
	TPtrC FileNamePtr;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   907
	TInt Balance = KMMFBalanceCenter;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   908
	TInt ParseError=KErrNone;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   909
	CStifItemParser *item;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   910
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   911
	if ( !section->GetLine(KTagSoundFile, FileNamePtr, ENoTag) )
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   912
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   913
	//	TInt BalanceError=KErrNone;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   914
		TFileName FileName = FileNamePtr;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   915
		iLogger->Log(_L("Creating simple player with file [%S]"), &FileNamePtr);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   916
		CSimpleSoundPlayer *sndPlayer = CSimpleSoundPlayer::NewL( FileName, TestModuleIf() , *iLogger);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   917
		CleanupStack::PushL(sndPlayer);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   918
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   919
		//*********************
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   920
		ParseError=KErrNotFound;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   921
		item = section->GetItemLineL(KTagBalance);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   922
		if (item)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   923
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   924
			CleanupStack::PushL(item);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   925
			ParseError = item->GetInt(KTagBalance, Balance);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   926
			CleanupStack::PopAndDestroy(item);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   927
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   928
		if (ParseError)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   929
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   930
			iLogger->Log(_L("Value for Balance not found, using default (%d)") , KMMFBalanceCenter);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   931
			Balance = KMMFBalanceCenter;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   932
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   933
		else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   934
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   935
			iLogger->Log(_L("Setting Balance to: %d"), Balance);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   936
			sndPlayer->iBalance = Balance;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   937
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   938
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   939
		sndPlayer->iSetBalance = true;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   940
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   941
//		iLogger->Log(_L("Setting Balance to: %d"), Balance);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   942
//		BalanceError = sndPlayer->SetBalance(Balance);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   943
	//	if (BalanceError)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   944
		//	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   945
		//	iLogger->Log(_L("Error setting balance"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   946
		//	aResult.iResult = BalanceError;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   947
		//	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   948
	//	else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   949
		//	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   950
			iLogger->Log(_L("Starting scheduler"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   951
			CActiveScheduler::Start();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   952
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   953
			iLogger->Log(_L("Returned from player, errorcode: %d"), sndPlayer->iFinalError );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   954
			aResult.iResult = sndPlayer->iFinalError;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   955
		//	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   956
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   957
		if (aResult.iResult)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   958
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   959
			iLogger->Log(_L("Test failed, error code %d"), aResult.iResult);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   960
			aResult.iResultDes.Copy(KTestCaseResultFail());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   961
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   962
		else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   963
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   964
			iLogger->Log(_L("Test was successful"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   965
			aResult.iResultDes.Copy(KTestCaseResultSuccess());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   966
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   967
		CleanupStack::PopAndDestroy(sndPlayer);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   968
		return KErrExecuted;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   969
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   970
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   971
	else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   972
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   973
		//The file name of the clip to play is missing
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   974
		aResult.iResultDes.Copy(KConfigInvalid());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   975
		aResult.iResult = KErrNotExecuted;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   976
		return KErrConfigInvalid;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   977
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   978
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   979
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   980
TInt CDRMAudioPlay::TestCasePlayDesL(CStifSectionParser *section , TTestResult &aResult)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   981
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   982
	TPtrC FileNamePtr;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   983
    CStifItemParser *item;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   984
    TInt parseError = KErrNone;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   985
    TBool Immediate = 0;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   986
    TBool DesReadOnly = 0;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   987
	if ( !section->GetLine(KTagSoundDes, FileNamePtr, ENoTag) )
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   988
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   989
		TFileName FileName = FileNamePtr;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   990
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   991
		HBufC8 *SoundFile = GetDescriptor8LC(FileName, section);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   992
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   993
        item = section->GetItemLineL(KTagImmediate);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   994
        if (item)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   995
            {
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   996
            CleanupStack::PushL(item);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   997
            parseError = item->GetInt(KTagImmediate, Immediate);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   998
            CleanupStack::PopAndDestroy(item);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   999
            }
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1000
        item = NULL;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1001
        item = section->GetItemLineL(KTagDesReadOnly);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1002
        if (item)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1003
        	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1004
        	CleanupStack::PushL(item);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1005
        	parseError = item->GetInt(KTagDesReadOnly, DesReadOnly);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1006
        	CleanupStack::PopAndDestroy(item);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1007
        	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1008
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1009
		iLogger->Log(_L("Creating simple player with descriptor from [%S]"), &FileNamePtr);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1010
		CSimpleSoundPlayer *sndPlayer = CSimpleSoundPlayer::NewL( *SoundFile, TestModuleIf() , *iLogger, Immediate, DesReadOnly);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1011
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1012
		CleanupStack::PushL(sndPlayer);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1013
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1014
		iLogger->Log(_L("Starting scheduler"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1015
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1016
		CActiveScheduler::Start();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1017
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1018
		iLogger->Log(_L("Returned from player, errorcode: %d"), sndPlayer->iFinalError );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1019
		aResult.iResult = sndPlayer->iFinalError ;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1020
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1021
		TBool DontCheckExpectedDuration;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1022
		TTimeIntervalMicroSeconds ErrorRange=GetTimeIntervalL(section, KTagErrorRange, DontCheckExpectedDuration);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1023
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1024
		if (!DontCheckExpectedDuration && !aResult.iResult)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1025
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1026
			TBool DontUseExpectedDuration;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1027
			TTimeIntervalMicroSeconds ExpectedDuration=GetTimeIntervalL(section, KTagExpectedDuration, DontUseExpectedDuration);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1028
			if (!IsDurationInRange(0, (DontUseExpectedDuration
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1029
						? sndPlayer->GetDuration()
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1030
						: ExpectedDuration
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1031
						), TTimeIntervalMicroSeconds(0), ErrorRange, sndPlayer->GetPlayStartTime(), sndPlayer->GetPlayStopTime() ) )
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1032
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1033
				iLogger->Log(_L("Duration too different"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1034
				aResult.iResult = KErrExpectedValueDifferent;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1035
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1036
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1037
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1038
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1039
		CleanupStack::PopAndDestroy(sndPlayer);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1040
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1041
		CleanupStack::PopAndDestroy(SoundFile);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1042
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1043
		if (aResult.iResult)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1044
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1045
			iLogger->Log(_L("Test failed, error code %d"), aResult.iResult);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1046
			aResult.iResultDes.Copy(KTestCaseResultFail());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1047
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1048
		else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1049
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1050
			iLogger->Log(_L("Test was successful"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1051
			aResult.iResultDes.Copy(KTestCaseResultSuccess());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1052
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1053
		return KErrExecuted;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1054
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1055
	else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1056
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1057
		aResult.iResultDes.Copy(KConfigInvalid());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1058
		aResult.iResult = KErrNotExecuted;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1059
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1060
		return KErrConfigInvalid;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1061
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1062
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1063
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1064
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1065
TInt CDRMAudioPlay::TestCasePlayFileReportPositionL(CStifSectionParser *section , TTestResult &aResult)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1066
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1067
	TPtrC FileNamePtr;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1068
	TTimeIntervalMicroSeconds32 ReportDelay = KDefaultReportDelay;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1069
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1070
	if ( !section->GetLine(KTagSoundFile, FileNamePtr, ENoTag) )
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1071
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1072
		TFileName FileName = FileNamePtr;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1073
		TBool UsingDefaultReportDelay;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1074
		iLogger->Log(_L("Creating simple player with file [%S]"), &FileNamePtr);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1075
		CSimpleSoundPlayer *sndPlayer = CSimpleSoundPlayer::NewL( FileName, TestModuleIf() , *iLogger);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1076
		CleanupStack::PushL(sndPlayer);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1077
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1078
		//*********************************************
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1079
		ReportDelay = GetTimeIntervalL(section, KTagDelay, UsingDefaultReportDelay, (TTimeIntervalMicroSeconds32)KDefaultReportDelay);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1080
		iLogger->Log(_L("Setting delays to report position to [%d]"), ReportDelay.Int());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1081
		//*********************************************
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1082
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1083
		CParameters *reportParams = new(ELeave)CParameters(CSimpleSoundPlayer::KPlayerActionReportPosition);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1084
		CleanupStack::PushL(reportParams);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1085
		CMediaEvent *mEventReportPosition = CMediaEvent::NewLC(TestModuleIf() , *iLogger, ReportDelay, ReportDelay, sndPlayer, reportParams);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1086
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1087
		iLogger->Log(_L("Starting scheduler"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1088
		CActiveScheduler::Start();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1089
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1090
		CleanupStack::PopAndDestroy(mEventReportPosition);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1091
		CleanupStack::Pop(reportParams);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1092
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1093
		iLogger->Log(_L("Returned from player, errorcode: %d"), sndPlayer->iFinalError );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1094
		aResult.iResult = sndPlayer->iFinalError;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1095
		if (aResult.iResult)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1096
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1097
			iLogger->Log(_L("Test failed, error code %d"), aResult.iResult);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1098
			aResult.iResultDes.Copy(KTestCaseResultFail());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1099
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1100
		else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1101
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1102
			iLogger->Log(_L("Test was successful"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1103
			aResult.iResultDes.Copy(KTestCaseResultSuccess());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1104
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1105
		CleanupStack::PopAndDestroy(sndPlayer);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1106
		return aResult.iResult;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1107
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1108
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1109
	else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1110
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1111
		//The file name of the clip to play is missing
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1112
		aResult.iResultDes.Copy(KConfigInvalid());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1113
		aResult.iResult = KErrNotExecuted;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1114
		return KErrConfigInvalid;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1115
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1116
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1117
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1118
//FH
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1119
TInt CDRMAudioPlay::TestCasePlayHandlerWithGetPositionL(CStifSectionParser *section , TTestResult &aResult)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1120
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1121
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1122
	TPtrC FileNamePtr;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1123
	User::LeaveIfError(iFs.Connect());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1124
	iFs.ShareProtected();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1125
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1126
	TTimeIntervalMicroSeconds32 ReportDelay = KDefaultReportDelay;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1127
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1128
	if ( !section->GetLine(KTagSoundFile, FileNamePtr, ENoTag) )
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1129
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1130
		TFileName FileName = FileNamePtr;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1131
		TBool UsingDefaultReportDelay;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1132
		User::LeaveIfError(iFile.Open( iFs, FileName, EFileRead));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1133
		iLogger->Log(_L("Creating simple player with file [%S]"), &FileNamePtr);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1134
	//	CSimpleSoundPlayer *sndPlayer = CSimpleSoundPlayer::NewL( FileName, TestModuleIf() , *iLogger);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1135
		CSimpleSoundPlayer *sndPlayer = CSimpleSoundPlayer::NewL( iFile, TestModuleIf() , *iLogger);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1136
		iFile.Close();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1137
		CleanupStack::PushL(sndPlayer);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1138
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1139
		//*********************************************
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1140
		ReportDelay = GetTimeIntervalL(section, KTagDelay, UsingDefaultReportDelay, (TTimeIntervalMicroSeconds32)KDefaultReportDelay);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1141
		iLogger->Log(_L("Setting delays to report position to [%d]"), ReportDelay.Int());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1142
		//*********************************************
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1143
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1144
		CParameters *reportParams = new(ELeave)CParameters(CSimpleSoundPlayer::KPlayerActionReportPosition);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1145
		CleanupStack::PushL(reportParams);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1146
		CMediaEvent *mEventReportPosition = CMediaEvent::NewLC(TestModuleIf() , *iLogger, ReportDelay, ReportDelay, sndPlayer, reportParams);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1147
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1148
		iLogger->Log(_L("Starting scheduler"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1149
		CActiveScheduler::Start();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1150
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1151
		iFs.Close();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1152
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1153
		CleanupStack::PopAndDestroy(mEventReportPosition);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1154
		CleanupStack::Pop(reportParams);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1155
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1156
		iLogger->Log(_L("Returned from player, errorcode: %d"), sndPlayer->iFinalError );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1157
		aResult.iResult = sndPlayer->iFinalError;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1158
		if (aResult.iResult)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1159
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1160
			iLogger->Log(_L("Test failed, error code %d"), aResult.iResult);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1161
			aResult.iResultDes.Copy(KTestCaseResultFail());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1162
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1163
		else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1164
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1165
			iLogger->Log(_L("Test was successful"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1166
			aResult.iResultDes.Copy(KTestCaseResultSuccess());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1167
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1168
		CleanupStack::PopAndDestroy(sndPlayer);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1169
		return aResult.iResult;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1170
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1171
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1172
	else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1173
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1174
		//The file name of the clip to play is missing
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1175
		aResult.iResultDes.Copy(KConfigInvalid());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1176
		aResult.iResult = KErrNotExecuted;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1177
		return KErrConfigInvalid;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1178
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1179
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1180
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1181
TInt CDRMAudioPlay::TestCasePlayFileReportDurationL(CStifSectionParser *section , TTestResult &aResult)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1182
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1183
	TPtrC FileNamePtr;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1184
	TTimeIntervalMicroSeconds32 ReportDelay=KDefaultReportDelay;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1185
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1186
	if ( !section->GetLine(KTagSoundFile, FileNamePtr, ENoTag) )
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1187
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1188
		TBool ExpectedDurationNotSet = EFalse, UsingDefaultReportDelay;;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1189
		TTimeIntervalMicroSeconds ExpectedDuration;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1190
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1191
		TFileName FileName = FileNamePtr;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1192
		iLogger->Log(_L("Creating simple player with file [%S]"), &FileNamePtr);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1193
		CSimpleSoundPlayer *sndPlayer = CSimpleSoundPlayer::NewL( FileName, TestModuleIf() , *iLogger);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1194
		CleanupStack::PushL(sndPlayer);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1195
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1196
		//*********************************************
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1197
		ReportDelay = GetTimeIntervalL(section, KTagDelay, UsingDefaultReportDelay, (TTimeIntervalMicroSeconds32)KDefaultReportDelay);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1198
		iLogger->Log(_L("Setting delays to report position to [%d]"), ReportDelay.Int());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1199
		//*********************************************
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1200
		ExpectedDuration = GetTimeIntervalL( section, KTagExpectedDuration, ExpectedDurationNotSet) ;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1201
		//*********************************************
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1202
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1203
		CParameters *reportParams = new(ELeave)CParameters(CSimpleSoundPlayer::KPlayerActionReportDuration);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1204
		CleanupStack::PushL(reportParams);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1205
		CMediaEvent *mEventReportPosition = CMediaEvent::NewLC(TestModuleIf() , *iLogger, ReportDelay, ReportDelay, sndPlayer, reportParams);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1206
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1207
		iLogger->Log(_L("Starting scheduler"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1208
		CActiveScheduler::Start();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1209
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1210
		iLogger->Log(_L("Returned from player, errorcode: %d"), sndPlayer->iFinalError );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1211
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1212
		aResult.iResult = sndPlayer->iFinalError;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1213
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1214
		if (mEventReportPosition->GetCount() <= 0)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1215
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1216
			aResult.iResult = KErrSkippedEvents;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1217
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1218
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1219
		if (!ExpectedDurationNotSet)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1220
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1221
			iLogger->Log(_L("Expected duration: (%d)") , ExpectedDuration.Int64() );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1222
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1223
			if ( ExpectedDuration!=sndPlayer->GetDuration() )
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1224
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1225
				aResult.iResult = KErrExpectedValueDifferent;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1226
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1227
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1228
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1229
		switch (aResult.iResult)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1230
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1231
			case KErrNone:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1232
				iLogger->Log(_L("Test was successful"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1233
				aResult.iResultDes.Copy( KTestCaseResultSuccess() );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1234
				break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1235
			case KErrExpectedValueDifferent:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1236
				iLogger->Log(_L("Test failed, error code %d"), aResult.iResult);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1237
				aResult.iResultDes.Copy( KTestCaseResultFailExpectedValueDifferent() );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1238
				break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1239
			case KErrSkippedEvents:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1240
				iLogger->Log(_L("Test failed, error code %d"), aResult.iResult);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1241
				aResult.iResultDes.Copy( KTestCaseResultFailSkippedEvents() );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1242
				break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1243
			default:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1244
				iLogger->Log(_L("Test failed, error code %d"), aResult.iResult);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1245
				aResult.iResultDes.Copy( KTestCaseResultFail() );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1246
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1247
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1248
		CleanupStack::PopAndDestroy(mEventReportPosition);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1249
		CleanupStack::Pop(reportParams);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1250
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1251
		CleanupStack::PopAndDestroy(sndPlayer);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1252
		return KErrNone;	//aResult.iResult;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1253
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1254
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1255
	else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1256
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1257
		//The file name of the clip to play is missing
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1258
		aResult.iResultDes.Copy(KConfigInvalid());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1259
		aResult.iResult = KErrNotExecuted;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1260
		return KErrConfigInvalid;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1261
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1262
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1263
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1264
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1265
TInt CDRMAudioPlay::TestCasePlayFileMaxVolumeL(CStifSectionParser *section , TTestResult &aResult)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1266
    {
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1267
    TPtrC FileNamePtr;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1268
    TTimeIntervalMicroSeconds32 ReportDelay=KDefaultReportDelay;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1269
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1270
    if ( !section->GetLine(KTagSoundFile, FileNamePtr, ENoTag) )
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1271
        {
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1272
        TBool UsingDefaultReportDelay;;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1273
        TFileName FileName = FileNamePtr;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1274
        iLogger->Log(_L("Creating simple player with file [%S]"), &FileNamePtr);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1275
        CSimpleSoundPlayer *sndPlayer = CSimpleSoundPlayer::NewL( FileName, TestModuleIf() , *iLogger);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1276
        CleanupStack::PushL(sndPlayer);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1277
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1278
        //###############################################
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1279
        ReportDelay = GetTimeIntervalL(section, KTagDelay, UsingDefaultReportDelay, (TTimeIntervalMicroSeconds32)KDefaultReportDelay);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1280
        iLogger->Log(_L("Setting delays to report position to [%d]"), ReportDelay.Int());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1281
        //###############################################
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1282
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1283
        CParameters *reportParams = new(ELeave)CParameters(CSimpleSoundPlayer::KplayerActionMaxVolume);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1284
        CleanupStack::PushL(reportParams);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1285
        CMediaEvent *mEventMaxVolume = CMediaEvent::NewLC(TestModuleIf() , *iLogger, ReportDelay, ReportDelay, sndPlayer, reportParams);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1286
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1287
        iLogger->Log(_L("Starting scheduler"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1288
        CActiveScheduler::Start();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1289
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1290
        iLogger->Log(_L("Returned from player, errorcode: %d"), sndPlayer->iFinalError );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1291
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1292
        aResult.iResult = sndPlayer->iFinalError;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1293
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1294
        if (mEventMaxVolume->GetCount() <= 0)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1295
            {
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1296
            aResult.iResult = KErrSkippedEvents;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1297
            }
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1298
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1299
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1300
        switch (aResult.iResult)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1301
            {
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1302
            case KErrNone:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1303
                iLogger->Log(_L("Test was successful"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1304
                aResult.iResultDes.Copy( KTestCaseResultSuccess() );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1305
                break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1306
            case KErrExpectedValueDifferent:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1307
                iLogger->Log(_L("Test failed, error code %d"), aResult.iResult);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1308
                aResult.iResultDes.Copy( KTestCaseResultFailExpectedValueDifferent() );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1309
                break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1310
            case KErrSkippedEvents:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1311
                iLogger->Log(_L("Test failed, error code %d"), aResult.iResult);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1312
                aResult.iResultDes.Copy( KTestCaseResultFailSkippedEvents() );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1313
                break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1314
            default:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1315
                iLogger->Log(_L("Test failed, error code %d"), aResult.iResult);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1316
                aResult.iResultDes.Copy( KTestCaseResultFail() );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1317
            }
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1318
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1319
        CleanupStack::PopAndDestroy(mEventMaxVolume);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1320
        CleanupStack::Pop(reportParams);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1321
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1322
        CleanupStack::PopAndDestroy(sndPlayer);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1323
        return KErrNone;    //aResult.iResult;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1324
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1325
        }
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1326
    else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1327
        {
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1328
        //The file name of the clip to play is missing
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1329
        aResult.iResultDes.Copy(KConfigInvalid());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1330
        aResult.iResult = KErrNotExecuted;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1331
        return KErrConfigInvalid;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1332
        }
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1333
    }
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1334
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1335
TInt CDRMAudioPlay::TestCasePlayFileSetVolumeL(CStifSectionParser *section , TTestResult &aResult)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1336
    {
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1337
    TPtrC FileNamePtr;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1338
    TTimeIntervalMicroSeconds32 ReportDelay=KDefaultReportDelay;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1339
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1340
    if ( !section->GetLine(KTagSoundFile, FileNamePtr, ENoTag) )
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1341
        {
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1342
        TBool UsingDefaultReportDelay;;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1343
        TFileName FileName = FileNamePtr;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1344
        iLogger->Log(_L("Creating simple player with file [%S]"), &FileNamePtr);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1345
        CSimpleSoundPlayer *sndPlayer = CSimpleSoundPlayer::NewL( FileName, TestModuleIf() , *iLogger);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1346
        CleanupStack::PushL(sndPlayer);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1347
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1348
        //###############################################
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1349
        ReportDelay = GetTimeIntervalL(section, KTagDelay, UsingDefaultReportDelay, (TTimeIntervalMicroSeconds32)KDefaultReportDelay);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1350
        iLogger->Log(_L("Setting delays to report position to [%d]"), ReportDelay.Int());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1351
        //###############################################
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1352
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1353
        CParameters *reportParams = new(ELeave)CParameters(CSimpleSoundPlayer::KplayerActionSetVolume);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1354
        CleanupStack::PushL(reportParams);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1355
        CMediaEvent *mEventSetVolume = CMediaEvent::NewLC(TestModuleIf() , *iLogger, ReportDelay, ReportDelay, sndPlayer, reportParams);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1356
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1357
        iLogger->Log(_L("Starting scheduler"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1358
        CActiveScheduler::Start();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1359
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1360
        iLogger->Log(_L("Returned from player, errorcode: %d"), sndPlayer->iFinalError );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1361
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1362
        aResult.iResult = sndPlayer->iFinalError;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1363
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1364
        if (mEventSetVolume->GetCount() <= 0)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1365
            {
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1366
            aResult.iResult = KErrSkippedEvents;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1367
            }
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1368
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1369
        switch (aResult.iResult)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1370
            {
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1371
            case KErrNone:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1372
                iLogger->Log(_L("Test was successful"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1373
                aResult.iResultDes.Copy( KTestCaseResultSuccess() );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1374
                break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1375
            case KErrExpectedValueDifferent:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1376
                iLogger->Log(_L("Test failed, error code %d"), aResult.iResult);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1377
                aResult.iResultDes.Copy( KTestCaseResultFailExpectedValueDifferent() );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1378
                break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1379
            case KErrSkippedEvents:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1380
                iLogger->Log(_L("Test failed, error code %d"), aResult.iResult);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1381
                aResult.iResultDes.Copy( KTestCaseResultFailSkippedEvents() );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1382
                break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1383
            default:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1384
                iLogger->Log(_L("Test failed, error code %d"), aResult.iResult);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1385
                aResult.iResultDes.Copy( KTestCaseResultFail() );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1386
            }
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1387
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1388
        CleanupStack::PopAndDestroy(mEventSetVolume);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1389
        CleanupStack::Pop(reportParams);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1390
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1391
        CleanupStack::PopAndDestroy(sndPlayer);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1392
        return KErrNone;    //aResult.iResult;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1393
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1394
        }
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1395
    else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1396
        {
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1397
        //The file name of the clip to play is missing
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1398
        aResult.iResultDes.Copy(KConfigInvalid());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1399
        aResult.iResult = KErrNotExecuted;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1400
        return KErrConfigInvalid;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1401
        }
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1402
    }
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1403
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1404
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1405
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1406
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1407
TInt CDRMAudioPlay::TestCasePlayFileGetBalanceL(CStifSectionParser *section , TTestResult &aResult)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1408
    {
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1409
    TPtrC FileNamePtr;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1410
    TTimeIntervalMicroSeconds32 ReportDelay=KDefaultReportDelay;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1411
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1412
    if ( !section->GetLine(KTagSoundFile, FileNamePtr, ENoTag) )
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1413
        {
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1414
        TBool UsingDefaultReportDelay;;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1415
        TFileName FileName = FileNamePtr;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1416
        iLogger->Log(_L("Creating simple player with file [%S]"), &FileNamePtr);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1417
        CSimpleSoundPlayer *sndPlayer = CSimpleSoundPlayer::NewL( FileName, TestModuleIf() , *iLogger);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1418
        CleanupStack::PushL(sndPlayer);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1419
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1420
        //###############################################
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1421
        ReportDelay = GetTimeIntervalL(section, KTagDelay, UsingDefaultReportDelay, (TTimeIntervalMicroSeconds32)KDefaultReportDelay);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1422
        iLogger->Log(_L("Setting delays to report position to [%d]"), ReportDelay.Int());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1423
        //###############################################
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1424
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1425
        CParameters *reportParams = new(ELeave)CParameters(CSimpleSoundPlayer::KplayerActionGetBalance);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1426
        CleanupStack::PushL(reportParams);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1427
        CMediaEvent *mEventGetBalance = CMediaEvent::NewLC(TestModuleIf() , *iLogger, ReportDelay, ReportDelay, sndPlayer, reportParams);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1428
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1429
        iLogger->Log(_L("Starting scheduler"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1430
        CActiveScheduler::Start();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1431
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1432
        iLogger->Log(_L("Returned from player, errorcode: %d"), sndPlayer->iFinalError );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1433
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1434
        aResult.iResult = sndPlayer->iFinalError;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1435
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1436
        if (mEventGetBalance->GetCount() <= 0)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1437
            {
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1438
            aResult.iResult = KErrSkippedEvents;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1439
            }
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1440
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1441
        switch (aResult.iResult)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1442
            {
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1443
            case KErrNone:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1444
                iLogger->Log(_L("Test was successful"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1445
                aResult.iResultDes.Copy( KTestCaseResultSuccess() );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1446
                break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1447
            case KErrExpectedValueDifferent:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1448
                iLogger->Log(_L("Test failed, error code %d"), aResult.iResult);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1449
                aResult.iResultDes.Copy( KTestCaseResultFailExpectedValueDifferent() );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1450
                break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1451
            case KErrSkippedEvents:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1452
                iLogger->Log(_L("Test failed, error code %d"), aResult.iResult);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1453
                aResult.iResultDes.Copy( KTestCaseResultFailSkippedEvents() );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1454
                break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1455
            default:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1456
                iLogger->Log(_L("Test failed, error code %d"), aResult.iResult);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1457
                aResult.iResultDes.Copy( KTestCaseResultFail() );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1458
            }
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1459
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1460
        CleanupStack::PopAndDestroy(mEventGetBalance);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1461
        CleanupStack::Pop(reportParams);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1462
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1463
        CleanupStack::PopAndDestroy(sndPlayer);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1464
        return KErrNone;    //aResult.iResult;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1465
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1466
        }
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1467
    else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1468
        {
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1469
        //The file name of the clip to play is missing
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1470
        aResult.iResultDes.Copy(KConfigInvalid());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1471
        aResult.iResult = KErrNotExecuted;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1472
        return KErrConfigInvalid;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1473
        }
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1474
    }
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1475
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1476
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1477
TInt CDRMAudioPlay::TestCasePlayFileSetBalanceL(CStifSectionParser *section , TTestResult &aResult)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1478
    {
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1479
    TPtrC FileNamePtr;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1480
    TTimeIntervalMicroSeconds32 ReportDelay=KDefaultReportDelay;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1481
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1482
    if ( !section->GetLine(KTagSoundFile, FileNamePtr, ENoTag) )
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1483
        {
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1484
        TBool UsingDefaultReportDelay;;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1485
        TFileName FileName = FileNamePtr;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1486
        iLogger->Log(_L("Creating simple player with file [%S]"), &FileNamePtr);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1487
        CSimpleSoundPlayer *sndPlayer = CSimpleSoundPlayer::NewL( FileName, TestModuleIf() , *iLogger);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1488
        CleanupStack::PushL(sndPlayer);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1489
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1490
        //###############################################
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1491
        ReportDelay = GetTimeIntervalL(section, KTagDelay, UsingDefaultReportDelay, (TTimeIntervalMicroSeconds32)KDefaultReportDelay);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1492
        iLogger->Log(_L("Setting delays to report position to [%d]"), ReportDelay.Int());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1493
        //###############################################
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1494
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1495
        CParameters *reportParams = new(ELeave)CParameters(CSimpleSoundPlayer::KplayerActionSetBalance);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1496
        CleanupStack::PushL(reportParams);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1497
        CMediaEvent *mEventSetBalance = CMediaEvent::NewLC(TestModuleIf() , *iLogger, ReportDelay, ReportDelay, sndPlayer, reportParams);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1498
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1499
        iLogger->Log(_L("Starting scheduler"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1500
        CActiveScheduler::Start();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1501
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1502
        iLogger->Log(_L("Returned from player, errorcode: %d"), sndPlayer->iFinalError );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1503
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1504
        aResult.iResult = sndPlayer->iFinalError;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1505
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1506
        if (mEventSetBalance->GetCount() <= 0)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1507
            {
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1508
            aResult.iResult = KErrSkippedEvents;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1509
            }
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1510
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1511
        switch (aResult.iResult)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1512
            {
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1513
            case KErrNone:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1514
                iLogger->Log(_L("Test was successful"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1515
                aResult.iResultDes.Copy( KTestCaseResultSuccess() );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1516
                break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1517
            case KErrExpectedValueDifferent:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1518
                iLogger->Log(_L("Test failed, error code %d"), aResult.iResult);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1519
                aResult.iResultDes.Copy( KTestCaseResultFailExpectedValueDifferent() );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1520
                break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1521
            case KErrSkippedEvents:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1522
                iLogger->Log(_L("Test failed, error code %d"), aResult.iResult);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1523
                aResult.iResultDes.Copy( KTestCaseResultFailSkippedEvents() );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1524
                break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1525
            default:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1526
                iLogger->Log(_L("Test failed, error code %d"), aResult.iResult);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1527
                aResult.iResultDes.Copy( KTestCaseResultFail() );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1528
            }
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1529
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1530
        CleanupStack::PopAndDestroy(mEventSetBalance);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1531
        CleanupStack::Pop(reportParams);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1532
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1533
        CleanupStack::PopAndDestroy(sndPlayer);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1534
        return KErrNone;    //aResult.iResult;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1535
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1536
        }
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1537
    else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1538
        {
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1539
        //The file name of the clip to play is missing
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1540
        aResult.iResultDes.Copy(KConfigInvalid());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1541
        aResult.iResult = KErrNotExecuted;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1542
        return KErrConfigInvalid;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1543
        }
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1544
    }
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1545
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1546
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1547
TInt CDRMAudioPlay::TestCasePlayFileSetPriorityL(CStifSectionParser *section , TTestResult &aResult)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1548
    {
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1549
    TPtrC FileNamePtr;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1550
    TTimeIntervalMicroSeconds32 ReportDelay=KDefaultReportDelay;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1551
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1552
    if ( !section->GetLine(KTagSoundFile, FileNamePtr, ENoTag) )
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1553
        {
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1554
        TBool UsingDefaultReportDelay;;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1555
        TFileName FileName = FileNamePtr;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1556
        iLogger->Log(_L("Creating simple player with file [%S]"), &FileNamePtr);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1557
        CSimpleSoundPlayer *sndPlayer = CSimpleSoundPlayer::NewL( FileName, TestModuleIf() , *iLogger);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1558
        CleanupStack::PushL(sndPlayer);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1559
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1560
        //###############################################
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1561
        ReportDelay = GetTimeIntervalL(section, KTagDelay, UsingDefaultReportDelay, (TTimeIntervalMicroSeconds32)KDefaultReportDelay);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1562
        iLogger->Log(_L("Setting delays to report position to [%d]"), ReportDelay.Int());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1563
        //###############################################
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1564
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1565
        CParameters *reportParams = new(ELeave)CParameters(CSimpleSoundPlayer::KplayerActionSetPriority);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1566
        CleanupStack::PushL(reportParams);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1567
        CMediaEvent *mEventGetBalance = CMediaEvent::NewLC(TestModuleIf() , *iLogger, ReportDelay, ReportDelay, sndPlayer, reportParams);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1568
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1569
        iLogger->Log(_L("Starting scheduler"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1570
        CActiveScheduler::Start();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1571
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1572
        iLogger->Log(_L("Returned from player, errorcode: %d"), sndPlayer->iFinalError );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1573
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1574
        aResult.iResult = sndPlayer->iFinalError;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1575
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1576
        if (mEventGetBalance->GetCount() <= 0)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1577
            {
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1578
            aResult.iResult = KErrSkippedEvents;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1579
            }
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1580
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1581
        switch (aResult.iResult)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1582
            {
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1583
            case KErrNone:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1584
                iLogger->Log(_L("Test was successful"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1585
                aResult.iResultDes.Copy( KTestCaseResultSuccess() );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1586
                break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1587
            case KErrExpectedValueDifferent:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1588
                iLogger->Log(_L("Test failed, error code %d"), aResult.iResult);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1589
                aResult.iResultDes.Copy( KTestCaseResultFailExpectedValueDifferent() );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1590
                break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1591
            case KErrSkippedEvents:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1592
                iLogger->Log(_L("Test failed, error code %d"), aResult.iResult);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1593
                aResult.iResultDes.Copy( KTestCaseResultFailSkippedEvents() );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1594
                break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1595
            default:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1596
                iLogger->Log(_L("Test failed, error code %d"), aResult.iResult);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1597
                aResult.iResultDes.Copy( KTestCaseResultFail() );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1598
            }
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1599
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1600
        CleanupStack::PopAndDestroy(mEventGetBalance);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1601
        CleanupStack::Pop(reportParams);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1602
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1603
        CleanupStack::PopAndDestroy(sndPlayer);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1604
        return KErrNone;    //aResult.iResult;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1605
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1606
        }
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1607
    else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1608
        {
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1609
        //The file name of the clip to play is missing
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1610
        aResult.iResultDes.Copy(KConfigInvalid());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1611
        aResult.iResult = KErrNotExecuted;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1612
        return KErrConfigInvalid;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1613
        }
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1614
    }
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1615
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1616
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1617
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1618
TInt CDRMAudioPlay::TestCasePlayFileSetRepeatsL(CStifSectionParser *section , TTestResult &aResult)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1619
    {
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1620
    TPtrC FileNamePtr;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1621
    TTimeIntervalMicroSeconds32 ReportDelay=KDefaultReportDelay;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1622
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1623
    if ( !section->GetLine(KTagSoundFile, FileNamePtr, ENoTag) )
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1624
        {
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1625
        TBool UsingDefaultReportDelay;;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1626
        TFileName FileName = FileNamePtr;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1627
        iLogger->Log(_L("Creating simple player with file [%S]"), &FileNamePtr);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1628
        CSimpleSoundPlayer *sndPlayer = CSimpleSoundPlayer::NewL( FileName, TestModuleIf() , *iLogger);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1629
        sndPlayer->ControllerImplementationInformationL();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1630
        CleanupStack::PushL(sndPlayer);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1631
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1632
        //###############################################
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1633
        ReportDelay = GetTimeIntervalL(section, KTagDelay, UsingDefaultReportDelay, (TTimeIntervalMicroSeconds32)KDefaultReportDelay);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1634
        iLogger->Log(_L("Setting delays to report position to [%d]"), ReportDelay.Int());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1635
        //###############################################
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1636
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1637
        //CParameters *reportParams = new(ELeave)CParameters(CSimpleSoundPlayer::KplayerActionSetRepeats);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1638
        //CleanupStack::PushL(reportParams);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1639
        //CMediaEvent *mEventSetRepeats = CMediaEvent::NewLC(TestModuleIf() , *iLogger, ReportDelay, ReportDelay, sndPlayer, reportParams);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1640
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1641
        iLogger->Log(_L("Starting scheduler"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1642
        CActiveScheduler::Start();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1643
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1644
        iLogger->Log(_L("Returned from player, errorcode: %d"), sndPlayer->iFinalError );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1645
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1646
        aResult.iResult = sndPlayer->iFinalError;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1647
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1648
        /*if (mEventSetRepeats->GetCount() <= 0)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1649
            {
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1650
            aResult.iResult = KErrSkippedEvents;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1651
            }*/
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1652
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1653
        switch (aResult.iResult)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1654
            {
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1655
            case KErrNone:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1656
                iLogger->Log(_L("Test was successful"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1657
                aResult.iResultDes.Copy( KTestCaseResultSuccess() );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1658
                break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1659
            case KErrExpectedValueDifferent:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1660
                iLogger->Log(_L("Test failed, error code %d"), aResult.iResult);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1661
                aResult.iResultDes.Copy( KTestCaseResultFailExpectedValueDifferent() );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1662
                break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1663
            case KErrSkippedEvents:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1664
                iLogger->Log(_L("Test failed, error code %d"), aResult.iResult);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1665
                aResult.iResultDes.Copy( KTestCaseResultFailSkippedEvents() );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1666
                break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1667
            default:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1668
                iLogger->Log(_L("Test failed, error code %d"), aResult.iResult);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1669
                aResult.iResultDes.Copy( KTestCaseResultFail() );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1670
            }
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1671
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1672
        //CleanupStack::PopAndDestroy(mEventSetRepeats);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1673
        //CleanupStack::Pop(reportParams);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1674
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1675
        CleanupStack::PopAndDestroy(sndPlayer);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1676
        return KErrNone;    //aResult.iResult;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1677
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1678
        }
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1679
    else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1680
        {
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1681
        //The file name of the clip to play is missing
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1682
        aResult.iResultDes.Copy(KConfigInvalid());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1683
        aResult.iResult = KErrNotExecuted;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1684
        return KErrConfigInvalid;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1685
        }
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1686
    }
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1687
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1688
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1689
TInt CDRMAudioPlay::TestCasePlayFilesGetMetaDataEntryL(CStifSectionParser *section , TTestResult &aResult)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1690
    {
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1691
    TPtrC FileNamePtr;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1692
    TTimeIntervalMicroSeconds32 ReportDelay=KDefaultReportDelay;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1693
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1694
    if ( !section->GetLine(KTagSoundFile, FileNamePtr, ENoTag) )
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1695
        {
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1696
        TBool UsingDefaultReportDelay;;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1697
        TFileName FileName = FileNamePtr;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1698
        iLogger->Log(_L("Creating simple player with file [%S]"), &FileNamePtr);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1699
        CSimpleSoundPlayer *sndPlayer = CSimpleSoundPlayer::NewL( FileName, TestModuleIf() , *iLogger);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1700
        CleanupStack::PushL(sndPlayer);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1701
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1702
        //###############################################
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1703
        ReportDelay = GetTimeIntervalL(section, KTagDelay, UsingDefaultReportDelay, (TTimeIntervalMicroSeconds32)KDefaultReportDelay);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1704
        iLogger->Log(_L("Setting delays to report position to [%d]"), ReportDelay.Int());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1705
        //###############################################
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1706
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1707
        CParameters *reportParams = new(ELeave)CParameters(CSimpleSoundPlayer::KplayerActionGetBalance);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1708
        CleanupStack::PushL(reportParams);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1709
        CMediaEvent *mEventGetBalance = CMediaEvent::NewLC(TestModuleIf() , *iLogger, ReportDelay, ReportDelay, sndPlayer, reportParams);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1710
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1711
        iLogger->Log(_L("Starting scheduler"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1712
        CActiveScheduler::Start();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1713
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1714
        iLogger->Log(_L("Returned from player, errorcode: %d"), sndPlayer->iFinalError );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1715
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1716
        aResult.iResult = sndPlayer->iFinalError;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1717
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1718
        if (mEventGetBalance->GetCount() <= 0)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1719
            {
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1720
            aResult.iResult = KErrSkippedEvents;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1721
            }
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1722
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1723
        switch (aResult.iResult)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1724
            {
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1725
            case KErrNone:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1726
                iLogger->Log(_L("Test was successful"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1727
                aResult.iResultDes.Copy( KTestCaseResultSuccess() );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1728
                break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1729
            case KErrExpectedValueDifferent:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1730
                iLogger->Log(_L("Test failed, error code %d"), aResult.iResult);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1731
                aResult.iResultDes.Copy( KTestCaseResultFailExpectedValueDifferent() );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1732
                break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1733
            case KErrSkippedEvents:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1734
                iLogger->Log(_L("Test failed, error code %d"), aResult.iResult);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1735
                aResult.iResultDes.Copy( KTestCaseResultFailSkippedEvents() );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1736
                break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1737
            default:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1738
                iLogger->Log(_L("Test failed, error code %d"), aResult.iResult);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1739
                aResult.iResultDes.Copy( KTestCaseResultFail() );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1740
            }
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1741
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1742
        CleanupStack::PopAndDestroy(mEventGetBalance);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1743
        CleanupStack::Pop(reportParams);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1744
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1745
        CleanupStack::PopAndDestroy(sndPlayer);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1746
        return KErrNone;    //aResult.iResult;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1747
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1748
        }
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1749
    else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1750
        {
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1751
        //The file name of the clip to play is missing
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1752
        aResult.iResultDes.Copy(KConfigInvalid());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1753
        aResult.iResult = KErrNotExecuted;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1754
        return KErrConfigInvalid;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1755
        }
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1756
    }
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1757
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1758
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1759
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1760
TInt CDRMAudioPlay::TestCasePlayFilesGetNumberOfMetaDataEntriesL(CStifSectionParser *section , TTestResult &aResult)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1761
    {
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1762
    TPtrC FileNamePtr;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1763
    TTimeIntervalMicroSeconds32 ReportDelay=KDefaultReportDelay;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1764
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1765
    if ( !section->GetLine(KTagSoundFile, FileNamePtr, ENoTag) )
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1766
        {
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1767
        TBool UsingDefaultReportDelay;;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1768
        TFileName FileName = FileNamePtr;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1769
        iLogger->Log(_L("Creating simple player with file [%S]"), &FileNamePtr);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1770
        CSimpleSoundPlayer *sndPlayer = CSimpleSoundPlayer::NewL( FileName, TestModuleIf() , *iLogger);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1771
        CleanupStack::PushL(sndPlayer);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1772
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1773
        //###############################################
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1774
        ReportDelay = GetTimeIntervalL(section, KTagDelay, UsingDefaultReportDelay, (TTimeIntervalMicroSeconds32)KDefaultReportDelay);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1775
        iLogger->Log(_L("Setting delays to report position to [%d]"), ReportDelay.Int());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1776
        //###############################################
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1777
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1778
        CParameters *reportParams = new(ELeave)CParameters(CSimpleSoundPlayer::KplayerActionGetBalance);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1779
        CleanupStack::PushL(reportParams);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1780
        CMediaEvent *mEventGetBalance = CMediaEvent::NewLC(TestModuleIf() , *iLogger, ReportDelay, ReportDelay, sndPlayer, reportParams);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1781
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1782
        iLogger->Log(_L("Starting scheduler"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1783
        CActiveScheduler::Start();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1784
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1785
        iLogger->Log(_L("Returned from player, errorcode: %d"), sndPlayer->iFinalError );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1786
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1787
        aResult.iResult = sndPlayer->iFinalError;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1788
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1789
        if (mEventGetBalance->GetCount() <= 0)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1790
            {
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1791
            aResult.iResult = KErrSkippedEvents;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1792
            }
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1793
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1794
        switch (aResult.iResult)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1795
            {
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1796
            case KErrNone:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1797
                iLogger->Log(_L("Test was successful"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1798
                aResult.iResultDes.Copy( KTestCaseResultSuccess() );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1799
                break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1800
            case KErrExpectedValueDifferent:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1801
                iLogger->Log(_L("Test failed, error code %d"), aResult.iResult);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1802
                aResult.iResultDes.Copy( KTestCaseResultFailExpectedValueDifferent() );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1803
                break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1804
            case KErrSkippedEvents:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1805
                iLogger->Log(_L("Test failed, error code %d"), aResult.iResult);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1806
                aResult.iResultDes.Copy( KTestCaseResultFailSkippedEvents() );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1807
                break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1808
            default:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1809
                iLogger->Log(_L("Test failed, error code %d"), aResult.iResult);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1810
                aResult.iResultDes.Copy( KTestCaseResultFail() );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1811
            }
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1812
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1813
        CleanupStack::PopAndDestroy(mEventGetBalance);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1814
        CleanupStack::Pop(reportParams);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1815
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1816
        CleanupStack::PopAndDestroy(sndPlayer);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1817
        return KErrNone;    //aResult.iResult;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1818
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1819
        }
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1820
    else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1821
        {
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1822
        //The file name of the clip to play is missing
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1823
        aResult.iResultDes.Copy(KConfigInvalid());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1824
        aResult.iResult = KErrNotExecuted;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1825
        return KErrConfigInvalid;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1826
        }
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1827
    }
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1828
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1829
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1830
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1831
TInt CDRMAudioPlay::TestCasePlayFileGetBitRateL(CStifSectionParser *section , TTestResult &aResult)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1832
    {
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1833
    TPtrC FileNamePtr;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1834
    TTimeIntervalMicroSeconds32 ReportDelay=KDefaultReportDelay;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1835
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1836
    if ( !section->GetLine(KTagSoundFile, FileNamePtr, ENoTag) )
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1837
        {
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1838
        TBool UsingDefaultReportDelay;;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1839
        TFileName FileName = FileNamePtr;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1840
        iLogger->Log(_L("Creating simple player with file [%S]"), &FileNamePtr);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1841
        CSimpleSoundPlayer *sndPlayer = CSimpleSoundPlayer::NewL( FileName, TestModuleIf() , *iLogger);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1842
        CleanupStack::PushL(sndPlayer);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1843
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1844
        //###############################################
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1845
        ReportDelay = GetTimeIntervalL(section, KTagDelay, UsingDefaultReportDelay, (TTimeIntervalMicroSeconds32)KDefaultReportDelay);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1846
        iLogger->Log(_L("Setting delays to report position to [%d]"), ReportDelay.Int());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1847
        //###############################################
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1848
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1849
        CParameters *reportParams = new(ELeave)CParameters(CSimpleSoundPlayer::KplayerActionGetBitRate);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1850
        CleanupStack::PushL(reportParams);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1851
        CMediaEvent *mEventGetBitRate = CMediaEvent::NewLC(TestModuleIf() , *iLogger, ReportDelay, ReportDelay, sndPlayer, reportParams);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1852
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1853
        iLogger->Log(_L("Starting scheduler"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1854
        CActiveScheduler::Start();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1855
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1856
        iLogger->Log(_L("Returned from player, errorcode: %d"), sndPlayer->iFinalError );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1857
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1858
        aResult.iResult = sndPlayer->iFinalError;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1859
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1860
        if (mEventGetBitRate->GetCount() <= 0)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1861
            {
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1862
            aResult.iResult = KErrSkippedEvents;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1863
            }
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1864
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1865
        switch (aResult.iResult)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1866
            {
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1867
            case KErrNone:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1868
                iLogger->Log(_L("Test was successful"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1869
                aResult.iResultDes.Copy( KTestCaseResultSuccess() );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1870
                break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1871
            case KErrExpectedValueDifferent:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1872
                iLogger->Log(_L("Test failed, error code %d"), aResult.iResult);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1873
                aResult.iResultDes.Copy( KTestCaseResultFailExpectedValueDifferent() );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1874
                break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1875
            case KErrSkippedEvents:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1876
                iLogger->Log(_L("Test failed, error code %d"), aResult.iResult);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1877
                aResult.iResultDes.Copy( KTestCaseResultFailSkippedEvents() );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1878
                break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1879
            default:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1880
                iLogger->Log(_L("Test failed, error code %d"), aResult.iResult);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1881
                aResult.iResultDes.Copy( KTestCaseResultFail() );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1882
            }
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1883
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1884
        CleanupStack::PopAndDestroy(mEventGetBitRate);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1885
        CleanupStack::Pop(reportParams);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1886
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1887
        CleanupStack::PopAndDestroy(sndPlayer);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1888
        return KErrNone;    //aResult.iResult;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1889
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1890
        }
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1891
    else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1892
        {
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1893
        //The file name of the clip to play is missing
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1894
        aResult.iResultDes.Copy(KConfigInvalid());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1895
        aResult.iResult = KErrNotExecuted;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1896
        return KErrConfigInvalid;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1897
        }
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1898
    }
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1899
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1900
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1901
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1902
TInt CDRMAudioPlay::TestCasePlayFilesImplementationInformation(CStifSectionParser *section , TTestResult &aResult)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1903
    {
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1904
    TPtrC FileNamePtr;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1905
    TTimeIntervalMicroSeconds32 ReportDelay=KDefaultReportDelay;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1906
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1907
    if ( !section->GetLine(KTagSoundFile, FileNamePtr, ENoTag) )
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1908
        {
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1909
        TBool UsingDefaultReportDelay;;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1910
        TFileName FileName = FileNamePtr;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1911
        iLogger->Log(_L("Creating simple player with file [%S]"), &FileNamePtr);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1912
        CSimpleSoundPlayer *sndPlayer = CSimpleSoundPlayer::NewL( FileName, TestModuleIf() , *iLogger);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1913
        CleanupStack::PushL(sndPlayer);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1914
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1915
        //###############################################
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1916
        ReportDelay = GetTimeIntervalL(section, KTagDelay, UsingDefaultReportDelay, (TTimeIntervalMicroSeconds32)KDefaultReportDelay);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1917
        iLogger->Log(_L("Setting delays to report position to [%d]"), ReportDelay.Int());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1918
        //###############################################
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1919
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1920
        CParameters *reportParams = new(ELeave)CParameters(CSimpleSoundPlayer::KplayerActionControllerImplementationInformation);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1921
        CleanupStack::PushL(reportParams);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1922
        CMediaEvent *mEventImplementationInformation = CMediaEvent::NewLC(TestModuleIf() , *iLogger, ReportDelay, ReportDelay, sndPlayer, reportParams);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1923
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1924
        iLogger->Log(_L("Starting scheduler"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1925
        CActiveScheduler::Start();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1926
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1927
        iLogger->Log(_L("Returned from player, errorcode: %d"), sndPlayer->iFinalError );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1928
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1929
        aResult.iResult = sndPlayer->iFinalError;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1930
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1931
        if (mEventImplementationInformation->GetCount() <= 0)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1932
            {
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1933
            aResult.iResult = KErrSkippedEvents;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1934
            }
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1935
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1936
        switch (aResult.iResult)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1937
            {
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1938
            case KErrNone:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1939
                iLogger->Log(_L("Test was successful"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1940
                aResult.iResultDes.Copy( KTestCaseResultSuccess() );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1941
                break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1942
            case KErrExpectedValueDifferent:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1943
                iLogger->Log(_L("Test failed, error code %d"), aResult.iResult);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1944
                aResult.iResultDes.Copy( KTestCaseResultFailExpectedValueDifferent() );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1945
                break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1946
            case KErrSkippedEvents:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1947
                iLogger->Log(_L("Test failed, error code %d"), aResult.iResult);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1948
                aResult.iResultDes.Copy( KTestCaseResultFailSkippedEvents() );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1949
                break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1950
            default:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1951
                iLogger->Log(_L("Test failed, error code %d"), aResult.iResult);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1952
                aResult.iResultDes.Copy( KTestCaseResultFail() );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1953
            }
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1954
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1955
        CleanupStack::PopAndDestroy(mEventImplementationInformation);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1956
        CleanupStack::Pop(reportParams);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1957
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1958
        CleanupStack::PopAndDestroy(sndPlayer);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1959
        return KErrNone;    //aResult.iResult;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1960
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1961
        }
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1962
    else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1963
        {
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1964
        //The file name of the clip to play is missing
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1965
        aResult.iResultDes.Copy(KConfigInvalid());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1966
        aResult.iResult = KErrNotExecuted;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1967
        return KErrConfigInvalid;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1968
        }
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1969
    }
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1970
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1971
TInt CDRMAudioPlay::TestCasePlayFilesRegisterForAudioLoadingNotification(CStifSectionParser *section , TTestResult &aResult)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1972
    {
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1973
    TPtrC FileNamePtr;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1974
    TTimeIntervalMicroSeconds32 ReportDelay=KDefaultReportDelay;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1975
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1976
    if ( !section->GetLine(KTagSoundFile, FileNamePtr, ENoTag) )
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1977
        {
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1978
        TBool UsingDefaultReportDelay;;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1979
        TFileName FileName = FileNamePtr;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1980
        iLogger->Log(_L("Creating simple player with file [%S]"), &FileNamePtr);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1981
        CSimpleSoundPlayer *sndPlayer = CSimpleSoundPlayer::NewL( FileName, TestModuleIf() , *iLogger);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1982
        CleanupStack::PushL(sndPlayer);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1983
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1984
        //###############################################
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1985
        ReportDelay = GetTimeIntervalL(section, KTagDelay, UsingDefaultReportDelay, (TTimeIntervalMicroSeconds32)KDefaultReportDelay);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1986
        iLogger->Log(_L("Setting delays to report position to [%d]"), ReportDelay.Int());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1987
        //###############################################
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1988
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1989
        CParameters *reportParams = new(ELeave)CParameters(CSimpleSoundPlayer::KplayerActionRegisterForAudioLoadingNotification);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1990
        CleanupStack::PushL(reportParams);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1991
        CMediaEvent *mEventRegisterForAudioLoadingNotification = CMediaEvent::NewLC(TestModuleIf() , *iLogger, ReportDelay, ReportDelay, sndPlayer, reportParams);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1992
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1993
        iLogger->Log(_L("Starting scheduler"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1994
        CActiveScheduler::Start();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1995
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1996
        iLogger->Log(_L("Returned from player, errorcode: %d"), sndPlayer->iFinalError );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1997
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1998
        aResult.iResult = sndPlayer->iFinalError;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1999
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2000
        if (mEventRegisterForAudioLoadingNotification->GetCount() <= 0)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2001
            {
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2002
            aResult.iResult = KErrSkippedEvents;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2003
            }
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2004
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2005
        switch (aResult.iResult)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2006
            {
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2007
            case KErrNone:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2008
                iLogger->Log(_L("Test was successful"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2009
                aResult.iResultDes.Copy( KTestCaseResultSuccess() );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2010
                break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2011
            case KErrExpectedValueDifferent:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2012
                iLogger->Log(_L("Test failed, error code %d"), aResult.iResult);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2013
                aResult.iResultDes.Copy( KTestCaseResultFailExpectedValueDifferent() );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2014
                break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2015
            case KErrSkippedEvents:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2016
                iLogger->Log(_L("Test failed, error code %d"), aResult.iResult);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2017
                aResult.iResultDes.Copy( KTestCaseResultFailSkippedEvents() );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2018
                break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2019
            default:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2020
                iLogger->Log(_L("Test failed, error code %d"), aResult.iResult);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2021
                aResult.iResultDes.Copy( KTestCaseResultFail() );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2022
            }
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2023
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2024
        CleanupStack::PopAndDestroy(mEventRegisterForAudioLoadingNotification);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2025
        CleanupStack::Pop(reportParams);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2026
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2027
        CleanupStack::PopAndDestroy(sndPlayer);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2028
        return KErrNone;    //aResult.iResult;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2029
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2030
        }
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2031
    else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2032
        {
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2033
        //The file name of the clip to play is missing
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2034
        aResult.iResultDes.Copy(KConfigInvalid());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2035
        aResult.iResult = KErrNotExecuted;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2036
        return KErrConfigInvalid;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2037
        }
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2038
    }
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2039
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2040
TInt CDRMAudioPlay::TestCasePlayFilesGetAudioLoadingProgress(CStifSectionParser *section , TTestResult &aResult)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2041
    {
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2042
    TPtrC FileNamePtr;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2043
    TTimeIntervalMicroSeconds32 ReportDelay=KDefaultReportDelay;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2044
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2045
    if ( !section->GetLine(KTagSoundFile, FileNamePtr, ENoTag) )
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2046
        {
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2047
        TBool UsingDefaultReportDelay;;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2048
        TFileName FileName = FileNamePtr;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2049
        iLogger->Log(_L("Creating simple player with file [%S]"), &FileNamePtr);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2050
        CSimpleSoundPlayer *sndPlayer = CSimpleSoundPlayer::NewL( FileName, TestModuleIf() , *iLogger);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2051
        CleanupStack::PushL(sndPlayer);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2052
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2053
        //###############################################
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2054
        ReportDelay = GetTimeIntervalL(section, KTagDelay, UsingDefaultReportDelay, (TTimeIntervalMicroSeconds32)KDefaultReportDelay);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2055
        iLogger->Log(_L("Setting delays to report position to [%d]"), ReportDelay.Int());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2056
        //###############################################
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2057
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2058
        CParameters *reportParams = new(ELeave)CParameters(CSimpleSoundPlayer::KplayerActionGetAudioLoadingProgress);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2059
        CleanupStack::PushL(reportParams);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2060
        CMediaEvent *mEventGetAudioLoadingProgress = CMediaEvent::NewLC(TestModuleIf() , *iLogger, ReportDelay, ReportDelay, sndPlayer, reportParams);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2061
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2062
        iLogger->Log(_L("Starting scheduler"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2063
        CActiveScheduler::Start();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2064
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2065
        iLogger->Log(_L("Returned from player, errorcode: %d"), sndPlayer->iFinalError );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2066
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2067
        aResult.iResult = sndPlayer->iFinalError;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2068
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2069
        if (mEventGetAudioLoadingProgress->GetCount() <= 0)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2070
            {
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2071
            aResult.iResult = KErrSkippedEvents;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2072
            }
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2073
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2074
        switch (aResult.iResult)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2075
            {
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2076
            case KErrNone:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2077
                iLogger->Log(_L("Test was successful"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2078
                aResult.iResultDes.Copy( KTestCaseResultSuccess() );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2079
                break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2080
            case KErrExpectedValueDifferent:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2081
                iLogger->Log(_L("Test failed, error code %d"), aResult.iResult);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2082
                aResult.iResultDes.Copy( KTestCaseResultFailExpectedValueDifferent() );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2083
                break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2084
            case KErrSkippedEvents:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2085
                iLogger->Log(_L("Test failed, error code %d"), aResult.iResult);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2086
                aResult.iResultDes.Copy( KTestCaseResultFailSkippedEvents() );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2087
                break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2088
            default:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2089
                iLogger->Log(_L("Test failed, error code %d"), aResult.iResult);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2090
                aResult.iResultDes.Copy( KTestCaseResultFail() );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2091
            }
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2092
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2093
        CleanupStack::PopAndDestroy(mEventGetAudioLoadingProgress);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2094
        CleanupStack::Pop(reportParams);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2095
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2096
        CleanupStack::PopAndDestroy(sndPlayer);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2097
        return KErrNone;    //aResult.iResult;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2098
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2099
        }
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2100
    else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2101
        {
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2102
        //The file name of the clip to play is missing
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2103
        aResult.iResultDes.Copy(KConfigInvalid());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2104
        aResult.iResult = KErrNotExecuted;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2105
        return KErrConfigInvalid;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2106
        }
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2107
    }
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2108
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2109
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2110
//FH
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2111
TInt CDRMAudioPlay::TestCasePlayHandlerWithDurationL(CStifSectionParser *section , TTestResult &aResult)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2112
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2113
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2114
	TPtrC FileNamePtr;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2115
	User::LeaveIfError(iFs.Connect());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2116
	iFs.ShareProtected();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2117
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2118
	TTimeIntervalMicroSeconds32 ReportDelay=KDefaultReportDelay;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2119
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2120
	if ( !section->GetLine(KTagSoundFile, FileNamePtr, ENoTag) )
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2121
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2122
		TBool ExpectedDurationNotSet = EFalse, UsingDefaultReportDelay;;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2123
		TTimeIntervalMicroSeconds ExpectedDuration;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2124
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2125
		TFileName FileName = FileNamePtr;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2126
		User::LeaveIfError(iFile.Open( iFs, FileName, EFileRead));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2127
		iLogger->Log(_L("Creating simple player with file [%S]"), &FileNamePtr);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2128
	//	CSimpleSoundPlayer *sndPlayer = CSimpleSoundPlayer::NewL( FileName, TestModuleIf() , *iLogger);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2129
		CSimpleSoundPlayer *sndPlayer = CSimpleSoundPlayer::NewL( iFile, TestModuleIf() , *iLogger);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2130
		iFile.Close();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2131
		CleanupStack::PushL(sndPlayer);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2132
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2133
		//*********************************************
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2134
		ReportDelay = GetTimeIntervalL(section, KTagDelay, UsingDefaultReportDelay, (TTimeIntervalMicroSeconds32)KDefaultReportDelay);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2135
		iLogger->Log(_L("Setting delays to report position to [%d]"), ReportDelay.Int());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2136
		//*********************************************
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2137
		ExpectedDuration = GetTimeIntervalL( section, KTagExpectedDuration, ExpectedDurationNotSet) ;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2138
		//*********************************************
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2139
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2140
		CParameters *reportParams = new(ELeave)CParameters(CSimpleSoundPlayer::KPlayerActionReportDuration);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2141
		CleanupStack::PushL(reportParams);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2142
		CMediaEvent *mEventReportPosition = CMediaEvent::NewLC(TestModuleIf() , *iLogger, ReportDelay, ReportDelay, sndPlayer, reportParams);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2143
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2144
		iLogger->Log(_L("Starting scheduler"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2145
		CActiveScheduler::Start();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2146
		iFs.Close();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2147
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2148
		iLogger->Log(_L("Returned from player, errorcode: %d"), sndPlayer->iFinalError );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2149
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2150
		aResult.iResult = sndPlayer->iFinalError;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2151
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2152
		if (mEventReportPosition->GetCount() <= 0)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2153
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2154
			aResult.iResult = KErrSkippedEvents;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2155
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2156
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2157
		if (!ExpectedDurationNotSet)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2158
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2159
			iLogger->Log(_L("Expected duration: (%d)") , ExpectedDuration.Int64() );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2160
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2161
			if ( ExpectedDuration!=sndPlayer->GetDuration() )
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2162
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2163
				aResult.iResult = KErrExpectedValueDifferent;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2164
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2165
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2166
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2167
		switch (aResult.iResult)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2168
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2169
			case KErrNone:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2170
				iLogger->Log(_L("Test was successful"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2171
				aResult.iResultDes.Copy( KTestCaseResultSuccess() );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2172
				break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2173
			case KErrExpectedValueDifferent:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2174
				iLogger->Log(_L("Test failed, error code %d"), aResult.iResult);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2175
				aResult.iResultDes.Copy( KTestCaseResultFailExpectedValueDifferent() );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2176
				break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2177
			case KErrSkippedEvents:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2178
				iLogger->Log(_L("Test failed, error code %d"), aResult.iResult);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2179
				aResult.iResultDes.Copy( KTestCaseResultFailSkippedEvents() );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2180
				break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2181
			default:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2182
				iLogger->Log(_L("Test failed, error code %d"), aResult.iResult);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2183
				aResult.iResultDes.Copy( KTestCaseResultFail() );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2184
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2185
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2186
		CleanupStack::PopAndDestroy(mEventReportPosition);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2187
		CleanupStack::Pop(reportParams);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2188
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2189
		CleanupStack::PopAndDestroy(sndPlayer);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2190
		return KErrNone;	//aResult.iResult;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2191
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2192
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2193
	else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2194
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2195
		//The file name of the clip to play is missing
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2196
		aResult.iResultDes.Copy(KConfigInvalid());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2197
		aResult.iResult = KErrNotExecuted;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2198
		return KErrConfigInvalid;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2199
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2200
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2201
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2202
TInt CDRMAudioPlay::TestCasePlayFileWindowL(CStifSectionParser *section , TTestResult &aResult)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2203
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2204
	TPtrC FileNamePtr;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2205
	TTimeIntervalMicroSeconds StartPosition = KDefaultPosition;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2206
	TTimeIntervalMicroSeconds EndPosition = KDefaultPosition;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2207
	TTimeIntervalMicroSeconds32 ReportDelay = KDefaultReportDelay;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2208
	TBool UsingDefault;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2209
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2210
	if ( !section->GetLine(KTagSoundFile, FileNamePtr, ENoTag) )
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2211
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2212
		TBool UsingStartDefault, UsingEndDefault, UsingDefaultReportDelay;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2213
		TFileName FileName = FileNamePtr;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2214
	//	TInt WindowError;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2215
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2216
		iLogger->Log(_L("Creating simple player with file [%S]"), &FileNamePtr);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2217
		CSimpleSoundPlayer *sndPlayer = CSimpleSoundPlayer::NewL( FileName, TestModuleIf() , *iLogger);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2218
		CleanupStack::PushL(sndPlayer);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2219
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2220
		//*********************
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2221
		StartPosition = GetTimeIntervalL(section, KTagWindowStart, UsingStartDefault, (TTimeIntervalMicroSeconds)(KDefaultPosition.Int64()-1E6));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2222
		EndPosition = GetTimeIntervalL(section, KTagWindowEnd, UsingEndDefault, (TTimeIntervalMicroSeconds)(KDefaultPosition.Int64()+1E6));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2223
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2224
		TTimeIntervalMicroSeconds ErrorRange = GetTimeIntervalL(section, KTagErrorRange, UsingDefault, KDefaultErrorRange);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2225
		if (UsingDefault) {iLogger->Log(_L("Using default error range"));}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2226
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2227
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2228
		sndPlayer->iStartPosition = StartPosition;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2229
		sndPlayer->iEndPosition = EndPosition;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2230
		sndPlayer->iPlayWindow = true;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2231
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2232
		ReportDelay = GetTimeIntervalL(section, KTagDelay, UsingDefaultReportDelay, (TTimeIntervalMicroSeconds32)KDefaultReportDelay);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2233
		iLogger->Log(_L("Setting delays to report position to [%d]"), ReportDelay.Int());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2234
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2235
		CParameters *reportParams = new(ELeave)CParameters(CSimpleSoundPlayer::KPlayerActionReportPosition);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2236
		CleanupStack::PushL(reportParams);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2237
		CMediaEvent *mEventReportPosition = CMediaEvent::NewLC(TestModuleIf() , *iLogger, ReportDelay, ReportDelay, sndPlayer, reportParams);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2238
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2239
		iLogger->Log(_L("Starting scheduler"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2240
		TTime StartTime,EndTime;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2241
		StartTime.HomeTime();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2242
		CActiveScheduler::Start();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2243
		EndTime.HomeTime();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2244
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2245
		TTimeIntervalMicroSeconds PerceivedDuration = EndTime.MicroSecondsFrom( StartTime );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2246
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2247
		iLogger->Log(_L("Returned from player, errorcode: %d"), sndPlayer->iFinalError );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2248
		iLogger->Log(_L("Perceived duration: %d") , PerceivedDuration.Int64() );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2249
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2250
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2251
		TTimeIntervalMicroSeconds ExpectedDuration = TTimeIntervalMicroSeconds(I64INT(EndPosition.Int64()) - I64INT(StartPosition.Int64()));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2252
		iLogger->Log(_L("ExpectedDuration: %d") ,ExpectedDuration.Int64() );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2253
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2254
		if (  Abs(ExpectedDuration.Int64() - PerceivedDuration.Int64()) > ErrorRange.Int64() )
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2255
			{	//Durations too different
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2256
			iLogger->Log(_L("The clips duration is too different from the actual duration + position") );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2257
			aResult.iResult = KErrExpectedValueDifferent;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2258
			aResult.iResultDes.Copy(KTestCaseResultFailExpectedValueDifferent());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2259
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2260
		else if (aResult.iResult = sndPlayer->iFinalError , aResult.iResult)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2261
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2262
			iLogger->Log(_L("Test failed, error code %d"), aResult.iResult);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2263
			aResult.iResultDes.Copy(KTestCaseResultFail());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2264
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2265
		else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2266
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2267
			iLogger->Log(_L("Test was successful"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2268
			aResult.iResultDes.Copy(KTestCaseResultSuccess());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2269
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2270
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2271
		CleanupStack::PopAndDestroy(mEventReportPosition);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2272
		CleanupStack::Pop(reportParams);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2273
		CleanupStack::PopAndDestroy(sndPlayer);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2274
		return KErrExecuted;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2275
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2276
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2277
	else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2278
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2279
		aResult.iResultDes.Copy(KConfigInvalid());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2280
		aResult.iResult = KErrNotExecuted;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2281
		return KErrConfigInvalid;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2282
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2283
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2284
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2285
//FH
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2286
TInt CDRMAudioPlay::TestCasePlayHandlerWithWindowL(CStifSectionParser *section , TTestResult &aResult)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2287
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2288
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2289
	TPtrC FileNamePtr;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2290
	User::LeaveIfError(iFs.Connect());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2291
	iFs.ShareProtected();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2292
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2293
	TTimeIntervalMicroSeconds StartPosition = KDefaultPosition;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2294
	TTimeIntervalMicroSeconds EndPosition = KDefaultPosition;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2295
	TTimeIntervalMicroSeconds32 ReportDelay = KDefaultReportDelay;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2296
	TBool UsingDefault;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2297
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2298
	if ( !section->GetLine(KTagSoundFile, FileNamePtr, ENoTag) )
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2299
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2300
		TBool UsingStartDefault, UsingEndDefault, UsingDefaultReportDelay;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2301
		TFileName FileName = FileNamePtr;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2302
	//	TInt WindowError;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2303
		User::LeaveIfError(iFile.Open( iFs, FileName, EFileRead));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2304
		iLogger->Log(_L("Creating simple player with file [%S]"), &FileNamePtr);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2305
	//	CSimpleSoundPlayer *sndPlayer = CSimpleSoundPlayer::NewL( FileName, TestModuleIf() , *iLogger);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2306
		CSimpleSoundPlayer *sndPlayer = CSimpleSoundPlayer::NewL( iFile, TestModuleIf() , *iLogger);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2307
		iFile.Close();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2308
		CleanupStack::PushL(sndPlayer);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2309
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2310
		//*********************
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2311
		StartPosition = GetTimeIntervalL(section, KTagWindowStart, UsingStartDefault, (TTimeIntervalMicroSeconds)(KDefaultPosition.Int64()-1E6));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2312
		EndPosition = GetTimeIntervalL(section, KTagWindowEnd, UsingEndDefault, (TTimeIntervalMicroSeconds)(KDefaultPosition.Int64()+1E6));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2313
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2314
		TTimeIntervalMicroSeconds ErrorRange = GetTimeIntervalL(section, KTagErrorRange, UsingDefault, KDefaultErrorRange);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2315
		if (UsingDefault) {iLogger->Log(_L("Using default error range"));}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2316
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2317
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2318
		sndPlayer->iStartPosition = StartPosition;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2319
		sndPlayer->iEndPosition = EndPosition;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2320
		sndPlayer->iPlayWindow = true;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2321
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2322
		ReportDelay = GetTimeIntervalL(section, KTagDelay, UsingDefaultReportDelay, (TTimeIntervalMicroSeconds32)KDefaultReportDelay);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2323
		iLogger->Log(_L("Setting delays to report position to [%d]"), ReportDelay.Int());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2324
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2325
		CParameters *reportParams = new(ELeave)CParameters(CSimpleSoundPlayer::KPlayerActionReportPosition);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2326
		CleanupStack::PushL(reportParams);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2327
		CMediaEvent *mEventReportPosition = CMediaEvent::NewLC(TestModuleIf() , *iLogger, ReportDelay, ReportDelay, sndPlayer, reportParams);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2328
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2329
		iLogger->Log(_L("Starting scheduler"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2330
		TTime StartTime,EndTime;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2331
		StartTime.HomeTime();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2332
		CActiveScheduler::Start();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2333
		EndTime.HomeTime();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2334
		iFs.Close();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2335
		TTimeIntervalMicroSeconds PerceivedDuration = EndTime.MicroSecondsFrom( StartTime );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2336
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2337
		iLogger->Log(_L("Returned from player, errorcode: %d"), sndPlayer->iFinalError );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2338
		iLogger->Log(_L("Perceived duration: %d") , PerceivedDuration.Int64() );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2339
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2340
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2341
		TTimeIntervalMicroSeconds ExpectedDuration = TTimeIntervalMicroSeconds(I64INT(EndPosition.Int64()) - I64INT(StartPosition.Int64()));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2342
		iLogger->Log(_L("ExpectedDuration: %d") ,ExpectedDuration.Int64() );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2343
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2344
		if (  Abs(ExpectedDuration.Int64() - PerceivedDuration.Int64()) > ErrorRange.Int64() )
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2345
			{	//Durations too different
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2346
			iLogger->Log(_L("The clips duration is too different from the actual duration + position") );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2347
			aResult.iResult = KErrExpectedValueDifferent;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2348
			aResult.iResultDes.Copy(KTestCaseResultFailExpectedValueDifferent());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2349
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2350
		else if (aResult.iResult = sndPlayer->iFinalError , aResult.iResult)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2351
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2352
			iLogger->Log(_L("Test failed, error code %d"), aResult.iResult);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2353
			aResult.iResultDes.Copy(KTestCaseResultFail());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2354
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2355
		else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2356
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2357
			iLogger->Log(_L("Test was successful"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2358
			aResult.iResultDes.Copy(KTestCaseResultSuccess());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2359
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2360
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2361
		CleanupStack::PopAndDestroy(mEventReportPosition);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2362
		CleanupStack::Pop(reportParams);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2363
		CleanupStack::PopAndDestroy(sndPlayer);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2364
		return KErrExecuted;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2365
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2366
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2367
	else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2368
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2369
		aResult.iResultDes.Copy(KConfigInvalid());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2370
		aResult.iResult = KErrNotExecuted;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2371
		return KErrConfigInvalid;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2372
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2373
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2374
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2375
TInt CDRMAudioPlay::TestCasePlayFileWindowClearL(CStifSectionParser *section , TTestResult &aResult)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2376
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2377
	TPtrC FileNamePtr;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2378
	TTimeIntervalMicroSeconds StartPosition = KDefaultPosition;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2379
	TTimeIntervalMicroSeconds EndPosition = KDefaultPosition;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2380
	TTimeIntervalMicroSeconds32 ReportDelay = KDefaultReportDelay;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2381
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2382
	if ( !section->GetLine(KTagSoundFile, FileNamePtr, ENoTag) )
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2383
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2384
		TBool UsingStartDefault, UsingEndDefault, UsingDefaultReportDelay;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2385
		TFileName FileName = FileNamePtr;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2386
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2387
		iLogger->Log(_L("Creating simple player with file [%S]"), &FileNamePtr);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2388
		CSimpleSoundPlayer *sndPlayer = CSimpleSoundPlayer::NewL( FileName, TestModuleIf() , *iLogger);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2389
		CleanupStack::PushL(sndPlayer);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2390
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2391
		//*********************
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2392
		StartPosition = GetTimeIntervalL(section, KTagWindowStart, UsingStartDefault, (TTimeIntervalMicroSeconds)(KDefaultPosition.Int64()-1E6));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2393
		EndPosition = GetTimeIntervalL(section, KTagWindowEnd, UsingEndDefault, (TTimeIntervalMicroSeconds)(KDefaultPosition.Int64()+1E6));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2394
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2395
		ReportDelay = GetTimeIntervalL(section, KTagDelay, UsingDefaultReportDelay, (TTimeIntervalMicroSeconds32)KDefaultReportDelay);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2396
		iLogger->Log(_L("Setting delays to report position to [%d]"), ReportDelay.Int());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2397
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2398
		CParameters *reportParams = new(ELeave)CParameters(CSimpleSoundPlayer::KPlayerActionReportPosition);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2399
		CleanupStack::PushL(reportParams);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2400
		CMediaEvent *mEventReportPosition = CMediaEvent::NewLC(TestModuleIf() , *iLogger, ReportDelay, ReportDelay, sndPlayer, reportParams);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2401
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2402
		sndPlayer->iStartPosition = StartPosition;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2403
		sndPlayer->iEndPosition = EndPosition;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2404
		sndPlayer->iPlayWindow = true;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2405
		sndPlayer->iClearWindow = true;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2406
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2407
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2408
		iLogger->Log(_L("Starting scheduler"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2409
		CActiveScheduler::Start();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2410
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2411
		TBool PositionReset=ETrue;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2412
		TTimeIntervalMicroSeconds position;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2413
		TInt PosError = sndPlayer->GetPosition(position);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2414
		if ( !PosError && (position!=TTimeIntervalMicroSeconds(0) ) )
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2415
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2416
			iLogger->Log(_L("Position not reset to zero, position is (%d)") , position.Int64() );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2417
			PositionReset=EFalse;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2418
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2419
		if (PosError)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2420
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2421
			iLogger->Log(_L("Error (%d) obtaining clip position"), PosError );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2422
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2423
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2424
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2425
		if (!PositionReset)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2426
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2427
			iLogger->Log(_L("Error clearing PlayWindow, position not reset to zero") );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2428
			aResult.iResult = KErrExpectedValueDifferent;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2429
			aResult.iResultDes.Copy(KTestCaseResultFail() );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2430
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2431
		else if (aResult.iResult = sndPlayer->iFinalError , aResult.iResult)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2432
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2433
			iLogger->Log(_L("Test failed, error code %d"), aResult.iResult);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2434
			aResult.iResultDes.Copy(KTestCaseResultFail());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2435
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2436
		else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2437
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2438
			iLogger->Log(_L("Test was successful"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2439
			aResult.iResultDes.Copy(KTestCaseResultSuccess());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2440
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2441
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2442
		CleanupStack::PopAndDestroy(mEventReportPosition);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2443
		CleanupStack::Pop(reportParams);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2444
		CleanupStack::PopAndDestroy(sndPlayer);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2445
		return KErrExecuted;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2446
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2447
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2448
	else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2449
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2450
		//The file name of the clip to play is missing
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2451
		aResult.iResultDes.Copy(KConfigInvalid());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2452
		aResult.iResult = KErrNotExecuted;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2453
		return KErrConfigInvalid;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2454
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2455
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2456
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2457
//FH
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2458
TInt CDRMAudioPlay::TestCasePlayHandlerWithClearWindowL(CStifSectionParser *section , TTestResult &aResult)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2459
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2460
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2461
	TPtrC FileNamePtr;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2462
	User::LeaveIfError(iFs.Connect());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2463
	iFs.ShareProtected();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2464
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2465
	TTimeIntervalMicroSeconds StartPosition = KDefaultPosition;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2466
	TTimeIntervalMicroSeconds EndPosition = KDefaultPosition;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2467
	TTimeIntervalMicroSeconds32 ReportDelay = KDefaultReportDelay;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2468
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2469
	if ( !section->GetLine(KTagSoundFile, FileNamePtr, ENoTag) )
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2470
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2471
		TBool UsingStartDefault, UsingEndDefault, UsingDefaultReportDelay;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2472
		TFileName FileName = FileNamePtr;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2473
		User::LeaveIfError(iFile.Open( iFs, FileName, EFileRead));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2474
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2475
		iLogger->Log(_L("Creating simple player with file [%S]"), &FileNamePtr);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2476
	//	CSimpleSoundPlayer *sndPlayer = CSimpleSoundPlayer::NewL( FileName, TestModuleIf() , *iLogger);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2477
		CSimpleSoundPlayer *sndPlayer = CSimpleSoundPlayer::NewL( iFile, TestModuleIf() , *iLogger);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2478
		iFile.Close();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2479
		CleanupStack::PushL(sndPlayer);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2480
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2481
		//*********************
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2482
		StartPosition = GetTimeIntervalL(section, KTagWindowStart, UsingStartDefault, (TTimeIntervalMicroSeconds)(KDefaultPosition.Int64()-1E6));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2483
		EndPosition = GetTimeIntervalL(section, KTagWindowEnd, UsingEndDefault, (TTimeIntervalMicroSeconds)(KDefaultPosition.Int64()+1E6));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2484
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2485
		ReportDelay = GetTimeIntervalL(section, KTagDelay, UsingDefaultReportDelay, (TTimeIntervalMicroSeconds32)KDefaultReportDelay);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2486
		iLogger->Log(_L("Setting delays to report position to [%d]"), ReportDelay.Int());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2487
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2488
		CParameters *reportParams = new(ELeave)CParameters(CSimpleSoundPlayer::KPlayerActionReportPosition);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2489
		CleanupStack::PushL(reportParams);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2490
		CMediaEvent *mEventReportPosition = CMediaEvent::NewLC(TestModuleIf() , *iLogger, ReportDelay, ReportDelay, sndPlayer, reportParams);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2491
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2492
		sndPlayer->iStartPosition = StartPosition;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2493
		sndPlayer->iEndPosition = EndPosition;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2494
		sndPlayer->iPlayWindow = true;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2495
		sndPlayer->iClearWindow = true;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2496
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2497
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2498
		iLogger->Log(_L("Starting scheduler"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2499
		CActiveScheduler::Start();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2500
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2501
		iFs.Close();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2502
		TBool PositionReset=ETrue;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2503
		TTimeIntervalMicroSeconds position;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2504
		TInt PosError = sndPlayer->GetPosition(position);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2505
		if ( !PosError && (position!=TTimeIntervalMicroSeconds(0) ) )
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2506
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2507
			iLogger->Log(_L("Position not reset to zero, position is (%d)") , position.Int64() );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2508
			PositionReset=EFalse;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2509
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2510
		if (PosError)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2511
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2512
			iLogger->Log(_L("Error (%d) obtaining clip position"), PosError );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2513
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2514
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2515
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2516
		if (!PositionReset)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2517
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2518
			iLogger->Log(_L("Error clearing PlayWindow, position not reset to zero") );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2519
			aResult.iResult = KErrExpectedValueDifferent;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2520
			aResult.iResultDes.Copy(KTestCaseResultFail() );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2521
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2522
		else if (aResult.iResult = sndPlayer->iFinalError , aResult.iResult)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2523
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2524
			iLogger->Log(_L("Test failed, error code %d"), aResult.iResult);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2525
			aResult.iResultDes.Copy(KTestCaseResultFail());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2526
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2527
		else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2528
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2529
			iLogger->Log(_L("Test was successful"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2530
			aResult.iResultDes.Copy(KTestCaseResultSuccess());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2531
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2532
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2533
		CleanupStack::PopAndDestroy(mEventReportPosition);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2534
		CleanupStack::Pop(reportParams);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2535
		CleanupStack::PopAndDestroy(sndPlayer);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2536
		return KErrExecuted;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2537
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2538
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2539
	else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2540
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2541
		//The file name of the clip to play is missing
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2542
		aResult.iResultDes.Copy(KConfigInvalid());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2543
		aResult.iResult = KErrNotExecuted;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2544
		return KErrConfigInvalid;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2545
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2546
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2547
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2548
TInt CDRMAudioPlay::TestCasePlayDesStopOpenL(CStifSectionParser *section , TTestResult &aResult)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2549
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2550
	TPtrC FileNamePtr;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2551
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2552
	if ( !section->GetLine(KTagSoundDes, FileNamePtr, ENoTag) )
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2553
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2554
		TFileName FileName = FileNamePtr;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2555
		iLogger->Log(_L("Creating simple player with descriptor from [%S]"), &FileName);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2556
		//*********************************************
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2557
		//Open descriptor
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2558
		HBufC8 *SoundFile = GetDescriptor8LC(FileName, section);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2559
		HBufC8 *SoundFile2;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2560
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2561
		//*********************************************
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2562
		//FileName of second file to play
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2563
		CParameters *stopParams ;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2564
		if ( section->GetNextLine(KTagSoundDes, FileNamePtr, ENoTag) )
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2565
			{	//Using same filename
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2566
			SoundFile2 = SoundFile->AllocLC();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2567
			stopParams = CDes8Parameters::NewLC(CSimpleSoundPlayer::KPlayerActionStopPlayDes, *SoundFile2 );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2568
			iLogger->Log(_L("Second descriptor filename not found, using the same file twice"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2569
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2570
		else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2571
			{	//Found second filename
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2572
			FileName=FileNamePtr;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2573
			SoundFile2 = GetDescriptor8LC(FileName, section);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2574
			stopParams = CDes8Parameters::NewLC(CSimpleSoundPlayer::KPlayerActionStopPlayDes, *SoundFile2 );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2575
			iLogger->Log(_L("Second descriptor from [%S]") , &FileName );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2576
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2577
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2578
		CSimpleSoundPlayer *sndPlayer = CSimpleSoundPlayer::NewLC( *SoundFile, TestModuleIf() , *iLogger);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2579
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2580
		TBool UsingDefault;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2581
		TTimeIntervalMicroSeconds32 StopDelay = GetTimeIntervalL(section, KTagDelay, UsingDefault, (TTimeIntervalMicroSeconds32)KDefaultStopOpenPlayDelay);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2582
		if (UsingDefault) {iLogger->Log(_L("Error retrieving stop delay, using default"));}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2583
		iLogger->Log(_L("Setting delays to stop and open descriptor to [%d]"), StopDelay.Int());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2584
		//*********************************************
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2585
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2586
		CMediaEvent *mEventStopPlay = CMediaEvent::NewLC(TestModuleIf() , *iLogger, StopDelay, StopDelay, sndPlayer, stopParams);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2587
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2588
		iLogger->Log(_L("Starting scheduler"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2589
		CActiveScheduler::Start();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2590
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2591
		iLogger->Log(_L("Returned from player, errorcode: %d"), sndPlayer->iFinalError );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2592
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2593
		//]TBool DontCheckExpectedDuration;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2594
		//]TTimeIntervalMicroSeconds ErrorRange=GetTimeIntervalL(section, KTagErrorRange, DontCheckExpectedDuration);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2595
		//]TBool DontUseExpectedDuration;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2596
		//]TTimeIntervalMicroSeconds ExpectedDuration=GetTimeIntervalL(section, KTagExpectedDuration, DontUseExpectedDuration);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2597
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2598
		if (mEventStopPlay->GetCount() <= 0)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2599
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2600
			aResult.iResult = KErrSkippedEvents;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2601
			aResult.iResultDes.Copy(KTestCaseResultFailSkippedEvents);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2602
			iLogger->Log(KTestCaseResultFailSkippedEvents() );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2603
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2604
		else if ( sndPlayer->iFinalError)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2605
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2606
			aResult.iResult = sndPlayer->iFinalError;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2607
			iLogger->Log(_L("Test failed, error code %d"), aResult.iResult);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2608
			aResult.iResultDes.Copy(KTestCaseResultFail() );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2609
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2610
		else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2611
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2612
			//]aResult.iResult = KErrNone;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2613
			//]if (!DontCheckExpectedDuration && !DontUseExpectedDuration)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2614
			//]	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2615
			//]	if (!IsDurationInRange(0, ExpectedDuration, TTimeIntervalMicroSeconds(0), ErrorRange, sndPlayer->GetPlayStartTime(), sndPlayer->GetPlayStopTime() ) )
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2616
			//]		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2617
			//]		iLogger->Log(_L("Duration too different"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2618
			//]		aResult.iResult = KErrExpectedValueDifferent;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2619
			//]		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2620
			//]	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2621
			//]if (aResult.iResult)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2622
			//]	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2623
			//]	aResult.iResultDes.Copy(KTestCaseResultFailExpectedValueDifferent());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2624
			//]	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2625
			//]else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2626
			//]	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2627
				iLogger->Log(_L("Test was successful"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2628
				aResult.iResultDes.Copy(KTestCaseResultSuccess());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2629
			//]	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2630
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2631
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2632
		CleanupStack::PopAndDestroy(mEventStopPlay);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2633
		CleanupStack::PopAndDestroy(sndPlayer);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2634
		CleanupStack::Pop(stopParams);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2635
		CleanupStack::PopAndDestroy(SoundFile2);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2636
		CleanupStack::PopAndDestroy(SoundFile);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2637
		return KErrExecuted;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2638
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2639
	else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2640
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2641
		//The file name of the clip to play is missing
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2642
		aResult.iResultDes.Copy(KConfigInvalid());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2643
		aResult.iResult = KErrNotExecuted;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2644
		return KErrConfigInvalid;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2645
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2646
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2647
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2648
TInt CDRMAudioPlay::TestCasePlayFileWithVolumeRampL(CStifSectionParser *section , TTestResult &aResult)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2649
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2650
	TPtrC FileNamePtr;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2651
	TTimeIntervalMicroSeconds RampDuration = KDefaultRampDuration;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2652
	TTimeIntervalMicroSeconds32 ReportDelay=KDefaultReportDelay;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2653
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2654
	if ( !section->GetLine(KTagSoundFile, FileNamePtr, ENoTag) )
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2655
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2656
		TFileName FileName = FileNamePtr;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2657
		iLogger->Log(_L("Creating simple player with file [%S]"), &FileNamePtr);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2658
		CSimpleSoundPlayer *sndPlayer = CSimpleSoundPlayer::NewL( FileName, TestModuleIf() , *iLogger);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2659
		CleanupStack::PushL(sndPlayer);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2660
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2661
		//*********************
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2662
		TBool UsingReportDefault, UsingRampDefault;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2663
		RampDuration = GetTimeIntervalL(section, KTagRampDuration, UsingRampDefault, KDefaultRampDuration);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2664
		ReportDelay = GetTimeIntervalL(section, KTagDelay, UsingReportDefault, (TTimeIntervalMicroSeconds32)KDefaultReportDelay );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2665
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2666
		// ******************************************
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2667
		iLogger->Log(_L("Seting up volume ramp with duration: %d"), RampDuration.Int64());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2668
		if (UsingRampDefault) {iLogger->Log(_L("Using default Ramp duration of: %d") , KDefaultRampDuration.Int64());}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2669
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2670
		sndPlayer->SetVolumeRamp(RampDuration);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2671
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2672
		CParameters *reportParams = new(ELeave)CParameters(CSimpleSoundPlayer::KPlayerActionReportVolume);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2673
		CleanupStack::PushL(reportParams);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2674
		CMediaEvent *mEventReportPosition = CMediaEvent::NewLC(TestModuleIf() , *iLogger, ReportDelay, ReportDelay, sndPlayer, reportParams);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2675
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2676
		iLogger->Log(_L("Starting scheduler"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2677
		CActiveScheduler::Start();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2678
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2679
		iLogger->Log(_L("Returned from player, errorcode: %d"), sndPlayer->iFinalError );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2680
		aResult.iResult = sndPlayer->iFinalError;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2681
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2682
		if (mEventReportPosition->GetCount() <= 0)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2683
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2684
			aResult.iResult = KErrSkippedEvents;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2685
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2686
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2687
		switch (aResult.iResult)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2688
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2689
			case KErrNone:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2690
				iLogger->Log(_L("Test was successful"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2691
				aResult.iResultDes.Copy( KTestCaseResultSuccess() );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2692
				break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2693
			case KErrSkippedEvents:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2694
				iLogger->Log(_L("Test failed, error code %d"), aResult.iResult);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2695
				aResult.iResultDes.Copy( KTestCaseResultFailSkippedEvents() );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2696
				break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2697
			default:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2698
				iLogger->Log(_L("Test failed, error code %d"), aResult.iResult);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2699
				aResult.iResultDes.Copy( KTestCaseResultFail() );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2700
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2701
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2702
		CleanupStack::PopAndDestroy(mEventReportPosition);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2703
		CleanupStack::Pop(reportParams);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2704
		CleanupStack::PopAndDestroy(sndPlayer);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2705
		return aResult.iResult;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2706
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2707
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2708
	else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2709
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2710
		//The file name of the clip to play is missing
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2711
		aResult.iResultDes.Copy(KConfigInvalid());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2712
		aResult.iResult = KErrNotExecuted;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2713
		return KErrConfigInvalid;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2714
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2715
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2716
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2717
//FH
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2718
TInt CDRMAudioPlay::TestCasePlayHandlerWithRampL(CStifSectionParser *section , TTestResult &aResult)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2719
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2720
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2721
	TPtrC FileNamePtr;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2722
	User::LeaveIfError(iFs.Connect());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2723
	iFs.ShareProtected();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2724
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2725
	TTimeIntervalMicroSeconds RampDuration = KDefaultRampDuration;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2726
	TTimeIntervalMicroSeconds32 ReportDelay=KDefaultReportDelay;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2727
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2728
	if ( !section->GetLine(KTagSoundFile, FileNamePtr, ENoTag) )
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2729
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2730
		TFileName FileName = FileNamePtr;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2731
		iLogger->Log(_L("Creating simple player with file [%S]"), &FileNamePtr);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2732
		User::LeaveIfError(iFile.Open( iFs, FileName, EFileRead));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2733
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2734
		//CSimpleSoundPlayer *sndPlayer = CSimpleSoundPlayer::NewL( FileName, TestModuleIf() , *iLogger);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2735
		CSimpleSoundPlayer *sndPlayer = CSimpleSoundPlayer::NewL( iFile, TestModuleIf() , *iLogger);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2736
		iFile.Close();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2737
		CleanupStack::PushL(sndPlayer);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2738
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2739
		//*********************
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2740
		TBool UsingReportDefault, UsingRampDefault;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2741
		RampDuration = GetTimeIntervalL(section, KTagRampDuration, UsingRampDefault, KDefaultRampDuration);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2742
		ReportDelay = GetTimeIntervalL(section, KTagDelay, UsingReportDefault, (TTimeIntervalMicroSeconds32)KDefaultReportDelay );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2743
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2744
		// ******************************************
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2745
		iLogger->Log(_L("Seting up volume ramp with duration: %d"), RampDuration.Int64());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2746
		if (UsingRampDefault) {iLogger->Log(_L("Using default Ramp duration of: %d") , KDefaultRampDuration.Int64());}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2747
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2748
		sndPlayer->SetVolumeRamp(RampDuration);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2749
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2750
		CParameters *reportParams = new(ELeave)CParameters(CSimpleSoundPlayer::KPlayerActionReportVolume);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2751
		CleanupStack::PushL(reportParams);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2752
		CMediaEvent *mEventReportPosition = CMediaEvent::NewLC(TestModuleIf() , *iLogger, ReportDelay, ReportDelay, sndPlayer, reportParams);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2753
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2754
		iLogger->Log(_L("Starting scheduler"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2755
		CActiveScheduler::Start();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2756
		iFs.Close();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2757
		iLogger->Log(_L("Returned from player, errorcode: %d"), sndPlayer->iFinalError );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2758
		aResult.iResult = sndPlayer->iFinalError;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2759
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2760
		if (mEventReportPosition->GetCount() <= 0)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2761
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2762
			aResult.iResult = KErrSkippedEvents;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2763
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2764
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2765
		switch (aResult.iResult)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2766
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2767
			case KErrNone:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2768
				iLogger->Log(_L("Test was successful"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2769
				aResult.iResultDes.Copy( KTestCaseResultSuccess() );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2770
				break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2771
			case KErrSkippedEvents:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2772
				iLogger->Log(_L("Test failed, error code %d"), aResult.iResult);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2773
				aResult.iResultDes.Copy( KTestCaseResultFailSkippedEvents() );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2774
				break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2775
			default:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2776
				iLogger->Log(_L("Test failed, error code %d"), aResult.iResult);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2777
				aResult.iResultDes.Copy( KTestCaseResultFail() );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2778
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2779
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2780
		CleanupStack::PopAndDestroy(mEventReportPosition);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2781
		CleanupStack::Pop(reportParams);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2782
		CleanupStack::PopAndDestroy(sndPlayer);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2783
		return aResult.iResult;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2784
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2785
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2786
	else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2787
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2788
		//The file name of the clip to play is missing
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2789
		aResult.iResultDes.Copy(KConfigInvalid());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2790
		aResult.iResult = KErrNotExecuted;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2791
		return KErrConfigInvalid;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2792
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2793
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2794
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2795
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2796
TInt CDRMAudioPlay::TestCasePlayFilesWithPrioritiesL(CStifSectionParser *section , TTestResult &aResult)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2797
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2798
	TPtrC FileNamePtr;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2799
	if ( !section->GetLine(KTagSoundFile, FileNamePtr, ENoTag) )
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2800
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2801
		TInt PriorityLow = EMdaPriorityNormal+1;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2802
		TInt PriorityHigh = EMdaPriorityNormal+20;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2803
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2804
		TBool UsingDefaultPriority;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2805
		PriorityHigh = GetIntL(section, KTagPriority, UsingDefaultPriority, PriorityHigh);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2806
		PriorityLow = GetIntL(section, KTagPriority, UsingDefaultPriority, PriorityLow, ETrue);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2807
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2808
		if (PriorityHigh < PriorityLow)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2809
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2810
			TInt tempPriority = PriorityHigh;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2811
			PriorityHigh = PriorityLow;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2812
			PriorityLow = tempPriority;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2813
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2814
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2815
		TBool UsingDefaultPriorityPreference;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2816
		TInt tmpPrefHigh = GetIntL(section, KTagPriorityPreference, UsingDefaultPriorityPreference, -1);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2817
		TInt tmpPrefLow = GetIntL(section, KTagPriorityPreference, UsingDefaultPriorityPreference, tmpPrefHigh, ETrue);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2818
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2819
		TMdaPriorityPreference prefHigh;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2820
		switch (tmpPrefHigh)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2821
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2822
			case 0:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2823
				prefHigh = EMdaPriorityPreferenceNone; break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2824
			case 1:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2825
				prefHigh = EMdaPriorityPreferenceTime; break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2826
			case 2:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2827
				prefHigh = EMdaPriorityPreferenceQuality; break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2828
			case 3:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2829
			default:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2830
				prefHigh = EMdaPriorityPreferenceTimeAndQuality; break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2831
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2832
		TMdaPriorityPreference prefLow;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2833
		switch (tmpPrefLow)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2834
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2835
			case 0:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2836
				prefLow = EMdaPriorityPreferenceNone; break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2837
			case 1:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2838
				prefLow = EMdaPriorityPreferenceTime; break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2839
			case 2:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2840
				prefLow = EMdaPriorityPreferenceQuality; break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2841
			case 3:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2842
			default:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2843
				prefLow = EMdaPriorityPreferenceTimeAndQuality; break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2844
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2845
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2846
		TFileName FileName = FileNamePtr;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2847
		TObjectCountDown counter;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2848
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2849
		iLogger->Log(_L("Creating playerHigh with file [%S]"), &FileName);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2850
		CSimpleSoundPlayer *sndPlayerHigh = CSimpleSoundPlayer::NewLC( FileName, TestModuleIf() , *iLogger);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2851
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2852
		if ( section->GetNextLine(KTagSoundFile, FileNamePtr, ENoTag) )
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2853
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2854
			iLogger->Log(_L("Second filename not found, using the same file twice"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2855
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2856
		else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2857
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2858
			FileName=FileNamePtr;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2859
			iLogger->Log(_L("Second filename set to [%S]") , &FileName );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2860
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2861
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2862
		// ***************
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2863
		iLogger->Log(_L("Creating playerLow with file [%S]"), &FileName);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2864
		CSimpleSoundPlayer *sndPlayerLow = CSimpleSoundPlayer::NewLC( FileName, TestModuleIf() , *iLogger);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2865
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2866
		iLogger->Log(_L("Setting playerLow priority to (%d)"), PriorityLow);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2867
		sndPlayerLow->SetPriority( PriorityLow, prefLow);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2868
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2869
		iLogger->Log(_L("Setting playerHigh priority to (%d)"), PriorityHigh);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2870
		sndPlayerHigh->SetPriority( PriorityHigh, prefHigh);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2871
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2872
		sndPlayerLow->SetSupervisor(&counter);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2873
		sndPlayerHigh->SetSupervisor(&counter);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2874
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2875
		iLogger->Log(_L("Starting scheduler"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2876
		CActiveScheduler::Start();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2877
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2878
		iLogger->Log(_L("Returned from playerHigh, errorcode: (%d)"), sndPlayerHigh->iFinalError );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2879
		iLogger->Log(_L("Returned from playerLow, errorcode: (%d)"), sndPlayerLow->iFinalError );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2880
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2881
		aResult.iResult = sndPlayerHigh->iFinalError ;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2882
		if (aResult.iResult)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2883
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2884
			iLogger->Log(_L("Test failed, error code %d"), aResult.iResult);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2885
			aResult.iResultDes.Copy(KTestCaseResultFail());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2886
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2887
		else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2888
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2889
			iLogger->Log(_L("Test was successful"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2890
			aResult.iResultDes.Copy(KTestCaseResultSuccess());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2891
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2892
		CleanupStack::PopAndDestroy(sndPlayerLow);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2893
		CleanupStack::PopAndDestroy(sndPlayerHigh);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2894
		return KErrExecuted;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2895
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2896
	else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2897
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2898
		aResult.iResultDes.Copy(KConfigInvalid());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2899
		aResult.iResult = KErrNotExecuted;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2900
		return KErrConfigInvalid;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2901
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2902
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2903
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2904
TInt CDRMAudioPlay::TestCasePlayFilesWithVolumesL(CStifSectionParser *section , TTestResult &aResult)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2905
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2906
	TPtrC FileNamePtr;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2907
	if ( !section->GetLine(KTagSoundFile, FileNamePtr, ENoTag) )
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2908
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2909
		TFileName FileName = FileNamePtr;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2910
		TObjectCountDown counter;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2911
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2912
		CSimpleSoundPlayer *sndPlayerHigh = CSimpleSoundPlayer::NewLC( FileName, TestModuleIf() , *iLogger);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2913
	//	TInt VolumeHigh;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2914
	//	sndPlayerHigh->SetVolume(VolumeHigh=sndPlayerHigh->MaxVolume());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2915
	//	iLogger->Log(_L("Creating player 1 (playerHigh) with file [%S] and volume (%d), max=(%d)"), &FileName, VolumeHigh, sndPlayerHigh->MaxVolume() );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2916
		iLogger->Log(_L("Creating player 1 (playerHigh) with file [%S] "), &FileName);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2917
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2918
		sndPlayerHigh->iPlayVolume = true;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2919
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2920
		if ( section->GetNextLine(KTagSoundFile, FileNamePtr, ENoTag) )
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2921
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2922
			iLogger->Log(_L("Second filename not found, using the same file twice"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2923
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2924
		else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2925
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2926
			FileName=FileNamePtr;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2927
			iLogger->Log(_L("Second filename set to [%S]") , &FileName );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2928
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2929
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2930
		// ***************
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2931
		CSimpleSoundPlayer *sndPlayerLow = CSimpleSoundPlayer::NewLC( FileName , TestModuleIf() , *iLogger , EFalse);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2932
	//	TInt VolumeLow;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2933
	//	sndPlayerLow->SetVolume(VolumeLow=sndPlayerLow->MaxVolume()/2);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2934
	//	iLogger->Log(_L("Creating player 2 (playerLow) with file [%S] and volume (%d), max=(%d)"), &FileName, VolumeLow, sndPlayerLow->MaxVolume() );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2935
		iLogger->Log(_L("Creating player 2 (playerHigh) with file [%S] "), &FileName);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2936
		sndPlayerLow->iPlayVolume = true;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2937
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2938
		CParameters *mPlayParameters = new (ELeave) CParameters( CSimpleSoundPlayer::KPlayerActionPlay );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2939
		CleanupStack::PushL(mPlayParameters);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2940
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2941
		sndPlayerHigh->SetPlayCompleteTarget(sndPlayerLow, mPlayParameters);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2942
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2943
		sndPlayerLow->SetSupervisor(&counter);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2944
		sndPlayerHigh->SetSupervisor(&counter);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2945
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2946
		iLogger->Log(_L("Starting scheduler"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2947
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2948
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2949
		CActiveScheduler::Start();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2950
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2951
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2952
		iLogger->Log(_L("Returned from playerHigh, errorcode: (%d)"), sndPlayerHigh->iFinalError );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2953
		iLogger->Log(_L("Returned from playerLow, errorcode: (%d)"), sndPlayerLow->iFinalError );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2954
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2955
		aResult.iResult = sndPlayerHigh->iFinalError ;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2956
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2957
		if (!sndPlayerHigh->iFinalError && !sndPlayerLow->iFinalError)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2958
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2959
			iLogger->Log(_L("Test was successful"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2960
			aResult.iResultDes.Copy(KTestCaseResultSuccess());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2961
			aResult.iResult = KErrNone;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2962
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2963
		else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2964
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2965
			if (sndPlayerHigh->iFinalError)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2966
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2967
				aResult.iResult = sndPlayerHigh->iFinalError;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2968
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2969
			if (sndPlayerLow->iFinalError)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2970
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2971
				aResult.iResult = sndPlayerLow->iFinalError;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2972
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2973
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2974
			iLogger->Log(_L("Test failed, error code %d"), aResult.iResult);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2975
			aResult.iResultDes.Copy(KTestCaseResultFail());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2976
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2977
		CleanupStack::PopAndDestroy(mPlayParameters);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2978
		CleanupStack::PopAndDestroy(sndPlayerLow);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2979
		CleanupStack::PopAndDestroy(sndPlayerHigh);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2980
		return KErrExecuted;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2981
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2982
	else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2983
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2984
		aResult.iResultDes.Copy(KConfigInvalid());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2985
		aResult.iResult = KErrNotExecuted;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2986
		return KErrConfigInvalid;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2987
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2988
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2989
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2990
TInt CDRMAudioPlay::TestCasePlayUrlL(CStifSectionParser *section , TTestResult &aResult)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2991
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2992
	TPtrC UrlPtr;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2993
	if ( !section->GetLine(KTagSoundUrl, UrlPtr, ENoTag) )
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2994
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2995
		CStifItemParser *item;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2996
		HBufC *Url = UrlPtr.AllocLC();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2997
		TInt IapId = KUseDefaultIap;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2998
		TPtrC MimePtr;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2999
		HBufC *Mime;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3000
		HBufC8 *Mime8;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3001
		if ( ! section->GetLine(KTagMime, MimePtr, ENoTag) )
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3002
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3003
			Mime = MimePtr.AllocLC();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3004
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3005
		else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3006
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3007
			Mime = KNullDesC().AllocLC();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3008
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3009
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3010
		if ( item=section->GetItemLineL(KTagIapId) , item)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3011
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3012
			CleanupStack::PushL(item);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3013
			TInt newVal;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3014
			if ( ! item->GetInt(KTagIapId, newVal) )
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3015
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3016
				IapId = newVal;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3017
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3018
			CleanupStack::PopAndDestroy(item);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3019
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3020
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3021
		Mime8 = HBufC8::NewLC( Mime->Length() );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3022
		TPtr8 Mime8Ptr = Mime8->Des();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3023
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3024
		for (TInt x=0 ; x < Mime->Length() ; x++)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3025
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3026
			//TUint8 tmp8 = (TUint8)( (*Mime)[x]);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3027
			//TBufC8<10> tmp( &tmp8 );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3028
			TUint8 tmp8Array[2] = {0, 0};
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3029
			//tmp8Array[1]=0;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3030
			tmp8Array[0]=(TUint8)( (*Mime)[x] );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3031
			TBufC8<10> tmp( tmp8Array );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3032
			Mime8Ptr += tmp.Left(1);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3033
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3034
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3035
		iLogger->Log(_L("Creating simple player with url [%S], IapId [%d] "), Url, IapId);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3036
		iLogger->Log(_L8("   and MIME Type [%S]L(%d)") , Mime8, Mime8->Length() );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3037
		CSimpleSoundPlayer *sndPlayer = CSimpleSoundPlayer::NewUrlLC( *Url, IapId, *Mime8, TestModuleIf() , *iLogger);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3038
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3039
		iLogger->Log(_L("Starting scheduler"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3040
		CActiveScheduler::Start();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3041
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3042
		iLogger->Log(_L("Returned from player, errorcode: %d"), sndPlayer->iFinalError );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3043
		aResult.iResult = sndPlayer->iFinalError ;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3044
		if (aResult.iResult)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3045
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3046
			iLogger->Log(_L("Test failed, error code %d"), aResult.iResult);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3047
			aResult.iResultDes.Copy(KTestCaseResultFail());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3048
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3049
		else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3050
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3051
			iLogger->Log(_L("Test was successful"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3052
			aResult.iResultDes.Copy(KTestCaseResultSuccess());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3053
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3054
		CleanupStack::PopAndDestroy(sndPlayer);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3055
		CleanupStack::PopAndDestroy(Mime8);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3056
		CleanupStack::PopAndDestroy(Mime);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3057
		CleanupStack::PopAndDestroy(Url);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3058
		return KErrExecuted;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3059
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3060
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3061
	else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3062
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3063
		//The file name of the clip to play is missing
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3064
		aResult.iResultDes.Copy(KConfigInvalid());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3065
		aResult.iResult = KErrNotExecuted;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3066
		return KErrConfigInvalid;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3067
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3068
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3069
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3070
TInt CDRMAudioPlay::TestCasePlayUrlStopOpenL(CStifSectionParser *section , TTestResult &aResult)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3071
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3072
	TPtrC UrlPtr;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3073
	TTimeIntervalMicroSeconds32 StopDelay=KDefaultStopOpenPlayDelay;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3074
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3075
	if ( !section->GetLine(KTagSoundUrl, UrlPtr, ENoTag) )
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3076
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3077
		CStifItemParser *item;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3078
		TInt IapId = KUseDefaultIap;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3079
		TInt IapIdB = KUseDefaultIap;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3080
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3081
		TPtrC MimePtr;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3082
		HBufC *Mime;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3083
		HBufC8 *Mime8;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3084
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3085
		HBufC *MimeB;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3086
		HBufC8 *Mime8B;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3087
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3088
		HBufC *Url = UrlPtr.AllocLC();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3089
		if ( ! section->GetLine(KTagMime, MimePtr, ENoTag) )
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3090
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3091
			Mime = MimePtr.AllocLC();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3092
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3093
		else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3094
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3095
			Mime = KNullDesC().AllocLC();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3096
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3097
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3098
		Mime8 = HBufC8::NewLC( Mime->Length() );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3099
		TPtr8 Mime8Ptr = Mime8->Des();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3100
		TInt x;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3101
		for (x=0 ; x < Mime->Length() ; x++)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3102
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3103
			TUint8 tmp8[2];
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3104
			tmp8[0] = (TUint8)( (*Mime)[x]);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3105
			tmp8[1] = '\0';
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3106
			TBufC8<10> tmp( tmp8 );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3107
			Mime8Ptr += tmp.Left(1);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3108
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3109
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3110
		if ( item=section->GetItemLineL(KTagIapId) , item)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3111
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3112
			CleanupStack::PushL(item);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3113
			TInt newVal;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3114
			if ( ! item->GetInt(KTagIapId, newVal) )
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3115
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3116
				IapId = newVal;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3117
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3118
			CleanupStack::PopAndDestroy(item);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3119
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3120
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3121
		iLogger->Log(_L("Creating simple player with url [%S], IapId [%d] "), Url, IapId);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3122
		iLogger->Log(_L8("   and MIME Type [%S]L(%d)") , Mime8, Mime8->Length() );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3123
		CSimpleSoundPlayer *sndPlayer = CSimpleSoundPlayer::NewUrlLC( *Url, IapId, *Mime8, TestModuleIf() , *iLogger);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3124
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3125
		//*********************************************
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3126
		//Url of second file to play
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3127
		HBufC *UrlB;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3128
		if ( ! section->GetLine(KTagMime, MimePtr, ENoTag) )
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3129
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3130
			MimeB = MimePtr.AllocLC();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3131
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3132
		else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3133
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3134
			MimeB = KNullDesC().AllocLC();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3135
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3136
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3137
		Mime8B = HBufC8::NewLC( MimeB->Length() );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3138
		TPtr8 Mime8PtrB = Mime8B->Des();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3139
		for (x=0 ; x < MimeB->Length() ; x++)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3140
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3141
			TUint8 tmp8B = (TUint8)( (*MimeB)[x]);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3142
			TBufC8<10> tmpB( &tmp8B );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3143
			Mime8PtrB += tmpB.Left(1);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3144
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3145
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3146
		if ( item=section->GetItemLineL(KTagIapId) , item)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3147
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3148
			CleanupStack::PushL(item);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3149
			TInt newValB;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3150
			if ( ! item->GetInt(KTagIapId, newValB) )
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3151
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3152
				IapIdB = newValB;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3153
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3154
			CleanupStack::PopAndDestroy(item);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3155
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3156
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3157
		CUrlParameters *stopParams ;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3158
		if ( section->GetNextLine(KTagSoundUrl, UrlPtr, ENoTag) )
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3159
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3160
			iLogger->Log(_L("Second url not found, using the same file twice"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3161
			UrlB = Url->AllocLC();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3162
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3163
		else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3164
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3165
			iLogger->Log(_L("Second url set to [%S]") , &UrlPtr );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3166
			UrlB = UrlPtr.AllocLC();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3167
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3168
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3169
		stopParams = new(ELeave) CUrlParameters (CSimpleSoundPlayer::KPlayerActionStopPlayUrl, *UrlB, IapIdB, *Mime8B);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3170
		CleanupStack::PushL(stopParams);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3171
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3172
		TBool UsingDefaultDelay=EFalse;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3173
		StopDelay = GetTimeIntervalL(section, KTagDelay, UsingDefaultDelay, (TTimeIntervalMicroSeconds32)KDefaultStopOpenPlayDelay);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3174
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3175
		iLogger->Log(_L("Setting delays to stop and open url to [%d]"), StopDelay.Int());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3176
		//*********************************************
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3177
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3178
		CMediaEvent *mEventStopPlay = CMediaEvent::NewLC(TestModuleIf() , *iLogger, StopDelay, StopDelay, sndPlayer, stopParams);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3179
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3180
		iLogger->Log(_L("Starting scheduler"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3181
		CActiveScheduler::Start();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3182
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3183
		CleanupStack::PopAndDestroy(mEventStopPlay);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3184
		CleanupStack::Pop(stopParams);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3185
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3186
		iLogger->Log(_L("Returned from player, errorcode: %d"), sndPlayer->iFinalError );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3187
		aResult.iResult = sndPlayer->iFinalError;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3188
		if (aResult.iResult)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3189
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3190
			iLogger->Log(_L("Test failed, error code %d"), aResult.iResult);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3191
			aResult.iResultDes.Copy(KTestCaseResultFail());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3192
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3193
		else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3194
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3195
			iLogger->Log(_L("Test was successful"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3196
			aResult.iResultDes.Copy(KTestCaseResultSuccess());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3197
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3198
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3199
		CleanupStack::PopAndDestroy(UrlB);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3200
		CleanupStack::PopAndDestroy(Mime8B);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3201
		CleanupStack::PopAndDestroy(MimeB);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3202
		CleanupStack::PopAndDestroy(sndPlayer);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3203
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3204
		CleanupStack::PopAndDestroy(Mime8);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3205
		CleanupStack::PopAndDestroy(Mime);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3206
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3207
		CleanupStack::PopAndDestroy(Url);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3208
		return KErrExecuted;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3209
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3210
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3211
	else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3212
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3213
		//The file name of the clip to play is missing
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3214
		aResult.iResultDes.Copy(KConfigInvalid());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3215
		aResult.iResult = KErrNotExecuted;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3216
		return KErrConfigInvalid;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3217
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3218
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3219
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3220
// ** Module *****************************************************************
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3221
HBufC8 *CDRMAudioPlay::GetDescriptor8LC(const TFileName &aFileName, CStifSectionParser *section)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3222
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3223
	TInt FileError, SoundSize=0;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3224
	RFile file;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3225
	RFs FsSession;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3226
	HBufC8 *SoundFile;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3227
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3228
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3229
	TInt MimeUsed = 0;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3230
	CStifItemParser *item;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3231
	item = section->GetItemLineL(KTagMime);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3232
	if (item)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3233
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3234
		CleanupStack::PushL(item);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3235
		item->GetInt(KTagMime, MimeUsed) ;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3236
		CleanupStack::PopAndDestroy(item);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3237
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3238
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3239
	iLogger->Log(_L("Connecting to File Server Session") );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3240
	FileError = FsSession.Connect();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3241
	if (FileError)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3242
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3243
		iLogger->Log(_L("File error FsSession.Connect() (%d)") , FileError);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3244
		User::LeaveIfError(FileError);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3245
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3246
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3247
	iLogger->Log(_L("Opening file to get size") );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3248
	FileError = file.Open(FsSession, aFileName, EFileStream);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3249
	if (FileError)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3250
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3251
		iLogger->Log(_L("File error file.Open() (%d)") , FileError);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3252
		User::LeaveIfError(FileError);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3253
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3254
	FileError = file.Size(SoundSize);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3255
	iLogger->Log(_L("File Size (%d)") , SoundSize);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3256
	if (FileError)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3257
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3258
		iLogger->Log(_L("Error getting size") );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3259
		User::LeaveIfError(FileError);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3260
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3261
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3262
//	TPtr8 helper;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3263
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3264
	if (MimeUsed == 1)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3265
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3266
		_LIT(MP3MIME,"zzaudio/mpeg");
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3267
		SoundFile = HBufC8::NewLC(SoundSize+12);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3268
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3269
		TPtr8 helper(SoundFile->Des());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3270
		helper.Append (MP3MIME);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3271
		helper.AppendFill (0x00, 1);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3272
		TPtr8 helper1(&helper[12], SoundSize);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3273
		User::LeaveIfError(file.Read(helper1, SoundSize));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3274
		helper.SetLength (SoundSize+12);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3275
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3276
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3277
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3278
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3279
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3280
	else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3281
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3282
		SoundFile = HBufC8::NewLC(SoundSize);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3283
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3284
	//	TPtr8 helper = SoundFile->Des();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3285
		TPtr8 helper(SoundFile->Des());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3286
	//	FileError = file.Read( helper );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3287
		User::LeaveIfError(file.Read(helper, SoundSize));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3288
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3289
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3290
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3291
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3292
	iLogger->Log(_L("Descriptor length [%d]") , SoundFile->Size() );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3293
	file.Close();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3294
	FsSession.Close();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3295
	return SoundFile;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3296
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3297
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3298
TTimeIntervalMicroSeconds CDRMAudioPlay::GetTimeIntervalL(CStifSectionParser *aSection, const TDesC &aTag, TBool &aUsingDefaults, const TTimeIntervalMicroSeconds &aDefaultInterval)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3299
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3300
	TInt TempInterval1=0 , TempInterval2=0;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3301
	TInt64 tmp=0;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3302
	TInt ParseError=KErrNotFound;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3303
	TTimeIntervalMicroSeconds ReturnValue = aDefaultInterval;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3304
	aUsingDefaults = ETrue;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3305
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3306
	CStifItemParser *item = aSection->GetItemLineL(aTag);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3307
	if (item)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3308
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3309
		CleanupStack::PushL(item);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3310
		ParseError = item->GetInt(aTag, TempInterval1) ;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3311
		if (!ParseError)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3312
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3313
			//First delay found.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3314
			aUsingDefaults = EFalse;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3315
			tmp = TempInterval1*1000000;	//convert from seconds to microseconds
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3316
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3317
			if ( ! item->GetNextInt(TempInterval2) )
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3318
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3319
				tmp += TempInterval2*1000;	//add miliseconds
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3320
				if ( ! item->GetNextInt(TempInterval2) )
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3321
					{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3322
					tmp += TempInterval2;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3323
					}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3324
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3325
			ReturnValue = tmp;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3326
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3327
		CleanupStack::PopAndDestroy(item);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3328
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3329
	if (ParseError) {iLogger->Log(_L("Error retrieving interval, [%S] not found"), &aTag);}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3330
	iLogger->Log(_L("Interval retrieved: (%d)") , ReturnValue.Int64());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3331
	return ReturnValue;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3332
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3333
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3334
	/*TTimeIntervalMicroSeconds CDRMAudioPlay::GetDelayL(CStifSectionParser *aSection, const TDesC &aTag)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3335
{return 0;}*/
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3336
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3337
TTimeIntervalMicroSeconds32 CDRMAudioPlay::GetTimeIntervalL(CStifSectionParser *aSection, const TDesC &aTag, TBool &aUsingDefault, const TTimeIntervalMicroSeconds32 &aDefaultDelay)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3338
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3339
	TInt ParseError=KErrNotFound;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3340
	TInt TempDelay=0;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3341
	TTimeIntervalMicroSeconds32 ReturnValue=aDefaultDelay;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3342
	CStifItemParser *item = aSection->GetItemLineL(aTag);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3343
	if (item)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3344
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3345
		CleanupStack::PushL(item);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3346
		ParseError = item->GetInt(aTag, TempDelay) ;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3347
		if (ParseError)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3348
			{	//Delay not found, using defaults
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3349
			aUsingDefault=ETrue;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3350
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3351
		else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3352
			{	//Delay found.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3353
			aUsingDefault=EFalse;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3354
			ReturnValue=TempDelay;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3355
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3356
		CleanupStack::PopAndDestroy(item);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3357
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3358
		if (ParseError) {iLogger->Log(_L("Error retrieving report delay, [%S] not found") , &aTag);}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3359
	return ReturnValue;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3360
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3361
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3362
TInt CDRMAudioPlay::RunTestCaseFunctionL(TInt id , CStifSectionParser *section , TTestResult &aResult)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3363
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3364
	switch (id)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3365
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3366
		case KCasePlayFile:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3367
			return TestCasePlayFileL(section, aResult);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3368
		case KCasePlayFileWithRamp:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3369
			return TestCasePlayFileWithVolumeRampL(section, aResult);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3370
		case KCasePlayFileWithRepeats:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3371
			return TestCasePlayFileWithRepeatsL(section, aResult);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3372
		case KCasePlayFileWithPause:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3373
			return TestCasePlayFileWithPauseL(section, aResult);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3374
		case KCasePlayFileWithPosition:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3375
			return TestCasePlayFileWithPositionL(section, aResult);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3376
		case KCasePlayFileWithBalance:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3377
			return TestCasePlayFileWithBalanceL(section, aResult);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3378
		case KCasePlayFileStopOpen:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3379
			return TestCasePlayFileStopOpenL(section, aResult);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3380
		case KCasePlayFileReportDuration:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3381
			return TestCasePlayFileReportDurationL(section, aResult);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3382
        case KCasePlayFileMaxVolume:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3383
            return TestCasePlayFileMaxVolumeL(section, aResult);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3384
        case KCasePlayFileSetVolume:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3385
            return TestCasePlayFileSetVolumeL(section, aResult);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3386
        case KCasePlayFileSetBalance:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3387
            return TestCasePlayFileSetBalanceL(section, aResult);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3388
        case KCasePlayFileGetBalance:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3389
            return TestCasePlayFileGetBalanceL(section, aResult);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3390
        case KCasePlayFileGetBitRate:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3391
            return TestCasePlayFileGetBitRateL(section, aResult);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3392
        case KCasePlayFileSetPriority:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3393
            return TestCasePlayFileSetPriorityL(section, aResult);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3394
        case KCasePlayFileSetRepeats:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3395
        	return TestCasePlayFileSetRepeatsL(section, aResult);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3396
        case KCasePlayFileReportPosition:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3397
			return TestCasePlayFileReportPositionL(section, aResult);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3398
		case KCasePlayFileWindow:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3399
			return TestCasePlayFileWindowL(section, aResult);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3400
		case KCasePlayFileClearWindow:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3401
			return TestCasePlayFileWindowClearL(section, aResult);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3402
		case KCasePlayFilesWithPriorities:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3403
			return TestCasePlayFilesWithPrioritiesL(section, aResult);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3404
		case KCasePlayFilesWithVolumes:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3405
			return TestCasePlayFilesWithVolumesL(section, aResult);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3406
        case KCasePlayFilesGetMetaDataEntry:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3407
            return TestCasePlayFilesGetMetaDataEntryL(section, aResult);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3408
        case KCasePlayFilesGetNumberOfMetaDataEntries:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3409
            return TestCasePlayFilesGetNumberOfMetaDataEntriesL(section, aResult);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3410
		case KCasePlayDes:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3411
			return TestCasePlayDesL(section, aResult);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3412
		case KCasePlayDesStopOpen:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3413
			return TestCasePlayDesStopOpenL(section, aResult);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3414
		case KCasePlayUrl:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3415
			return TestCasePlayUrlL(section, aResult);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3416
		case KCasePlayUrlStopOpen:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3417
			return TestCasePlayUrlStopOpenL(section, aResult);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3418
		case KCasePlayFileMetaInfo:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3419
			return TestCasePlayFileMetaInfoL(section, aResult);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3420
		case KCaseImplementationInformation:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3421
			return TestCasePlayFileFormatsL(section, aResult);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3422
		case KCasePlayHandler:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3423
			return TestCasePlayHandlerL(section, aResult);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3424
		case KCasePlayHandlerStopOpen:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3425
			return TestCasePlayHandlerStopOpenL(section, aResult);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3426
		case KCasePlayHandlerWithPause:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3427
			return TestCasePlayHandlerWithPauseL(section, aResult);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3428
		case KCasePlayFileHandlerWithRamp:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3429
			return TestCasePlayHandlerWithRampL(section, aResult);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3430
		case KCasePlayFileHandlerWithSetPosition:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3431
			return TestCasePlayHandlerWithSetPositionL(section, aResult);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3432
		case KCasePlayFileHandlerWithGetPosition:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3433
			return TestCasePlayHandlerWithGetPositionL(section, aResult);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3434
		case KCasePlayFileHandlerWithDuration:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3435
			return TestCasePlayHandlerWithDurationL(section, aResult);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3436
		case KCasePlayFileHandlerWithWindow:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3437
			return TestCasePlayHandlerWithWindowL(section, aResult);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3438
		case KCasePlayFileHandlerWithClearWindow:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3439
			return TestCasePlayHandlerWithClearWindowL(section, aResult);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3440
		case KCasePlayFileGetAudioLoadingProgress:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3441
			return TestCasePlayFilesGetAudioLoadingProgress(section, aResult);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3442
		case KCasePlayFileRegisterForAudioLoadingNotification:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3443
			return TestCasePlayFilesRegisterForAudioLoadingNotification(section, aResult);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3444
		case KCasePlayFileImplementationInformation:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3445
			return TestCasePlayFilesImplementationInformation(section, aResult);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3446
		case KCasePlayRepeatDRMFile:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3447
            return TestCasePlayRepeatDRMFile(section, aResult);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3448
        case KCasePlayPauseRepeatDRMFile:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3449
            return TestCasePlayPauseRepeatDRMFile(section, aResult);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3450
        case KCasePlayRepeatDRMFileForever:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3451
            return TestCasePlayRepeatDRMFileForever(section, aResult);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3452
        case KCasePlayRepeatDRMFileWithPlayWindow:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3453
            return TestCasePlayRepeatDRMFileWithPlayWindow(section, aResult);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3454
        case KCasePlayPauseRepeatDRMFileWithPlayWindow:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3455
            return TestCasePlayPauseRepeatDRMFileWithPlayWindow(section, aResult);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3456
        case KCasePlayRepeatForeverDRMFileWithPlayWindow:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3457
            return TestCasePlayRepeatForeverDRMFileWithPlayWindow(section, aResult);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3458
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3459
	aResult.iResultDes.Copy(KConfigInvalid());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3460
	aResult.iResult = KErrNotExecuted;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3461
	return KErrConfigInvalid;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3462
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3463
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3464
TBool CDRMAudioPlay::IsDurationInRange
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3465
	(	TInt aRepeatTimes, TTimeIntervalMicroSeconds aToneDuration, TTimeIntervalMicroSeconds aRepeatSilence,
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3466
		TTimeIntervalMicroSeconds aErrorRange , TTime aStartTime , TTime aEndTime )
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3467
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3468
	TInt64 tmp=aToneDuration.Int64();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3469
	TInt64 tmp2=aRepeatSilence.Int64();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3470
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3471
	tmp*=(aRepeatTimes+1);  tmp2*=(aRepeatTimes);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3472
	TTimeIntervalMicroSeconds ExpectedDuration = tmp+tmp2;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3473
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3474
	TTime EndTimeRange1 = aStartTime;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3475
	EndTimeRange1+= ExpectedDuration;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3476
	TTime EndTimeRange2 = EndTimeRange1;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3477
	EndTimeRange1-=aErrorRange;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3478
	EndTimeRange2+=aErrorRange;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3479
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3480
	iLogger->Log(_L("Actual play duration (%d)") , (aEndTime.MicroSecondsFrom(aStartTime)).Int64() );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3481
	iLogger->Log(_L("Expected duration (%d)") , ExpectedDuration.Int64());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3482
	iLogger->Log(_L("Error range (%d)") , aErrorRange.Int64());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3483
	return (EndTimeRange1<aEndTime && aEndTime<EndTimeRange2) ;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3484
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3485
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3486
void CDRMAudioPlay::TestCasePreCheck(CStifSectionParser *section, TFileName& aFileName)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3487
    {
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3488
    TPtrC FileNamePtr;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3489
    TPtrC RightsPtr;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3490
    RFs rightsFs;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3491
    RFile rightsFile;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3492
    RFs contentFs;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3493
    RFile contentFile;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3494
    if (( ! section->GetLine(KTagSoundFile, FileNamePtr, ENoTag) ) && ( ! section->GetLine(KTagRightsFile, RightsPtr, ENoTag) ))
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3495
        {
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3496
        User::LeaveIfError(rightsFs.Connect());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3497
        rightsFs.ShareProtected();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3498
        TFileName rightsFileName = RightsPtr;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3499
        iLogger->Log(_L("Rights file location [%S] "), &rightsFileName);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3500
        if (! BaflUtils::FileExists(rightsFs, rightsFileName))
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3501
            {
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3502
            iLogger->Log(_L("Rights file [%S] doesn't exits !!! "), &rightsFileName);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3503
            User::Leave(KErrNotFound);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3504
            }
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3505
#ifdef __WINSCW__
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3506
        // copy the DRM rights file to the destination folder (\private\DRM_AGENT_SID\Import) only for WINSCW
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3507
        if (! BaflUtils::PathExists(rightsFs, KTagOMADRMRightsDir))
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3508
            {
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3509
            TRAPD(err, rightsFs.MkDirAll(KTagOMADRMRightsDir));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3510
            if ((err != KErrNone) && (err != KErrAlreadyExists))
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3511
                {
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3512
                iLogger->Log(_L("Unable to create the path [%S] Err[%d]"), &KTagOMADRMRightsDir, err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3513
                User::Leave(err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3514
                }
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3515
            }
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3516
        iLogger->Log(_L("Copying Rights file [%S] to [%S] "),&rightsFileName, &KTagOMADRMRightsDir);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3517
        BaflUtils::CopyFile(rightsFs, rightsFileName, KTagOMADRMRightsDir);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3518
#endif        
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3519
        rightsFs.Close();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3520
        User::LeaveIfError(rightsFs.Connect());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3521
        rightsFs.ShareProtected();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3522
        User::LeaveIfError(rightsFile.Open( rightsFs, rightsFileName, EFileRead));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3523
        HBufC8* rContent = HBufC8::NewL(2048);      // incase the drm rights file size is more than 2kb then this size must be altered accordingly
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3524
        CleanupStack::PushL(rContent);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3525
        TPtr8 rightsContentPtr = rContent->Des();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3526
        rightsFile.Read(rightsContentPtr);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3527
        ProcessRightsL(rightsContentPtr);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3528
        CleanupStack::PopAndDestroy(rContent);  // HBufC8*
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3529
        rightsFile.Close();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3530
        rightsFs.Close();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3531
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3532
        // copy the DRM content file to the destination folder (\private\DRM_AGENT_SID\DRM_AGENT_NAME)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3533
        User::LeaveIfError(contentFs.Connect());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3534
        contentFs.ShareProtected();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3535
        TFileName contentFileName = FileNamePtr;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3536
        iLogger->Log(_L("Audio file location [%S] "), &contentFileName);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3537
        if (! BaflUtils::FileExists(contentFs, contentFileName))
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3538
            {
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3539
            iLogger->Log(_L("Content file [%S] doesn't exits !!! "), &contentFileName);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3540
            User::Leave(KErrNotFound);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3541
            }
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3542
        if (! BaflUtils::PathExists(contentFs, KTagOMADRMContentDir))
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3543
            {
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3544
            TRAPD(err, contentFs.MkDirAll(KTagOMADRMContentDir));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3545
            if ((err != KErrNone) && (err != KErrAlreadyExists))
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3546
                {
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3547
                iLogger->Log(_L("Unable to create the path [%S] Err[%d]"), &KTagOMADRMContentDir, err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3548
                User::Leave(err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3549
                }
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3550
            }
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3551
        iLogger->Log(_L("Copying Content file [%S] to [%S] "),&contentFileName, &KTagOMADRMContentDir);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3552
        BaflUtils::CopyFile(contentFs, contentFileName, KTagOMADRMContentDir);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3553
        contentFs.Close();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3554
        User::LeaveIfError(contentFs.Connect());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3555
        contentFs.ShareProtected();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3556
        User::LeaveIfError(contentFile.Open( contentFs, contentFileName, EFileRead));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3557
        TFileName contentFileNameWithExt;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3558
        contentFile.Name(contentFileNameWithExt);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3559
        aFileName.Append(KTagOMADRMContentDir);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3560
        aFileName.Append(contentFileNameWithExt);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3561
        iLogger->Log(_L("contentFileNameWithExt [%S]"), &contentFileNameWithExt);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3562
        contentFile.Close();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3563
        contentFs.Close();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3564
        iDRMPreCheckPassed = ETrue;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3565
        }
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3566
    else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3567
        {
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3568
        iDRMPreCheckPassed = EFalse;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3569
        }
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3570
    }
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3571
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3572
_LIT(KDirectoryPath, "C:\\private\\12345678\\");
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3573
void CDRMAudioPlay::ProcessRightsL(const TDesC8& aRightsXMLContent)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3574
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3575
    iLogger->Log(_L("ProcessRightsL <==="));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3576
	TInt err = KErrNone;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3577
	TFileName fileName;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3578
	TPath outputFileName;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3579
	CSupplier *mySupplier = CSupplier::NewL();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3580
	CleanupStack::PushL(mySupplier);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3581
	iLogger->Log(_L("ProcessRightsL: Supplier created ... "));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3582
	CMetaDataArray* metaDataArray = CMetaDataArray::NewL();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3583
	iLogger->Log(_L("ProcessRightsL: MetaDataArray created ... "));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3584
	CleanupStack::PushL(metaDataArray);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3585
	metaDataArray->AddL(_L("Content Type"),_L("application/vnd.oma.drm.rights+xml")); 
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3586
	// Create the import object
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3587
	CImportFile* import = mySupplier->ImportFileL(KOma1XmlRoContentType, *metaDataArray);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3588
	iLogger->Log(_L("ProcessRightsL: ImportFile created ... "));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3589
	CleanupStack::PushL(import);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3590
	err = import->WriteData(aRightsXMLContent);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3591
	iLogger->Log(_L("ProcessRightsL: Wrote the rightsfile to ImportData err[%d] "), err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3592
	while(err == KErrCANewFileHandleRequired)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3593
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3594
        iLogger->Log(_L("ProcessRightsL:  KErrCANewFileHandleRequired"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3595
        RFs  newfs; 
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3596
		RFile newFile;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3597
		User::LeaveIfError(newfs.Connect());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3598
		import->GetSuggestedOutputFileName(fileName);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3599
		outputFileName.Copy(KDirectoryPath);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3600
		outputFileName.Append(fileName);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3601
		newFile.Open(newfs, outputFileName, EFileWrite);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3602
		err = import->ContinueWithNewOutputFile(newFile, outputFileName);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3603
		newFile.Close(); // agent makes a copy so we don't need to keep our file handle
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3604
		newfs.Close();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3605
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3606
	iLogger->Log(_L("ProcessRightsL:  Error after the Writing ImportFile [%d]"), err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3607
	// tell CAF (and hence the agent) it's now got the entire file
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3608
	if (err == KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3609
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3610
		err = import->WriteDataComplete();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3611
		iLogger->Log(_L("ProcessRightsL:  Error after the ImportFile WriteDataComplete [%d]"), err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3612
		if (err == KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3613
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3614
			// Look at the output of the import operation
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3615
			for(TInt i = 0; i < import->OutputFileCountL(); i++)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3616
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3617
				// for this example only add content output files
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3618
				// (absorb any rights in the original attachment 'silently')
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3619
				if(import->OutputFileL(i).OutputType() == EContent)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3620
					{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3621
					// Add file to list of attachments for this message
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3622
                    iLogger->Log(_L("FileName [%S]"),(import->OutputFileL(i).FileName().Ptr()));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3623
					}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3624
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3625
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3626
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3627
		// Error handling
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3628
		if (err != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3629
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3630
			if (err == KErrNotReady)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3631
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3632
                iLogger->Log(_L("Agent not ready for import"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3633
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3634
			else if (err == KErrCACorruptContent)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3635
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3636
                iLogger->Log(_L("Content data is corrupt"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3637
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3638
			else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3639
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3640
                iLogger->Log(_L("Unexpected error: %d"), err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3641
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3642
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3643
			// Finished
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3644
	CleanupStack::PopAndDestroy(3);         // mySupplier, metaDataArray, import
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3645
	iLogger->Log(_L("ProcessRightsL ===>"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3646
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3647
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3648
TInt CDRMAudioPlay::TestCasePlayRepeatDRMFile(CStifSectionParser *section , TTestResult &aResult)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3649
    {
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3650
    TTimeIntervalMicroSeconds32 ReportDelay = KDefaultReportDelay;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3651
    TTimeIntervalMicroSeconds repeatSilenceTimer = KDefaultSilenceDuration;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3652
    TInt repeatCount = 0;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3653
    TFileName fileName;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3654
    iDRMPreCheckPassed = EFalse;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3655
    TestCasePreCheck(section, fileName);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3656
    if (iDRMPreCheckPassed)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3657
        {
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3658
        TBool UsingRepeatCountDefault, UsingRepeatSilencerDefault;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3659
        repeatCount = GetIntL(section, KTagRepeatTimes, UsingRepeatCountDefault, KDefaultRepeats);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3660
        repeatSilenceTimer = GetTimeIntervalL(section, KTagSilenceDuration, UsingRepeatSilencerDefault, KDefaultSilenceDuration);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3661
        iLogger->Log(_L("Repeat count [%d] Silence timer [%d]"), repeatCount, I64LOW(repeatSilenceTimer.Int64()));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3662
        User::LeaveIfError(iFs.Connect());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3663
        iFs.ShareProtected();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3664
        User::LeaveIfError(iFile.Open( iFs, fileName, EFileRead));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3665
        iLogger->Log(_L("Creating simple player with file [%S]"), &fileName);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3666
        CSimpleSoundPlayer *sndPlayer = CSimpleSoundPlayer::NewL( iFile, TestModuleIf() , *iLogger);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3667
        CleanupStack::PushL(sndPlayer);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3668
        sndPlayer->iDontPlayAudioClip = ETrue; // don't start the play back after initialize complete
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3669
        CActiveScheduler::Start();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3670
        sndPlayer->SetRepeats(repeatCount, TTimeIntervalMicroSeconds(repeatSilenceTimer));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3671
        sndPlayer->SetVolumeRamp(100000);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3672
        sndPlayer->Play(); // Start the playback
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3673
        iLogger->Log(_L("Starting scheduler"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3674
        CActiveScheduler::Start();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3675
        iLogger->Log(_L("Returned from player, errorcode: %d"), sndPlayer->iFinalError );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3676
        aResult.iResult = sndPlayer->iFinalError;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3677
        sndPlayer->SetRepeats(0,0);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3678
        if ((aResult.iResult != KErrNone) && (aResult.iResult != KErrCANoRights))
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3679
            {
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3680
            iLogger->Log(_L("Test failed, error code %d"), aResult.iResult);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3681
            aResult.iResultDes.Copy(KTestCaseResultFail());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3682
            }
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3683
        else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3684
            {
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3685
            iLogger->Log(_L("Test was successful"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3686
            if (aResult.iResult == KErrCANoRights)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3687
                aResult.iResult = KErrNone;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3688
            aResult.iResultDes.Copy(KTestCaseResultSuccess());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3689
            }
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3690
        iFile.Close();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3691
        iFs.Close();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3692
        CleanupStack::PopAndDestroy(sndPlayer);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3693
        return KErrExecuted;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3694
        }
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3695
    else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3696
        {
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3697
        aResult.iResultDes.Copy(KConfigInvalid());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3698
        aResult.iResult = KErrNotExecuted;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3699
        iFs.Close();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3700
        return KErrConfigInvalid;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3701
        }
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3702
    }
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3703
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3704
TInt CDRMAudioPlay::TestCasePlayPauseRepeatDRMFile(CStifSectionParser *section , TTestResult &aResult)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3705
    {
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3706
    TTimeIntervalMicroSeconds32 ReportDelay = KDefaultReportDelay;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3707
    TInt repeatCount = 0;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3708
    TTimeIntervalMicroSeconds repeatSilenceTimer = KDefaultSilenceDuration;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3709
    TTimeIntervalMicroSeconds32 PauseDelay=KDefaultPauseDelay;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3710
    TTimeIntervalMicroSeconds32 PlayDelay=KDefaultPlayDelay;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3711
    TFileName fileName;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3712
    iDRMPreCheckPassed = EFalse;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3713
    TestCasePreCheck(section, fileName);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3714
    if (iDRMPreCheckPassed)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3715
        {
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3716
        TBool UsingRepeatCountDefault, UsingRepeatSilencerDefault, UsingDefault;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3717
        repeatCount = GetIntL(section, KTagRepeatTimes, UsingRepeatCountDefault, KDefaultRepeats);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3718
        repeatSilenceTimer = GetTimeIntervalL(section, KTagSilenceDuration, UsingRepeatSilencerDefault, KDefaultSilenceDuration);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3719
        iLogger->Log(_L("Repeat count [%d] Silence timer [%d]"), repeatCount, I64LOW(repeatSilenceTimer.Int64()));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3720
        User::LeaveIfError(iFs.Connect());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3721
        iFs.ShareProtected();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3722
        User::LeaveIfError(iFile.Open( iFs, fileName, EFileRead));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3723
        iLogger->Log(_L("Creating simple player with file [%S]"), &fileName);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3724
        CSimpleSoundPlayer *sndPlayer = CSimpleSoundPlayer::NewL( iFile, TestModuleIf() , *iLogger);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3725
        CleanupStack::PushL(sndPlayer);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3726
        PauseDelay = GetTimeIntervalL(section, KTagPauseDelay, UsingDefault, (TTimeIntervalMicroSeconds32)KDefaultPauseDelay);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3727
        if (UsingDefault) {iLogger->Log(_L("Error retrieving pause delay, using default"));}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3728
        PlayDelay = GetTimeIntervalL(section, KTagPlayDelay, UsingDefault, (TTimeIntervalMicroSeconds32)KDefaultPlayDelay);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3729
        if (UsingDefault) {iLogger->Log(_L("Error retrieving play delay, using default"));}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3730
        iLogger->Log(_L("Setting Pause and Play delays to [%d] and [%d]"), PauseDelay.Int(), PlayDelay.Int());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3731
        sndPlayer->SetRepeats(repeatCount, TTimeIntervalMicroSeconds(repeatSilenceTimer));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3732
        sndPlayer->SetVolumeRamp(100000);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3733
        sndPlayer->iDontPlayAudioClip = ETrue; // don't start the play back after initialize complete
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3734
        iLogger->Log(_L("Starting scheduler"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3735
        CActiveScheduler::Start(); // initialize the player and wait for the intialize complete event
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3736
        TTimeIntervalMicroSeconds dur = sndPlayer->GetDuration();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3737
        sndPlayer->Play(); // Start the loop play in the play window
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3738
        /*********************************************/
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3739
        /* For generating the Pause event during playback */
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3740
        /*********************************************/
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3741
        TTimeIntervalMicroSeconds32 interval = TTimeIntervalMicroSeconds32(dur.Int64() + repeatSilenceTimer.Int64() + (PlayDelay.Int() - PauseDelay.Int()));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3742
        CParameters *pauseParams = new (ELeave) CParameters( CSimpleSoundPlayer::KPlayerActionPause );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3743
        CleanupStack::PushL(pauseParams);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3744
        CParameters *playParams = new (ELeave) CParameters( CSimpleSoundPlayer::KPlayerActionPlay );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3745
        CleanupStack::PushL(playParams);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3746
        CMediaEvent* mEventPause = CMediaEvent::NewLC(TestModuleIf() , *iLogger, PauseDelay, interval, sndPlayer, pauseParams);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3747
        CMediaEvent* mEventPlay = CMediaEvent::NewLC(TestModuleIf() , *iLogger, PlayDelay, interval, sndPlayer, playParams);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3748
        CActiveScheduler::Start(); // start the playback in the play window and loop play
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3749
        sndPlayer->SetRepeats(0,0);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3750
        iLogger->Log(_L("Returned from player, errorcode: %d"), sndPlayer->iFinalError );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3751
        aResult.iResult = sndPlayer->iFinalError;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3752
        if ((aResult.iResult != KErrNone) && (aResult.iResult != KErrCANoRights))
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3753
            {
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3754
            iLogger->Log(_L("Test failed, error code %d"), aResult.iResult);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3755
            aResult.iResultDes.Copy(KTestCaseResultFail());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3756
            }
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3757
        else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3758
            {
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3759
            iLogger->Log(_L("Test was successful"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3760
            if (aResult.iResult == KErrCANoRights)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3761
                aResult.iResult = KErrNone;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3762
            aResult.iResultDes.Copy(KTestCaseResultSuccess());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3763
            }
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3764
        iFile.Close();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3765
        iFs.Close();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3766
        CleanupStack::PopAndDestroy(mEventPlay);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3767
        CleanupStack::PopAndDestroy(mEventPause);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3768
        CleanupStack::Pop(playParams);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3769
        CleanupStack::Pop(pauseParams);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3770
        CleanupStack::PopAndDestroy(sndPlayer);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3771
        return KErrExecuted;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3772
        }
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3773
    else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3774
        {
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3775
        aResult.iResultDes.Copy(KConfigInvalid());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3776
        aResult.iResult = KErrNotExecuted;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3777
        return KErrConfigInvalid;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3778
        }
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3779
    }
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3780
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3781
TInt CDRMAudioPlay::TestCasePlayRepeatDRMFileForever(CStifSectionParser *section , TTestResult &aResult)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3782
    {
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3783
    TTimeIntervalMicroSeconds32 ReportDelay = KDefaultReportDelay;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3784
    TInt repeatCount = 0;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3785
    TTimeIntervalMicroSeconds repeatSilenceTimer = 0;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3786
    TFileName fileName;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3787
    iDRMPreCheckPassed = EFalse;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3788
    TestCasePreCheck(section, fileName);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3789
   if (iDRMPreCheckPassed)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3790
        {
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3791
        TBool UsingRepeatCountDefault, UsingRepeatSilencerDefault;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3792
        User::LeaveIfError(iFs.Connect());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3793
        iFs.ShareProtected();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3794
        User::LeaveIfError(iFile.Open( iFs, fileName, EFileRead));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3795
        iLogger->Log(_L("Creating simple player with file [%S]"), &fileName);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3796
        CSimpleSoundPlayer *sndPlayer = CSimpleSoundPlayer::NewL( iFile, TestModuleIf() , *iLogger);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3797
        CleanupStack::PushL(sndPlayer);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3798
        repeatCount = GetIntL(section, KTagRepeatTimes, UsingRepeatCountDefault, KDefaultRepeats);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3799
        if (repeatCount != KDefaultRepeatForever)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3800
            repeatCount = KDefaultRepeatForever;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3801
        repeatSilenceTimer = GetTimeIntervalL(section, KTagSilenceDuration, UsingRepeatSilencerDefault, (TTimeIntervalMicroSeconds)KDefaultSilenceDuration);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3802
        sndPlayer->SetRepeats(repeatCount, repeatSilenceTimer);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3803
        sndPlayer->SetVolumeRamp(100000);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3804
        CActiveScheduler::Start();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3805
        iLogger->Log(_L("Returned from player, errorcode: %d"), sndPlayer->iFinalError );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3806
        aResult.iResult = sndPlayer->iFinalError;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3807
        sndPlayer->SetRepeats(0,0);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3808
        CleanupStack::PopAndDestroy(sndPlayer);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3809
        if ((aResult.iResult != KErrNone) && (aResult.iResult != KErrCANoRights))
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3810
            {
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3811
            iLogger->Log(_L("Test failed, error code %d"), aResult.iResult);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3812
            aResult.iResultDes.Copy(KTestCaseResultFail());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3813
            }
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3814
        else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3815
            {
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3816
            iLogger->Log(_L("Test was successful"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3817
            if (aResult.iResult == KErrCANoRights)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3818
                aResult.iResult = KErrNone;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3819
            aResult.iResultDes.Copy(KTestCaseResultSuccess());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3820
            }
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3821
        iFile.Close();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3822
        iFs.Close();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3823
        return KErrExecuted;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3824
        }
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3825
    else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3826
        {
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3827
        aResult.iResultDes.Copy(KConfigInvalid());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3828
        aResult.iResult = KErrNotExecuted;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3829
        return KErrConfigInvalid;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3830
        }
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3831
    }
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3832
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3833
TInt CDRMAudioPlay::TestCasePlayRepeatDRMFileWithPlayWindow(CStifSectionParser *section , TTestResult &aResult)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3834
    {
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3835
    TTimeIntervalMicroSeconds startPosition = KDefaultPosition;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3836
    TTimeIntervalMicroSeconds endPosition = KDefaultPosition;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3837
    TTimeIntervalMicroSeconds32 ReportDelay = KDefaultReportDelay;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3838
    TInt repeatCount = 0;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3839
    TTimeIntervalMicroSeconds repeatSilenceTimer = 0;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3840
    TFileName fileName;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3841
    iDRMPreCheckPassed = EFalse;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3842
    TestCasePreCheck(section, fileName);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3843
    if (iDRMPreCheckPassed)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3844
        {
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3845
        TBool UsingStartDefault, UsingEndDefault, UsingRepeatCountDefault, UsingRepeatSilencerDefault;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3846
        User::LeaveIfError(iFs.Connect());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3847
        iFs.ShareProtected();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3848
        User::LeaveIfError(iFile.Open( iFs, fileName, EFileRead));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3849
        iLogger->Log(_L("Creating simple player with file [%S]"), &fileName);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3850
        CSimpleSoundPlayer *sndPlayer = CSimpleSoundPlayer::NewL( iFile, TestModuleIf() , *iLogger);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3851
        CleanupStack::PushL(sndPlayer);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3852
        repeatCount = GetIntL(section, KTagRepeatTimes, UsingRepeatCountDefault, KDefaultRepeats);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3853
        repeatSilenceTimer = GetTimeIntervalL(section, KTagSilenceDuration, UsingRepeatSilencerDefault, (TTimeIntervalMicroSeconds)KDefaultSilenceDuration);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3854
        startPosition = GetTimeIntervalL(section, KTagWindowStart, UsingStartDefault, (TTimeIntervalMicroSeconds)(KDefaultPosition.Int64()-1E6));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3855
        endPosition = GetTimeIntervalL(section, KTagWindowEnd, UsingEndDefault, (TTimeIntervalMicroSeconds)(KDefaultPosition.Int64()+1E6));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3856
        // sndPlayer->iDontPlayAudioClip = ETrue; // don't start the play back after initialize complete
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3857
        iLogger->Log(_L("Starting scheduler"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3858
        sndPlayer->SetRepeats(repeatCount, repeatSilenceTimer);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3859
        sndPlayer->SetVolumeRamp(100000);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3860
        sndPlayer->iPlayWindow = ETrue;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3861
        sndPlayer->iStartPosition = startPosition;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3862
        sndPlayer->iEndPosition = endPosition;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3863
        iLogger->Log(_L("Starting scheduler"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3864
        CActiveScheduler::Start(); // initialize the player and wait for the intialize complete event
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3865
        iLogger->Log(_L("Returned from player, errorcode: %d"), sndPlayer->iFinalError );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3866
        aResult.iResult = sndPlayer->iFinalError;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3867
        sndPlayer->SetRepeats(0,0);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3868
        sndPlayer->iPlayWindow = EFalse;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3869
        sndPlayer->ClearPlayWindow();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3870
        CleanupStack::PopAndDestroy(sndPlayer);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3871
        if ((aResult.iResult != KErrNone) && (aResult.iResult != KErrCANoRights))
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3872
            {
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3873
            iLogger->Log(_L("Test failed, error code %d"), aResult.iResult);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3874
            aResult.iResultDes.Copy(KTestCaseResultFail());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3875
            }
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3876
        else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3877
            {
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3878
            iLogger->Log(_L("Test was successful"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3879
            if (aResult.iResult == KErrCANoRights)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3880
                aResult.iResult = KErrNone;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3881
            aResult.iResultDes.Copy(KTestCaseResultSuccess());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3882
            }
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3883
        iFile.Close();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3884
        iFs.Close();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3885
        return KErrExecuted;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3886
        }
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3887
    else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3888
        {
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3889
        aResult.iResultDes.Copy(KConfigInvalid());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3890
        aResult.iResult = KErrNotExecuted;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3891
        return KErrConfigInvalid;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3892
        }
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3893
    }
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3894
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3895
TInt CDRMAudioPlay::TestCasePlayPauseRepeatDRMFileWithPlayWindow(CStifSectionParser *section , TTestResult &aResult)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3896
    {
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3897
    TTimeIntervalMicroSeconds startPosition = KDefaultPosition;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3898
    TTimeIntervalMicroSeconds endPosition = KDefaultPosition;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3899
    TTimeIntervalMicroSeconds32 ReportDelay = KDefaultReportDelay;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3900
    TTimeIntervalMicroSeconds32 PauseDelay=KDefaultPauseDelay;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3901
    TTimeIntervalMicroSeconds32 PlayDelay=KDefaultPlayDelay;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3902
    TInt repeatCount = 0;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3903
    TTimeIntervalMicroSeconds repeatSilenceTimer = 0;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3904
    TFileName fileName;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3905
    iDRMPreCheckPassed = EFalse;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3906
    TestCasePreCheck(section, fileName);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3907
    if (iDRMPreCheckPassed)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3908
        {
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3909
        TBool UsingStartDefault, UsingEndDefault, UsingRepeatCountDefault, UsingRepeatSilencerDefault, UsingDefault;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3910
        User::LeaveIfError(iFs.Connect());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3911
        iFs.ShareProtected();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3912
        User::LeaveIfError(iFile.Open( iFs, fileName, EFileRead));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3913
        iLogger->Log(_L("Creating simple player with file [%S]"), &fileName);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3914
        CSimpleSoundPlayer *sndPlayer = CSimpleSoundPlayer::NewL( iFile, TestModuleIf() , *iLogger);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3915
        CleanupStack::PushL(sndPlayer);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3916
        repeatCount = GetIntL(section, KTagRepeatTimes, UsingRepeatCountDefault, KDefaultRepeats);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3917
        repeatSilenceTimer = GetTimeIntervalL(section, KTagSilenceDuration, UsingRepeatSilencerDefault, (TTimeIntervalMicroSeconds)KDefaultSilenceDuration);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3918
        startPosition = GetTimeIntervalL(section, KTagWindowStart, UsingStartDefault, (TTimeIntervalMicroSeconds)(KDefaultPosition.Int64()-1E6));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3919
        endPosition = GetTimeIntervalL(section, KTagWindowEnd, UsingEndDefault, (TTimeIntervalMicroSeconds)(KDefaultPosition.Int64()+1E6));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3920
        PauseDelay = GetTimeIntervalL(section, KTagPauseDelay, UsingDefault, (TTimeIntervalMicroSeconds32)KDefaultPauseDelay);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3921
        if (UsingDefault) {iLogger->Log(_L("Error retrieving pause delay, using default"));}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3922
        PlayDelay = GetTimeIntervalL(section, KTagPlayDelay, UsingDefault, (TTimeIntervalMicroSeconds32)KDefaultPlayDelay);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3923
        if (UsingDefault) {iLogger->Log(_L("Error retrieving play delay, using default"));}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3924
        iLogger->Log(_L("Setting Pause and Play delays to [%d] and [%d]"), PauseDelay.Int(), PlayDelay.Int());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3925
        sndPlayer->iDontPlayAudioClip = ETrue; // don't start the play back after initialize complete
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3926
        sndPlayer->SetRepeats(repeatCount, repeatSilenceTimer);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3927
        sndPlayer->SetVolumeRamp(100000);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3928
        sndPlayer->iPlayWindow = ETrue;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3929
        sndPlayer->iStartPosition = startPosition;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3930
        sndPlayer->iEndPosition = endPosition;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3931
        iLogger->Log(_L("Starting scheduler"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3932
        CActiveScheduler::Start(); // initialize the player and wait for the intialize complete event
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3933
        TTimeIntervalMicroSeconds dur = sndPlayer->GetDuration();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3934
        TTimeIntervalMicroSeconds32 interval = TTimeIntervalMicroSeconds32((endPosition.Int64() - startPosition.Int64()) + repeatSilenceTimer.Int64() + (PlayDelay.Int() - PauseDelay.Int()));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3935
        sndPlayer->Play(); // Start the loop play in the play window
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3936
        // sndPlayer->SetPlayWindow(startPosition, endPosition);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3937
        /*********************************************/
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3938
        /* For generating the Pause event during playback */
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3939
        /*********************************************/
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3940
        CParameters *pauseParams = new (ELeave) CParameters( CSimpleSoundPlayer::KPlayerActionPause );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3941
        CleanupStack::PushL(pauseParams);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3942
        CParameters *playParams = new (ELeave) CParameters( CSimpleSoundPlayer::KPlayerActionPlay );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3943
        CleanupStack::PushL(playParams);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3944
        CMediaEvent* mEventPause = CMediaEvent::NewLC(TestModuleIf() , *iLogger, PauseDelay, interval, sndPlayer, pauseParams);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3945
        CMediaEvent* mEventPlay = CMediaEvent::NewLC(TestModuleIf() , *iLogger, PlayDelay, interval, sndPlayer, playParams);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3946
        CActiveScheduler::Start(); // start the playback in the play window and loop play
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3947
        iLogger->Log(_L("Returned from player, errorcode: %d"), sndPlayer->iFinalError );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3948
        aResult.iResult = sndPlayer->iFinalError;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3949
        if ((aResult.iResult != KErrNone) && (aResult.iResult != KErrCANoRights))
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3950
            {
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3951
            iLogger->Log(_L("Test failed, error code %d"), aResult.iResult);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3952
            aResult.iResultDes.Copy(KTestCaseResultFail());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3953
            }
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3954
        else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3955
            {
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3956
            iLogger->Log(_L("Test was successful"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3957
            if (aResult.iResult == KErrCANoRights)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3958
                aResult.iResult = KErrNone;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3959
            aResult.iResultDes.Copy(KTestCaseResultSuccess());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3960
            }
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3961
        sndPlayer->SetRepeats(0,0);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3962
        sndPlayer->iPlayWindow = EFalse;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3963
        sndPlayer->ClearPlayWindow();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3964
        CleanupStack::PopAndDestroy(mEventPlay);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3965
        CleanupStack::PopAndDestroy(mEventPause);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3966
        CleanupStack::Pop(playParams);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3967
        CleanupStack::Pop(pauseParams);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3968
        CleanupStack::PopAndDestroy(sndPlayer);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3969
        iFile.Close();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3970
        iFs.Close();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3971
        return KErrExecuted;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3972
        }
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3973
    else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3974
        {
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3975
        aResult.iResultDes.Copy(KConfigInvalid());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3976
        aResult.iResult = KErrNotExecuted;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3977
        return KErrConfigInvalid;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3978
        }
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3979
    }
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3980
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3981
TInt CDRMAudioPlay::TestCasePlayRepeatForeverDRMFileWithPlayWindow(CStifSectionParser *section , TTestResult &aResult)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3982
    {
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3983
    TTimeIntervalMicroSeconds startPosition = KDefaultPosition;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3984
    TTimeIntervalMicroSeconds endPosition = KDefaultPosition;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3985
    TTimeIntervalMicroSeconds32 ReportDelay = KDefaultReportDelay;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3986
    TInt repeatCount = 0;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3987
    TTimeIntervalMicroSeconds repeatSilenceTimer = 0;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3988
    TFileName fileName;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3989
    iDRMPreCheckPassed = EFalse;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3990
    TestCasePreCheck(section, fileName);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3991
    if (iDRMPreCheckPassed)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3992
        {
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3993
        TBool UsingStartDefault, UsingEndDefault, UsingRepeatCountDefault, UsingRepeatSilencerDefault;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3994
        User::LeaveIfError(iFs.Connect());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3995
        iFs.ShareProtected();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3996
        User::LeaveIfError(iFile.Open( iFs, fileName, EFileRead));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3997
        iLogger->Log(_L("Creating simple player with file [%S]"), &fileName);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3998
        CSimpleSoundPlayer *sndPlayer = CSimpleSoundPlayer::NewL( iFile, TestModuleIf() , *iLogger);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3999
        CleanupStack::PushL(sndPlayer);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4000
        repeatCount = GetIntL(section, KTagRepeatTimes, UsingRepeatCountDefault, KDefaultRepeats);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4001
        if (repeatCount != KDefaultRepeatForever)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4002
            repeatCount = KDefaultRepeatForever;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4003
        repeatSilenceTimer = GetTimeIntervalL(section, KTagSilenceDuration, UsingRepeatSilencerDefault, (TTimeIntervalMicroSeconds)KDefaultSilenceDuration);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4004
        startPosition = GetTimeIntervalL(section, KTagWindowStart, UsingStartDefault, (TTimeIntervalMicroSeconds)(KDefaultPosition.Int64()-1E6));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4005
        endPosition = GetTimeIntervalL(section, KTagWindowEnd, UsingEndDefault, (TTimeIntervalMicroSeconds)(KDefaultPosition.Int64()+1E6));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4006
        sndPlayer->SetRepeats(repeatCount, repeatSilenceTimer);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4007
        sndPlayer->SetVolumeRamp(100000);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4008
        sndPlayer->iPlayWindow = ETrue;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4009
        sndPlayer->iStartPosition = startPosition;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4010
        sndPlayer->iEndPosition = endPosition;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4011
        sndPlayer->iDontPlayAudioClip = ETrue; // don't start the play back after initialize complete
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4012
        iLogger->Log(_L("Starting scheduler"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4013
        CActiveScheduler::Start(); // initialize the player and wait for the intialize complete event
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4014
        sndPlayer->Play(); // Start the loop play in the play window
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4015
        CActiveScheduler::Start();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4016
        iLogger->Log(_L("Returned from player, errorcode: %d"), sndPlayer->iFinalError );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4017
        aResult.iResult = sndPlayer->iFinalError;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4018
        sndPlayer->SetRepeats(0,0);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4019
        sndPlayer->iPlayWindow = EFalse;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4020
        sndPlayer->ClearPlayWindow();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4021
        CleanupStack::PopAndDestroy(sndPlayer);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4022
        if ((aResult.iResult != KErrNone) && (aResult.iResult != KErrCANoRights))
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4023
            {
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4024
            iLogger->Log(_L("Test failed, error code %d"), aResult.iResult);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4025
            aResult.iResultDes.Copy(KTestCaseResultFail());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4026
            }
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4027
        else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4028
            {
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4029
            iLogger->Log(_L("Test was successful"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4030
            if (aResult.iResult == KErrCANoRights)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4031
                aResult.iResult = KErrNone;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4032
            aResult.iResultDes.Copy(KTestCaseResultSuccess());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4033
            }
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4034
        iFile.Close();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4035
        iFs.Close();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4036
        return KErrExecuted;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4037
        }
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4038
    else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4039
        {
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4040
        aResult.iResultDes.Copy(KConfigInvalid());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4041
        aResult.iResult = KErrNotExecuted;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4042
        return KErrConfigInvalid;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4043
        }
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4044
    }