mmlibs/mmfw/tsrc/mmfunittest/aclnt/TSU_MMF_ACLNT_01/TestStepCtrlSetRepeatsCustomCommands.cpp
author hgs
Thu, 07 Oct 2010 22:34:12 +0100
changeset 0 b8ed18f6c07b
permissions -rw-r--r--
2010wk40
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
0
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
     1
// Copyright (c) 2002-2009 Nokia Corporation and/or its subsidiary(-ies).
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
     2
// All rights reserved.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
     3
// This component and the accompanying materials are made available
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
     4
// under the terms of "Eclipse Public License v1.0"
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
     5
// which accompanies this distribution, and is available
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
     6
// at the URL "http://www.eclipse.org/legal/epl-v10.html".
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
     7
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
     8
// Initial Contributors:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
     9
// Nokia Corporation - initial contribution.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    10
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    11
// Contributors:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    12
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    13
// Description:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    14
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    15
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    16
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    17
#include "TestStepCtrlSetRepeatsCustomCommands.h"
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    18
#ifdef SYMBIAN_ENABLE_SPLIT_HEADERS
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    19
#include <mmf/common/mmfstandardcustomcommandsenums.h>
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    20
#include <mmf/common/mmfstandardcustomcommandsimpl.h>
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    21
#endif
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    22
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    23
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    24
CAsyncTestStepCtrlSetRepeatsCustomCommands::CAsyncTestStepCtrlSetRepeatsCustomCommands(const TDesC& aTestName, const TDesC& aSectName, const TDesC& aKeyName)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    25
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    26
	iTestStepName=aTestName;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    27
	iSectName = aSectName;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    28
	iKeyName = aKeyName;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    29
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    30
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    31
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    32
CAsyncTestStepCtrlSetRepeatsCustomCommands * CAsyncTestStepCtrlSetRepeatsCustomCommands::NewL(const TDesC& aTestName, const TDesC& aSectName, const TDesC& aKeyName)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    33
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    34
	return new (ELeave) CAsyncTestStepCtrlSetRepeatsCustomCommands(aTestName, aSectName, aKeyName);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    35
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    36
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    37
	// from RAsyncTestStep
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    38
void CAsyncTestStepCtrlSetRepeatsCustomCommands::KickoffTestL()
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    39
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    40
	INFO_PRINTF1(_L("This a test for Controller SetRepeat custom command "));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    41
	iPriority.iPriority = KDefaultPriority;  // set the priority to some default value
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    42
	iPriority.iPref = EMdaPriorityPreferenceQuality;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    43
	iControllerEventMonitor = CMMFControllerEventMonitor::NewL(*this, iController);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    44
	
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    45
	//Prepare the TMMFFileConfig from filename to pass it to the AddDataSource
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    46
	TPtrC fileName;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    47
	if(!GetStringFromConfig(iSectName, iKeyName, fileName))
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    48
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    49
		INFO_PRINTF1(_L("GetStringFromConfig: Failed "));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    50
		StopTest(KErrGeneral, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    51
		return;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    52
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    53
 	iFileConfig().iPath = fileName;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    54
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    55
	// Open the controller
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    56
	INFO_PRINTF1(_L("Controller: Open"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    57
	TInt errorCode = iController.Open(KMmfAudioControllerUid, iPriority);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    58
	if(errorCode)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    59
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    60
		INFO_PRINTF2(_L("Failed to load the controller  %d "), errorCode);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    61
		StopTest(errorCode, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    62
		User::Leave( errorCode );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    63
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    64
	// Start the event monitor
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    65
	iControllerEventMonitor->Start();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    66
	
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    67
	// Add the DataSource
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    68
	INFO_PRINTF1(_L("Controller: AddDataSource "));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    69
	errorCode = iController.AddDataSource(KUidMmfFileSource, iFileConfig);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    70
	if(errorCode)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    71
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    72
		INFO_PRINTF2(_L("AddDataSource failed with  %d "), errorCode);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    73
		StopTest(errorCode, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    74
		User::Leave( errorCode );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    75
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    76
	// Add the DataSink
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    77
	INFO_PRINTF1(_L("Controller: AddDataSink "));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    78
	errorCode = iController.AddDataSink(KUidMmfAudioOutput,KNullDesC8);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    79
	if(errorCode)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    80
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    81
		INFO_PRINTF2(_L("AddDataSink failed with  %d "), errorCode);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    82
		StopTest(errorCode, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    83
		User::Leave( errorCode );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    84
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    85
	INFO_PRINTF1(_L("RMMFAudioPlayControllerSetRepeatsCustomCommands::SetRepeats"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    86
	RMMFAudioPlayControllerSetRepeatsCustomCommands theCommander(iController);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    87
	errorCode = theCommander.SetRepeats(1, TTimeIntervalMicroSeconds(3000000) );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    88
	#ifndef SYMBIAN_MULTIMEDIA_A3FDEVSOUND
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    89
	if(errorCode == KErrNotSupported)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    90
		{//controller on old devsound does not support this custom command
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    91
		INFO_PRINTF2(_L("SetRepeats is failed with  %d on legacy devsound"), errorCode);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    92
		StopTest();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    93
		return;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    94
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    95
	else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    96
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    97
		INFO_PRINTF2(_L("SetRepeats is not failed with KErrNotSupported but failed with %d on legacy devsound"), errorCode);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    98
		StopTest(errorCode, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    99
		User::Leave(errorCode);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   100
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   101
	#else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   102
	if(errorCode)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   103
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   104
		INFO_PRINTF2(_L("SetRepeats is failed with  %d "), errorCode);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   105
		StopTest(errorCode, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   106
		User::Leave( errorCode );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   107
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   108
	#endif
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   109
	// Prime The Controller
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   110
	INFO_PRINTF1(_L("Prime"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   111
	errorCode = iController.Prime();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   112
	if(errorCode)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   113
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   114
		INFO_PRINTF2(_L("Prime is failed with  %d "), errorCode);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   115
		StopTest(errorCode, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   116
		User::Leave( errorCode );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   117
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   118
	// Start Playing 
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   119
	INFO_PRINTF1(_L("Play"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   120
	errorCode = iController.Play();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   121
	if(errorCode)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   122
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   123
		INFO_PRINTF2(_L("Play() is failed with  %d "), errorCode);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   124
		StopTest(errorCode, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   125
		User::Leave( errorCode );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   126
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   127
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   128
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   129
void CAsyncTestStepCtrlSetRepeatsCustomCommands::CloseTest()
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   130
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   131
	iController.Stop();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   132
	iController.Reset();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   133
	iControllerEventMonitor->Cancel();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   134
	delete iControllerEventMonitor;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   135
	iController.Close();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   136
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   137
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   138
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   139
/**
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   140
 * This is from MMMFControllerEventMonitorObserver. CMMFControllerEventMonitor
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   141
 * calls the method whenever it receives an event from PlayController. Basically
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   142
 * checks for the Playcompletion event and passes the error back to the test step.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   143
 */
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   144
void CAsyncTestStepCtrlSetRepeatsCustomCommands::HandleEvent(const TMMFEvent& aEvent)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   145
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   146
	if (aEvent.iEventType==KMMFEventCategoryPlaybackComplete)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   147
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   148
		if((aEvent.iErrorCode == KErrNone) || (aEvent.iErrorCode == KErrEof))
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   149
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   150
			INFO_PRINTF2(_L("Playcompletion Error %d "), aEvent.iErrorCode);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   151
			StopTest();//Success
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   152
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   153
		else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   154
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   155
			INFO_PRINTF2(_L("Playcompletion is failed with  %d "), aEvent.iErrorCode);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   156
			StopTest(aEvent.iErrorCode, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   157
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   158
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   159
	else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   160
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   161
		INFO_PRINTF1(_L("Failed to receive Playcompletion Event "));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   162
		StopTest(KErrGeneral, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   163
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   164
	}