os/mm/devsound/a3fcharacterisationtest/src/char_a3f_devsound_tonetest.cpp
author sl
Tue, 10 Jun 2014 14:32:02 +0200 (2014-06-10)
changeset 1 260cb5ec6c19
permissions -rw-r--r--
Update contrib.
sl@0
     1
// Copyright (c) 2008-2009 Nokia Corporation and/or its subsidiary(-ies).
sl@0
     2
// All rights reserved.
sl@0
     3
// This component and the accompanying materials are made available
sl@0
     4
// under the terms of "Eclipse Public License v1.0"
sl@0
     5
// which accompanies this distribution, and is available
sl@0
     6
// at the URL "http://www.eclipse.org/legal/epl-v10.html".
sl@0
     7
//
sl@0
     8
// Initial Contributors:
sl@0
     9
// Nokia Corporation - initial contribution.
sl@0
    10
//
sl@0
    11
// Contributors:
sl@0
    12
//
sl@0
    13
// Description:
sl@0
    14
//
sl@0
    15
sl@0
    16
#include "char_a3f_devsound_tonetest.h"
sl@0
    17
sl@0
    18
sl@0
    19
/*
sl@0
    20
 *========================================================================================================
sl@0
    21
 * MM-A3F-DEVSOUND-CHRTZ-TONE-0001
sl@0
    22
 */
sl@0
    23
RA3FDevSoundToneSetConfigTest::RA3FDevSoundToneSetConfigTest(const TDesC& aTestName)
sl@0
    24
	:	RA3FDevSoundTestBase(aTestName), iSampleRate(0),
sl@0
    25
		iChannels(0)
sl@0
    26
	{
sl@0
    27
	}
sl@0
    28
sl@0
    29
RA3FDevSoundToneSetConfigTest* RA3FDevSoundToneSetConfigTest::NewL(const TDesC& aTestName)
sl@0
    30
	{
sl@0
    31
	RA3FDevSoundToneSetConfigTest * self = new(ELeave)RA3FDevSoundToneSetConfigTest(aTestName);
sl@0
    32
	return self;
sl@0
    33
	}
sl@0
    34
sl@0
    35
void RA3FDevSoundToneSetConfigTest::DoKickoffTestL()
sl@0
    36
	{
sl@0
    37
	if (!GetIntFromConfig(iTestStepName, KSampleRate, iSampleRate))
sl@0
    38
		{
sl@0
    39
		ERR_PRINTF2(KMsgErrorGetParameter, &KSampleRate);
sl@0
    40
		StopTest(KErrNotFound);
sl@0
    41
		return;
sl@0
    42
		}
sl@0
    43
	if (!GetIntFromConfig(iTestStepName, KChannel, iChannels))
sl@0
    44
		{
sl@0
    45
		ERR_PRINTF2(KMsgErrorGetParameter, &KChannel);
sl@0
    46
		StopTest(KErrNotFound);
sl@0
    47
		return;
sl@0
    48
		}
sl@0
    49
	}
sl@0
    50
sl@0
    51
sl@0
    52
void RA3FDevSoundToneSetConfigTest::Fsm(TMmfDevSoundEvent aDevSoundEvent, TInt aError)
sl@0
    53
	{
sl@0
    54
	switch(iDevSoundState)
sl@0
    55
		{
sl@0
    56
		case EStateCreated:
sl@0
    57
			{
sl@0
    58
			if(aDevSoundEvent == EEventInitialize)
sl@0
    59
				{
sl@0
    60
				__ASSERT_ALWAYS((aError == KErrNone), Panic(_L("RA3FDevSoundToneSetConfigTest"), EFsmIncorrectErrorPassed));
sl@0
    61
				INFO_PRINTF1(_L("Calling CMMFDevSound::InitializeL"));
sl@0
    62
				TRAPD(err, iMMFDevSound->InitializeL(*this, EMMFStateTonePlaying));
sl@0
    63
				if (err != KErrNone)
sl@0
    64
					{
sl@0
    65
					ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"), err);
sl@0
    66
					StopTest(err);
sl@0
    67
					break;
sl@0
    68
					}
sl@0
    69
				INFO_PRINTF1(_L("DevSound State: EStateInitializing"));
sl@0
    70
				iDevSoundState = EStateInitializing;
sl@0
    71
				}
sl@0
    72
			else
sl@0
    73
				{
sl@0
    74
				ERR_PRINTF2(_L("DevSound EEventInitialize not received as expected. Received event: %d"), aDevSoundEvent);
sl@0
    75
				StopTest(aError, EFail);
sl@0
    76
				}
sl@0
    77
			break;
sl@0
    78
			}
sl@0
    79
		case EStateInitializing:
sl@0
    80
			{
sl@0
    81
			if (aDevSoundEvent == EEventInitComplete && aError == KErrNone)
sl@0
    82
				{
sl@0
    83
				TMMFCapabilities capabilitiesSet;
sl@0
    84
				TBuf<KMaxSampleRateStringLength> stringSampleRateSet;
sl@0
    85
				TBuf<KMaxChannelsStringLength> stringChannelsSet;
sl@0
    86
				TMMFSampleRate eSampleRate;
sl@0
    87
				SampleRateFromTIntToTMMFSampleRate (iSampleRate, eSampleRate);
sl@0
    88
				capabilitiesSet.iRate = eSampleRate;
sl@0
    89
				capabilitiesSet.iChannels = iChannels;
sl@0
    90
				SampleRateFromTUintToString (capabilitiesSet.iRate,	stringSampleRateSet);
sl@0
    91
				ChannelsFromTUintToString (capabilitiesSet.iChannels, stringChannelsSet);
sl@0
    92
				INFO_PRINTF3(_L("Calling CMMFDevSound::SetConfigL using sample rate = %S and channel mode =%S"), &stringSampleRateSet, &stringChannelsSet);
sl@0
    93
				TRAPD(err, iMMFDevSound->SetConfigL(capabilitiesSet));
sl@0
    94
				if (err != KErrNone)
sl@0
    95
					{
sl@0
    96
					ERR_PRINTF2(_L("CMMFDevSound::SetConfigL left with error = %d"), err);
sl@0
    97
					StopTest(err);
sl@0
    98
					break;
sl@0
    99
					}
sl@0
   100
				TMMFCapabilities capabilitiesGet;
sl@0
   101
				TBuf<KMaxSampleRateStringLength> stringSampleRateGet;
sl@0
   102
				TBuf<KMaxChannelsStringLength> stringChannelsGet;
sl@0
   103
				capabilitiesGet=iMMFDevSound->Config();
sl@0
   104
				SampleRateFromTUintToString (capabilitiesGet.iRate, stringSampleRateGet);
sl@0
   105
				ChannelsFromTUintToString (capabilitiesGet.iChannels, stringChannelsGet);
sl@0
   106
				if (capabilitiesGet.iRate != capabilitiesSet.iRate && capabilitiesGet.iChannels != capabilitiesSet.iChannels)
sl@0
   107
					{
sl@0
   108
					ERR_PRINTF3(_L("Retrieved sample rate and channel %S %S"), &stringSampleRateGet, &stringChannelsGet);
sl@0
   109
					ERR_PRINTF3(_L("Expected %S %S"), &stringSampleRateSet, &stringChannelsSet);
sl@0
   110
					StopTest(aError, EFail);
sl@0
   111
					break;
sl@0
   112
					}
sl@0
   113
				INFO_PRINTF1(_L("========== Test Case Successfully Completed =========="));
sl@0
   114
				StopTest();
sl@0
   115
				}
sl@0
   116
			else if (aDevSoundEvent == EEventInitComplete && aError != KErrNone)
sl@0
   117
				{
sl@0
   118
				ERR_PRINTF2(_L("DevSound called CMMFDevSound::InitializeComplete with error = %d"), aError);
sl@0
   119
				StopTest(aError);
sl@0
   120
				}
sl@0
   121
			else
sl@0
   122
				{
sl@0
   123
				ERR_PRINTF2(_L("DevSound EEventInitComplete not received as expected. Received event: %d"), aDevSoundEvent);
sl@0
   124
				StopTest(aError, EFail);
sl@0
   125
				}
sl@0
   126
			break;
sl@0
   127
			}
sl@0
   128
		default:
sl@0
   129
			{
sl@0
   130
			ERR_PRINTF2(_L("Invalid DevSound state received: %d"), iDevSoundState);
sl@0
   131
			StopTest(aError, EFail);
sl@0
   132
			}
sl@0
   133
		}
sl@0
   134
	}
sl@0
   135
sl@0
   136
/*
sl@0
   137
 *========================================================================================================
sl@0
   138
 * MM-A3F-DEVSOUND-CHRTZ-TONE-0002
sl@0
   139
 */
sl@0
   140
RA3FDevSoundToneSetPrioritySettingsTest::RA3FDevSoundToneSetPrioritySettingsTest(const TDesC& aTestName)
sl@0
   141
	:	RA3FDevSoundTestBase(aTestName), iPriority(0)
sl@0
   142
	{
sl@0
   143
	}
sl@0
   144
sl@0
   145
RA3FDevSoundToneSetPrioritySettingsTest* RA3FDevSoundToneSetPrioritySettingsTest::NewL(const TDesC& aTestName)
sl@0
   146
	{
sl@0
   147
	RA3FDevSoundToneSetPrioritySettingsTest * self = new(ELeave)RA3FDevSoundToneSetPrioritySettingsTest(aTestName);
sl@0
   148
	return self;
sl@0
   149
	}
sl@0
   150
sl@0
   151
void RA3FDevSoundToneSetPrioritySettingsTest::DoKickoffTestL()
sl@0
   152
	{
sl@0
   153
	if (!GetIntFromConfig(iTestStepName, KPriority, iPriority))
sl@0
   154
		{
sl@0
   155
		ERR_PRINTF2(KMsgErrorGetParameter, &KPriority);
sl@0
   156
		StopTest(KErrUnknown);
sl@0
   157
		}
sl@0
   158
	}
sl@0
   159
sl@0
   160
void RA3FDevSoundToneSetPrioritySettingsTest::Fsm(TMmfDevSoundEvent aDevSoundEvent, TInt aError)
sl@0
   161
	{
sl@0
   162
	switch (iDevSoundState)
sl@0
   163
		{
sl@0
   164
		case EStateCreated:
sl@0
   165
			{
sl@0
   166
			if (aDevSoundEvent == EEventInitialize)
sl@0
   167
				{
sl@0
   168
				__ASSERT_ALWAYS((aError == KErrNone), Panic(_L("RA3FDevSoundToneSetPrioritySettingsTest"), EFsmIncorrectErrorPassed));
sl@0
   169
				INFO_PRINTF1(_L("Calling CMMFDevSound::InitializeL"));
sl@0
   170
				TRAPD(err, iMMFDevSound->InitializeL(*this, EMMFStateTonePlaying));
sl@0
   171
				if (err != KErrNone)
sl@0
   172
					{
sl@0
   173
					ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"), err);
sl@0
   174
					StopTest(err);
sl@0
   175
					break;
sl@0
   176
					}
sl@0
   177
				INFO_PRINTF1(_L("DevSound State: EStateInitializing"));
sl@0
   178
				iDevSoundState = EStateInitializing;
sl@0
   179
				}
sl@0
   180
			else
sl@0
   181
				{
sl@0
   182
				ERR_PRINTF2(_L("DevSound EEventInitialize not received as expected. Received event: %d"), aDevSoundEvent);
sl@0
   183
				StopTest(aError, EFail);
sl@0
   184
				}
sl@0
   185
			break;
sl@0
   186
			}
sl@0
   187
		case EStateInitializing:
sl@0
   188
			{
sl@0
   189
			if (aDevSoundEvent == EEventInitComplete && aError == KErrNone)
sl@0
   190
				{
sl@0
   191
				TMMFPrioritySettings priority;
sl@0
   192
				priority.iPriority = iPriority;
sl@0
   193
				INFO_PRINTF2(_L("Calling CMMFDevSound::SetPrioritySettings using a priority value = %d"), iPriority);
sl@0
   194
				iMMFDevSound->SetPrioritySettings (priority);
sl@0
   195
				INFO_PRINTF1(_L("========== Test Case Successfully Completed =========="));
sl@0
   196
				StopTest();
sl@0
   197
				}
sl@0
   198
			else if (aDevSoundEvent == EEventInitComplete && aError != KErrNone)
sl@0
   199
				{
sl@0
   200
				ERR_PRINTF2(_L("DevSound called CMMFDevSound::InitializeComplete with error = %d"), aError);
sl@0
   201
				StopTest(aError);
sl@0
   202
				}
sl@0
   203
			else
sl@0
   204
				{
sl@0
   205
				ERR_PRINTF2(_L("DevSound EEventInitComplete not received as expected. Received event: %d"), aDevSoundEvent);
sl@0
   206
				StopTest(aError, EFail);
sl@0
   207
				}
sl@0
   208
			break;
sl@0
   209
			}
sl@0
   210
		default:
sl@0
   211
			{
sl@0
   212
			ERR_PRINTF2(_L("Invalid DevSound state received: %d"), iDevSoundState);
sl@0
   213
			StopTest(aError, EFail);
sl@0
   214
			}
sl@0
   215
		}
sl@0
   216
	}
sl@0
   217
sl@0
   218
/*
sl@0
   219
 *========================================================================================================
sl@0
   220
 * MM-A3F-DEVSOUND-CHRTZ-TONE-0003
sl@0
   221
 */
sl@0
   222
RA3FDevSoundToneSetVolumeTest::RA3FDevSoundToneSetVolumeTest(const TDesC& aTestName)
sl@0
   223
	:	RA3FDevSoundTestBase(aTestName), iVolume(0)
sl@0
   224
	{
sl@0
   225
	}
sl@0
   226
sl@0
   227
RA3FDevSoundToneSetVolumeTest* RA3FDevSoundToneSetVolumeTest::NewL(const TDesC& aTestName)
sl@0
   228
	{
sl@0
   229
	RA3FDevSoundToneSetVolumeTest * self = new(ELeave)RA3FDevSoundToneSetVolumeTest(aTestName);
sl@0
   230
	return self;
sl@0
   231
	}
sl@0
   232
sl@0
   233
void RA3FDevSoundToneSetVolumeTest::DoKickoffTestL()
sl@0
   234
	{
sl@0
   235
	if (!GetIntFromConfig(iTestStepName, KVolume, iVolume))
sl@0
   236
		{
sl@0
   237
		ERR_PRINTF2(KMsgErrorGetParameter, &KVolume);
sl@0
   238
		StopTest(KErrUnknown);
sl@0
   239
		return;
sl@0
   240
		}
sl@0
   241
	}
sl@0
   242
sl@0
   243
void RA3FDevSoundToneSetVolumeTest::Fsm(TMmfDevSoundEvent aDevSoundEvent, TInt aError)
sl@0
   244
	{
sl@0
   245
	switch (iDevSoundState)
sl@0
   246
		{
sl@0
   247
		case EStateCreated:
sl@0
   248
			{
sl@0
   249
			if (aDevSoundEvent == EEventInitialize)
sl@0
   250
				{
sl@0
   251
				__ASSERT_ALWAYS((aError == KErrNone), Panic(_L("RA3FDevSoundToneSetVolumeTest"), EFsmIncorrectErrorPassed));
sl@0
   252
				INFO_PRINTF1(_L("Calling CMMFDevSound::InitializeL"));
sl@0
   253
				TRAPD(err, iMMFDevSound->InitializeL(*this, EMMFStateTonePlaying));
sl@0
   254
				if (err != KErrNone)
sl@0
   255
					{
sl@0
   256
					ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"), err);
sl@0
   257
					StopTest(err);
sl@0
   258
					break;
sl@0
   259
					}
sl@0
   260
				INFO_PRINTF1(_L("DevSound State: EStateInitializing"));
sl@0
   261
				iDevSoundState = EStateInitializing;
sl@0
   262
				}
sl@0
   263
			else
sl@0
   264
				{
sl@0
   265
				ERR_PRINTF2(_L("DevSound EEventInitialize not received as expected. Received event: %d"), aDevSoundEvent);
sl@0
   266
				StopTest(aError, EFail);
sl@0
   267
				}
sl@0
   268
			break;
sl@0
   269
			}
sl@0
   270
		case EStateInitializing:
sl@0
   271
			{
sl@0
   272
			if (aDevSoundEvent == EEventInitComplete && aError == KErrNone)
sl@0
   273
				{
sl@0
   274
				INFO_PRINTF2(_L("Calling CMMFDevSound::SetVolume with volume value = %d"), iVolume);
sl@0
   275
				iMMFDevSound->SetVolume(iVolume);
sl@0
   276
				TInt volumeGet;
sl@0
   277
				volumeGet=iMMFDevSound->Volume();
sl@0
   278
				if (volumeGet == iVolume)
sl@0
   279
					{
sl@0
   280
					INFO_PRINTF2(_L("CMMFDevSound::SetVolume succeeded with value = %d"), volumeGet);
sl@0
   281
					StopTest();
sl@0
   282
					}
sl@0
   283
				else
sl@0
   284
					{
sl@0
   285
					ERR_PRINTF2(_L("CMMFDevSound::SetVolume failed with value = %d"), volumeGet);
sl@0
   286
					ERR_PRINTF2(_L("Expected value = %d"), iVolume);
sl@0
   287
					StopTest(aError, EFail);
sl@0
   288
					}
sl@0
   289
				}
sl@0
   290
			else if (aDevSoundEvent == EEventInitComplete && aError != KErrNone)
sl@0
   291
				{
sl@0
   292
				ERR_PRINTF2(_L("DevSound called CMMFDevSound::InitializeComplete with error = %d"), aError);
sl@0
   293
				StopTest(aError);
sl@0
   294
				}
sl@0
   295
			else
sl@0
   296
				{
sl@0
   297
				ERR_PRINTF2(_L("DevSound EEventInitComplete not received as expected. Received event: %d"), aDevSoundEvent);
sl@0
   298
				StopTest(aError, EFail);
sl@0
   299
				}
sl@0
   300
			break;
sl@0
   301
			}
sl@0
   302
		default:
sl@0
   303
			{
sl@0
   304
			ERR_PRINTF2(_L("Invalid DevSound state received: %d"), iDevSoundState);
sl@0
   305
			StopTest(aError, EFail);
sl@0
   306
			}
sl@0
   307
		}
sl@0
   308
	}
sl@0
   309
sl@0
   310
/*
sl@0
   311
 *========================================================================================================
sl@0
   312
 * MM-A3F-DEVSOUND-CHRTZ-TONE-0004
sl@0
   313
 */
sl@0
   314
RA3FDevSoundToneVolumeRampTest::RA3FDevSoundToneVolumeRampTest(const TDesC& aTestName)
sl@0
   315
	:	RA3FDevSoundTestBase(aTestName), iVolumeRamp(0),
sl@0
   316
		iDuration(0), iFrequencyTone1(0)
sl@0
   317
	{
sl@0
   318
	}
sl@0
   319
sl@0
   320
RA3FDevSoundToneVolumeRampTest* RA3FDevSoundToneVolumeRampTest::NewL(const TDesC& aTestName)
sl@0
   321
	{
sl@0
   322
	RA3FDevSoundToneVolumeRampTest * self = new(ELeave)RA3FDevSoundToneVolumeRampTest(aTestName);
sl@0
   323
	return self;
sl@0
   324
	}
sl@0
   325
sl@0
   326
void RA3FDevSoundToneVolumeRampTest::DoKickoffTestL()
sl@0
   327
	{
sl@0
   328
	if (!GetIntFromConfig(iTestStepName, KVolumeRamp, iVolumeRamp))
sl@0
   329
		{
sl@0
   330
		ERR_PRINTF2(KMsgErrorGetParameter, &KVolumeRamp);
sl@0
   331
		StopTest(KErrNotFound);
sl@0
   332
		return;
sl@0
   333
		}
sl@0
   334
	if (!GetIntFromConfig(iTestStepName, KDuration, iDuration))
sl@0
   335
			{
sl@0
   336
			ERR_PRINTF2(KMsgErrorGetParameter, &KDuration);
sl@0
   337
			StopTest(KErrNotFound);
sl@0
   338
			return;
sl@0
   339
			}
sl@0
   340
	if (!GetIntFromConfig(iTestStepName, KFrequencyTone1, iFrequencyTone1))
sl@0
   341
		{
sl@0
   342
		ERR_PRINTF2(KMsgErrorGetParameter, &KFrequencyTone1);
sl@0
   343
		StopTest(KErrNotFound);
sl@0
   344
		return;
sl@0
   345
		}
sl@0
   346
	}
sl@0
   347
sl@0
   348
void RA3FDevSoundToneVolumeRampTest::Fsm(TMmfDevSoundEvent aDevSoundEvent, TInt aError)
sl@0
   349
	{
sl@0
   350
	switch (iDevSoundState)
sl@0
   351
		{
sl@0
   352
		case EStateCreated:
sl@0
   353
			{
sl@0
   354
			if (aDevSoundEvent == EEventInitialize)
sl@0
   355
				{
sl@0
   356
				__ASSERT_ALWAYS((aError == KErrNone), Panic(_L("RA3FDevSoundToneVolumeRampTest"), EFsmIncorrectErrorPassed));
sl@0
   357
				INFO_PRINTF1(_L("Calling CMMFDevSound::InitializeL"));
sl@0
   358
				TRAPD(err, iMMFDevSound->InitializeL(*this, EMMFStateTonePlaying));
sl@0
   359
				if (err != KErrNone)
sl@0
   360
					{
sl@0
   361
					ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"), err);
sl@0
   362
					StopTest(err);
sl@0
   363
					break;
sl@0
   364
					}
sl@0
   365
				INFO_PRINTF1(_L("DevSound State: EStateInitializing"));
sl@0
   366
				iDevSoundState = EStateInitializing;
sl@0
   367
				}
sl@0
   368
			else
sl@0
   369
				{
sl@0
   370
				ERR_PRINTF2(_L("DevSound EEventInitialize not received as expected. Received event: %d"), aDevSoundEvent);
sl@0
   371
				StopTest(aError, EFail);
sl@0
   372
				}
sl@0
   373
			break;
sl@0
   374
			}
sl@0
   375
		case EStateInitializing:
sl@0
   376
			{
sl@0
   377
			if (aDevSoundEvent == EEventInitComplete && aError == KErrNone)
sl@0
   378
				{
sl@0
   379
				INFO_PRINTF2(_L("Calling CMMFDevSound::SetVolumeRamp using volume ramp time = %d"), iVolumeRamp);
sl@0
   380
				iMMFDevSound->SetVolumeRamp(iVolumeRamp);
sl@0
   381
				iStartTime.HomeTime();
sl@0
   382
				INFO_PRINTF3(_L("Calling CMMFDevSound::PlayToneL %d Hz during %d secs "), iFrequencyTone1, iDuration);
sl@0
   383
				TRAPD(err, iMMFDevSound->PlayToneL(iFrequencyTone1, iDuration*KMicroSecsInOneSec));
sl@0
   384
				if (err != KErrNone)
sl@0
   385
					{
sl@0
   386
					ERR_PRINTF2(_L("CMMFDevSound::PlayToneL left with error : %d!"), err);
sl@0
   387
					StopTest(err);
sl@0
   388
					break;
sl@0
   389
					}
sl@0
   390
				}
sl@0
   391
			else if (aDevSoundEvent == EEventInitComplete && aError != KErrNone)
sl@0
   392
				{
sl@0
   393
				ERR_PRINTF2(_L("DevSound called CMMFDevSound::InitializeComplete with error = %d"), aError);
sl@0
   394
				StopTest(aError);
sl@0
   395
				}
sl@0
   396
			else
sl@0
   397
				{
sl@0
   398
				ERR_PRINTF2(_L("DevSound EEventInitComplete not received as expected. Received event: %d"), aDevSoundEvent);
sl@0
   399
				StopTest(aError, EFail);
sl@0
   400
				}
sl@0
   401
			break;
sl@0
   402
			}
sl@0
   403
		default:
sl@0
   404
			{
sl@0
   405
			ERR_PRINTF2(_L("Invalid DevSound state received: %d"), iDevSoundState);
sl@0
   406
			StopTest(aError, EFail);
sl@0
   407
			}
sl@0
   408
		}
sl@0
   409
	}
sl@0
   410
sl@0
   411
void RA3FDevSoundToneVolumeRampTest::ToneFinished(TInt aError)
sl@0
   412
	{
sl@0
   413
	INFO_PRINTF1(_L("========== DevSound ToneFinished() callback =========="));
sl@0
   414
	if (aError == KErrUnderflow)
sl@0
   415
		{
sl@0
   416
		iEndTime.HomeTime();
sl@0
   417
		iPlayToneTime = iEndTime.MicroSecondsFrom(iStartTime);
sl@0
   418
		TInt totalExpectedReproductionTime = iDuration * KMicroSecsInOneSec;
sl@0
   419
		if(iPlayToneTime < totalExpectedReproductionTime + KPlayVarianceTime && iPlayToneTime > totalExpectedReproductionTime - KPlayVarianceTime)
sl@0
   420
			{
sl@0
   421
			INFO_PRINTF2(_L("Play time is %Ld microseconds"), iPlayToneTime.Int64());
sl@0
   422
			StopTest();
sl@0
   423
			}
sl@0
   424
		else
sl@0
   425
			{
sl@0
   426
			ERR_PRINTF3(_L("Play time is %Ld microseconds and it should have been %d microseconds"), iPlayToneTime.Int64(), totalExpectedReproductionTime);
sl@0
   427
			StopTest(KErrNone, EFail);
sl@0
   428
			}
sl@0
   429
		}
sl@0
   430
	else
sl@0
   431
		{
sl@0
   432
		ERR_PRINTF2(_L("DevSound called ToneFinished with error = %d"), aError);
sl@0
   433
		ERR_PRINTF2(_L("Expected error = %d"), KErrUnderflow);
sl@0
   434
		StopTest(aError, EFail);
sl@0
   435
		}
sl@0
   436
	}
sl@0
   437
sl@0
   438
/*
sl@0
   439
 *========================================================================================================
sl@0
   440
 * MM-A3F-DEVSOUND-CHRTZ-TONE-0005
sl@0
   441
 */
sl@0
   442
RA3FDevSoundToneSetToneRepeatsTest::RA3FDevSoundToneSetToneRepeatsTest(const TDesC& aTestName)
sl@0
   443
	:	RA3FDevSoundTestBase(aTestName),
sl@0
   444
		iDuration(0),
sl@0
   445
		iFrequencyTone1(0),
sl@0
   446
		iRepeatTrailingSilence(0),
sl@0
   447
		iRepeatCount(0)
sl@0
   448
	{
sl@0
   449
	}
sl@0
   450
sl@0
   451
RA3FDevSoundToneSetToneRepeatsTest* RA3FDevSoundToneSetToneRepeatsTest::NewL(const TDesC& aTestName)
sl@0
   452
	{
sl@0
   453
	RA3FDevSoundToneSetToneRepeatsTest * self = new(ELeave)RA3FDevSoundToneSetToneRepeatsTest(aTestName);
sl@0
   454
	return self;
sl@0
   455
	}
sl@0
   456
sl@0
   457
void RA3FDevSoundToneSetToneRepeatsTest::DoKickoffTestL()
sl@0
   458
	{
sl@0
   459
	if (!GetIntFromConfig(iTestStepName, KRepeatCount, iRepeatCount))
sl@0
   460
		{
sl@0
   461
		ERR_PRINTF2(KMsgErrorGetParameter, &KRepeatCount);
sl@0
   462
		StopTest(KErrNotFound);
sl@0
   463
		return;
sl@0
   464
		}
sl@0
   465
	if (!GetIntFromConfig(iTestStepName, KRepeatTrailingSilence, iRepeatTrailingSilence))
sl@0
   466
		{
sl@0
   467
		ERR_PRINTF2(KMsgErrorGetParameter, &KRepeatTrailingSilence);
sl@0
   468
		StopTest(KErrNotFound);
sl@0
   469
		return;
sl@0
   470
		}
sl@0
   471
	if (!GetIntFromConfig(iTestStepName, KDuration, iDuration))
sl@0
   472
		{
sl@0
   473
		ERR_PRINTF2(KMsgErrorGetParameter, &KDuration);
sl@0
   474
		StopTest(KErrNotFound);
sl@0
   475
		return;
sl@0
   476
		}
sl@0
   477
	if (!GetIntFromConfig(iTestStepName, KFrequencyTone1, iFrequencyTone1))
sl@0
   478
		{
sl@0
   479
		ERR_PRINTF2(KMsgErrorGetParameter, &KFrequencyTone1);
sl@0
   480
		StopTest(KErrNotFound);
sl@0
   481
		return;
sl@0
   482
		}
sl@0
   483
	}
sl@0
   484
sl@0
   485
void RA3FDevSoundToneSetToneRepeatsTest::Fsm(TMmfDevSoundEvent aDevSoundEvent, TInt aError)
sl@0
   486
	{
sl@0
   487
	switch (iDevSoundState)
sl@0
   488
		{
sl@0
   489
		case EStateCreated:
sl@0
   490
			{
sl@0
   491
			if (aDevSoundEvent == EEventInitialize)
sl@0
   492
				{
sl@0
   493
				__ASSERT_ALWAYS((aError == KErrNone), Panic(_L("RA3FDevSoundToneSetToneRepeatsTest"), EFsmIncorrectErrorPassed));
sl@0
   494
				INFO_PRINTF1(_L("Calling CMMFDevSound::InitializeL"));
sl@0
   495
				TRAPD(err, iMMFDevSound->InitializeL(*this, EMMFStateTonePlaying));
sl@0
   496
				if (err != KErrNone)
sl@0
   497
					{
sl@0
   498
					ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"), err);
sl@0
   499
					StopTest(err);
sl@0
   500
					break;
sl@0
   501
					}
sl@0
   502
				INFO_PRINTF1(_L("DevSound State: EStateInitializing"));
sl@0
   503
				iDevSoundState = EStateInitializing;
sl@0
   504
				}
sl@0
   505
			else
sl@0
   506
				{
sl@0
   507
				ERR_PRINTF2(_L("DevSound EEventInitialize not received as expected. Received event: %d"), aDevSoundEvent);
sl@0
   508
				StopTest(aError, EFail);
sl@0
   509
				}
sl@0
   510
			break;
sl@0
   511
			}
sl@0
   512
		case EStateInitializing:
sl@0
   513
			{
sl@0
   514
			if (aDevSoundEvent == EEventInitComplete && aError == KErrNone)
sl@0
   515
				{
sl@0
   516
				iMMFDevSound->SetVolume(iMMFDevSound->MaxVolume());
sl@0
   517
				iStartTime.HomeTime();
sl@0
   518
				INFO_PRINTF3(_L("Calling CMMFDevSound::SetToneRepeats using repeatCount = %d and trailingSilence = %d"), iRepeatCount, iRepeatTrailingSilence);
sl@0
   519
				iMMFDevSound->SetToneRepeats(iRepeatCount, iRepeatTrailingSilence);
sl@0
   520
				INFO_PRINTF3(_L("Calling CMMFDevSound::PlayToneL %d Hz during %d secs "), iFrequencyTone1, iDuration);
sl@0
   521
				TRAPD(err, iMMFDevSound->PlayToneL(iFrequencyTone1, iDuration*KMicroSecsInOneSec));
sl@0
   522
				if (err != KErrNone)
sl@0
   523
					{
sl@0
   524
					ERR_PRINTF2(_L("CMMFDevSound::PlayToneL left with error : %d!"), err);
sl@0
   525
					StopTest(err);
sl@0
   526
					break;
sl@0
   527
					}
sl@0
   528
				}
sl@0
   529
			else if (aDevSoundEvent == EEventInitComplete && aError != KErrNone)
sl@0
   530
				{
sl@0
   531
				ERR_PRINTF2(_L("DevSound called CMMFDevSound::InitializeComplete with error = %d"), aError);
sl@0
   532
				StopTest(aError);
sl@0
   533
				}
sl@0
   534
			else
sl@0
   535
				{
sl@0
   536
				ERR_PRINTF2(_L("DevSound EEventInitComplete not received as expected. Received event: %d"), aDevSoundEvent);
sl@0
   537
				StopTest(aError, EFail);
sl@0
   538
				}
sl@0
   539
			break;
sl@0
   540
			}
sl@0
   541
		default:
sl@0
   542
			{
sl@0
   543
			ERR_PRINTF2(_L("Invalid DevSound state received: %d"), iDevSoundState);
sl@0
   544
			StopTest(aError, EFail);
sl@0
   545
			}
sl@0
   546
		}
sl@0
   547
	}
sl@0
   548
sl@0
   549
void RA3FDevSoundToneSetToneRepeatsTest::ToneFinished(TInt aError)
sl@0
   550
	{
sl@0
   551
	INFO_PRINTF1(_L("========== DevSound ToneFinished() callback =========="));
sl@0
   552
	if (aError == KErrUnderflow)
sl@0
   553
		{
sl@0
   554
		iEndTime.HomeTime();
sl@0
   555
		iPlayToneTime = iEndTime.MicroSecondsFrom(iStartTime);
sl@0
   556
		TInt repeatTrailingSilenceToSecs = iRepeatTrailingSilence/KMicroSecsInOneSec;
sl@0
   557
		TInt totalExpectedReproductionTime = (iRepeatCount * iDuration + iDuration + (repeatTrailingSilenceToSecs*iRepeatCount))*KMicroSecsInOneSec;
sl@0
   558
		if(iPlayToneTime < totalExpectedReproductionTime + KPlayVarianceTime && iPlayToneTime > totalExpectedReproductionTime - KPlayVarianceTime)
sl@0
   559
			{
sl@0
   560
			INFO_PRINTF1(_L("Play tone repeats succeded."));
sl@0
   561
			INFO_PRINTF2(_L("Play time is %Ld microseconds"), iPlayToneTime.Int64());
sl@0
   562
			StopTest();
sl@0
   563
			}
sl@0
   564
		else
sl@0
   565
			{
sl@0
   566
			ERR_PRINTF1(_L("Play tone repeats did not work as planned."));
sl@0
   567
			ERR_PRINTF3(_L("Play time is %Ld microseconds and it should have been %d microseconds"), iPlayToneTime.Int64(), totalExpectedReproductionTime);
sl@0
   568
			StopTest(KErrNone, EFail);
sl@0
   569
			}
sl@0
   570
		}
sl@0
   571
	else
sl@0
   572
		{
sl@0
   573
		ERR_PRINTF2(_L("DevSound called ToneFinished with error = %d"), aError);
sl@0
   574
		ERR_PRINTF2(_L("Expected error = %d"), KErrUnderflow);
sl@0
   575
		StopTest(aError, EFail);
sl@0
   576
		}
sl@0
   577
	}
sl@0
   578
sl@0
   579
/*
sl@0
   580
 *========================================================================================================
sl@0
   581
 * MM-A3F-DEVSOUND-CHRTZ-TONE-0006
sl@0
   582
 */
sl@0
   583
RA3FDevSoundToneSetDTMFLengthsTest::RA3FDevSoundToneSetDTMFLengthsTest(const TDesC& aTestName)
sl@0
   584
	:	RA3FDevSoundTestBase(aTestName), iToneOnLength(0),
sl@0
   585
		iToneOffLength(0), iPauseLength(0), iDTMFPauses(0),
sl@0
   586
		iDTMFTones(0)
sl@0
   587
	{
sl@0
   588
	}
sl@0
   589
sl@0
   590
RA3FDevSoundToneSetDTMFLengthsTest* RA3FDevSoundToneSetDTMFLengthsTest::NewL(const TDesC& aTestName)
sl@0
   591
	{
sl@0
   592
	RA3FDevSoundToneSetDTMFLengthsTest * self = new(ELeave)RA3FDevSoundToneSetDTMFLengthsTest(aTestName);
sl@0
   593
	return self;
sl@0
   594
	}
sl@0
   595
sl@0
   596
void RA3FDevSoundToneSetDTMFLengthsTest::DoKickoffTestL()
sl@0
   597
	{
sl@0
   598
	if (!GetIntFromConfig(iTestStepName, KToneOnLength, iToneOnLength))
sl@0
   599
		{
sl@0
   600
		ERR_PRINTF2(KMsgErrorGetParameter, &KToneOnLength);
sl@0
   601
		StopTest(KErrNotFound);
sl@0
   602
		return;
sl@0
   603
		}
sl@0
   604
	if (!GetIntFromConfig(iTestStepName, KToneOffLength, iToneOffLength))
sl@0
   605
		{
sl@0
   606
		ERR_PRINTF2(KMsgErrorGetParameter, &KToneOffLength);
sl@0
   607
		StopTest(KErrNotFound);
sl@0
   608
		return;
sl@0
   609
		}
sl@0
   610
	if (!GetIntFromConfig(iTestStepName, KPauseLength, iPauseLength))
sl@0
   611
		{
sl@0
   612
		ERR_PRINTF2(KMsgErrorGetParameter, &KPauseLength);
sl@0
   613
		StopTest(KErrNotFound);
sl@0
   614
		return;
sl@0
   615
		}
sl@0
   616
	TPtrC DTMF;
sl@0
   617
	if (!GetStringFromConfig(iTestStepName, KDTMFString, DTMF))
sl@0
   618
		{
sl@0
   619
		ERR_PRINTF2(KMsgErrorGetParameter, &KDTMFString);
sl@0
   620
		StopTest(KErrNotFound);
sl@0
   621
		return;
sl@0
   622
		}
sl@0
   623
	iDTMFString.Copy(DTMF);
sl@0
   624
	for(TInt i =0 ; i< iDTMFString.Length() ; i++)
sl@0
   625
		{
sl@0
   626
		if (iDTMFString[i] == ',')
sl@0
   627
			{
sl@0
   628
			iDTMFPauses++;
sl@0
   629
			}
sl@0
   630
		else
sl@0
   631
			{
sl@0
   632
			iDTMFTones++;
sl@0
   633
			}
sl@0
   634
		}
sl@0
   635
	}
sl@0
   636
sl@0
   637
void RA3FDevSoundToneSetDTMFLengthsTest::Fsm(TMmfDevSoundEvent aDevSoundEvent, TInt aError)
sl@0
   638
	{
sl@0
   639
	switch (iDevSoundState)
sl@0
   640
		{
sl@0
   641
		case EStateCreated:
sl@0
   642
			{
sl@0
   643
			if (aDevSoundEvent == EEventInitialize)
sl@0
   644
				{
sl@0
   645
				__ASSERT_ALWAYS((aError == KErrNone), Panic(_L("RA3FDevSoundToneSetDTMFLengthsTest"), EFsmIncorrectErrorPassed));
sl@0
   646
				INFO_PRINTF1(_L("Calling CMMFDevSound::InitializeL"));
sl@0
   647
				TRAPD(err, iMMFDevSound->InitializeL(*this, EMMFStateTonePlaying));
sl@0
   648
				if (err != KErrNone)
sl@0
   649
					{
sl@0
   650
					ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"), err);
sl@0
   651
					StopTest(err);
sl@0
   652
					break;
sl@0
   653
					}
sl@0
   654
				INFO_PRINTF1(_L("DevSound State: EStateInitializing"));
sl@0
   655
				iDevSoundState = EStateInitializing;
sl@0
   656
				}
sl@0
   657
			else
sl@0
   658
				{
sl@0
   659
				ERR_PRINTF2(_L("DevSound EEventInitialize not received as expected. Received event: %d"), aDevSoundEvent);
sl@0
   660
				StopTest(aError, EFail);
sl@0
   661
				}
sl@0
   662
			break;
sl@0
   663
			}
sl@0
   664
		case EStateInitializing:
sl@0
   665
			{
sl@0
   666
			if (aDevSoundEvent == EEventInitComplete && aError == KErrNone)
sl@0
   667
				{
sl@0
   668
				iMMFDevSound->SetVolume(iMMFDevSound->MaxVolume());
sl@0
   669
				TTimeIntervalMicroSeconds32 ToneOnLength(iToneOnLength);
sl@0
   670
				TTimeIntervalMicroSeconds32 ToneOffLength(iToneOffLength);
sl@0
   671
				TTimeIntervalMicroSeconds32 PauseLength(iPauseLength);
sl@0
   672
				INFO_PRINTF4(_L("Calling CMMFDevSound::SetDTMFLengths. ToneOnLength = %d, ToneOffLength = %d and PauseLength = %d"), ToneOnLength.Int(), ToneOffLength.Int(), PauseLength.Int());
sl@0
   673
				iMMFDevSound->SetDTMFLengths(ToneOnLength, ToneOffLength, PauseLength);
sl@0
   674
				iStartTime.HomeTime();
sl@0
   675
				INFO_PRINTF2(_L("Calling CMMFDevSound::PlayDTMFStringL %S"), &iDTMFString);
sl@0
   676
				TRAPD(err, iMMFDevSound->PlayDTMFStringL(iDTMFString));
sl@0
   677
				if (err != KErrNone)
sl@0
   678
					{
sl@0
   679
					ERR_PRINTF2(_L("CMMFDevSound::PlayDTMFStringL left with error : %d!"), err);
sl@0
   680
					StopTest(err);
sl@0
   681
					break;
sl@0
   682
					}
sl@0
   683
				}
sl@0
   684
			else if (aDevSoundEvent == EEventInitComplete && aError != KErrNone)
sl@0
   685
				{
sl@0
   686
				ERR_PRINTF2(_L("DevSound called CMMFDevSound::InitializeComplete with error = %d"), aError);
sl@0
   687
				StopTest(aError);
sl@0
   688
				}
sl@0
   689
			else
sl@0
   690
				{
sl@0
   691
				ERR_PRINTF2(_L("DevSound EEventInitComplete not received as expected. Received event: %d"), aDevSoundEvent);
sl@0
   692
				StopTest(aError, EFail);
sl@0
   693
				}
sl@0
   694
			break;
sl@0
   695
			}
sl@0
   696
		default:
sl@0
   697
			{
sl@0
   698
			ERR_PRINTF2(_L("Invalid DevSound state received: %d"), iDevSoundState);
sl@0
   699
			StopTest(aError, EFail);
sl@0
   700
			}
sl@0
   701
		}
sl@0
   702
	}
sl@0
   703
sl@0
   704
void RA3FDevSoundToneSetDTMFLengthsTest::ToneFinished(TInt aError)
sl@0
   705
	{
sl@0
   706
	INFO_PRINTF1(_L("========== DevSound ToneFinished() callback =========="));
sl@0
   707
	if (aError == KErrUnderflow)
sl@0
   708
		{
sl@0
   709
		iEndTime.HomeTime();
sl@0
   710
		iPlayToneTime = iEndTime.MicroSecondsFrom(iStartTime);
sl@0
   711
		TInt totalExpectedReproductionTime = iToneOnLength*iDTMFTones + iToneOffLength * iDTMFTones + iDTMFPauses * iPauseLength;
sl@0
   712
		if (iPlayToneTime.Int64() < totalExpectedReproductionTime + KPlayVarianceTime && iPlayToneTime.Int64() > totalExpectedReproductionTime - KPlayVarianceTime)
sl@0
   713
			{
sl@0
   714
			INFO_PRINTF1(_L("Calling CMMFDevSound::SetDTMFLengths succeded."));
sl@0
   715
			INFO_PRINTF2(_L("Play time is %Ld microseconds"), iPlayToneTime.Int64());
sl@0
   716
			StopTest();
sl@0
   717
			}
sl@0
   718
		else
sl@0
   719
			{
sl@0
   720
			ERR_PRINTF2(_L("Calling CMMFDevSound::SetDTMFLengths failed with %Ld"), iPlayToneTime.Int64());
sl@0
   721
			ERR_PRINTF2(_L("Expected time %d"), totalExpectedReproductionTime);
sl@0
   722
			StopTest(KErrNone, EFail);
sl@0
   723
			}
sl@0
   724
		}
sl@0
   725
	else
sl@0
   726
		{
sl@0
   727
		ERR_PRINTF2(_L("DevSound called ToneFinished with error = %d"), aError);
sl@0
   728
		ERR_PRINTF2(_L("Expected error = %d"), KErrUnderflow);
sl@0
   729
		StopTest(aError, EFail);
sl@0
   730
		}
sl@0
   731
	}
sl@0
   732
sl@0
   733
/*
sl@0
   734
 *========================================================================================================
sl@0
   735
 * MM-A3F-DEVSOUND-CHRTZ-TONE-0007
sl@0
   736
 */
sl@0
   737
RA3FDevSoundToneSetVolumeWhilePlayingTest::RA3FDevSoundToneSetVolumeWhilePlayingTest(const TDesC& aTestName)
sl@0
   738
	:	RA3FDevSoundTestBase(aTestName), iDuration(0),
sl@0
   739
		iVolume(0), iFrequencyTone1(0)
sl@0
   740
	{
sl@0
   741
	}
sl@0
   742
sl@0
   743
RA3FDevSoundToneSetVolumeWhilePlayingTest* RA3FDevSoundToneSetVolumeWhilePlayingTest::NewL(const TDesC& aTestName)
sl@0
   744
	{
sl@0
   745
	RA3FDevSoundToneSetVolumeWhilePlayingTest * self = new(ELeave)RA3FDevSoundToneSetVolumeWhilePlayingTest(aTestName);
sl@0
   746
	return self;
sl@0
   747
	}
sl@0
   748
sl@0
   749
void RA3FDevSoundToneSetVolumeWhilePlayingTest::DoKickoffTestL()
sl@0
   750
	{
sl@0
   751
	if (!GetIntFromConfig(iTestStepName, KVolume, iVolume))
sl@0
   752
		{
sl@0
   753
		ERR_PRINTF2(KMsgErrorGetParameter, &KVolume);
sl@0
   754
		StopTest(KErrNotFound);
sl@0
   755
		return;
sl@0
   756
		}
sl@0
   757
	if (!GetIntFromConfig(iTestStepName, KDuration, iDuration))
sl@0
   758
		{
sl@0
   759
		ERR_PRINTF2(KMsgErrorGetParameter, &KDuration);
sl@0
   760
		StopTest(KErrNotFound);
sl@0
   761
		return;
sl@0
   762
		}
sl@0
   763
	if (!GetIntFromConfig(iTestStepName, KFrequencyTone1, iFrequencyTone1))
sl@0
   764
		{
sl@0
   765
		ERR_PRINTF2(KMsgErrorGetParameter, &KFrequencyTone1);
sl@0
   766
		StopTest(KErrNotFound);
sl@0
   767
		return;
sl@0
   768
		}
sl@0
   769
	iTimer = CPeriodic::NewL(CActive::EPriorityHigh);
sl@0
   770
	}
sl@0
   771
sl@0
   772
void RA3FDevSoundToneSetVolumeWhilePlayingTest::Fsm(TMmfDevSoundEvent aDevSoundEvent, TInt aError)
sl@0
   773
	{
sl@0
   774
	switch (iDevSoundState)
sl@0
   775
		{
sl@0
   776
		case EStateCreated:
sl@0
   777
			{
sl@0
   778
			if (aDevSoundEvent == EEventInitialize)
sl@0
   779
				{
sl@0
   780
				__ASSERT_ALWAYS((aError == KErrNone), Panic(_L("RA3FDevSoundToneSetVolumeWhilePlayingTest"), EFsmIncorrectErrorPassed));
sl@0
   781
				INFO_PRINTF1(_L("Calling CMMFDevSound::InitializeL"));
sl@0
   782
				TRAPD(err, iMMFDevSound->InitializeL(*this, EMMFStateTonePlaying));
sl@0
   783
				if (err != KErrNone)
sl@0
   784
					{
sl@0
   785
					ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"), err);
sl@0
   786
					StopTest(err);
sl@0
   787
					break;
sl@0
   788
					}
sl@0
   789
				INFO_PRINTF1(_L("DevSound State: EStateInitializing"));
sl@0
   790
				iDevSoundState = EStateInitializing;
sl@0
   791
				}
sl@0
   792
			else
sl@0
   793
				{
sl@0
   794
				ERR_PRINTF2(_L("DevSound EEventInitialize not received as expected. Received event: %d"), aDevSoundEvent);
sl@0
   795
				StopTest(aError, EFail);
sl@0
   796
				}
sl@0
   797
			break;
sl@0
   798
			}
sl@0
   799
		case EStateInitializing:
sl@0
   800
			{
sl@0
   801
			if (aDevSoundEvent == EEventInitComplete && aError == KErrNone)
sl@0
   802
				{
sl@0
   803
				iStartTime.HomeTime();
sl@0
   804
				INFO_PRINTF3(_L("Calling CMMFDevSound::PlayToneL using frequency = %d Hz and duration = %d secs "), iFrequencyTone1, iDuration);
sl@0
   805
				TRAPD(err, iMMFDevSound->PlayToneL(iFrequencyTone1, iDuration*KMicroSecsInOneSec));
sl@0
   806
				if (err != KErrNone)
sl@0
   807
					{
sl@0
   808
					ERR_PRINTF2(_L("CMMFDevSound::PlayToneL left with error : %d!"), err);
sl@0
   809
					StopTest(err);
sl@0
   810
					break;
sl@0
   811
					}
sl@0
   812
				StartTimer(KMicroSecsTwoSec);
sl@0
   813
				INFO_PRINTF1(_L("DevSound State: EStatePlaying"));
sl@0
   814
				iDevSoundState = EStatePlaying;
sl@0
   815
				}
sl@0
   816
			else if (aDevSoundEvent == EEventInitComplete && aError != KErrNone)
sl@0
   817
				{
sl@0
   818
				ERR_PRINTF2(_L("DevSound called CMMFDevSound::InitializeComplete with error = %d"), aError);
sl@0
   819
				StopTest(aError);
sl@0
   820
				}
sl@0
   821
			else
sl@0
   822
				{
sl@0
   823
				ERR_PRINTF2(_L("DevSound EEventInitComplete not received as expected. Received event: %d"), aDevSoundEvent);
sl@0
   824
				StopTest(aError, EFail);
sl@0
   825
				}
sl@0
   826
			break;
sl@0
   827
			}
sl@0
   828
		default:
sl@0
   829
			{
sl@0
   830
			ERR_PRINTF2(_L("Invalid DevSound state received: %d"), iDevSoundState);
sl@0
   831
			StopTest(aError, EFail);
sl@0
   832
			}
sl@0
   833
		}
sl@0
   834
	}
sl@0
   835
sl@0
   836
void RA3FDevSoundToneSetVolumeWhilePlayingTest::DoTimerCallback()
sl@0
   837
	{
sl@0
   838
	iTimer->Cancel();
sl@0
   839
	INFO_PRINTF1(_L("DevSound Event: EEventTimerComplete"));
sl@0
   840
	INFO_PRINTF2(_L("Calling CMMFDevSound::SetVolume with volume value = %d"), iVolume);
sl@0
   841
	iMMFDevSound->SetVolume(iVolume);
sl@0
   842
	TInt volumeGet;
sl@0
   843
	volumeGet=iMMFDevSound->Volume();
sl@0
   844
	if (volumeGet == iVolume)
sl@0
   845
		{
sl@0
   846
		INFO_PRINTF2(_L("CMMFDevSound::SetVolume succeeded with value = %d"), volumeGet);
sl@0
   847
		}
sl@0
   848
	else
sl@0
   849
		{
sl@0
   850
		ERR_PRINTF2(_L("CMMFDevSound::SetVolume failed with value = %d"), volumeGet);
sl@0
   851
		ERR_PRINTF2(_L("Expected value = %d"), iVolume);
sl@0
   852
		StopTest(KErrNone, EFail);
sl@0
   853
		}
sl@0
   854
	}
sl@0
   855
sl@0
   856
void RA3FDevSoundToneSetVolumeWhilePlayingTest::ToneFinished(TInt aError)
sl@0
   857
	{
sl@0
   858
	INFO_PRINTF1(_L("========== DevSound ToneFinished() callback =========="));
sl@0
   859
	if (aError == KErrUnderflow)
sl@0
   860
		{
sl@0
   861
		iEndTime.HomeTime();
sl@0
   862
		iPlayToneTime = iEndTime.MicroSecondsFrom(iStartTime);
sl@0
   863
		TInt totalExpectedReproductionTime = iDuration * KMicroSecsInOneSec;
sl@0
   864
		if(iPlayToneTime < totalExpectedReproductionTime + KPlayVarianceTime && iPlayToneTime > totalExpectedReproductionTime - KPlayVarianceTime)
sl@0
   865
			{
sl@0
   866
			INFO_PRINTF2(_L("Play time is %Ld microseconds"), iPlayToneTime.Int64());
sl@0
   867
			StopTest();
sl@0
   868
			}
sl@0
   869
		else
sl@0
   870
			{
sl@0
   871
			ERR_PRINTF3(_L("Play time is %Ld microseconds and it should have been %d microseconds"), iPlayToneTime.Int64(), totalExpectedReproductionTime);
sl@0
   872
			StopTest(KErrNone, EFail);
sl@0
   873
			}
sl@0
   874
		}
sl@0
   875
	else
sl@0
   876
		{
sl@0
   877
		ERR_PRINTF2(_L("DevSound called ToneFinished with error = %d"), aError);
sl@0
   878
		ERR_PRINTF2(_L("Expected error = %d"), KErrUnderflow);
sl@0
   879
		StopTest(aError, EFail);
sl@0
   880
		}
sl@0
   881
	}
sl@0
   882
sl@0
   883
/*
sl@0
   884
 *========================================================================================================
sl@0
   885
 * MM-A3F-DEVSOUND-CHRTZ-TONE-0008
sl@0
   886
 */
sl@0
   887
RA3FDevSoundToneSetPlayBalanceWhilePlayingTest::RA3FDevSoundToneSetPlayBalanceWhilePlayingTest(const TDesC& aTestName)
sl@0
   888
	:	RA3FDevSoundTestBase(aTestName), iDuration(0),
sl@0
   889
		iVolume(0), iFrequencyTone1(0), iLSpeakerBalance(0),
sl@0
   890
		iRSpeakerBalance(0)
sl@0
   891
sl@0
   892
	{
sl@0
   893
	}
sl@0
   894
sl@0
   895
RA3FDevSoundToneSetPlayBalanceWhilePlayingTest* RA3FDevSoundToneSetPlayBalanceWhilePlayingTest::NewL(const TDesC& aTestName)
sl@0
   896
	{
sl@0
   897
	RA3FDevSoundToneSetPlayBalanceWhilePlayingTest * self = new(ELeave)RA3FDevSoundToneSetPlayBalanceWhilePlayingTest(aTestName);
sl@0
   898
	return self;
sl@0
   899
	}
sl@0
   900
sl@0
   901
void RA3FDevSoundToneSetPlayBalanceWhilePlayingTest::DoKickoffTestL()
sl@0
   902
	{
sl@0
   903
	if (!GetIntFromConfig(iTestStepName, KVolume, iVolume))
sl@0
   904
		{
sl@0
   905
		ERR_PRINTF2(KMsgErrorGetParameter, &KVolume);
sl@0
   906
		StopTest(KErrNotFound);
sl@0
   907
		return;
sl@0
   908
		}
sl@0
   909
	if (!GetIntFromConfig(iTestStepName, KDuration, iDuration))
sl@0
   910
		{
sl@0
   911
		ERR_PRINTF2(KMsgErrorGetParameter, &KDuration);
sl@0
   912
		StopTest(KErrNotFound);
sl@0
   913
		return;
sl@0
   914
		}
sl@0
   915
	if (!GetIntFromConfig(iTestStepName, KFrequencyTone1, iFrequencyTone1))
sl@0
   916
		{
sl@0
   917
		ERR_PRINTF2(KMsgErrorGetParameter, &KFrequencyTone1);
sl@0
   918
		StopTest(KErrNotFound);
sl@0
   919
		return;
sl@0
   920
		}
sl@0
   921
	if (!GetIntFromConfig(iTestStepName, KLSpeakerBalance, iLSpeakerBalance))
sl@0
   922
		{
sl@0
   923
		ERR_PRINTF2(KMsgErrorGetParameter, &KLSpeakerBalance);
sl@0
   924
		StopTest(KErrNotFound);
sl@0
   925
		return;
sl@0
   926
		}
sl@0
   927
	if (!GetIntFromConfig(iTestStepName, KRSpeakerBalance, iRSpeakerBalance))
sl@0
   928
		{
sl@0
   929
		ERR_PRINTF2(KMsgErrorGetParameter, &KRSpeakerBalance);
sl@0
   930
		StopTest(KErrNotFound);
sl@0
   931
		return;
sl@0
   932
		}
sl@0
   933
	iTimer = CPeriodic::NewL(CActive::EPriorityHigh);
sl@0
   934
	}
sl@0
   935
sl@0
   936
void RA3FDevSoundToneSetPlayBalanceWhilePlayingTest::Fsm(TMmfDevSoundEvent aDevSoundEvent, TInt aError)
sl@0
   937
	{
sl@0
   938
	switch (iDevSoundState)
sl@0
   939
		{
sl@0
   940
		case EStateCreated:
sl@0
   941
			{
sl@0
   942
			if (aDevSoundEvent == EEventInitialize)
sl@0
   943
				{
sl@0
   944
				__ASSERT_ALWAYS((aError == KErrNone), Panic(_L("RA3FDevSoundToneSetPlayBalanceWhilePlayingTest"), EFsmIncorrectErrorPassed));
sl@0
   945
				INFO_PRINTF1(_L("Calling CMMFDevSound::InitializeL"));
sl@0
   946
				TRAPD(err, iMMFDevSound->InitializeL(*this, EMMFStateTonePlaying));
sl@0
   947
				if (err != KErrNone)
sl@0
   948
					{
sl@0
   949
					ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"), err);
sl@0
   950
					StopTest(err);
sl@0
   951
					break;
sl@0
   952
					}
sl@0
   953
				INFO_PRINTF1(_L("DevSound State: EStateInitializing"));
sl@0
   954
				iDevSoundState = EStateInitializing;
sl@0
   955
				}
sl@0
   956
			else
sl@0
   957
				{
sl@0
   958
				ERR_PRINTF2(_L("DevSound EEventInitialize not received as expected. Received event: %d"), aDevSoundEvent);
sl@0
   959
				StopTest(aError, EFail);
sl@0
   960
				}
sl@0
   961
			break;
sl@0
   962
			}
sl@0
   963
		case EStateInitializing:
sl@0
   964
			{
sl@0
   965
			if (aDevSoundEvent == EEventInitComplete && aError == KErrNone)
sl@0
   966
				{
sl@0
   967
				iStartTime.HomeTime();
sl@0
   968
				INFO_PRINTF3(_L("Calling CMMFDevSound::PlayToneL using frequency = %d Hz and duration = %d secs "), iFrequencyTone1, iDuration);
sl@0
   969
				TRAPD(err, iMMFDevSound->PlayToneL(iFrequencyTone1, iDuration*KMicroSecsInOneSec));
sl@0
   970
				if (err != KErrNone)
sl@0
   971
					{
sl@0
   972
					ERR_PRINTF2(_L("CMMFDevSound::PlayToneL left with error : %d!"), err);
sl@0
   973
					StopTest(err);
sl@0
   974
					break;
sl@0
   975
					}
sl@0
   976
				StartTimer(KMicroSecsTwoSec);
sl@0
   977
				INFO_PRINTF1(_L("DevSound State: EStatePlaying"));
sl@0
   978
				iDevSoundState = EStatePlaying;
sl@0
   979
				}
sl@0
   980
			else if (aDevSoundEvent == EEventInitComplete && aError != KErrNone)
sl@0
   981
				{
sl@0
   982
				ERR_PRINTF2(_L("DevSound called CMMFDevSound::InitializeComplete with error = %d"), aError);
sl@0
   983
				StopTest(aError);
sl@0
   984
				}
sl@0
   985
			else
sl@0
   986
				{
sl@0
   987
				ERR_PRINTF2(_L("DevSound EEventInitComplete not received as expected. Received event: %d"), aDevSoundEvent);
sl@0
   988
				StopTest(aError, EFail);
sl@0
   989
				}
sl@0
   990
			break;
sl@0
   991
			}
sl@0
   992
		default:
sl@0
   993
			{
sl@0
   994
			ERR_PRINTF2(_L("Invalid DevSound state received: %d"), iDevSoundState);
sl@0
   995
			StopTest(aError, EFail);
sl@0
   996
			}
sl@0
   997
		}
sl@0
   998
	}
sl@0
   999
sl@0
  1000
void RA3FDevSoundToneSetPlayBalanceWhilePlayingTest::DoTimerCallback()
sl@0
  1001
	{
sl@0
  1002
	iTimer->Cancel();
sl@0
  1003
	INFO_PRINTF1(_L("DevSound Event: EEventTimerComplete"));
sl@0
  1004
	INFO_PRINTF3(_L("Calling CMMFDevSound::SetPlayBalanceL using left = %d right = %d"), iLSpeakerBalance, iRSpeakerBalance);
sl@0
  1005
	TRAPD(err, iMMFDevSound->SetPlayBalanceL(iLSpeakerBalance, iRSpeakerBalance));
sl@0
  1006
	if (err == KErrNone)
sl@0
  1007
		{
sl@0
  1008
		TInt getBalanceL, getBalanceR;
sl@0
  1009
		TRAPD(err, iMMFDevSound->GetPlayBalanceL(getBalanceL, getBalanceR));
sl@0
  1010
		if (err == KErrNone)
sl@0
  1011
			{
sl@0
  1012
			if(iLSpeakerBalance == getBalanceL && iRSpeakerBalance == getBalanceR)
sl@0
  1013
				{
sl@0
  1014
				INFO_PRINTF3(_L("Calling CMMFDevSound::SetPlayBalanceL to set balance values succeeded, left = %d right = %d"), getBalanceL, getBalanceR);
sl@0
  1015
				}
sl@0
  1016
			else
sl@0
  1017
				{
sl@0
  1018
				ERR_PRINTF3(_L("Calling CMMFDevSound::SetPlayBalanceL to set balance values failed, left = %d right = %d"), getBalanceL, getBalanceR);
sl@0
  1019
				ERR_PRINTF3(_L("Expected balances values for right and left respectively %d, %d"),iLSpeakerBalance, iRSpeakerBalance);
sl@0
  1020
				StopTest(err,EFail);
sl@0
  1021
				}
sl@0
  1022
			}
sl@0
  1023
		}
sl@0
  1024
	else
sl@0
  1025
		{
sl@0
  1026
		ERR_PRINTF1(_L("Error in setting left and right play balance."));
sl@0
  1027
		StopTest (err, EFail);
sl@0
  1028
		}
sl@0
  1029
	}
sl@0
  1030
sl@0
  1031
void RA3FDevSoundToneSetPlayBalanceWhilePlayingTest::ToneFinished(TInt aError)
sl@0
  1032
	{
sl@0
  1033
	INFO_PRINTF1(_L("========== DevSound ToneFinished() callback =========="));
sl@0
  1034
	if (aError == KErrUnderflow)
sl@0
  1035
		{
sl@0
  1036
		iEndTime.HomeTime();
sl@0
  1037
		iPlayToneTime = iEndTime.MicroSecondsFrom(iStartTime);
sl@0
  1038
		TInt totalExpectedReproductionTime = iDuration * KMicroSecsInOneSec;
sl@0
  1039
		if(iPlayToneTime < totalExpectedReproductionTime + KPlayVarianceTime && iPlayToneTime > totalExpectedReproductionTime - KPlayVarianceTime)
sl@0
  1040
			{
sl@0
  1041
			INFO_PRINTF2(_L("Play time is %Ld microseconds"), iPlayToneTime.Int64());
sl@0
  1042
			StopTest();
sl@0
  1043
			}
sl@0
  1044
		else
sl@0
  1045
			{
sl@0
  1046
			ERR_PRINTF3(_L("Play time is %Ld microseconds and it should have been %d microseconds"), iPlayToneTime.Int64(), totalExpectedReproductionTime);
sl@0
  1047
			StopTest(KErrNone, EFail);
sl@0
  1048
			}
sl@0
  1049
		}
sl@0
  1050
	else
sl@0
  1051
		{
sl@0
  1052
		ERR_PRINTF2(_L("DevSound called ToneFinished with error = %d"), aError);
sl@0
  1053
		ERR_PRINTF2(_L("Expected error = %d"), KErrUnderflow);
sl@0
  1054
		StopTest(aError, EFail);
sl@0
  1055
		}
sl@0
  1056
	}
sl@0
  1057
sl@0
  1058
/*
sl@0
  1059
 *  **========================================================================================================
sl@0
  1060
 * MM-A3F-DEVSOUND-CHRTZ-TONE-0009
sl@0
  1061
 */
sl@0
  1062
RA3FDevSoundToneSetVolumeWhilePausePlayingTest::RA3FDevSoundToneSetVolumeWhilePausePlayingTest(const TDesC& aTestName)
sl@0
  1063
	:	RA3FDevSoundTestBase(aTestName),
sl@0
  1064
		iDuration(0), iVolume(0),
sl@0
  1065
		iFrequencyTone1(0),
sl@0
  1066
		iTimeToEnterPauseElapsed(EFalse)
sl@0
  1067
	{
sl@0
  1068
	}
sl@0
  1069
sl@0
  1070
RA3FDevSoundToneSetVolumeWhilePausePlayingTest* RA3FDevSoundToneSetVolumeWhilePausePlayingTest::NewL(const TDesC& aTestName)
sl@0
  1071
	{
sl@0
  1072
	RA3FDevSoundToneSetVolumeWhilePausePlayingTest * self = new(ELeave)RA3FDevSoundToneSetVolumeWhilePausePlayingTest(aTestName);
sl@0
  1073
	return self;
sl@0
  1074
	}
sl@0
  1075
sl@0
  1076
void RA3FDevSoundToneSetVolumeWhilePausePlayingTest::DoKickoffTestL()
sl@0
  1077
	{
sl@0
  1078
	if (!GetIntFromConfig(iTestStepName, KVolume, iVolume))
sl@0
  1079
		{
sl@0
  1080
		ERR_PRINTF2(KMsgErrorGetParameter, &KVolume);
sl@0
  1081
		StopTest(KErrNotFound);
sl@0
  1082
		return;
sl@0
  1083
		}
sl@0
  1084
	if (!GetIntFromConfig(iTestStepName, KDuration, iDuration))
sl@0
  1085
		{
sl@0
  1086
		ERR_PRINTF2(KMsgErrorGetParameter, &KDuration);
sl@0
  1087
		StopTest(KErrNotFound);
sl@0
  1088
		return;
sl@0
  1089
		}
sl@0
  1090
	if (!GetIntFromConfig(iTestStepName, KFrequencyTone1, iFrequencyTone1))
sl@0
  1091
		{
sl@0
  1092
		ERR_PRINTF2(KMsgErrorGetParameter, &KFrequencyTone1);
sl@0
  1093
		StopTest(KErrNotFound);
sl@0
  1094
		return;
sl@0
  1095
		}
sl@0
  1096
	iTimer = CPeriodic::NewL(CActive::EPriorityHigh);
sl@0
  1097
	}
sl@0
  1098
sl@0
  1099
void RA3FDevSoundToneSetVolumeWhilePausePlayingTest::Fsm(TMmfDevSoundEvent aDevSoundEvent,  TInt aError)
sl@0
  1100
	{
sl@0
  1101
	switch (iDevSoundState)
sl@0
  1102
		{
sl@0
  1103
		case EStateCreated:
sl@0
  1104
			{
sl@0
  1105
			__ASSERT_ALWAYS((aError == KErrNone), Panic(_L("RA3FDevSoundToneSetVolumeWhilePausePlayingTest"), EFsmIncorrectErrorPassed));
sl@0
  1106
			if (aDevSoundEvent == EEventInitialize)
sl@0
  1107
				{
sl@0
  1108
				INFO_PRINTF1(_L("Calling CMMFDevSound::InitializeL"));
sl@0
  1109
				TRAPD(err, iMMFDevSound->InitializeL(*this, EMMFStateTonePlaying));
sl@0
  1110
				if (err != KErrNone)
sl@0
  1111
					{
sl@0
  1112
					ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"), err);
sl@0
  1113
					StopTest(err);
sl@0
  1114
					break;
sl@0
  1115
					}
sl@0
  1116
				INFO_PRINTF1(_L("DevSound State: EStateInitializing"));
sl@0
  1117
				iDevSoundState = EStateInitializing;
sl@0
  1118
				}
sl@0
  1119
			else
sl@0
  1120
				{
sl@0
  1121
				ERR_PRINTF2(_L("DevSound EEventInitialize not received as expected. Received event: %d"), aDevSoundEvent);
sl@0
  1122
				StopTest(aError, EFail);
sl@0
  1123
				}
sl@0
  1124
			break;
sl@0
  1125
			}
sl@0
  1126
		case EStateInitializing:
sl@0
  1127
			{
sl@0
  1128
			if (aDevSoundEvent == EEventInitComplete && aError == KErrNone)
sl@0
  1129
				{
sl@0
  1130
				INFO_PRINTF3(_L("CMMFDevSound::PlayToneL %d Hz during %d secs "), iFrequencyTone1, iDuration);
sl@0
  1131
				TRAPD(err, iMMFDevSound->PlayToneL(iFrequencyTone1, iDuration*KMicroSecsInOneSec));
sl@0
  1132
				if (err != KErrNone)
sl@0
  1133
					{
sl@0
  1134
					ERR_PRINTF2(_L("CMMFDevSound::PlayToneL left with error : %d!"), err);
sl@0
  1135
					StopTest(err);
sl@0
  1136
					break;
sl@0
  1137
					}
sl@0
  1138
				StartTimer(KMicroSecsTwoSec);
sl@0
  1139
				INFO_PRINTF1(_L("DevSound State: EStatePlaying"));
sl@0
  1140
				iDevSoundState = EStatePlaying;
sl@0
  1141
				}
sl@0
  1142
			else if (aDevSoundEvent == EEventInitComplete && aError != KErrNone)
sl@0
  1143
				{
sl@0
  1144
				ERR_PRINTF2(_L("DevSound called CMMFDevSound::InitializeComplete with error = %d"), aError);
sl@0
  1145
				StopTest(aError);
sl@0
  1146
				}
sl@0
  1147
			else
sl@0
  1148
				{
sl@0
  1149
				ERR_PRINTF2(_L("DevSound EEventInitComplete not received as expected. Received event: %d"),  aDevSoundEvent);
sl@0
  1150
				StopTest(aError, EFail);
sl@0
  1151
				}
sl@0
  1152
			break;
sl@0
  1153
			}
sl@0
  1154
		case EStatePlaying:
sl@0
  1155
			{
sl@0
  1156
			if(aDevSoundEvent == EEventTimerComplete)
sl@0
  1157
				{
sl@0
  1158
				INFO_PRINTF1(_L("Calling CMMFDevSound::Pause"));
sl@0
  1159
				iMMFDevSound->Pause();
sl@0
  1160
				INFO_PRINTF1(_L("DevSound State: EStatePause"));
sl@0
  1161
				iDevSoundState = EStatePause;
sl@0
  1162
				}
sl@0
  1163
			else
sl@0
  1164
				{
sl@0
  1165
				ERR_PRINTF2(_L("DevSound EEventTimerComplete not received as expected. Received event: %d"), aDevSoundEvent);
sl@0
  1166
				StopTest(aError, EFail);
sl@0
  1167
				}
sl@0
  1168
			break;
sl@0
  1169
			}
sl@0
  1170
		case EStatePause:
sl@0
  1171
			{
sl@0
  1172
			if(aDevSoundEvent == EEventTimerComplete)
sl@0
  1173
				{
sl@0
  1174
				INFO_PRINTF2(_L("Calling CMMFDevSound::SetVolume with volume value = %d"), iVolume);
sl@0
  1175
				iMMFDevSound->SetVolume(iVolume);
sl@0
  1176
				TInt volumeGet;
sl@0
  1177
				volumeGet=iMMFDevSound->Volume();
sl@0
  1178
				if (volumeGet == iVolume)
sl@0
  1179
					{
sl@0
  1180
					INFO_PRINTF2(_L("CMMFDevSound::SetVolume succeeded with value = %d"), volumeGet);
sl@0
  1181
					StopTest();
sl@0
  1182
					}
sl@0
  1183
				else
sl@0
  1184
					{
sl@0
  1185
					ERR_PRINTF2(_L("CMMFDevSound::SetVolume failed with value = %d"), volumeGet);
sl@0
  1186
					ERR_PRINTF2(_L("Expected value = %d"), iVolume);
sl@0
  1187
					StopTest(aError, EFail);
sl@0
  1188
					}
sl@0
  1189
				}
sl@0
  1190
			else
sl@0
  1191
				{
sl@0
  1192
				ERR_PRINTF2(_L("DevSound EEventTimerComplete not received as expected. Received event: %d"), aDevSoundEvent);
sl@0
  1193
				StopTest(aError, EFail);
sl@0
  1194
				}
sl@0
  1195
			break;
sl@0
  1196
			}
sl@0
  1197
		default:
sl@0
  1198
			{
sl@0
  1199
			ERR_PRINTF2(_L("Invalid DevSound state received: %d"), iDevSoundState);
sl@0
  1200
			StopTest(aError, EFail);
sl@0
  1201
			}
sl@0
  1202
		}
sl@0
  1203
	}
sl@0
  1204
sl@0
  1205
void RA3FDevSoundToneSetVolumeWhilePausePlayingTest::DoTimerCallback()
sl@0
  1206
	{
sl@0
  1207
	INFO_PRINTF1(_L("TimerEvent called"));
sl@0
  1208
	if(!iTimeToEnterPauseElapsed)
sl@0
  1209
		{
sl@0
  1210
		iTimeToEnterPauseElapsed = ETrue;
sl@0
  1211
		INFO_PRINTF1(_L("DevSound Event: EEventTimerComplete"));
sl@0
  1212
		Fsm(EEventTimerComplete, KErrNone);
sl@0
  1213
		iTimeToEnterPauseElapsed = ETrue;
sl@0
  1214
		}
sl@0
  1215
	else
sl@0
  1216
		{
sl@0
  1217
		iTimer->Cancel();
sl@0
  1218
		INFO_PRINTF1(_L("DevSound Event: EEventTimerComplete"));
sl@0
  1219
		Fsm(EEventTimerComplete, KErrNone);
sl@0
  1220
		}
sl@0
  1221
	}
sl@0
  1222
sl@0
  1223
void RA3FDevSoundToneSetVolumeWhilePausePlayingTest::ToneFinished(TInt aError)
sl@0
  1224
	{
sl@0
  1225
	INFO_PRINTF1(_L("========== DevSound ToneFinished() callback =========="));
sl@0
  1226
	ERR_PRINTF1(_L("DevSound should not have called ToneFinished because it is supposed to be paused"));
sl@0
  1227
	StopTest(aError, EFail);
sl@0
  1228
	}
sl@0
  1229
/*
sl@0
  1230
 *========================================================================================================
sl@0
  1231
 * MM-A3F-DEVSOUND-CHRTZ-TONE-0010
sl@0
  1232
 */
sl@0
  1233
RA3FDevSoundToneSetVolumeThenInitializeToPlayAudioTest::RA3FDevSoundToneSetVolumeThenInitializeToPlayAudioTest(const TDesC& aTestName)
sl@0
  1234
	:	RA3FDevSoundTestBase(aTestName), iVolume(0),
sl@0
  1235
		iReinitialized(EFalse)
sl@0
  1236
	{
sl@0
  1237
	}
sl@0
  1238
sl@0
  1239
RA3FDevSoundToneSetVolumeThenInitializeToPlayAudioTest* RA3FDevSoundToneSetVolumeThenInitializeToPlayAudioTest::NewL(const TDesC& aTestName)
sl@0
  1240
	{
sl@0
  1241
	RA3FDevSoundToneSetVolumeThenInitializeToPlayAudioTest * self = new(ELeave)RA3FDevSoundToneSetVolumeThenInitializeToPlayAudioTest(aTestName);
sl@0
  1242
	return self;
sl@0
  1243
	}
sl@0
  1244
sl@0
  1245
void RA3FDevSoundToneSetVolumeThenInitializeToPlayAudioTest::DoKickoffTestL()
sl@0
  1246
	{
sl@0
  1247
	if (!GetIntFromConfig(iTestStepName, KVolume, iVolume))
sl@0
  1248
		{
sl@0
  1249
		ERR_PRINTF2(KMsgErrorGetParameter, &KVolume);
sl@0
  1250
		StopTest(KErrNotFound);
sl@0
  1251
		return;
sl@0
  1252
		}
sl@0
  1253
	}
sl@0
  1254
sl@0
  1255
void RA3FDevSoundToneSetVolumeThenInitializeToPlayAudioTest::Fsm(TMmfDevSoundEvent aDevSoundEvent,  TInt aError)
sl@0
  1256
	{
sl@0
  1257
	switch (iDevSoundState)
sl@0
  1258
		{
sl@0
  1259
		case EStateCreated:
sl@0
  1260
			{
sl@0
  1261
			__ASSERT_ALWAYS((aError == KErrNone), Panic(_L("RA3FDevSoundToneSetVolumeThenInitializeToPlayAudioTest"), EFsmIncorrectErrorPassed));
sl@0
  1262
			if (aDevSoundEvent == EEventInitialize)
sl@0
  1263
				{
sl@0
  1264
				INFO_PRINTF1(_L("Calling CMMFDevSound::InitializeL"));
sl@0
  1265
				TRAPD(err, iMMFDevSound->InitializeL(*this, EMMFStateTonePlaying));
sl@0
  1266
				if (err != KErrNone)
sl@0
  1267
					{
sl@0
  1268
					ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"), err);
sl@0
  1269
					StopTest(err);
sl@0
  1270
					break;
sl@0
  1271
					}
sl@0
  1272
				INFO_PRINTF1(_L("DevSound State: EStateInitializing"));
sl@0
  1273
				iDevSoundState = EStateInitializing;
sl@0
  1274
				}
sl@0
  1275
			else
sl@0
  1276
				{
sl@0
  1277
				ERR_PRINTF2(_L("DevSound EEventInitialize not received as expected. Received event: %d"), aDevSoundEvent);
sl@0
  1278
				StopTest(aError, EFail);
sl@0
  1279
				}
sl@0
  1280
			break;
sl@0
  1281
			}
sl@0
  1282
		case EStateInitializing:
sl@0
  1283
			{
sl@0
  1284
			if (aDevSoundEvent == EEventInitComplete && aError == KErrNone)
sl@0
  1285
				{
sl@0
  1286
				if(!iReinitialized)
sl@0
  1287
					{
sl@0
  1288
					INFO_PRINTF1(_L("Calling CMMFDevSound::InitializeL"));
sl@0
  1289
					TRAPD(err, iMMFDevSound->InitializeL(*this, EMMFStateTonePlaying));
sl@0
  1290
					if (err != KErrNone)
sl@0
  1291
						{
sl@0
  1292
						ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"), err);
sl@0
  1293
						StopTest(err);
sl@0
  1294
						break;
sl@0
  1295
						}
sl@0
  1296
					INFO_PRINTF1(_L("DevSound State: EStateInitializing"));
sl@0
  1297
					iDevSoundState = EStateInitializing;
sl@0
  1298
					iReinitialized = ETrue;
sl@0
  1299
					INFO_PRINTF2(_L("Calling CMMFDevSound::SetVolume with volume value = %d"), iVolume);
sl@0
  1300
					iMMFDevSound->SetVolume(iVolume);
sl@0
  1301
					INFO_PRINTF1(_L("DevSound State: EStateInitializing"));
sl@0
  1302
					iDevSoundState = EStateInitializing;
sl@0
  1303
					}
sl@0
  1304
				else
sl@0
  1305
					{
sl@0
  1306
					TInt volumeGet;
sl@0
  1307
					volumeGet=iMMFDevSound->Volume();
sl@0
  1308
					if (volumeGet == iVolume)
sl@0
  1309
						{
sl@0
  1310
						INFO_PRINTF1(_L("After calling CMMFDevSound::InitializeL for playing audio, "));
sl@0
  1311
						INFO_PRINTF2(_L("the volume which was set when calling CMMFDevSound::InitializeL for playing tones is kept. Volume = %d"), volumeGet);
sl@0
  1312
						StopTest();
sl@0
  1313
						}
sl@0
  1314
					else
sl@0
  1315
						{
sl@0
  1316
						INFO_PRINTF1(_L("After calling CMMFDevSound::InitializeL for playing audio, "));
sl@0
  1317
						INFO_PRINTF2(_L("the volume which was set when calling CMMFDevSound::InitializeL for playing tones is  NOT kept. Volume = %d"), volumeGet);
sl@0
  1318
						ERR_PRINTF2(_L("Expected value = %d"), iVolume);
sl@0
  1319
						StopTest(aError, EFail);
sl@0
  1320
						}
sl@0
  1321
					}
sl@0
  1322
				}
sl@0
  1323
			else if (aDevSoundEvent == EEventInitComplete && aError != KErrNone)
sl@0
  1324
				{
sl@0
  1325
				ERR_PRINTF2(_L("DevSound called CMMFDevSound::InitializeComplete with error = %d"), aError);
sl@0
  1326
				StopTest(aError);
sl@0
  1327
				}
sl@0
  1328
			else
sl@0
  1329
				{
sl@0
  1330
				ERR_PRINTF2(_L("DevSound EEventInitComplete not received as expected. Received event: %d"),  aDevSoundEvent);
sl@0
  1331
				StopTest(aError, EFail);
sl@0
  1332
				}
sl@0
  1333
			break;
sl@0
  1334
			}
sl@0
  1335
		default:
sl@0
  1336
			{
sl@0
  1337
			ERR_PRINTF2(_L("Invalid DevSound state received: %d"), iDevSoundState);
sl@0
  1338
			StopTest(aError, EFail);
sl@0
  1339
			}
sl@0
  1340
		}
sl@0
  1341
	}
sl@0
  1342
sl@0
  1343
/*
sl@0
  1344
 *========================================================================================================
sl@0
  1345
 * MM-A3F-DEVSOUND-CHRTZ-TONE-0011
sl@0
  1346
 */
sl@0
  1347
RA3FDevSoundToneSetVolumeRampWhilePlayingTest::RA3FDevSoundToneSetVolumeRampWhilePlayingTest(const TDesC& aTestName)
sl@0
  1348
	:	RA3FDevSoundTestBase(aTestName), iDuration(0),
sl@0
  1349
		iVolume(0), iFrequencyTone1(0),iTonePlayedTwice(EFalse),
sl@0
  1350
		iTimesToneFinishedCalled(0)
sl@0
  1351
	{
sl@0
  1352
	}
sl@0
  1353
sl@0
  1354
RA3FDevSoundToneSetVolumeRampWhilePlayingTest* RA3FDevSoundToneSetVolumeRampWhilePlayingTest::NewL(const TDesC& aTestName)
sl@0
  1355
	{
sl@0
  1356
	RA3FDevSoundToneSetVolumeRampWhilePlayingTest * self = new(ELeave)RA3FDevSoundToneSetVolumeRampWhilePlayingTest(aTestName);
sl@0
  1357
	return self;
sl@0
  1358
	}
sl@0
  1359
sl@0
  1360
void RA3FDevSoundToneSetVolumeRampWhilePlayingTest::DoKickoffTestL()
sl@0
  1361
	{
sl@0
  1362
	if (!GetIntFromConfig(iTestStepName, KVolume, iVolume))
sl@0
  1363
		{
sl@0
  1364
		ERR_PRINTF2(KMsgErrorGetParameter, &KVolume);
sl@0
  1365
		StopTest(KErrNotFound);
sl@0
  1366
		return;
sl@0
  1367
		}
sl@0
  1368
	if (!GetIntFromConfig(iTestStepName, KDuration, iDuration))
sl@0
  1369
		{
sl@0
  1370
		ERR_PRINTF2(KMsgErrorGetParameter, &KDuration);
sl@0
  1371
		StopTest(KErrNotFound);
sl@0
  1372
		return;
sl@0
  1373
		}
sl@0
  1374
	if (!GetIntFromConfig(iTestStepName, KFrequencyTone1, iFrequencyTone1))
sl@0
  1375
		{
sl@0
  1376
		ERR_PRINTF2(KMsgErrorGetParameter, &KFrequencyTone1);
sl@0
  1377
		StopTest(KErrNotFound);
sl@0
  1378
		return;
sl@0
  1379
		}
sl@0
  1380
	if (!GetIntFromConfig(iTestStepName, KVolumeRamp, iVolumeRamp))
sl@0
  1381
			{
sl@0
  1382
			ERR_PRINTF2(KMsgErrorGetParameter, &KVolumeRamp);
sl@0
  1383
			StopTest(KErrNotFound);
sl@0
  1384
			return;
sl@0
  1385
			}
sl@0
  1386
	iTimer = CPeriodic::NewL(CActive::EPriorityHigh);
sl@0
  1387
	}
sl@0
  1388
sl@0
  1389
void RA3FDevSoundToneSetVolumeRampWhilePlayingTest::Fsm(TMmfDevSoundEvent aDevSoundEvent,  TInt aError)
sl@0
  1390
	{
sl@0
  1391
	switch (iDevSoundState)
sl@0
  1392
		{
sl@0
  1393
		case EStateCreated:
sl@0
  1394
			{
sl@0
  1395
			if (aDevSoundEvent == EEventInitialize)
sl@0
  1396
				{
sl@0
  1397
				__ASSERT_ALWAYS((aError == KErrNone), Panic(_L("RA3FDevSoundToneSetVolumeRampWhilePlayingTest"), EFsmIncorrectErrorPassed));
sl@0
  1398
				INFO_PRINTF1(_L("Calling CMMFDevSound::InitializeL"));
sl@0
  1399
				TRAPD(err, iMMFDevSound->InitializeL(*this, EMMFStateTonePlaying));
sl@0
  1400
				if (err != KErrNone)
sl@0
  1401
					{
sl@0
  1402
					ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"),  err);
sl@0
  1403
					StopTest(err);
sl@0
  1404
					break;
sl@0
  1405
					}
sl@0
  1406
				INFO_PRINTF1(_L("DevSound State: EStateInitializing"));
sl@0
  1407
				iDevSoundState = EStateInitializing;
sl@0
  1408
				}
sl@0
  1409
			else
sl@0
  1410
				{
sl@0
  1411
				ERR_PRINTF2(_L("DevSound EEventInitialize not received as expected. Received event: %d"), aDevSoundEvent);
sl@0
  1412
				StopTest(aError, EFail);
sl@0
  1413
				}
sl@0
  1414
			break;
sl@0
  1415
			}
sl@0
  1416
		case EStateInitializing:
sl@0
  1417
			{
sl@0
  1418
			if (aDevSoundEvent == EEventInitComplete && aError == KErrNone)
sl@0
  1419
				{
sl@0
  1420
				iMMFDevSound->SetVolume(iMMFDevSound->MaxVolume());
sl@0
  1421
				iStartTime.HomeTime();
sl@0
  1422
				INFO_PRINTF3(_L("Calling CMMFDevSound::PlayToneL using frequency = %d Hz and duration = %d secs "), iFrequencyTone1, iDuration);
sl@0
  1423
				TRAPD(err, iMMFDevSound->PlayToneL(iFrequencyTone1, iDuration*KMicroSecsInOneSec));
sl@0
  1424
				if (err != KErrNone)
sl@0
  1425
					{
sl@0
  1426
					ERR_PRINTF2(_L("Play tone left with error : %d!"), err);
sl@0
  1427
					StopTest(err);
sl@0
  1428
					break;
sl@0
  1429
					}
sl@0
  1430
				StartTimer(KMicroSecsTwoSec);
sl@0
  1431
				INFO_PRINTF1(_L("DevSound State: EStatePlaying"));
sl@0
  1432
				iDevSoundState = EStatePlaying;
sl@0
  1433
				}
sl@0
  1434
			else if (aDevSoundEvent == EEventInitComplete && aError != KErrNone)
sl@0
  1435
				{
sl@0
  1436
				ERR_PRINTF2(_L("DevSound called CMMFDevSound::InitializeComplete with error = %d"), aError);
sl@0
  1437
				StopTest(aError);
sl@0
  1438
				}
sl@0
  1439
			else
sl@0
  1440
				{
sl@0
  1441
				ERR_PRINTF2(_L("DevSound EEventInitComplete not received as expected. Received event: %d"), aDevSoundEvent);
sl@0
  1442
				StopTest(aError, EFail);
sl@0
  1443
				}
sl@0
  1444
			break;
sl@0
  1445
			}
sl@0
  1446
		default:
sl@0
  1447
			{
sl@0
  1448
			ERR_PRINTF2(_L("Invalid DevSound state received: %d"), iDevSoundState);
sl@0
  1449
			StopTest(aError, EFail);
sl@0
  1450
			}
sl@0
  1451
		}
sl@0
  1452
	}
sl@0
  1453
sl@0
  1454
void RA3FDevSoundToneSetVolumeRampWhilePlayingTest::DoTimerCallback()
sl@0
  1455
	{
sl@0
  1456
	iTimer->Cancel();
sl@0
  1457
	INFO_PRINTF1(_L("DevSound Event: EEventTimerComplete"));
sl@0
  1458
	INFO_PRINTF2(_L("Calling CMMFDevSound::SetVolumeRamp using volume ramp time = %d"), iVolumeRamp);
sl@0
  1459
	iMMFDevSound->SetVolumeRamp(iVolumeRamp);
sl@0
  1460
	}
sl@0
  1461
sl@0
  1462
void RA3FDevSoundToneSetVolumeRampWhilePlayingTest::ToneFinished(TInt aError)
sl@0
  1463
	{
sl@0
  1464
	INFO_PRINTF1(_L("========== DevSound ToneFinished() callback =========="));
sl@0
  1465
	if (aError == KErrUnderflow)
sl@0
  1466
		{
sl@0
  1467
		TInt totalExpectedReproductionTime;
sl@0
  1468
		iTimesToneFinishedCalled++;
sl@0
  1469
		totalExpectedReproductionTime = iDuration * iTimesToneFinishedCalled * KMicroSecsInOneSec;
sl@0
  1470
		iEndTime.HomeTime();
sl@0
  1471
		iPlayToneTime = iEndTime.MicroSecondsFrom(iStartTime);
sl@0
  1472
		if(!iTonePlayedTwice)
sl@0
  1473
			{
sl@0
  1474
			INFO_PRINTF2(_L("DevSound called ToneFinished with error = %d"), aError);
sl@0
  1475
			INFO_PRINTF3(_L("Calling CMMFDevSound::PlayToneL using frequency = %d Hz and duration = %d secs "), iFrequencyTone1, iDuration);
sl@0
  1476
			TRAPD(err, iMMFDevSound->PlayToneL(iFrequencyTone1, iDuration*KMicroSecsInOneSec));
sl@0
  1477
			if (err != KErrNone)
sl@0
  1478
				{
sl@0
  1479
				ERR_PRINTF2(_L("CMMFDevSound::PlayToneL with error : %d!"), err);
sl@0
  1480
				StopTest(err);
sl@0
  1481
				}
sl@0
  1482
			iTonePlayedTwice = ETrue;
sl@0
  1483
			}
sl@0
  1484
		else if (iPlayToneTime < totalExpectedReproductionTime + (2*KPlayVarianceTime) && iPlayToneTime > totalExpectedReproductionTime - (2*KPlayVarianceTime))
sl@0
  1485
			{
sl@0
  1486
			INFO_PRINTF2(_L("DevSound called ToneFinished twice with error = %d"), aError);
sl@0
  1487
			INFO_PRINTF2(_L("Play time is %Ld microseconds"), iPlayToneTime.Int64());
sl@0
  1488
			StopTest();
sl@0
  1489
			}
sl@0
  1490
		else
sl@0
  1491
			{
sl@0
  1492
			ERR_PRINTF3(_L("Play time is %Ld microseconds and it should have been %d microseconds"), iPlayToneTime.Int64(), totalExpectedReproductionTime);
sl@0
  1493
			StopTest(KErrNone, EFail);
sl@0
  1494
			}
sl@0
  1495
		}
sl@0
  1496
	else
sl@0
  1497
		{
sl@0
  1498
		ERR_PRINTF2(_L("DevSound called ToneFinished with error = %d"), aError);
sl@0
  1499
		ERR_PRINTF2(_L("Expected error = %d"), KErrUnderflow);
sl@0
  1500
		StopTest(aError, EFail);
sl@0
  1501
		}
sl@0
  1502
	}
sl@0
  1503
sl@0
  1504
/*
sl@0
  1505
 *========================================================================================================
sl@0
  1506
 * MM-A3F-DEVSOUND-CHRTZ-TONE-0012
sl@0
  1507
 */
sl@0
  1508
RA3FDevSoundToneSetToneRepetitionsWhilePlayingTest::RA3FDevSoundToneSetToneRepetitionsWhilePlayingTest(const TDesC& aTestName)
sl@0
  1509
	:	RA3FDevSoundTestBase(aTestName),
sl@0
  1510
		iDuration(0),
sl@0
  1511
		iFrequencyTone1(0),
sl@0
  1512
		iRepeatTrailingSilence(0),
sl@0
  1513
		iRepeatCount(0)
sl@0
  1514
	{
sl@0
  1515
	}
sl@0
  1516
sl@0
  1517
RA3FDevSoundToneSetToneRepetitionsWhilePlayingTest* RA3FDevSoundToneSetToneRepetitionsWhilePlayingTest::NewL(const TDesC& aTestName)
sl@0
  1518
	{
sl@0
  1519
	RA3FDevSoundToneSetToneRepetitionsWhilePlayingTest * self = new(ELeave)RA3FDevSoundToneSetToneRepetitionsWhilePlayingTest(aTestName);
sl@0
  1520
	return self;
sl@0
  1521
	}
sl@0
  1522
sl@0
  1523
void RA3FDevSoundToneSetToneRepetitionsWhilePlayingTest::DoKickoffTestL()
sl@0
  1524
	{
sl@0
  1525
	if (!GetIntFromConfig(iTestStepName, KRepeatCount, iRepeatCount))
sl@0
  1526
		{
sl@0
  1527
		ERR_PRINTF2(KMsgErrorGetParameter, &KRepeatCount);
sl@0
  1528
		StopTest(KErrNotFound);
sl@0
  1529
		return;
sl@0
  1530
		}
sl@0
  1531
	if (!GetIntFromConfig(iTestStepName, KRepeatTrailingSilence, iRepeatTrailingSilence))
sl@0
  1532
		{
sl@0
  1533
		ERR_PRINTF2(KMsgErrorGetParameter, &KRepeatTrailingSilence);
sl@0
  1534
		StopTest(KErrNotFound);
sl@0
  1535
		return;
sl@0
  1536
		}
sl@0
  1537
	if (!GetIntFromConfig(iTestStepName, KDuration, iDuration))
sl@0
  1538
		{
sl@0
  1539
		ERR_PRINTF2(KMsgErrorGetParameter, &KDuration);
sl@0
  1540
		StopTest(KErrNotFound);
sl@0
  1541
		return;
sl@0
  1542
		}
sl@0
  1543
	if (!GetIntFromConfig(iTestStepName, KFrequencyTone1, iFrequencyTone1))
sl@0
  1544
		{
sl@0
  1545
		ERR_PRINTF2(KMsgErrorGetParameter, &KFrequencyTone1);
sl@0
  1546
		StopTest(KErrNotFound);
sl@0
  1547
		return;
sl@0
  1548
		}
sl@0
  1549
	iTimer = CPeriodic::NewL(CActive::EPriorityHigh);
sl@0
  1550
	}
sl@0
  1551
sl@0
  1552
void RA3FDevSoundToneSetToneRepetitionsWhilePlayingTest::Fsm(TMmfDevSoundEvent aDevSoundEvent, TInt aError)
sl@0
  1553
	{
sl@0
  1554
	switch (iDevSoundState)
sl@0
  1555
		{
sl@0
  1556
		case EStateCreated:
sl@0
  1557
			{
sl@0
  1558
			__ASSERT_ALWAYS((aError == KErrNone), Panic(_L("RA3FDevSoundToneSetToneRepetitionsWhilePlayingConfigurationTest"), EFsmIncorrectErrorPassed));
sl@0
  1559
			if(aDevSoundEvent == EEventInitialize)
sl@0
  1560
				{
sl@0
  1561
				INFO_PRINTF1(_L("Calling CMMFDevSound::InitializeL"));
sl@0
  1562
				TRAPD(err, iMMFDevSound->InitializeL(*this, EMMFStateTonePlaying));
sl@0
  1563
				if (err != KErrNone)
sl@0
  1564
					{
sl@0
  1565
					ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"), err);
sl@0
  1566
					StopTest(err);
sl@0
  1567
					break;
sl@0
  1568
					}
sl@0
  1569
				INFO_PRINTF1(_L("DevSound State: EStateInitializing"));
sl@0
  1570
				iDevSoundState = EStateInitializing;
sl@0
  1571
				}
sl@0
  1572
			else
sl@0
  1573
				{
sl@0
  1574
				ERR_PRINTF2(_L("DevSound EEventInitialize not received as expected. Received event: %d"), aDevSoundEvent);
sl@0
  1575
				StopTest(aError, EFail);
sl@0
  1576
				}
sl@0
  1577
			break;
sl@0
  1578
			}
sl@0
  1579
		case EStateInitializing:
sl@0
  1580
			{
sl@0
  1581
			if (aDevSoundEvent == EEventInitComplete && aError == KErrNone)
sl@0
  1582
				{
sl@0
  1583
				iMMFDevSound->SetVolume(iMMFDevSound->MaxVolume());
sl@0
  1584
				iStartTime.HomeTime();
sl@0
  1585
				INFO_PRINTF3(_L("Calling CMMFDevSound::PlayToneL %d Hz during %d secs "), iFrequencyTone1, iDuration);
sl@0
  1586
				TRAPD(err, iMMFDevSound->PlayToneL(iFrequencyTone1, iDuration*KMicroSecsInOneSec));
sl@0
  1587
				if (err != KErrNone)
sl@0
  1588
					{
sl@0
  1589
					ERR_PRINTF2(_L("CMMFDevSound::PlayToneL left with error : %d!"), err);
sl@0
  1590
					StopTest(err);
sl@0
  1591
					break;
sl@0
  1592
					}
sl@0
  1593
				StartTimer(KMicroSecsTwoSec);
sl@0
  1594
				INFO_PRINTF1(_L("DevSound State: EStatePlaying"));
sl@0
  1595
				iDevSoundState = EStatePlaying;
sl@0
  1596
				}
sl@0
  1597
			else if (aDevSoundEvent == EEventInitComplete && aError != KErrNone)
sl@0
  1598
				{
sl@0
  1599
				ERR_PRINTF2(_L("DevSound called CMMFDevSound::InitializeComplete with error = %d"), aError);
sl@0
  1600
				StopTest(aError);
sl@0
  1601
				}
sl@0
  1602
			else
sl@0
  1603
				{
sl@0
  1604
				ERR_PRINTF2(_L("DevSound EEventInitComplete not received as expected. Received event: %d"), aDevSoundEvent);
sl@0
  1605
				StopTest(aError, EFail);
sl@0
  1606
				}
sl@0
  1607
			break;
sl@0
  1608
			}
sl@0
  1609
		default:
sl@0
  1610
			{
sl@0
  1611
			ERR_PRINTF2(_L("Invalid DevSound state received: %d"), iDevSoundState);
sl@0
  1612
			StopTest(aError, EFail);
sl@0
  1613
			}
sl@0
  1614
		}
sl@0
  1615
	}
sl@0
  1616
sl@0
  1617
void RA3FDevSoundToneSetToneRepetitionsWhilePlayingTest::DoTimerCallback()
sl@0
  1618
	{
sl@0
  1619
	iTimer->Cancel();
sl@0
  1620
	INFO_PRINTF1(_L("DevSound Event: EEventTimerComplete"));
sl@0
  1621
	INFO_PRINTF3(_L("Calling CMMFDevSound::SetToneRepeats using RepeatCount = %d and RepeatTrailingSilence = %d microsecs"), iRepeatCount, iRepeatTrailingSilence);
sl@0
  1622
	iMMFDevSound->SetToneRepeats(iRepeatCount, iRepeatTrailingSilence);
sl@0
  1623
	}
sl@0
  1624
sl@0
  1625
void RA3FDevSoundToneSetToneRepetitionsWhilePlayingTest::ToneFinished(TInt aError)
sl@0
  1626
	{
sl@0
  1627
	INFO_PRINTF1(_L("========== DevSound ToneFinished() callback =========="));
sl@0
  1628
	const TInt KtimesPlayToneIsCalled = 2;
sl@0
  1629
	if (aError == KErrUnderflow)
sl@0
  1630
		{
sl@0
  1631
		iEndTime.HomeTime();
sl@0
  1632
		iPlayToneTime = iEndTime.MicroSecondsFrom(iStartTime);
sl@0
  1633
		TInt repeatTrailingSilenceToSecs = iRepeatTrailingSilence/KMicroSecsInOneSec;
sl@0
  1634
		TInt totalExpectedReproductionTime = (KtimesPlayToneIsCalled*iDuration+iRepeatCount*iDuration + (repeatTrailingSilenceToSecs*iRepeatCount))*KMicroSecsInOneSec;
sl@0
  1635
		if(iPlayToneTime < ((iDuration*KMicroSecsInOneSec) + KPlayVarianceTime)&& iPlayToneTime > (iDuration*KMicroSecsInOneSec) - KPlayVarianceTime)
sl@0
  1636
			{
sl@0
  1637
			INFO_PRINTF1(_L("First play tone succeded."));
sl@0
  1638
			INFO_PRINTF2(_L("Play time is %Ld microseconds"), iPlayToneTime.Int64());
sl@0
  1639
			TRAPD(err, iMMFDevSound->PlayToneL(iFrequencyTone1, iDuration*KMicroSecsInOneSec));
sl@0
  1640
			if (err != KErrNone)
sl@0
  1641
				{
sl@0
  1642
				ERR_PRINTF2(_L("CMMFDevSound::PlayToneL failed with error : %d!"), err);
sl@0
  1643
				StopTest(err);
sl@0
  1644
				}
sl@0
  1645
			}
sl@0
  1646
		else if(iPlayToneTime < totalExpectedReproductionTime + KPlayVarianceTime && iPlayToneTime > totalExpectedReproductionTime - KPlayVarianceTime)
sl@0
  1647
			{
sl@0
  1648
			INFO_PRINTF1(_L("Play tone repeats succeded."));
sl@0
  1649
			INFO_PRINTF2(_L("Play time is %Ld microseconds"), iPlayToneTime.Int64());
sl@0
  1650
			StopTest();
sl@0
  1651
			}
sl@0
  1652
		else
sl@0
  1653
			{
sl@0
  1654
			ERR_PRINTF1(_L("Play tone repeats did not work as planned."));
sl@0
  1655
			ERR_PRINTF3(_L("Play time is %Ld microseconds and it should have been %d microseconds"), iPlayToneTime.Int64(), totalExpectedReproductionTime);
sl@0
  1656
			StopTest(KErrNone, EFail);
sl@0
  1657
			}
sl@0
  1658
		}
sl@0
  1659
	else
sl@0
  1660
		{
sl@0
  1661
		ERR_PRINTF2(_L("DevSound called ToneFinished with error = %d"), aError);
sl@0
  1662
		ERR_PRINTF2(_L("Expected error = %d"), KErrUnderflow);
sl@0
  1663
		StopTest(aError, EFail);
sl@0
  1664
		}
sl@0
  1665
	}
sl@0
  1666
sl@0
  1667
/*
sl@0
  1668
 *========================================================================================================
sl@0
  1669
 * MM-A3F-DEVSOUND-CHRTZ-TONE-0013
sl@0
  1670
 */
sl@0
  1671
RA3FDevSoundToneSetDTMFLengthsWhilePlayingTest::RA3FDevSoundToneSetDTMFLengthsWhilePlayingTest(const TDesC& aTestName)
sl@0
  1672
	:	RA3FDevSoundTestBase(aTestName),
sl@0
  1673
		iFirstToneFinishedCall(EFalse),
sl@0
  1674
		iToneOnLength(0), iToneOffLength(0),
sl@0
  1675
		iPauseLength(0), iDTMFString(KNullDesC),
sl@0
  1676
		iDTMFPauses(0), iDTMFTones(0),
sl@0
  1677
		iTotalExpectedPlayToneTime(0)
sl@0
  1678
	{
sl@0
  1679
	}
sl@0
  1680
RA3FDevSoundToneSetDTMFLengthsWhilePlayingTest* RA3FDevSoundToneSetDTMFLengthsWhilePlayingTest::NewL(const TDesC& aTestName)
sl@0
  1681
	{
sl@0
  1682
	RA3FDevSoundToneSetDTMFLengthsWhilePlayingTest * self = new(ELeave)RA3FDevSoundToneSetDTMFLengthsWhilePlayingTest(aTestName);
sl@0
  1683
	return self;
sl@0
  1684
	}
sl@0
  1685
sl@0
  1686
void RA3FDevSoundToneSetDTMFLengthsWhilePlayingTest::DoKickoffTestL()
sl@0
  1687
	{
sl@0
  1688
	if (!GetIntFromConfig(iTestStepName, KToneOnLength, iToneOnLength))
sl@0
  1689
		{
sl@0
  1690
		ERR_PRINTF2(KMsgErrorGetParameter, &KToneOnLength);
sl@0
  1691
		StopTest(KErrNotFound);
sl@0
  1692
		return;
sl@0
  1693
		}
sl@0
  1694
	if (!GetIntFromConfig(iTestStepName, KToneOffLength, iToneOffLength))
sl@0
  1695
		{
sl@0
  1696
		ERR_PRINTF2(KMsgErrorGetParameter, &KToneOffLength);
sl@0
  1697
		StopTest(KErrNotFound);
sl@0
  1698
		return;
sl@0
  1699
		}
sl@0
  1700
	if (!GetIntFromConfig(iTestStepName, KPauseLength, iPauseLength))
sl@0
  1701
		{
sl@0
  1702
		ERR_PRINTF2(KMsgErrorGetParameter, &KPauseLength);
sl@0
  1703
		StopTest(KErrNotFound);
sl@0
  1704
		return;
sl@0
  1705
		}
sl@0
  1706
	TPtrC DTMF;
sl@0
  1707
	if (!GetStringFromConfig(iTestStepName, KDTMFString, DTMF))
sl@0
  1708
		{
sl@0
  1709
		ERR_PRINTF2(KMsgErrorGetParameter, &KDTMFString);
sl@0
  1710
		StopTest(KErrNotFound);
sl@0
  1711
		return;
sl@0
  1712
		}
sl@0
  1713
	iDTMFString.Copy(DTMF);
sl@0
  1714
	for(TInt i =0 ; i< iDTMFString.Length() ; i++)
sl@0
  1715
		{
sl@0
  1716
		if (iDTMFString[i] == ',')
sl@0
  1717
			{
sl@0
  1718
			iDTMFPauses++;
sl@0
  1719
			}
sl@0
  1720
		else
sl@0
  1721
			{
sl@0
  1722
			iDTMFTones++;
sl@0
  1723
			}
sl@0
  1724
		}
sl@0
  1725
	iTimer = CPeriodic::NewL(CActive::EPriorityHigh);
sl@0
  1726
	}
sl@0
  1727
sl@0
  1728
void RA3FDevSoundToneSetDTMFLengthsWhilePlayingTest::Fsm(TMmfDevSoundEvent aDevSoundEvent, TInt aError)
sl@0
  1729
	{
sl@0
  1730
	switch (iDevSoundState)
sl@0
  1731
		{
sl@0
  1732
		case EStateCreated:
sl@0
  1733
			{
sl@0
  1734
			__ASSERT_ALWAYS((aError == KErrNone), Panic(_L("RA3FDevSoundToneSetDTMFToneRepetitionsWhilePlayingConfigurationTest"), EFsmIncorrectErrorPassed));
sl@0
  1735
			if(aDevSoundEvent == EEventInitialize)
sl@0
  1736
				{
sl@0
  1737
				INFO_PRINTF1(_L("Calling CMMFDevSound::InitializeL"));
sl@0
  1738
				TRAPD(err, iMMFDevSound->InitializeL(*this, EMMFStateTonePlaying));
sl@0
  1739
				if (err != KErrNone)
sl@0
  1740
					{
sl@0
  1741
					ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"), err);
sl@0
  1742
					StopTest(err);
sl@0
  1743
					break;
sl@0
  1744
					}
sl@0
  1745
				INFO_PRINTF1(_L("DevSound State: EStateInitializing"));
sl@0
  1746
				iDevSoundState = EStateInitializing;
sl@0
  1747
				}
sl@0
  1748
			else
sl@0
  1749
				{
sl@0
  1750
				ERR_PRINTF2(_L("DevSound EEventInitialize not received as expected. Received event: %d"), aDevSoundEvent);
sl@0
  1751
				StopTest(aError, EFail);
sl@0
  1752
				}
sl@0
  1753
			break;
sl@0
  1754
			}
sl@0
  1755
		case EStateInitializing:
sl@0
  1756
			{
sl@0
  1757
			if (aDevSoundEvent == EEventInitComplete && aError == KErrNone)
sl@0
  1758
				{
sl@0
  1759
				iMMFDevSound->SetVolume(iMMFDevSound->MaxVolume());
sl@0
  1760
				iStartTime.HomeTime();
sl@0
  1761
				INFO_PRINTF2(_L("Calling CMMFDevSound::L %S"), &iDTMFString);
sl@0
  1762
				TRAPD(err, iMMFDevSound->PlayDTMFStringL(iDTMFString));
sl@0
  1763
				if (err != KErrNone)
sl@0
  1764
					{
sl@0
  1765
					ERR_PRINTF2(_L("CMMFDevSound::PlayDTMFStringL left with error : %d!"), err);
sl@0
  1766
					StopTest(err);
sl@0
  1767
					break;
sl@0
  1768
					}
sl@0
  1769
				StartTimer(KMicroSecsTwoSec);
sl@0
  1770
				INFO_PRINTF1(_L("DevSound State: EStatePlaying"));
sl@0
  1771
				iDevSoundState=EStatePlaying;
sl@0
  1772
				}
sl@0
  1773
			else if (aDevSoundEvent == EEventInitComplete && aError != KErrNone)
sl@0
  1774
				{
sl@0
  1775
				ERR_PRINTF2(_L("DevSound called CMMFDevSound::InitializeComplete with error = %d"), aError);
sl@0
  1776
				StopTest(aError);
sl@0
  1777
				}
sl@0
  1778
			else
sl@0
  1779
				{
sl@0
  1780
				ERR_PRINTF2(_L("DevSound EEventInitComplete not received as expected. Received event: %d"), aDevSoundEvent);
sl@0
  1781
				StopTest(aError, EFail);
sl@0
  1782
				}
sl@0
  1783
			break;
sl@0
  1784
			}
sl@0
  1785
		default:
sl@0
  1786
			{
sl@0
  1787
			ERR_PRINTF2(_L("Invalid DevSound state received: %d"), iDevSoundState);
sl@0
  1788
			StopTest(aError, EFail);
sl@0
  1789
			}
sl@0
  1790
		}
sl@0
  1791
	}
sl@0
  1792
sl@0
  1793
void RA3FDevSoundToneSetDTMFLengthsWhilePlayingTest::DoTimerCallback()
sl@0
  1794
	{
sl@0
  1795
	iTimer->Cancel();
sl@0
  1796
	INFO_PRINTF1(_L("DevSound Event: EEventTimerComplete"));
sl@0
  1797
	TTimeIntervalMicroSeconds32 ToneOnLength(iToneOnLength);
sl@0
  1798
	TTimeIntervalMicroSeconds32 ToneOffLength(iToneOffLength);
sl@0
  1799
	TTimeIntervalMicroSeconds32 PauseLength(iPauseLength);
sl@0
  1800
	INFO_PRINTF4(_L("Calling CMMFDevSound::SetDTMFLengths. ToneOnLength = %d, ToneOffLength = %d and PauseLength = %d"), ToneOnLength.Int(), ToneOffLength.Int(), PauseLength.Int());
sl@0
  1801
	iMMFDevSound->SetDTMFLengths(ToneOnLength, ToneOffLength, PauseLength);
sl@0
  1802
	}
sl@0
  1803
sl@0
  1804
void RA3FDevSoundToneSetDTMFLengthsWhilePlayingTest::ToneFinished(TInt aError)
sl@0
  1805
	{
sl@0
  1806
	INFO_PRINTF1(_L("========== DevSound ToneFinished() callback =========="));
sl@0
  1807
	if (aError == KErrUnderflow)
sl@0
  1808
		{
sl@0
  1809
		iEndTime.HomeTime();
sl@0
  1810
		iPlayToneTime = iEndTime.MicroSecondsFrom(iStartTime);
sl@0
  1811
		if (!iFirstToneFinishedCall)
sl@0
  1812
			{
sl@0
  1813
			INFO_PRINTF1(_L("First play tone succeded"));
sl@0
  1814
			INFO_PRINTF2(_L("Play time is %Ld microseconds"), iPlayToneTime.Int64());
sl@0
  1815
			iFirstToneFinishedCall = ETrue;
sl@0
  1816
			INFO_PRINTF2(_L("Calling CMMFDevSound::PlayDTMFStringL %S"), &iDTMFString);
sl@0
  1817
			TRAPD(err, iMMFDevSound->PlayDTMFStringL(iDTMFString));
sl@0
  1818
			if (err != KErrNone)
sl@0
  1819
				{
sl@0
  1820
				ERR_PRINTF2(_L("CMMFDevSound::PlayDTMFStringL left with error = %d"), err);
sl@0
  1821
				StopTest(err);
sl@0
  1822
				}
sl@0
  1823
			iTotalExpectedPlayToneTime = iToneOnLength*iDTMFTones + iToneOffLength * iDTMFTones + iDTMFPauses * iPauseLength + iPlayToneTime.Int64();
sl@0
  1824
			return;
sl@0
  1825
			}
sl@0
  1826
		if (iPlayToneTime.Int64() < iTotalExpectedPlayToneTime + KPlayVarianceTime && iPlayToneTime.Int64() > iTotalExpectedPlayToneTime - KPlayVarianceTime)
sl@0
  1827
			{
sl@0
  1828
			INFO_PRINTF1(_L("Calling CMMFDevSound::SetDTMFLengths succeded."));
sl@0
  1829
			INFO_PRINTF2(_L("Play time is %Ld microseconds"), iPlayToneTime.Int64());
sl@0
  1830
			StopTest();
sl@0
  1831
			}
sl@0
  1832
		else
sl@0
  1833
			{
sl@0
  1834
			ERR_PRINTF2(_L("Calling CMMFDevSound::SetDTMFLengths failed with %Ld"), iPlayToneTime.Int64());
sl@0
  1835
			ERR_PRINTF2(_L("Expected time %d"), iTotalExpectedPlayToneTime);
sl@0
  1836
			StopTest(KErrNone, EFail);
sl@0
  1837
			}
sl@0
  1838
		}
sl@0
  1839
	else
sl@0
  1840
		{
sl@0
  1841
		ERR_PRINTF2(_L("DevSound called ToneFinished with error = %d"), aError);
sl@0
  1842
		ERR_PRINTF2(_L("Expected error = %Ld"), KErrUnderflow);
sl@0
  1843
		StopTest(aError, EFail);
sl@0
  1844
		}
sl@0
  1845
	}
sl@0
  1846
sl@0
  1847
/*
sl@0
  1848
 *========================================================================================================
sl@0
  1849
 * MM-A3F-DEVSOUND-CHRTZ-TONE-0014
sl@0
  1850
 */
sl@0
  1851
RA3FDevSoundToneSetToneRepetitionsNotPlayingTonesModeTest::RA3FDevSoundToneSetToneRepetitionsNotPlayingTonesModeTest(const TDesC& aTestName)
sl@0
  1852
	:	RA3FDevSoundTestBase(aTestName), iDuration(0),
sl@0
  1853
		iFrequencyTone1(0),
sl@0
  1854
		iRepeatTrailingSilence(0), iRepeatCount(0),
sl@0
  1855
		iInitializedToPlayTones(EFalse)
sl@0
  1856
	{
sl@0
  1857
	}
sl@0
  1858
sl@0
  1859
RA3FDevSoundToneSetToneRepetitionsNotPlayingTonesModeTest* RA3FDevSoundToneSetToneRepetitionsNotPlayingTonesModeTest::NewL(const TDesC& aTestName)
sl@0
  1860
	{
sl@0
  1861
	RA3FDevSoundToneSetToneRepetitionsNotPlayingTonesModeTest * self = new(ELeave)RA3FDevSoundToneSetToneRepetitionsNotPlayingTonesModeTest(aTestName);
sl@0
  1862
	return self;
sl@0
  1863
	}
sl@0
  1864
sl@0
  1865
void RA3FDevSoundToneSetToneRepetitionsNotPlayingTonesModeTest::DoKickoffTestL()
sl@0
  1866
	{
sl@0
  1867
	if (!GetIntFromConfig(iTestStepName, KRepeatCount, iRepeatCount))
sl@0
  1868
		{
sl@0
  1869
		ERR_PRINTF2(KMsgErrorGetParameter, &KRepeatCount);
sl@0
  1870
		StopTest(KErrNotFound);
sl@0
  1871
		return;
sl@0
  1872
		}
sl@0
  1873
	if (!GetIntFromConfig(iTestStepName, KRepeatTrailingSilence, iRepeatTrailingSilence))
sl@0
  1874
		{
sl@0
  1875
		ERR_PRINTF2(KMsgErrorGetParameter, &KRepeatTrailingSilence);
sl@0
  1876
		StopTest(KErrNotFound);
sl@0
  1877
		return;
sl@0
  1878
		}
sl@0
  1879
	if (!GetIntFromConfig(iTestStepName, KDuration, iDuration))
sl@0
  1880
		{
sl@0
  1881
		ERR_PRINTF2(KMsgErrorGetParameter, &KDuration);
sl@0
  1882
		StopTest(KErrNotFound);
sl@0
  1883
		return;
sl@0
  1884
		}
sl@0
  1885
	if (!GetIntFromConfig(iTestStepName, KFrequencyTone1, iFrequencyTone1))
sl@0
  1886
		{
sl@0
  1887
		ERR_PRINTF2(KMsgErrorGetParameter, &KFrequencyTone1);
sl@0
  1888
		StopTest(KErrNotFound);
sl@0
  1889
		return;
sl@0
  1890
		}
sl@0
  1891
	}
sl@0
  1892
sl@0
  1893
void RA3FDevSoundToneSetToneRepetitionsNotPlayingTonesModeTest::Fsm(TMmfDevSoundEvent aDevSoundEvent, TInt aError)
sl@0
  1894
	{
sl@0
  1895
	switch (iDevSoundState)
sl@0
  1896
		{
sl@0
  1897
		case EStateCreated:
sl@0
  1898
			{
sl@0
  1899
			__ASSERT_ALWAYS((aError == KErrNone), Panic(_L("RA3FDevSoundToneSetToneRepetitionsNotPlayingTonesModeConfigurationTest"), EFsmIncorrectErrorPassed));
sl@0
  1900
			if(aDevSoundEvent == EEventInitialize)
sl@0
  1901
				{
sl@0
  1902
				INFO_PRINTF1(_L("Calling CMMFDevSound::InitializeL"));
sl@0
  1903
				TRAPD(err, iMMFDevSound->InitializeL(*this, EMMFStatePlaying));
sl@0
  1904
				if (err != KErrNone)
sl@0
  1905
					{
sl@0
  1906
					ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"), err);
sl@0
  1907
					StopTest(err);
sl@0
  1908
					break;
sl@0
  1909
					}
sl@0
  1910
				INFO_PRINTF1(_L("DevSound State: EStateInitializing"));
sl@0
  1911
				iDevSoundState = EStateInitializing;
sl@0
  1912
				}
sl@0
  1913
			else
sl@0
  1914
				{
sl@0
  1915
				ERR_PRINTF2(_L("DevSound EEventInitialize not received as expected. Received event: %d"), aDevSoundEvent);
sl@0
  1916
				StopTest(aError, EFail);
sl@0
  1917
				}
sl@0
  1918
			break;
sl@0
  1919
			}
sl@0
  1920
		case EStateInitializing:
sl@0
  1921
			{
sl@0
  1922
			if (aDevSoundEvent == EEventInitComplete && aError == KErrNone)
sl@0
  1923
				{
sl@0
  1924
				if(!iInitializedToPlayTones)
sl@0
  1925
					{
sl@0
  1926
					INFO_PRINTF3(_L("Calling CMMFDevSound::SetToneRepeats using RepeatCount = %d and RepeatTrailingSilence = %d microsecs"), iRepeatCount, iRepeatTrailingSilence);
sl@0
  1927
					iMMFDevSound->SetToneRepeats(iRepeatCount, iRepeatTrailingSilence);
sl@0
  1928
					INFO_PRINTF1(_L("Calling CMMFDevSound::InitializeL for playing tones"));
sl@0
  1929
					TRAPD(err, iMMFDevSound->InitializeL(*this, EMMFStateTonePlaying));
sl@0
  1930
					if (err != KErrNone)
sl@0
  1931
						{
sl@0
  1932
						ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"), err);
sl@0
  1933
						StopTest(err);
sl@0
  1934
						break;
sl@0
  1935
						}
sl@0
  1936
					iInitializedToPlayTones = ETrue;
sl@0
  1937
					}
sl@0
  1938
				else
sl@0
  1939
					{
sl@0
  1940
					iMMFDevSound->SetVolume(iMMFDevSound->MaxVolume());
sl@0
  1941
					iStartTime.HomeTime();
sl@0
  1942
					INFO_PRINTF3(_L("Calling CMMFDevSound::PlayToneL %d Hz during %d secs "), iFrequencyTone1, iDuration);
sl@0
  1943
					TRAPD(err, iMMFDevSound->PlayToneL(iFrequencyTone1, iDuration*KMicroSecsInOneSec));
sl@0
  1944
					if (err != KErrNone)
sl@0
  1945
						{
sl@0
  1946
						ERR_PRINTF2(_L("CMMFDevSound::PlayToneL left with error : %d!"), err);
sl@0
  1947
						StopTest(err);
sl@0
  1948
						break;
sl@0
  1949
						}
sl@0
  1950
					INFO_PRINTF1(_L("DevSound State: EStatePlaying"));
sl@0
  1951
					iDevSoundState = EStatePlaying;
sl@0
  1952
					}
sl@0
  1953
				}
sl@0
  1954
			else if (aDevSoundEvent == EEventInitComplete && aError != KErrNone)
sl@0
  1955
				{
sl@0
  1956
				ERR_PRINTF2(_L("DevSound called CMMFDevSound::InitializeComplete with error = %d"), aError);
sl@0
  1957
				StopTest(aError);
sl@0
  1958
				}
sl@0
  1959
			else
sl@0
  1960
				{
sl@0
  1961
				ERR_PRINTF2(_L("DevSound EEventInitComplete not received as expected. Received event: %d"), aDevSoundEvent);
sl@0
  1962
				StopTest(aError, EFail);
sl@0
  1963
				}
sl@0
  1964
			break;
sl@0
  1965
			}
sl@0
  1966
		default:
sl@0
  1967
			{
sl@0
  1968
			ERR_PRINTF2(_L("Invalid DevSound state received: %d"), iDevSoundState);
sl@0
  1969
			StopTest(aError, EFail);
sl@0
  1970
			}
sl@0
  1971
		}
sl@0
  1972
	}
sl@0
  1973
sl@0
  1974
sl@0
  1975
void RA3FDevSoundToneSetToneRepetitionsNotPlayingTonesModeTest::ToneFinished(TInt aError)
sl@0
  1976
	{
sl@0
  1977
	INFO_PRINTF1(_L("========== DevSound ToneFinished() callback =========="));
sl@0
  1978
	if (aError == KErrUnderflow)
sl@0
  1979
		{
sl@0
  1980
		iEndTime.HomeTime();
sl@0
  1981
		iPlayToneTime = iEndTime.MicroSecondsFrom(iStartTime);
sl@0
  1982
		TInt repeatTrailingSilenceToSecs = iRepeatTrailingSilence/KMicroSecsInOneSec;
sl@0
  1983
		TInt totalExpectedReproductionTime = (iDuration + iRepeatCount * iDuration+ (repeatTrailingSilenceToSecs*iRepeatCount)) * KMicroSecsInOneSec;
sl@0
  1984
		if(iPlayToneTime < (totalExpectedReproductionTime + KPlayVarianceTime) && iPlayToneTime > (totalExpectedReproductionTime - KPlayVarianceTime))
sl@0
  1985
			{
sl@0
  1986
			INFO_PRINTF1(_L("Play tone repeats succeded."));
sl@0
  1987
			INFO_PRINTF2(_L("Play time is %Ld microseconds"), iPlayToneTime.Int64());
sl@0
  1988
			StopTest();
sl@0
  1989
			}
sl@0
  1990
		else
sl@0
  1991
			{
sl@0
  1992
			ERR_PRINTF1(_L("Play tone repeats did not work as planned."));
sl@0
  1993
			ERR_PRINTF3(_L("Play time is %Ld microseconds and it should have been %d microseconds"), iPlayToneTime.Int64(), totalExpectedReproductionTime);
sl@0
  1994
			StopTest(KErrNone, EFail);
sl@0
  1995
			}
sl@0
  1996
		}
sl@0
  1997
	else
sl@0
  1998
		{
sl@0
  1999
		ERR_PRINTF2(_L("DevSound called ToneFinished with error = %d"), aError);
sl@0
  2000
		ERR_PRINTF2(_L("Expected error = %d"), KErrUnderflow);
sl@0
  2001
		StopTest(aError, EFail);
sl@0
  2002
		}
sl@0
  2003
	}
sl@0
  2004
sl@0
  2005
/*
sl@0
  2006
 *========================================================================================================
sl@0
  2007
 * MM-A3F-DEVSOUND-CHRTZ-TONE-0015
sl@0
  2008
 */
sl@0
  2009
RA3FDevSoundToneSetDTMFLengthsNotPlayingTonesModeTest::RA3FDevSoundToneSetDTMFLengthsNotPlayingTonesModeTest(const TDesC& aTestName)
sl@0
  2010
	:	RA3FDevSoundTestBase(aTestName), iInitializedToPlayTones(EFalse),
sl@0
  2011
		iDTMFString(KNullDesC), iToneOnLength(0),
sl@0
  2012
		iToneOffLength(0), iPauseLength(0),
sl@0
  2013
		iDTMFPauses(0), iDTMFTones(0)
sl@0
  2014
sl@0
  2015
	{
sl@0
  2016
	}
sl@0
  2017
sl@0
  2018
RA3FDevSoundToneSetDTMFLengthsNotPlayingTonesModeTest* RA3FDevSoundToneSetDTMFLengthsNotPlayingTonesModeTest::NewL(const TDesC& aTestName)
sl@0
  2019
	{
sl@0
  2020
	RA3FDevSoundToneSetDTMFLengthsNotPlayingTonesModeTest * self = new(ELeave)RA3FDevSoundToneSetDTMFLengthsNotPlayingTonesModeTest(aTestName);
sl@0
  2021
	return self;
sl@0
  2022
	}
sl@0
  2023
sl@0
  2024
void RA3FDevSoundToneSetDTMFLengthsNotPlayingTonesModeTest::DoKickoffTestL()
sl@0
  2025
	{
sl@0
  2026
	if (!GetIntFromConfig(iTestStepName, KToneOnLength, iToneOnLength))
sl@0
  2027
		{
sl@0
  2028
		ERR_PRINTF2(KMsgErrorGetParameter, &KToneOnLength);
sl@0
  2029
		StopTest(KErrNotFound);
sl@0
  2030
		return;
sl@0
  2031
		}
sl@0
  2032
	if (!GetIntFromConfig(iTestStepName, KToneOffLength, iToneOffLength))
sl@0
  2033
		{
sl@0
  2034
		ERR_PRINTF2(KMsgErrorGetParameter, &KToneOffLength);
sl@0
  2035
		StopTest(KErrNotFound);
sl@0
  2036
		return;
sl@0
  2037
		}
sl@0
  2038
	if (!GetIntFromConfig(iTestStepName, KPauseLength, iPauseLength))
sl@0
  2039
		{
sl@0
  2040
		ERR_PRINTF2(KMsgErrorGetParameter, &KPauseLength);
sl@0
  2041
		StopTest(KErrNotFound);
sl@0
  2042
		return;
sl@0
  2043
		}
sl@0
  2044
	TPtrC DTMF;
sl@0
  2045
	if (!GetStringFromConfig(iTestStepName, KDTMFString, DTMF))
sl@0
  2046
		{
sl@0
  2047
		ERR_PRINTF2(KMsgErrorGetParameter, &KDTMFString);
sl@0
  2048
		StopTest(KErrNotFound);
sl@0
  2049
		return;
sl@0
  2050
		}
sl@0
  2051
	iDTMFString.Copy(DTMF);
sl@0
  2052
	for(TInt i =0 ; i< iDTMFString.Length() ; i++)
sl@0
  2053
		{
sl@0
  2054
		if (iDTMFString[i] == ',')
sl@0
  2055
			{
sl@0
  2056
			iDTMFPauses++;
sl@0
  2057
			}
sl@0
  2058
		else
sl@0
  2059
			{
sl@0
  2060
			iDTMFTones++;
sl@0
  2061
			}
sl@0
  2062
		}
sl@0
  2063
	}
sl@0
  2064
sl@0
  2065
void RA3FDevSoundToneSetDTMFLengthsNotPlayingTonesModeTest::Fsm(TMmfDevSoundEvent aDevSoundEvent, TInt aError)
sl@0
  2066
	{
sl@0
  2067
	switch (iDevSoundState)
sl@0
  2068
		{
sl@0
  2069
		case EStateCreated:
sl@0
  2070
			{
sl@0
  2071
			__ASSERT_ALWAYS((aError == KErrNone), Panic(_L("RA3FDevSoundToneSetDTMFLengthsNotPlayingTonesModeConfigurationTest"), EFsmIncorrectErrorPassed));
sl@0
  2072
			if(aDevSoundEvent == EEventInitialize)
sl@0
  2073
				{
sl@0
  2074
				INFO_PRINTF1(_L("Calling CMMFDevSound::InitializeL"));
sl@0
  2075
				TRAPD(err, iMMFDevSound->InitializeL(*this, EMMFStateRecording));
sl@0
  2076
				if (err != KErrNone)
sl@0
  2077
					{
sl@0
  2078
					ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"), err);
sl@0
  2079
					StopTest(err);
sl@0
  2080
					break;
sl@0
  2081
					}
sl@0
  2082
				INFO_PRINTF1(_L("DevSound State: EStateInitializing"));
sl@0
  2083
				iDevSoundState = EStateInitializing;
sl@0
  2084
				}
sl@0
  2085
			else
sl@0
  2086
				{
sl@0
  2087
				ERR_PRINTF2(_L("DevSound EEventInitialize not received as expected. Received event: %d"),  aDevSoundEvent);
sl@0
  2088
				StopTest(aError, EFail);
sl@0
  2089
				}
sl@0
  2090
			break;
sl@0
  2091
			}
sl@0
  2092
		case EStateInitializing:
sl@0
  2093
			{
sl@0
  2094
			if (aDevSoundEvent == EEventInitComplete && aError == KErrNone)
sl@0
  2095
				{
sl@0
  2096
				if(!iInitializedToPlayTones)
sl@0
  2097
					{
sl@0
  2098
					TTimeIntervalMicroSeconds32 ToneOnLength(iToneOnLength);
sl@0
  2099
					TTimeIntervalMicroSeconds32 ToneOffLength(iToneOffLength);
sl@0
  2100
					TTimeIntervalMicroSeconds32 PauseLength(iPauseLength);
sl@0
  2101
					INFO_PRINTF4(_L("Calling CMMFDevSound::SetDTMFLengths. ToneOnLength = %d, ToneOffLength = %d and PauseLength = %d"), ToneOnLength.Int(), ToneOffLength.Int(), PauseLength.Int());
sl@0
  2102
					iMMFDevSound->SetDTMFLengths(ToneOnLength, ToneOffLength, PauseLength);
sl@0
  2103
					INFO_PRINTF1(_L("Calling CMMFDevSound::InitializeL"));
sl@0
  2104
					TRAPD(err, iMMFDevSound->InitializeL(*this, EMMFStateTonePlaying));
sl@0
  2105
					if (err != KErrNone)
sl@0
  2106
						{
sl@0
  2107
						ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"), err);
sl@0
  2108
						StopTest(err);
sl@0
  2109
						break;
sl@0
  2110
						}
sl@0
  2111
					iInitializedToPlayTones = ETrue;
sl@0
  2112
					}
sl@0
  2113
				else
sl@0
  2114
					{
sl@0
  2115
					iMMFDevSound->SetVolume(iMMFDevSound->MaxVolume());
sl@0
  2116
					iStartTime.HomeTime();
sl@0
  2117
					INFO_PRINTF2(_L("Calling CMMFDevSound::PlayDTMFStringL %S"), &iDTMFString);
sl@0
  2118
					TRAPD(err, iMMFDevSound->PlayDTMFStringL(iDTMFString));
sl@0
  2119
					if (err != KErrNone)
sl@0
  2120
						{
sl@0
  2121
						ERR_PRINTF2(_L("Play DTMF string failed with error : %d!"), err);
sl@0
  2122
						StopTest(err);
sl@0
  2123
						break;
sl@0
  2124
						}
sl@0
  2125
					INFO_PRINTF1(_L("DevSound State: EStatePlaying"));
sl@0
  2126
					iDevSoundState = EStatePlaying;
sl@0
  2127
					}
sl@0
  2128
				}
sl@0
  2129
			else if (aDevSoundEvent == EEventInitComplete && aError != KErrNone)
sl@0
  2130
				{
sl@0
  2131
				ERR_PRINTF2(_L("DevSound called CMMFDevSound::InitializeComplete with error = %d"), aError);
sl@0
  2132
				StopTest(aError);
sl@0
  2133
				}
sl@0
  2134
			else
sl@0
  2135
				{
sl@0
  2136
				ERR_PRINTF2(_L("DevSound EEventInitComplete not received as expected. Received event: %d"), aDevSoundEvent);
sl@0
  2137
				StopTest(aError, EFail);
sl@0
  2138
				}
sl@0
  2139
			break;
sl@0
  2140
			}
sl@0
  2141
		default:
sl@0
  2142
			{
sl@0
  2143
			ERR_PRINTF2(_L("Invalid DevSound state received: %d"), iDevSoundState);
sl@0
  2144
			StopTest(aError, EFail);
sl@0
  2145
			}
sl@0
  2146
		}
sl@0
  2147
	}
sl@0
  2148
sl@0
  2149
void RA3FDevSoundToneSetDTMFLengthsNotPlayingTonesModeTest::ToneFinished(TInt aError)
sl@0
  2150
	{
sl@0
  2151
	INFO_PRINTF1(_L("========== DevSound ToneFinished() callback =========="));
sl@0
  2152
	if (aError == KErrUnderflow)
sl@0
  2153
		{
sl@0
  2154
		iEndTime.HomeTime();
sl@0
  2155
		iPlayToneTime = iEndTime.MicroSecondsFrom(iStartTime);
sl@0
  2156
		TInt totalExpectedReproductionTime = iToneOnLength*iDTMFTones + iToneOffLength * iDTMFTones + iDTMFPauses * iPauseLength;
sl@0
  2157
		if (iPlayToneTime.Int64() < totalExpectedReproductionTime + KPlayVarianceTime && iPlayToneTime.Int64() > totalExpectedReproductionTime - KPlayVarianceTime)
sl@0
  2158
			{
sl@0
  2159
			INFO_PRINTF1(_L("CMMFDevSound::SetDTMFLengths settings were remembered after re-initialization."));
sl@0
  2160
			INFO_PRINTF2(_L("Play time is %Ld microseconds"), iPlayToneTime.Int64());
sl@0
  2161
			StopTest();
sl@0
  2162
			}
sl@0
  2163
		else
sl@0
  2164
			{
sl@0
  2165
			ERR_PRINTF1(_L("CMMFDevSound::SetDTMFLengths settings were not remembered after re-initialization."));
sl@0
  2166
			ERR_PRINTF2(_L("Expected time %d"), totalExpectedReproductionTime);
sl@0
  2167
			StopTest(KErrNone, EFail);
sl@0
  2168
			}
sl@0
  2169
		}
sl@0
  2170
	else
sl@0
  2171
		{
sl@0
  2172
		ERR_PRINTF2(_L("DevSound called ToneFinished with error = %d"), aError);
sl@0
  2173
		ERR_PRINTF2(_L("Expected error = %d"), KErrUnderflow);
sl@0
  2174
		StopTest(aError, EFail);
sl@0
  2175
		}
sl@0
  2176
	}
sl@0
  2177
sl@0
  2178
/*
sl@0
  2179
 *========================================================================================================
sl@0
  2180
 * MM-A3F-DEVSOUND-CHRTZ-TONE-0016
sl@0
  2181
 */
sl@0
  2182
RA3FDevSoundToneSetConfigWhilePlayingTest::RA3FDevSoundToneSetConfigWhilePlayingTest(const TDesC& aTestName)
sl@0
  2183
	:	RA3FDevSoundTestBase(aTestName), iDuration(0),
sl@0
  2184
		iVolume(0), iFrequencyTone1(0),
sl@0
  2185
		iSampleRate(0), iChannels(0)
sl@0
  2186
	{
sl@0
  2187
	}
sl@0
  2188
sl@0
  2189
RA3FDevSoundToneSetConfigWhilePlayingTest* RA3FDevSoundToneSetConfigWhilePlayingTest::NewL(const TDesC& aTestName)
sl@0
  2190
	{
sl@0
  2191
	RA3FDevSoundToneSetConfigWhilePlayingTest * self = new(ELeave)RA3FDevSoundToneSetConfigWhilePlayingTest(aTestName);
sl@0
  2192
	return self;
sl@0
  2193
	}
sl@0
  2194
sl@0
  2195
void RA3FDevSoundToneSetConfigWhilePlayingTest::DoKickoffTestL()
sl@0
  2196
	{
sl@0
  2197
	if (!GetIntFromConfig(iTestStepName, KSampleRate, iSampleRate))
sl@0
  2198
		{
sl@0
  2199
		ERR_PRINTF2(KMsgErrorGetParameter, &KSampleRate);
sl@0
  2200
		StopTest(KErrNotFound);
sl@0
  2201
		return;
sl@0
  2202
		}
sl@0
  2203
	if (!GetIntFromConfig(iTestStepName, KChannel, iChannels))
sl@0
  2204
		{
sl@0
  2205
		ERR_PRINTF2(KMsgErrorGetParameter, &KChannel);
sl@0
  2206
		StopTest(KErrNotFound);
sl@0
  2207
		return;
sl@0
  2208
		}
sl@0
  2209
	if (!GetIntFromConfig(iTestStepName, KDuration, iDuration))
sl@0
  2210
		{
sl@0
  2211
		ERR_PRINTF2(KMsgErrorGetParameter, &KDuration);
sl@0
  2212
		StopTest(KErrNotFound);
sl@0
  2213
		return;
sl@0
  2214
		}
sl@0
  2215
	if (!GetIntFromConfig(iTestStepName, KFrequencyTone1, iFrequencyTone1))
sl@0
  2216
		{
sl@0
  2217
		ERR_PRINTF2(KMsgErrorGetParameter, &KFrequencyTone1);
sl@0
  2218
		StopTest(KErrNotFound);
sl@0
  2219
		return;
sl@0
  2220
		}
sl@0
  2221
	iTimer = CPeriodic::NewL(CActive::EPriorityHigh);
sl@0
  2222
	}
sl@0
  2223
sl@0
  2224
void RA3FDevSoundToneSetConfigWhilePlayingTest::Fsm(TMmfDevSoundEvent aDevSoundEvent,  TInt aError)
sl@0
  2225
	{
sl@0
  2226
	switch (iDevSoundState)
sl@0
  2227
		{
sl@0
  2228
		case EStateCreated:
sl@0
  2229
			{
sl@0
  2230
			__ASSERT_ALWAYS((aError == KErrNone), Panic(_L("RA3FDevSoundToneSetConfigWhilePlayingTest"), EFsmIncorrectErrorPassed));
sl@0
  2231
			if (aDevSoundEvent == EEventInitialize)
sl@0
  2232
				{
sl@0
  2233
				INFO_PRINTF1(_L("Calling CMMFDevSound::InitializeL"));
sl@0
  2234
				TRAPD(err, iMMFDevSound->InitializeL(*this, EMMFStateTonePlaying));
sl@0
  2235
				if (err != KErrNone)
sl@0
  2236
					{
sl@0
  2237
					ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"), err);
sl@0
  2238
					StopTest(err);
sl@0
  2239
					break;
sl@0
  2240
					}
sl@0
  2241
				StartTimer(KMicroSecsTwoSec);
sl@0
  2242
				INFO_PRINTF1(_L("DevSound State: EStateInitializing"));
sl@0
  2243
				iDevSoundState = EStateInitializing;
sl@0
  2244
				}
sl@0
  2245
			else
sl@0
  2246
				{
sl@0
  2247
				ERR_PRINTF2(_L("DevSound EEventInitialize not received as expected. Received event: %d"), aDevSoundEvent);
sl@0
  2248
				StopTest(aError, EFail);
sl@0
  2249
				}
sl@0
  2250
			break;
sl@0
  2251
			}
sl@0
  2252
		case EStateInitializing:
sl@0
  2253
			{
sl@0
  2254
			if (aDevSoundEvent == EEventInitComplete && aError == KErrNone)
sl@0
  2255
				{
sl@0
  2256
				INFO_PRINTF1(_L("CMMFDevSound::PlayToneL"));
sl@0
  2257
				TRAPD(err, iMMFDevSound->PlayToneL(iFrequencyTone1,  iDuration*KMicroSecsInOneSec));
sl@0
  2258
				if (err != KErrNone)
sl@0
  2259
					{
sl@0
  2260
					ERR_PRINTF2(_L("CMMFDevSound::PlayToneL left with error : %d"), err);
sl@0
  2261
					StopTest(err);
sl@0
  2262
					break;
sl@0
  2263
					}
sl@0
  2264
				INFO_PRINTF1(_L("DevSound State: EStatePlaying"));
sl@0
  2265
				iDevSoundState = EStatePlaying;
sl@0
  2266
				}
sl@0
  2267
			else if (aDevSoundEvent == EEventInitComplete && aError != KErrNone)
sl@0
  2268
				{
sl@0
  2269
				ERR_PRINTF2(_L("DevSound called CMMFDevSound::InitializeComplete with error = %d"), aError);
sl@0
  2270
				StopTest(aError);
sl@0
  2271
				}
sl@0
  2272
			else
sl@0
  2273
				{
sl@0
  2274
				ERR_PRINTF2(_L("DevSound EEventInitComplete not received as expected. Received event: %d"), aDevSoundEvent);
sl@0
  2275
				StopTest(aError, EFail);
sl@0
  2276
				}
sl@0
  2277
			break;
sl@0
  2278
			}
sl@0
  2279
		default:
sl@0
  2280
			{
sl@0
  2281
			ERR_PRINTF2(_L("Invalid DevSound state received: %d"), iDevSoundState);
sl@0
  2282
			StopTest(aError, EFail);
sl@0
  2283
			}
sl@0
  2284
		}
sl@0
  2285
	}
sl@0
  2286
sl@0
  2287
void RA3FDevSoundToneSetConfigWhilePlayingTest::DoTimerCallback()
sl@0
  2288
	{
sl@0
  2289
	iTimer->Cancel();
sl@0
  2290
	INFO_PRINTF1(_L("DevSound Event: EEventTimerComplete"));
sl@0
  2291
	TMMFCapabilities capabilitiesSet;
sl@0
  2292
	TBuf<KMaxSampleRateStringLength> stringSampleRateSet;
sl@0
  2293
	TBuf<KMaxChannelsStringLength> stringChannelsSet;
sl@0
  2294
	TMMFSampleRate eSampleRate;
sl@0
  2295
	SampleRateFromTIntToTMMFSampleRate (iSampleRate, eSampleRate);
sl@0
  2296
	capabilitiesSet.iRate = eSampleRate;
sl@0
  2297
	capabilitiesSet.iChannels = iChannels;
sl@0
  2298
	SampleRateFromTUintToString (capabilitiesSet.iRate,	stringSampleRateSet);
sl@0
  2299
	ChannelsFromTUintToString (capabilitiesSet.iChannels, stringChannelsSet);
sl@0
  2300
	INFO_PRINTF3(_L("Calling CMMFDevSound::SetConfigL using sample rate = %S and channel mode = %S"), &stringSampleRateSet, &stringChannelsSet);
sl@0
  2301
	TRAPD(err, iMMFDevSound->SetConfigL(capabilitiesSet));
sl@0
  2302
	if (err == KErrNotReady)
sl@0
  2303
		{
sl@0
  2304
		INFO_PRINTF2(_L("CMMFDevSound::SetConfigL succeeded with error = %d"), err);
sl@0
  2305
		StopTest(err, EPass);
sl@0
  2306
		}
sl@0
  2307
	else
sl@0
  2308
		{
sl@0
  2309
		ERR_PRINTF2(_L("CMMFDevSound::SetConfigL failed with error = %d"), err);
sl@0
  2310
		ERR_PRINTF2(_L("Expected  error = %d"), KErrNotReady);
sl@0
  2311
		StopTest(err, EFail);
sl@0
  2312
		}
sl@0
  2313
	}
sl@0
  2314
sl@0
  2315
/*
sl@0
  2316
 *========================================================================================================
sl@0
  2317
 * MM-A3F-DEVSOUND-CHRTZ-TONE-0017
sl@0
  2318
 */
sl@0
  2319
RA3FDevSoundToneSetPriorityWhilePlayingTest::RA3FDevSoundToneSetPriorityWhilePlayingTest(const TDesC& aTestName)
sl@0
  2320
	:	RA3FDevSoundTestBase(aTestName),
sl@0
  2321
		iDuration(0), iFrequencyTone1(0)
sl@0
  2322
	{
sl@0
  2323
	}
sl@0
  2324
sl@0
  2325
RA3FDevSoundToneSetPriorityWhilePlayingTest* RA3FDevSoundToneSetPriorityWhilePlayingTest::NewL(const TDesC& aTestName)
sl@0
  2326
	{
sl@0
  2327
	RA3FDevSoundToneSetPriorityWhilePlayingTest * self = new(ELeave)RA3FDevSoundToneSetPriorityWhilePlayingTest(aTestName);
sl@0
  2328
	return self;
sl@0
  2329
	}
sl@0
  2330
sl@0
  2331
void RA3FDevSoundToneSetPriorityWhilePlayingTest::DoKickoffTestL()
sl@0
  2332
	{
sl@0
  2333
	if (!GetIntFromConfig(iTestStepName, KDuration, iDuration))
sl@0
  2334
		{
sl@0
  2335
		ERR_PRINTF2(KMsgErrorGetParameter, &KDuration);
sl@0
  2336
		StopTest(KErrNotFound);
sl@0
  2337
		return;
sl@0
  2338
		}
sl@0
  2339
	if (!GetIntFromConfig(iTestStepName, KFrequencyTone1, iFrequencyTone1))
sl@0
  2340
		{
sl@0
  2341
		ERR_PRINTF2(KMsgErrorGetParameter, &KFrequencyTone1);
sl@0
  2342
		StopTest(KErrNotFound);
sl@0
  2343
		return;
sl@0
  2344
		}
sl@0
  2345
	iTimer = CPeriodic::NewL(CActive::EPriorityHigh);
sl@0
  2346
	iDevsoundToneClient = CA3FDevSoundToneClient::NewL(*this);
sl@0
  2347
	}
sl@0
  2348
sl@0
  2349
void RA3FDevSoundToneSetPriorityWhilePlayingTest::Fsm(TMmfDevSoundEvent aDevSoundEvent, TInt aError)
sl@0
  2350
	{
sl@0
  2351
	switch(iDevSoundState)
sl@0
  2352
		{
sl@0
  2353
		case EStateCreated:
sl@0
  2354
			{
sl@0
  2355
			__ASSERT_ALWAYS((aError == KErrNone), Panic(_L("RA3FDevSoundToneSetPriorityWhilePlayingConfigurationTest"), EFsmIncorrectErrorPassed));
sl@0
  2356
			if(aDevSoundEvent == EEventInitialize)
sl@0
  2357
				{
sl@0
  2358
				INFO_PRINTF1(_L("Calling CMMFDevSound::InitializeL"));
sl@0
  2359
				TRAPD(err, iMMFDevSound->InitializeL(*this, EMMFStateTonePlaying));
sl@0
  2360
				if (err != KErrNone)
sl@0
  2361
					{
sl@0
  2362
					ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"), err);
sl@0
  2363
					StopTest(err);
sl@0
  2364
					break;
sl@0
  2365
					}
sl@0
  2366
				INFO_PRINTF1(_L("DevSound State: EStateInitializing"));
sl@0
  2367
				iDevSoundState = EStateInitializing;
sl@0
  2368
				}
sl@0
  2369
			else
sl@0
  2370
				{
sl@0
  2371
				ERR_PRINTF2(_L("DevSound EEventInitialize not received as expected. Received event: %d"), aDevSoundEvent);
sl@0
  2372
				StopTest(aError, EFail);
sl@0
  2373
				}
sl@0
  2374
			break;
sl@0
  2375
			}
sl@0
  2376
		case EStateInitializing:
sl@0
  2377
			{
sl@0
  2378
			if (aDevSoundEvent == EEventInitComplete && aError == KErrNone)
sl@0
  2379
				{
sl@0
  2380
				iMMFDevSound->SetVolume(iMMFDevSound->MaxVolume ());
sl@0
  2381
				INFO_PRINTF1(_L("Calling CMMFDevSound::PlayToneL"));
sl@0
  2382
				TRAPD(err, iMMFDevSound->PlayToneL(iFrequencyTone1, iDuration*KMicroSecsInOneSec));
sl@0
  2383
				if (err != KErrNone)
sl@0
  2384
					{
sl@0
  2385
					ERR_PRINTF2(_L("CMMFDevSound::PlayToneL left with error : %d!"), err);
sl@0
  2386
					StopTest(err);
sl@0
  2387
					break;
sl@0
  2388
					}
sl@0
  2389
				StartTimer(KMicroSecsTwoSec);
sl@0
  2390
				INFO_PRINTF1(_L("DevSound State: EStatePlaying"));
sl@0
  2391
				iDevSoundState = EStatePlaying;
sl@0
  2392
				INFO_PRINTF2(_L("Calling CMMFDevSound::SetPrioritySettings using a priority(highest) value = %d"), KMaximumPriority);
sl@0
  2393
				TMMFPrioritySettings priority;
sl@0
  2394
				priority.iPriority = KMaximumPriority;
sl@0
  2395
				iMMFDevSound->SetPrioritySettings(priority);
sl@0
  2396
				}
sl@0
  2397
			else if (aDevSoundEvent == EEventInitComplete && aError != KErrNone)
sl@0
  2398
				{
sl@0
  2399
				ERR_PRINTF2(_L("DevSound called CMMFDevSound::InitializeComplete with error = %d"), aError);
sl@0
  2400
				StopTest(aError);
sl@0
  2401
				}
sl@0
  2402
			else
sl@0
  2403
				{
sl@0
  2404
				ERR_PRINTF2(_L("DevSound EEventInitComplete not received as expected. Received event: %d"), aDevSoundEvent);
sl@0
  2405
				StopTest(aError,  EFail);
sl@0
  2406
				}
sl@0
  2407
			break;
sl@0
  2408
			}
sl@0
  2409
		default:
sl@0
  2410
			{
sl@0
  2411
			ERR_PRINTF2(_L("Invalid DevSound state received: %d"), iDevSoundState);
sl@0
  2412
			StopTest(aError, EFail);
sl@0
  2413
			}
sl@0
  2414
		}
sl@0
  2415
	}
sl@0
  2416
sl@0
  2417
void RA3FDevSoundToneSetPriorityWhilePlayingTest::ClientInitializeCompleteCallback(TInt aError)
sl@0
  2418
	{
sl@0
  2419
	INFO_PRINTF1(_L("==========Second DevSound client called InitializeComplete()=========="));
sl@0
  2420
	if (aError == KErrNone)
sl@0
  2421
		{
sl@0
  2422
		TInt err = iDevsoundToneClient->PlayTone ();
sl@0
  2423
		if (err != KErrNone)
sl@0
  2424
			{
sl@0
  2425
			ERR_PRINTF2(_L("Second Devsound client called PlayTone and failed with error = %d"), err);
sl@0
  2426
			StopTest(err);
sl@0
  2427
			}
sl@0
  2428
		}
sl@0
  2429
	else
sl@0
  2430
		{
sl@0
  2431
		ERR_PRINTF2(_L("Second Devsound InitializeComplete received an error = %d"), aError);
sl@0
  2432
		StopTest(aError);
sl@0
  2433
		}
sl@0
  2434
	}
sl@0
  2435
sl@0
  2436
void RA3FDevSoundToneSetPriorityWhilePlayingTest::ClientToneFinishedCallback(TInt aError)
sl@0
  2437
	{
sl@0
  2438
	INFO_PRINTF1(_L("========== Second  DevSound client called ToneFinished()=========="));
sl@0
  2439
	if (aError == KErrUnderflow)
sl@0
  2440
		{
sl@0
  2441
		INFO_PRINTF2(_L("Second DevSound client called ToneFinished and succeeded with error = %d"), aError);
sl@0
  2442
		StopTest(aError, EPass);
sl@0
  2443
		}
sl@0
  2444
	else
sl@0
  2445
		{
sl@0
  2446
		ERR_PRINTF2(_L("Second DevSound client called ToneFinished and failed with error = %d"), aError);
sl@0
  2447
		StopTest(aError, EFail);
sl@0
  2448
		}
sl@0
  2449
	}
sl@0
  2450
sl@0
  2451
void RA3FDevSoundToneSetPriorityWhilePlayingTest::DoTimerCallback()
sl@0
  2452
	{
sl@0
  2453
	INFO_PRINTF1(_L("TimerEvent called"));
sl@0
  2454
	iTimer->Cancel();
sl@0
  2455
	INFO_PRINTF1(_L("Starting another devsound client using the highest priority"));
sl@0
  2456
	iDevsoundToneClient->SetPriority(KMaximumPriority);
sl@0
  2457
	TInt err = iDevsoundToneClient->InitTonePlay(iFrequencyTone1, iDuration*KMicroSecsInOneSec);
sl@0
  2458
	if(err != KErrNone)
sl@0
  2459
		{
sl@0
  2460
		ERR_PRINTF1(_L("Initialization to play tone thru second devsound client failed"));
sl@0
  2461
		StopTest(err);
sl@0
  2462
		}
sl@0
  2463
	}
sl@0
  2464
sl@0
  2465
void RA3FDevSoundToneSetPriorityWhilePlayingTest::ToneFinished(TInt aError)
sl@0
  2466
	{
sl@0
  2467
	INFO_PRINTF1(_L("========== DevSound ToneFinished() callback =========="));
sl@0
  2468
	if (aError == KErrInUse || aError == KErrDied || aError == KErrAccessDenied)
sl@0
  2469
		{
sl@0
  2470
		INFO_PRINTF1(_L("========== Preempting 1st DevSound Instance=========="));
sl@0
  2471
		}
sl@0
  2472
	else
sl@0
  2473
		{
sl@0
  2474
		ERR_PRINTF2(_L("DevSound called ToneFinished and failed with error = %d"), aError);
sl@0
  2475
		ERR_PRINTF4(_L("Expected errors posibilities %d %d %d"), KErrInUse, KErrDied, KErrAccessDenied);
sl@0
  2476
		StopTest(aError, EFail);
sl@0
  2477
		}
sl@0
  2478
	}
sl@0
  2479
sl@0
  2480
/*
sl@0
  2481
 *========================================================================================================
sl@0
  2482
 * MM-A3F-DEVSOUND-CHRTZ-TONE-0018
sl@0
  2483
 */
sl@0
  2484
RA3FDevSoundToneSetConfigTestToInvalidSampleRateValue::RA3FDevSoundToneSetConfigTestToInvalidSampleRateValue(const TDesC& aTestName)
sl@0
  2485
	:	RA3FDevSoundTestBase(aTestName), iSampleRate(0),
sl@0
  2486
		iChannels(0)
sl@0
  2487
	{
sl@0
  2488
	}
sl@0
  2489
sl@0
  2490
RA3FDevSoundToneSetConfigTestToInvalidSampleRateValue* RA3FDevSoundToneSetConfigTestToInvalidSampleRateValue::NewL(const TDesC& aTestName)
sl@0
  2491
	{
sl@0
  2492
	RA3FDevSoundToneSetConfigTestToInvalidSampleRateValue * self = new(ELeave)RA3FDevSoundToneSetConfigTestToInvalidSampleRateValue(aTestName);
sl@0
  2493
	return self;
sl@0
  2494
	}
sl@0
  2495
sl@0
  2496
void RA3FDevSoundToneSetConfigTestToInvalidSampleRateValue::DoKickoffTestL()
sl@0
  2497
	{
sl@0
  2498
	if (!GetIntFromConfig(iTestStepName, KSampleRate, iSampleRate))
sl@0
  2499
		{
sl@0
  2500
		ERR_PRINTF2(KMsgErrorGetParameter, &KSampleRate);
sl@0
  2501
		StopTest(KErrNotFound);
sl@0
  2502
		return;
sl@0
  2503
		}
sl@0
  2504
	if (!GetIntFromConfig(iTestStepName, KChannel, iChannels))
sl@0
  2505
		{
sl@0
  2506
		ERR_PRINTF2(KMsgErrorGetParameter, &KChannel);
sl@0
  2507
		StopTest(KErrNotFound);
sl@0
  2508
		return;
sl@0
  2509
		}
sl@0
  2510
	}
sl@0
  2511
sl@0
  2512
void RA3FDevSoundToneSetConfigTestToInvalidSampleRateValue::Fsm(TMmfDevSoundEvent aDevSoundEvent, TInt aError)
sl@0
  2513
	{
sl@0
  2514
#ifdef MM_TB101_L
sl@0
  2515
		//Reason: Check remains since this is a valid test case, but we need to know why we are not testing invalid rates.
sl@0
  2516
		INFO_PRINTF1(_L("MM_TB101_L defined: All sample rates are valid for MM_TB101_L (HW), therefore no invalid rates can be tested."));
sl@0
  2517
		StopTest(KErrNotSupported, EPass);
sl@0
  2518
#else
sl@0
  2519
	switch(iDevSoundState)
sl@0
  2520
		{
sl@0
  2521
		case EStateCreated:
sl@0
  2522
			{
sl@0
  2523
			if(aDevSoundEvent == EEventInitialize)
sl@0
  2524
				{
sl@0
  2525
				__ASSERT_ALWAYS((aError == KErrNone), Panic(_L("RA3FDevSoundToneSetConfigTestToInvalidSampleRateValue"), EFsmIncorrectErrorPassed));
sl@0
  2526
				INFO_PRINTF1(_L("Calling CMMFDevSound::InitializeL"));
sl@0
  2527
				TRAPD(err, iMMFDevSound->InitializeL(*this, EMMFStateTonePlaying));
sl@0
  2528
				if (err != KErrNone)
sl@0
  2529
					{
sl@0
  2530
					ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"), err);
sl@0
  2531
					StopTest(err);
sl@0
  2532
					break;
sl@0
  2533
					}
sl@0
  2534
				INFO_PRINTF1(_L("DevSound State: EStateInitializing"));
sl@0
  2535
				iDevSoundState = EStateInitializing;
sl@0
  2536
				}
sl@0
  2537
			else
sl@0
  2538
				{
sl@0
  2539
				ERR_PRINTF2(_L("DevSound EEventInitialize not received as expected. Received event: %d"), aDevSoundEvent);
sl@0
  2540
				StopTest(aError, EFail);
sl@0
  2541
				}
sl@0
  2542
			break;
sl@0
  2543
			}
sl@0
  2544
		case EStateInitializing:
sl@0
  2545
			{
sl@0
  2546
			if (aDevSoundEvent == EEventInitComplete && aError == KErrNone)
sl@0
  2547
				{
sl@0
  2548
				TMMFCapabilities capabilitiesSet;
sl@0
  2549
				TBuf<KMaxSampleRateStringLength> stringSampleRateSet;
sl@0
  2550
				TBuf<KMaxChannelsStringLength> stringChannelsSet;
sl@0
  2551
				TMMFSampleRate eSampleRate;
sl@0
  2552
				SampleRateFromTIntToTMMFSampleRate (iSampleRate, eSampleRate);
sl@0
  2553
				capabilitiesSet.iRate = eSampleRate;
sl@0
  2554
				capabilitiesSet.iChannels = iChannels;
sl@0
  2555
				SampleRateFromTUintToString (capabilitiesSet.iRate,	stringSampleRateSet);
sl@0
  2556
				ChannelsFromTUintToString (capabilitiesSet.iChannels, stringChannelsSet);
sl@0
  2557
				INFO_PRINTF3(_L("Calling CMMFDevSound::SetConfigL using an invalid sample rate = %S and channel mode = %S"), &stringSampleRateSet, &stringChannelsSet);
sl@0
  2558
				TRAPD(err, iMMFDevSound->SetConfigL(capabilitiesSet));
sl@0
  2559
				if (err == KErrNotSupported || err == KErrArgument)
sl@0
  2560
					{
sl@0
  2561
					INFO_PRINTF2(_L("CMMFDevSound::SetConfigL succeeded with error = %d"), err);
sl@0
  2562
					StopTest(err, EPass);
sl@0
  2563
					}
sl@0
  2564
				else
sl@0
  2565
					{
sl@0
  2566
					ERR_PRINTF2(_L("CMMFDevSound::SetConfigL failed with error = %d"), err);
sl@0
  2567
					ERR_PRINTF3(_L("Expected  error posibilities %d %d"), KErrArgument, KErrNotSupported);
sl@0
  2568
					StopTest(err, EFail);
sl@0
  2569
					}
sl@0
  2570
				}
sl@0
  2571
			else if (aDevSoundEvent == EEventInitComplete && aError != KErrNone)
sl@0
  2572
				{
sl@0
  2573
				ERR_PRINTF2(_L("DevSound called CMMFDevSound::InitializeComplete with error = %d"), aError);
sl@0
  2574
				StopTest(aError);
sl@0
  2575
				}
sl@0
  2576
			else
sl@0
  2577
				{
sl@0
  2578
				ERR_PRINTF2(_L("DevSound EEventInitComplete not received as expected. Received event: %d"), aDevSoundEvent);
sl@0
  2579
				StopTest(aError, EFail);
sl@0
  2580
				}
sl@0
  2581
			break;
sl@0
  2582
			}
sl@0
  2583
		default:
sl@0
  2584
			{
sl@0
  2585
			ERR_PRINTF2(_L("Invalid DevSound state received: %d"), iDevSoundState);
sl@0
  2586
			StopTest(aError, EFail);
sl@0
  2587
			}
sl@0
  2588
		}
sl@0
  2589
#endif// MM_TB101_L
sl@0
  2590
	}
sl@0
  2591
sl@0
  2592
/*
sl@0
  2593
 *========================================================================================================
sl@0
  2594
 * MM-A3F-DEVSOUND-CHRTZ-TONE-0019
sl@0
  2595
 */
sl@0
  2596
RA3FDevSoundToneSetConfigTestToInvalidChannelValueTest::RA3FDevSoundToneSetConfigTestToInvalidChannelValueTest(const TDesC& aTestName)
sl@0
  2597
	:	RA3FDevSoundTestBase(aTestName), iSampleRate(0),
sl@0
  2598
		iChannels(0)
sl@0
  2599
	{
sl@0
  2600
	}
sl@0
  2601
sl@0
  2602
RA3FDevSoundToneSetConfigTestToInvalidChannelValueTest* RA3FDevSoundToneSetConfigTestToInvalidChannelValueTest::NewL(const TDesC& aTestName)
sl@0
  2603
	{
sl@0
  2604
	RA3FDevSoundToneSetConfigTestToInvalidChannelValueTest * self = new(ELeave)RA3FDevSoundToneSetConfigTestToInvalidChannelValueTest(aTestName);
sl@0
  2605
	return self;
sl@0
  2606
	}
sl@0
  2607
sl@0
  2608
void RA3FDevSoundToneSetConfigTestToInvalidChannelValueTest::DoKickoffTestL()
sl@0
  2609
	{
sl@0
  2610
	if (!GetIntFromConfig(iTestStepName, KSampleRate, iSampleRate))
sl@0
  2611
		{
sl@0
  2612
		ERR_PRINTF2(KMsgErrorGetParameter, &KSampleRate);
sl@0
  2613
		StopTest(KErrNotFound);
sl@0
  2614
		return;
sl@0
  2615
		}
sl@0
  2616
	if (!GetIntFromConfig(iTestStepName, KChannel, iChannels))
sl@0
  2617
		{
sl@0
  2618
		ERR_PRINTF2(KMsgErrorGetParameter, &KChannel);
sl@0
  2619
		StopTest(KErrNotFound);
sl@0
  2620
		return;
sl@0
  2621
		}
sl@0
  2622
	}
sl@0
  2623
sl@0
  2624
void RA3FDevSoundToneSetConfigTestToInvalidChannelValueTest::Fsm(TMmfDevSoundEvent aDevSoundEvent, TInt aError)
sl@0
  2625
	{
sl@0
  2626
	switch(iDevSoundState)
sl@0
  2627
		{
sl@0
  2628
		case EStateCreated:
sl@0
  2629
			{
sl@0
  2630
			if(aDevSoundEvent == EEventInitialize)
sl@0
  2631
				{
sl@0
  2632
				__ASSERT_ALWAYS((aError == KErrNone), Panic(_L("RA3FDevSoundToneSetConfigTestToInvalidChannelValueTest"), EFsmIncorrectErrorPassed));
sl@0
  2633
				INFO_PRINTF1(_L("Calling CMMFDevSound::InitializeL"));
sl@0
  2634
				TRAPD(err, iMMFDevSound->InitializeL(*this, EMMFStateTonePlaying));
sl@0
  2635
				if (err != KErrNone)
sl@0
  2636
					{
sl@0
  2637
					ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"), err);
sl@0
  2638
					StopTest(err);
sl@0
  2639
					break;
sl@0
  2640
					}
sl@0
  2641
				INFO_PRINTF1(_L("DevSound State: EStateInitializing"));
sl@0
  2642
				iDevSoundState = EStateInitializing;
sl@0
  2643
				}
sl@0
  2644
			else
sl@0
  2645
				{
sl@0
  2646
				ERR_PRINTF2(_L("DevSound EEventInitialize not received as expected. Received event: %d"), aDevSoundEvent);
sl@0
  2647
				StopTest(aError, EFail);
sl@0
  2648
				}
sl@0
  2649
			break;
sl@0
  2650
			}
sl@0
  2651
		case EStateInitializing:
sl@0
  2652
			{
sl@0
  2653
			if (aDevSoundEvent == EEventInitComplete && aError == KErrNone)
sl@0
  2654
				{
sl@0
  2655
				TMMFCapabilities capabilitiesSet;
sl@0
  2656
				TBuf<KMaxSampleRateStringLength> stringSampleRateSet;
sl@0
  2657
				TBuf<KMaxChannelsStringLength> stringChannelsSet;
sl@0
  2658
				TMMFSampleRate eSampleRate;
sl@0
  2659
				SampleRateFromTIntToTMMFSampleRate (iSampleRate, eSampleRate);
sl@0
  2660
				capabilitiesSet.iRate = eSampleRate;
sl@0
  2661
				capabilitiesSet.iChannels = iChannels;
sl@0
  2662
				SampleRateFromTUintToString (capabilitiesSet.iRate,	stringSampleRateSet);
sl@0
  2663
				INFO_PRINTF3(_L("Calling CMMFDevSound::SetConfigL using a sample rate = %S and an invalid channel mode = %d"), &stringSampleRateSet, iChannels);
sl@0
  2664
				TRAPD(err, iMMFDevSound->SetConfigL(capabilitiesSet));
sl@0
  2665
				if (err == KErrNotSupported || err == KErrArgument)
sl@0
  2666
					{
sl@0
  2667
					INFO_PRINTF2(_L("CMMFDevSound::SetConfigL succeeded with error = %d"), err);
sl@0
  2668
					StopTest(err, EPass);
sl@0
  2669
					}
sl@0
  2670
				else
sl@0
  2671
					{
sl@0
  2672
					ERR_PRINTF2(_L("CMMFDevSound::SetConfigL failed with error = %d"), err);
sl@0
  2673
					ERR_PRINTF3(_L("Expected  error posibilities %d %d"), KErrArgument, KErrNotSupported);
sl@0
  2674
					StopTest(err, EFail);
sl@0
  2675
					}
sl@0
  2676
				}
sl@0
  2677
			else if (aDevSoundEvent == EEventInitComplete && aError != KErrNone)
sl@0
  2678
				{
sl@0
  2679
				ERR_PRINTF2(_L("DevSound called CMMFDevSound::InitializeComplete with error = %d"), aError);
sl@0
  2680
				StopTest(aError);
sl@0
  2681
				}
sl@0
  2682
			else
sl@0
  2683
				{
sl@0
  2684
				ERR_PRINTF2(_L("DevSound EEventInitComplete not received as expected. Received event: %d"), aDevSoundEvent);
sl@0
  2685
				StopTest(aError, EFail);
sl@0
  2686
				}
sl@0
  2687
			break;
sl@0
  2688
			}
sl@0
  2689
		default:
sl@0
  2690
			{
sl@0
  2691
			ERR_PRINTF2(_L("Invalid DevSound state received: %d"), iDevSoundState);
sl@0
  2692
			StopTest(aError, EFail);
sl@0
  2693
			}
sl@0
  2694
		}
sl@0
  2695
	}
sl@0
  2696
sl@0
  2697
/*
sl@0
  2698
 *========================================================================================================
sl@0
  2699
 * MM-A3F-DEVSOUND-CHRTZ-TONE-0020
sl@0
  2700
 */
sl@0
  2701
RA3FDevSoundToneSetDTMFLengthsToNegativeTest::RA3FDevSoundToneSetDTMFLengthsToNegativeTest(const TDesC& aTestName)
sl@0
  2702
	:	RA3FDevSoundTestBase(aTestName), iToneOnLength(0),
sl@0
  2703
		iToneOffLength(0), iPauseLength(0),
sl@0
  2704
		iDTMFString(KNullDesC)
sl@0
  2705
	{
sl@0
  2706
	}
sl@0
  2707
sl@0
  2708
RA3FDevSoundToneSetDTMFLengthsToNegativeTest* RA3FDevSoundToneSetDTMFLengthsToNegativeTest::NewL(const TDesC& aTestName)
sl@0
  2709
	{
sl@0
  2710
	RA3FDevSoundToneSetDTMFLengthsToNegativeTest * self = new(ELeave)RA3FDevSoundToneSetDTMFLengthsToNegativeTest(aTestName);
sl@0
  2711
	return self;
sl@0
  2712
	}
sl@0
  2713
sl@0
  2714
void RA3FDevSoundToneSetDTMFLengthsToNegativeTest::DoKickoffTestL()
sl@0
  2715
	{
sl@0
  2716
	if ( !GetIntFromConfig(iTestStepName, KToneOnLength, iToneOnLength) )
sl@0
  2717
		{
sl@0
  2718
		ERR_PRINTF2(KMsgErrorGetParameter, &KToneOnLength);
sl@0
  2719
		StopTest(KErrNotFound);
sl@0
  2720
		return;
sl@0
  2721
		}
sl@0
  2722
	if ( !GetIntFromConfig(iTestStepName, KToneOffLength, iToneOffLength) )
sl@0
  2723
		{
sl@0
  2724
		ERR_PRINTF2(KMsgErrorGetParameter, &KToneOffLength);
sl@0
  2725
		StopTest(KErrNotFound);
sl@0
  2726
		return;
sl@0
  2727
		}
sl@0
  2728
	if ( !GetIntFromConfig(iTestStepName, KPauseLength, iPauseLength) )
sl@0
  2729
		{
sl@0
  2730
		ERR_PRINTF2(KMsgErrorGetParameter, &KPauseLength);
sl@0
  2731
		StopTest(KErrNotFound);
sl@0
  2732
		return;
sl@0
  2733
		}
sl@0
  2734
	TPtrC DTMF;
sl@0
  2735
	if ( !GetStringFromConfig(iTestStepName,  KDTMFString,  DTMF) )
sl@0
  2736
		{
sl@0
  2737
		ERR_PRINTF2(KMsgErrorGetParameter, &KDTMFString);
sl@0
  2738
		StopTest(KErrNotFound);
sl@0
  2739
		return;
sl@0
  2740
		}
sl@0
  2741
	iDTMFString.Copy(DTMF);
sl@0
  2742
	}
sl@0
  2743
sl@0
  2744
void RA3FDevSoundToneSetDTMFLengthsToNegativeTest::Fsm(TMmfDevSoundEvent aDevSoundEvent, TInt aError)
sl@0
  2745
	{
sl@0
  2746
	switch (iDevSoundState)
sl@0
  2747
		{
sl@0
  2748
		case EStateCreated:
sl@0
  2749
			{
sl@0
  2750
			__ASSERT_ALWAYS((aError == KErrNone), Panic(_L("RA3FDevSoundToneSetDTMFLengthsToNegativeConfigurationTest"), EFsmIncorrectErrorPassed));
sl@0
  2751
			if (aDevSoundEvent == EEventInitialize)
sl@0
  2752
				{
sl@0
  2753
				INFO_PRINTF1(_L("Calling iMMFDevSound::InitializeL"));
sl@0
  2754
				TRAPD(err, iMMFDevSound->InitializeL(*this, EMMFStateTonePlaying));
sl@0
  2755
				if (err != KErrNone)
sl@0
  2756
					{
sl@0
  2757
					ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"), err);
sl@0
  2758
					StopTest(err);
sl@0
  2759
					break;
sl@0
  2760
					}
sl@0
  2761
				INFO_PRINTF1(_L("DevSound State: EStateInitializing"));
sl@0
  2762
				iDevSoundState = EStateInitializing;
sl@0
  2763
				}
sl@0
  2764
			else
sl@0
  2765
				{
sl@0
  2766
				ERR_PRINTF2(_L("DevSound EEventInitialize not received as expected. Received event: %d"), aDevSoundEvent);
sl@0
  2767
				StopTest(aError, EFail);
sl@0
  2768
				}
sl@0
  2769
			break;
sl@0
  2770
			}
sl@0
  2771
		case EStateInitializing:
sl@0
  2772
			{
sl@0
  2773
			if (aDevSoundEvent == EEventInitComplete && aError == KErrNone)
sl@0
  2774
				{
sl@0
  2775
				iMMFDevSound->SetVolume(iMMFDevSound->MaxVolume());
sl@0
  2776
				TTimeIntervalMicroSeconds32 ToneOnLength(iToneOnLength);
sl@0
  2777
				TTimeIntervalMicroSeconds32 ToneOffLength(iToneOffLength);
sl@0
  2778
				TTimeIntervalMicroSeconds32 PauseLength(iPauseLength);
sl@0
  2779
				INFO_PRINTF4(_L("Setting DTMF tone to negative lengths. ToneOnLength %d, ToneOffLength %d and PauseLength %d"), iToneOnLength, iToneOffLength, iPauseLength);
sl@0
  2780
				iMMFDevSound->SetDTMFLengths(ToneOnLength, ToneOffLength, PauseLength);
sl@0
  2781
				iStartTime.HomeTime();
sl@0
  2782
				INFO_PRINTF2(_L("Calling CMMFDevSound::PlayDTMFStringL %S"), &iDTMFString);
sl@0
  2783
				TRAPD(err, iMMFDevSound->PlayDTMFStringL(iDTMFString));
sl@0
  2784
				if (err != KErrNone)
sl@0
  2785
					{
sl@0
  2786
					ERR_PRINTF2(_L("CMMFDevSound::PlayDTMFStringL left with error : %d!"),  err);
sl@0
  2787
					StopTest(err);
sl@0
  2788
					break;
sl@0
  2789
					}
sl@0
  2790
				INFO_PRINTF1(_L("DevSound State: EStatePlaying"));
sl@0
  2791
				iDevSoundState = EStatePlaying;
sl@0
  2792
				}
sl@0
  2793
			else if (aDevSoundEvent == EEventInitComplete && aError != KErrNone)
sl@0
  2794
				{
sl@0
  2795
				ERR_PRINTF2(_L("DevSound called CMMFDevSound::InitializeComplete with error = %d"), aError);
sl@0
  2796
				StopTest(aError);
sl@0
  2797
				}
sl@0
  2798
			else
sl@0
  2799
				{
sl@0
  2800
				ERR_PRINTF2(_L("DevSound EEventInitComplete not received as expected. Received event: %d"), aDevSoundEvent);
sl@0
  2801
				StopTest(aError, EFail);
sl@0
  2802
				}
sl@0
  2803
			break;
sl@0
  2804
			}
sl@0
  2805
		default:
sl@0
  2806
			{
sl@0
  2807
			ERR_PRINTF2(_L("Invalid DevSound state received: %d"), iDevSoundState);
sl@0
  2808
			StopTest(aError, EFail);
sl@0
  2809
			}
sl@0
  2810
		}
sl@0
  2811
	}
sl@0
  2812
sl@0
  2813
void RA3FDevSoundToneSetDTMFLengthsToNegativeTest::ToneFinished(TInt aError)
sl@0
  2814
	{
sl@0
  2815
	INFO_PRINTF1(_L("========== DevSound ToneFinished() callback =========="));
sl@0
  2816
	INFO_PRINTF3(KMsgErrorDevSoundCallback, &KToneFinishedText, aError);
sl@0
  2817
sl@0
  2818
	if (aError == KErrUnderflow)
sl@0
  2819
		{
sl@0
  2820
		iEndTime.HomeTime();
sl@0
  2821
		iPlayToneTime = iEndTime.MicroSecondsFrom(iStartTime);
sl@0
  2822
		if(iPlayToneTime <= KPlayVarianceTime)
sl@0
  2823
			{
sl@0
  2824
			INFO_PRINTF2(_L("Setting DTMF tone lengths to negative gives a reproduction time of %Ld microseconds which is the expected result"), iPlayToneTime.Int64());
sl@0
  2825
			StopTest(aError, EPass);
sl@0
  2826
			}
sl@0
  2827
		}
sl@0
  2828
	else
sl@0
  2829
		{
sl@0
  2830
		INFO_PRINTF2(_L("DevSound called ToneFinished with error = %d that was NOT expected"), aError);
sl@0
  2831
		StopTest(aError, EFail);
sl@0
  2832
		}
sl@0
  2833
	}
sl@0
  2834
sl@0
  2835
/*
sl@0
  2836
 *========================================================================================================
sl@0
  2837
 * MM-A3F-DEVSOUND-CHRTZ-TONE-0021
sl@0
  2838
 */
sl@0
  2839
RA3FDevSoundToneSetDTMFToneOnLengthToMinusOneTest::RA3FDevSoundToneSetDTMFToneOnLengthToMinusOneTest(const TDesC& aTestName)
sl@0
  2840
	:	RA3FDevSoundTestBase(aTestName),
sl@0
  2841
		iFirstToneFinishedCall(EFalse),
sl@0
  2842
		iToneOnLength(0), iToneOffLength(0),
sl@0
  2843
		iPauseLength(0), iDTMFString(KNullDesC)
sl@0
  2844
	{
sl@0
  2845
	}
sl@0
  2846
RA3FDevSoundToneSetDTMFToneOnLengthToMinusOneTest* RA3FDevSoundToneSetDTMFToneOnLengthToMinusOneTest::NewL(const TDesC& aTestName)
sl@0
  2847
	{
sl@0
  2848
	RA3FDevSoundToneSetDTMFToneOnLengthToMinusOneTest * self = new(ELeave)RA3FDevSoundToneSetDTMFToneOnLengthToMinusOneTest(aTestName);
sl@0
  2849
	return self;
sl@0
  2850
	}
sl@0
  2851
sl@0
  2852
void RA3FDevSoundToneSetDTMFToneOnLengthToMinusOneTest::DoKickoffTestL()
sl@0
  2853
	{
sl@0
  2854
	if (!GetIntFromConfig(iTestStepName, KToneOnLength, iToneOnLength))
sl@0
  2855
		{
sl@0
  2856
		ERR_PRINTF2(KMsgErrorGetParameter, &KToneOnLength);
sl@0
  2857
		StopTest(KErrNotFound);
sl@0
  2858
		return;
sl@0
  2859
		}
sl@0
  2860
	if (!GetIntFromConfig(iTestStepName, KToneOffLength, iToneOffLength))
sl@0
  2861
		{
sl@0
  2862
		ERR_PRINTF2(KMsgErrorGetParameter, &KToneOffLength);
sl@0
  2863
		StopTest(KErrNotFound);
sl@0
  2864
		return;
sl@0
  2865
		}
sl@0
  2866
	if (!GetIntFromConfig(iTestStepName, KPauseLength, iPauseLength))
sl@0
  2867
		{
sl@0
  2868
		ERR_PRINTF2(KMsgErrorGetParameter, &KPauseLength);
sl@0
  2869
		StopTest(KErrNotFound);
sl@0
  2870
		return;
sl@0
  2871
		}
sl@0
  2872
	TPtrC DTMF;
sl@0
  2873
	if (!GetStringFromConfig(iTestStepName, KDTMFString, DTMF))
sl@0
  2874
		{
sl@0
  2875
		ERR_PRINTF2(KMsgErrorGetParameter, &KDTMFString);
sl@0
  2876
		StopTest(KErrNotFound);
sl@0
  2877
		return;
sl@0
  2878
		}
sl@0
  2879
	iDTMFString.Copy(DTMF);
sl@0
  2880
	iTimer = CPeriodic::NewL(CActive::EPriorityHigh);
sl@0
  2881
	}
sl@0
  2882
sl@0
  2883
void RA3FDevSoundToneSetDTMFToneOnLengthToMinusOneTest::Fsm(TMmfDevSoundEvent aDevSoundEvent, TInt aError)
sl@0
  2884
	{
sl@0
  2885
	switch (iDevSoundState)
sl@0
  2886
		{
sl@0
  2887
		case EStateCreated:
sl@0
  2888
			{
sl@0
  2889
			__ASSERT_ALWAYS((aError == KErrNone), Panic(_L("RA3FDevSoundToneSetDTMFToneOnLengthToMinusOneTest"), EFsmIncorrectErrorPassed));
sl@0
  2890
			if(aDevSoundEvent == EEventInitialize)
sl@0
  2891
				{
sl@0
  2892
				INFO_PRINTF1(_L("Calling CMMFDevSound::InitializeL"));
sl@0
  2893
				TRAPD(err, iMMFDevSound->InitializeL(*this, EMMFStateTonePlaying));
sl@0
  2894
				if (err != KErrNone)
sl@0
  2895
					{
sl@0
  2896
					ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"), err);
sl@0
  2897
					StopTest(err);
sl@0
  2898
					break;
sl@0
  2899
					}
sl@0
  2900
				INFO_PRINTF1(_L("DevSound State: EStateInitializing"));
sl@0
  2901
				iDevSoundState = EStateInitializing;
sl@0
  2902
				}
sl@0
  2903
			else
sl@0
  2904
				{
sl@0
  2905
				ERR_PRINTF2(_L("DevSound EEventInitialize not received as expected. Received event: %d"), aDevSoundEvent);
sl@0
  2906
				StopTest(aError, EFail);
sl@0
  2907
				}
sl@0
  2908
			break;
sl@0
  2909
			}
sl@0
  2910
		case EStateInitializing:
sl@0
  2911
			{
sl@0
  2912
			if (aDevSoundEvent == EEventInitComplete && aError == KErrNone)
sl@0
  2913
				{
sl@0
  2914
				iMMFDevSound->SetVolume(iMMFDevSound->MaxVolume());
sl@0
  2915
				iStartTime.HomeTime();
sl@0
  2916
				TTimeIntervalMicroSeconds32 ToneOnLength(iToneOnLength);
sl@0
  2917
				TTimeIntervalMicroSeconds32 ToneOffLength(iToneOffLength);
sl@0
  2918
				TTimeIntervalMicroSeconds32 PauseLength(iPauseLength);
sl@0
  2919
				INFO_PRINTF4(_L("Calling CMMFDevSound::SetDTMFLengths. ToneOnLength = %Ld, ToneOffLength = %Ld and PauseLength = %Ld"), iToneOnLength, iToneOffLength, iPauseLength);
sl@0
  2920
				iMMFDevSound->SetDTMFLengths(ToneOnLength, ToneOffLength, PauseLength);
sl@0
  2921
				INFO_PRINTF2(_L("Calling CMMFDevSound::PlayDTMFStringL %S"), &iDTMFString);
sl@0
  2922
				TRAPD(err, iMMFDevSound->PlayDTMFStringL(iDTMFString));
sl@0
  2923
				if (err != KErrNone)
sl@0
  2924
					{
sl@0
  2925
					ERR_PRINTF2(_L("CMMFDevSound::PlayDTMFStringL left with error : %d!"), err);
sl@0
  2926
					StopTest(err);
sl@0
  2927
					break;
sl@0
  2928
					}
sl@0
  2929
				StartTimer(KMicrosecsInTenSec);
sl@0
  2930
				INFO_PRINTF1(_L("DevSound State: EStatePlaying"));
sl@0
  2931
				iDevSoundState=EStatePlaying;
sl@0
  2932
				}
sl@0
  2933
			else if (aDevSoundEvent == EEventInitComplete && aError != KErrNone)
sl@0
  2934
				{
sl@0
  2935
				ERR_PRINTF2(_L("DevSound called CMMFDevSound::InitializeComplete with error = %d"), aError);
sl@0
  2936
				StopTest(aError);
sl@0
  2937
				}
sl@0
  2938
			else
sl@0
  2939
				{
sl@0
  2940
				ERR_PRINTF2(_L("DevSound EEventInitComplete not received as expected. Received event: %d"), aDevSoundEvent);
sl@0
  2941
				StopTest(aError, EFail);
sl@0
  2942
				}
sl@0
  2943
			break;
sl@0
  2944
			}
sl@0
  2945
		default:
sl@0
  2946
			{
sl@0
  2947
			ERR_PRINTF2(_L("Invalid DevSound state received: %d"), iDevSoundState);
sl@0
  2948
			StopTest(aError, EFail);
sl@0
  2949
			}
sl@0
  2950
		}
sl@0
  2951
	}
sl@0
  2952
sl@0
  2953
void RA3FDevSoundToneSetDTMFToneOnLengthToMinusOneTest::DoTimerCallback()
sl@0
  2954
	{
sl@0
  2955
	iTimer->Cancel();
sl@0
  2956
	INFO_PRINTF1(_L("DevSound Event: EEventTimerComplete"));
sl@0
  2957
	iEndTime.HomeTime();
sl@0
  2958
	iPlayToneTime = iEndTime.MicroSecondsFrom(iStartTime);
sl@0
  2959
	INFO_PRINTF1(_L("SetDTMF lengths succeded."));
sl@0
  2960
	INFO_PRINTF2(_L("Play time is %Ld microseconds"), iPlayToneTime.Int64());
sl@0
  2961
	StopTest();
sl@0
  2962
	}
sl@0
  2963
sl@0
  2964
void RA3FDevSoundToneSetDTMFToneOnLengthToMinusOneTest::ToneFinished(TInt aError)
sl@0
  2965
	{
sl@0
  2966
	INFO_PRINTF1(_L("========== DevSound ToneFinished() callback =========="));
sl@0
  2967
	if (aError == KErrUnderflow)
sl@0
  2968
		{
sl@0
  2969
		INFO_PRINTF1(_L("ToneFinished was called before the timer event."));
sl@0
  2970
		StopTest(aError);
sl@0
  2971
		}
sl@0
  2972
	else
sl@0
  2973
		{
sl@0
  2974
		ERR_PRINTF2(_L("DevSound called ToneFinished with error = %d"), aError);
sl@0
  2975
		ERR_PRINTF2(_L("Expected error = %d"), KErrUnderflow);
sl@0
  2976
		StopTest(aError, EFail);
sl@0
  2977
		}
sl@0
  2978
	}
sl@0
  2979
sl@0
  2980
/*
sl@0
  2981
 *========================================================================================================
sl@0
  2982
 * MM-A3F-DEVSOUND-CHRTZ-TONE-0022
sl@0
  2983
 */
sl@0
  2984
RA3FDevSoundToneSetToneRepetitionsRepeatTrailingSilenceToNegativeTest::RA3FDevSoundToneSetToneRepetitionsRepeatTrailingSilenceToNegativeTest(const TDesC& aTestName)
sl@0
  2985
	:	RA3FDevSoundTestBase(aTestName), iDuration(0),
sl@0
  2986
		iFrequencyTone1(0),
sl@0
  2987
		iRepeatTrailingSilence(0), iRepeatCount(0),
sl@0
  2988
		iInitializedToPlayTones(EFalse)
sl@0
  2989
	{
sl@0
  2990
	}
sl@0
  2991
sl@0
  2992
RA3FDevSoundToneSetToneRepetitionsRepeatTrailingSilenceToNegativeTest* RA3FDevSoundToneSetToneRepetitionsRepeatTrailingSilenceToNegativeTest::NewL(const TDesC& aTestName)
sl@0
  2993
	{
sl@0
  2994
	RA3FDevSoundToneSetToneRepetitionsRepeatTrailingSilenceToNegativeTest * self = new(ELeave)RA3FDevSoundToneSetToneRepetitionsRepeatTrailingSilenceToNegativeTest(aTestName);
sl@0
  2995
	return self;
sl@0
  2996
	}
sl@0
  2997
sl@0
  2998
void RA3FDevSoundToneSetToneRepetitionsRepeatTrailingSilenceToNegativeTest::DoKickoffTestL()
sl@0
  2999
	{
sl@0
  3000
	if (!GetIntFromConfig(iTestStepName, KRepeatCount, iRepeatCount))
sl@0
  3001
		{
sl@0
  3002
		ERR_PRINTF2(KMsgErrorGetParameter, &KRepeatCount);
sl@0
  3003
		StopTest(KErrNotFound);
sl@0
  3004
		return;
sl@0
  3005
		}
sl@0
  3006
	if (!GetIntFromConfig(iTestStepName, KRepeatTrailingSilence, iRepeatTrailingSilence))
sl@0
  3007
		{
sl@0
  3008
		ERR_PRINTF2(KMsgErrorGetParameter, &KRepeatTrailingSilence);
sl@0
  3009
		StopTest(KErrNotFound);
sl@0
  3010
		return;
sl@0
  3011
		}
sl@0
  3012
	if (!GetIntFromConfig(iTestStepName, KDuration, iDuration))
sl@0
  3013
		{
sl@0
  3014
		ERR_PRINTF2(KMsgErrorGetParameter, &KDuration);
sl@0
  3015
		StopTest(KErrNotFound);
sl@0
  3016
		return;
sl@0
  3017
		}
sl@0
  3018
	if (!GetIntFromConfig(iTestStepName, KFrequencyTone1, iFrequencyTone1))
sl@0
  3019
		{
sl@0
  3020
		ERR_PRINTF2(KMsgErrorGetParameter, &KFrequencyTone1);
sl@0
  3021
		StopTest(KErrNotFound);
sl@0
  3022
		return;
sl@0
  3023
		}
sl@0
  3024
	}
sl@0
  3025
sl@0
  3026
void RA3FDevSoundToneSetToneRepetitionsRepeatTrailingSilenceToNegativeTest::Fsm(TMmfDevSoundEvent aDevSoundEvent, TInt aError)
sl@0
  3027
	{
sl@0
  3028
	switch (iDevSoundState)
sl@0
  3029
		{
sl@0
  3030
		case EStateCreated:
sl@0
  3031
			{
sl@0
  3032
			__ASSERT_ALWAYS((aError == KErrNone), Panic(_L("RA3FDevSoundToneSetToneRepetitionsRepeatTrailingSilenceToNegativeTest"), EFsmIncorrectErrorPassed));
sl@0
  3033
			if(aDevSoundEvent == EEventInitialize)
sl@0
  3034
				{
sl@0
  3035
				INFO_PRINTF1(_L("Calling CMMFDevSound::InitializeL"));
sl@0
  3036
				TRAPD(err, iMMFDevSound->InitializeL(*this, EMMFStateTonePlaying));
sl@0
  3037
				if (err != KErrNone)
sl@0
  3038
					{
sl@0
  3039
					ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"), err);
sl@0
  3040
					StopTest(err);
sl@0
  3041
					break;
sl@0
  3042
					}
sl@0
  3043
				INFO_PRINTF1(_L("DevSound State: EStateInitializing"));
sl@0
  3044
				iDevSoundState = EStateInitializing;
sl@0
  3045
				}
sl@0
  3046
			else
sl@0
  3047
				{
sl@0
  3048
				ERR_PRINTF2(_L("DevSound EEventInitialize not received as expected. Received event: %d"), aDevSoundEvent);
sl@0
  3049
				StopTest(aError, EFail);
sl@0
  3050
				}
sl@0
  3051
			break;
sl@0
  3052
			}
sl@0
  3053
		case EStateInitializing:
sl@0
  3054
			{
sl@0
  3055
			if (aDevSoundEvent == EEventInitComplete && aError == KErrNone)
sl@0
  3056
				{
sl@0
  3057
				iMMFDevSound->SetVolume(iMMFDevSound->MaxVolume());
sl@0
  3058
				INFO_PRINTF3(_L("Calling CMMFDevSound::SetToneRepeats using RepeatCount = %d and RepeatTrailingSilence = %d microsecs"), iRepeatCount, iRepeatTrailingSilence);
sl@0
  3059
				iMMFDevSound->SetToneRepeats(iRepeatCount, iRepeatTrailingSilence);
sl@0
  3060
				iStartTime.HomeTime();
sl@0
  3061
				INFO_PRINTF3(_L("Calling CMMFDevSound::PlayToneL %d Hz during %d secs "), iFrequencyTone1, iDuration);
sl@0
  3062
				TRAPD(err, iMMFDevSound->PlayToneL(iFrequencyTone1, iDuration*KMicroSecsInOneSec));
sl@0
  3063
				if (err != KErrNone)
sl@0
  3064
					{
sl@0
  3065
					ERR_PRINTF2(_L("CMMFDevSound::PlayToneL left with error : %d!"), err);
sl@0
  3066
					StopTest(err);
sl@0
  3067
					break;
sl@0
  3068
					}
sl@0
  3069
				INFO_PRINTF1(_L("DevSound State: EStatePlaying"));
sl@0
  3070
				iDevSoundState = EStatePlaying;
sl@0
  3071
				}
sl@0
  3072
			else if (aDevSoundEvent == EEventInitComplete && aError != KErrNone)
sl@0
  3073
				{
sl@0
  3074
				ERR_PRINTF2(_L("DevSound called CMMFDevSound::InitializeComplete with error = %d"), aError);
sl@0
  3075
				StopTest(aError);
sl@0
  3076
				}
sl@0
  3077
			else
sl@0
  3078
				{
sl@0
  3079
				ERR_PRINTF2(_L("DevSound EEventInitComplete not received as expected. Received event: %d"), aDevSoundEvent);
sl@0
  3080
				StopTest(aError, EFail);
sl@0
  3081
				}
sl@0
  3082
			break;
sl@0
  3083
			}
sl@0
  3084
		default:
sl@0
  3085
			{
sl@0
  3086
			ERR_PRINTF2(_L("Invalid DevSound state received: %d"), iDevSoundState);
sl@0
  3087
			StopTest(aError, EFail);
sl@0
  3088
			}
sl@0
  3089
		}
sl@0
  3090
	}
sl@0
  3091
sl@0
  3092
sl@0
  3093
void RA3FDevSoundToneSetToneRepetitionsRepeatTrailingSilenceToNegativeTest::ToneFinished(TInt aError)
sl@0
  3094
	{
sl@0
  3095
	INFO_PRINTF1(_L("========== DevSound ToneFinished() callback =========="));
sl@0
  3096
	if (aError == KErrUnderflow)
sl@0
  3097
		{
sl@0
  3098
		iEndTime.HomeTime();
sl@0
  3099
		iPlayToneTime = iEndTime.MicroSecondsFrom(iStartTime);
sl@0
  3100
		TInt repeatTrailingSilenceToSecs = iRepeatTrailingSilence/KMicroSecsInOneSec;
sl@0
  3101
		TInt totalExpectedReproductionTime = (iRepeatCount * iDuration + iDuration + (repeatTrailingSilenceToSecs*iRepeatCount))*KMicroSecsInOneSec;
sl@0
  3102
		if(iPlayToneTime < totalExpectedReproductionTime + KPlayVarianceTime && iPlayToneTime > totalExpectedReproductionTime - KPlayVarianceTime)
sl@0
  3103
			{
sl@0
  3104
			INFO_PRINTF1(_L("Play tone repeats succeded."));
sl@0
  3105
			INFO_PRINTF2(_L("Play time is %Ld microseconds"), iPlayToneTime.Int64());
sl@0
  3106
			StopTest();
sl@0
  3107
			}
sl@0
  3108
		else
sl@0
  3109
			{
sl@0
  3110
			ERR_PRINTF1(_L("Play tone repeats did not work as planned."));
sl@0
  3111
			ERR_PRINTF3(_L("Play time is %Ld microseconds and it should have been %d microseconds"), iPlayToneTime.Int64(), totalExpectedReproductionTime);
sl@0
  3112
			StopTest(KErrNone, EFail);
sl@0
  3113
			}
sl@0
  3114
		}
sl@0
  3115
	else
sl@0
  3116
		{
sl@0
  3117
		ERR_PRINTF2(_L("DevSound called ToneFinished with error = %d"), aError);
sl@0
  3118
		ERR_PRINTF2(_L("Expected error = %d"), KErrUnderflow);
sl@0
  3119
		StopTest(aError);
sl@0
  3120
		}
sl@0
  3121
	}
sl@0
  3122
sl@0
  3123
/*
sl@0
  3124
 *========================================================================================================
sl@0
  3125
 * MM-A3F-DEVSOUND-CHRTZ-TONE-0023
sl@0
  3126
 */
sl@0
  3127
RA3FDevSoundToneSetToneRepetitionsRepeatCountToKMdaRepeatForeverTest::RA3FDevSoundToneSetToneRepetitionsRepeatCountToKMdaRepeatForeverTest(const TDesC& aTestName)
sl@0
  3128
	:	RA3FDevSoundTestBase(aTestName), iDuration(0),
sl@0
  3129
		iFrequencyTone1(0),
sl@0
  3130
		iRepeatTrailingSilence(0), iRepeatCount(0),
sl@0
  3131
		iInitializedToPlayTones(EFalse)
sl@0
  3132
	{
sl@0
  3133
	}
sl@0
  3134
sl@0
  3135
RA3FDevSoundToneSetToneRepetitionsRepeatCountToKMdaRepeatForeverTest* RA3FDevSoundToneSetToneRepetitionsRepeatCountToKMdaRepeatForeverTest::NewL(const TDesC& aTestName)
sl@0
  3136
	{
sl@0
  3137
	RA3FDevSoundToneSetToneRepetitionsRepeatCountToKMdaRepeatForeverTest * self = new(ELeave)RA3FDevSoundToneSetToneRepetitionsRepeatCountToKMdaRepeatForeverTest(aTestName);
sl@0
  3138
	return self;
sl@0
  3139
	}
sl@0
  3140
sl@0
  3141
void RA3FDevSoundToneSetToneRepetitionsRepeatCountToKMdaRepeatForeverTest::DoKickoffTestL()
sl@0
  3142
	{
sl@0
  3143
	if (!GetIntFromConfig(iTestStepName, KRepeatCount, iRepeatCount))
sl@0
  3144
		{
sl@0
  3145
		ERR_PRINTF2(KMsgErrorGetParameter, &KRepeatCount);
sl@0
  3146
		StopTest(KErrNotFound);
sl@0
  3147
		return;
sl@0
  3148
		}
sl@0
  3149
	if (!GetIntFromConfig(iTestStepName, KRepeatTrailingSilence, iRepeatTrailingSilence))
sl@0
  3150
		{
sl@0
  3151
		ERR_PRINTF2(KMsgErrorGetParameter, &KRepeatTrailingSilence);
sl@0
  3152
		StopTest(KErrNotFound);
sl@0
  3153
		return;
sl@0
  3154
		}
sl@0
  3155
	if (!GetIntFromConfig(iTestStepName, KDuration, iDuration))
sl@0
  3156
		{
sl@0
  3157
		ERR_PRINTF2(KMsgErrorGetParameter, &KDuration);
sl@0
  3158
		StopTest(KErrNotFound);
sl@0
  3159
		return;
sl@0
  3160
		}
sl@0
  3161
	if (!GetIntFromConfig(iTestStepName, KFrequencyTone1, iFrequencyTone1))
sl@0
  3162
		{
sl@0
  3163
		ERR_PRINTF2(KMsgErrorGetParameter, &KFrequencyTone1);
sl@0
  3164
		StopTest(KErrNotFound);
sl@0
  3165
		return;
sl@0
  3166
		}
sl@0
  3167
	iTimer = CPeriodic::NewL(CActive::EPriorityHigh);
sl@0
  3168
	}
sl@0
  3169
sl@0
  3170
void RA3FDevSoundToneSetToneRepetitionsRepeatCountToKMdaRepeatForeverTest::Fsm(TMmfDevSoundEvent aDevSoundEvent, TInt aError)
sl@0
  3171
	{
sl@0
  3172
	switch (iDevSoundState)
sl@0
  3173
		{
sl@0
  3174
		case EStateCreated:
sl@0
  3175
			{
sl@0
  3176
			__ASSERT_ALWAYS((aError == KErrNone), Panic(_L("RA3FDevSoundToneSetToneRepetitionsRepeatCountToKMdaRepeatForeverTest"), EFsmIncorrectErrorPassed));
sl@0
  3177
			if(aDevSoundEvent == EEventInitialize)
sl@0
  3178
				{
sl@0
  3179
				INFO_PRINTF1(_L("Calling CMMFDevSound::InitializeL"));
sl@0
  3180
				TRAPD(err, iMMFDevSound->InitializeL(*this, EMMFStateTonePlaying));
sl@0
  3181
				if (err != KErrNone)
sl@0
  3182
					{
sl@0
  3183
					ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"), err);
sl@0
  3184
					StopTest(err);
sl@0
  3185
					break;
sl@0
  3186
					}
sl@0
  3187
				StartTimer(KMicrosecsInTenSec);
sl@0
  3188
				INFO_PRINTF1(_L("DevSound State: EStateInitializing"));
sl@0
  3189
				iDevSoundState = EStateInitializing;
sl@0
  3190
				}
sl@0
  3191
			else
sl@0
  3192
				{
sl@0
  3193
				ERR_PRINTF2(_L("DevSound EEventInitialize not received as expected. Received event: %d"), aDevSoundEvent);
sl@0
  3194
				StopTest(aError, EFail);
sl@0
  3195
				}
sl@0
  3196
			break;
sl@0
  3197
			}
sl@0
  3198
		case EStateInitializing:
sl@0
  3199
			{
sl@0
  3200
			if (aDevSoundEvent == EEventInitComplete && aError == KErrNone)
sl@0
  3201
				{
sl@0
  3202
				iMMFDevSound->SetVolume(iMMFDevSound->MaxVolume());
sl@0
  3203
				INFO_PRINTF3(_L("Calling CMMFDevSound::SetToneRepeats using RepeatCount = %d and RepeatTrailingSilence = %d microsecs"), iRepeatCount, iRepeatTrailingSilence);
sl@0
  3204
				iMMFDevSound->SetToneRepeats(iRepeatCount, iRepeatTrailingSilence);
sl@0
  3205
				iStartTime.HomeTime();
sl@0
  3206
				INFO_PRINTF3(_L("Calling CMMFDevSound::PlayToneL %d Hz during %d secs "), iFrequencyTone1, iDuration);
sl@0
  3207
				TRAPD(err, iMMFDevSound->PlayToneL(iFrequencyTone1, iDuration*KMicroSecsInOneSec));
sl@0
  3208
				if (err != KErrNone)
sl@0
  3209
					{
sl@0
  3210
					ERR_PRINTF2(_L("CMMFDevSound::PlayToneL left with error : %d!"), err);
sl@0
  3211
					StopTest(err);
sl@0
  3212
					break;
sl@0
  3213
					}
sl@0
  3214
				INFO_PRINTF1(_L("DevSound State: EStatePlaying"));
sl@0
  3215
				iDevSoundState = EStatePlaying;
sl@0
  3216
				}
sl@0
  3217
			else if (aDevSoundEvent == EEventInitComplete && aError != KErrNone)
sl@0
  3218
				{
sl@0
  3219
				ERR_PRINTF2(_L("DevSound called CMMFDevSound::InitializeComplete with error = %d"), aError);
sl@0
  3220
				StopTest(aError);
sl@0
  3221
				}
sl@0
  3222
			else
sl@0
  3223
				{
sl@0
  3224
				ERR_PRINTF2(_L("DevSound EEventInitComplete not received as expected. Received event: %d"), aDevSoundEvent);
sl@0
  3225
				StopTest(aError, EFail);
sl@0
  3226
				}
sl@0
  3227
			break;
sl@0
  3228
			}
sl@0
  3229
		default:
sl@0
  3230
			{
sl@0
  3231
			ERR_PRINTF2(_L("Invalid DevSound state received: %d"), iDevSoundState);
sl@0
  3232
			StopTest(aError, EFail);
sl@0
  3233
			}
sl@0
  3234
		}
sl@0
  3235
	}
sl@0
  3236
sl@0
  3237
sl@0
  3238
void RA3FDevSoundToneSetToneRepetitionsRepeatCountToKMdaRepeatForeverTest::DoTimerCallback()
sl@0
  3239
	{
sl@0
  3240
	iTimer->Cancel();
sl@0
  3241
	INFO_PRINTF1(_L("DevSound Event: EEventTimerComplete"));
sl@0
  3242
	iEndTime.HomeTime();
sl@0
  3243
	iPlayToneTime = iEndTime.MicroSecondsFrom(iStartTime);
sl@0
  3244
	INFO_PRINTF1(_L("Setting repeatCount value to KMdaRepeatForeverTest succeded."));
sl@0
  3245
	INFO_PRINTF2(_L("Play time is %Ld microseconds"), iPlayToneTime.Int64());
sl@0
  3246
	iMMFDevSound->Stop();
sl@0
  3247
	StopTest();
sl@0
  3248
	}
sl@0
  3249
sl@0
  3250
void RA3FDevSoundToneSetToneRepetitionsRepeatCountToKMdaRepeatForeverTest::ToneFinished(TInt aError)
sl@0
  3251
	{
sl@0
  3252
	INFO_PRINTF1(_L("========== DevSound ToneFinished() callback =========="));
sl@0
  3253
	if (aError == KErrUnderflow)
sl@0
  3254
		{
sl@0
  3255
		INFO_PRINTF1(_L("ToneFinished was called before the timer event."));
sl@0
  3256
		StopTest(aError);
sl@0
  3257
		}
sl@0
  3258
	else
sl@0
  3259
		{
sl@0
  3260
		ERR_PRINTF2(_L("DevSound called ToneFinished with error = %d"), aError);
sl@0
  3261
		ERR_PRINTF2(_L("Expected error = %d"), KErrUnderflow);
sl@0
  3262
		StopTest(aError, EFail);
sl@0
  3263
		}
sl@0
  3264
	}
sl@0
  3265
sl@0
  3266
/*
sl@0
  3267
 *========================================================================================================
sl@0
  3268
 * MM-A3F-DEVSOUND-CHRTZ-TONE-0024
sl@0
  3269
 */
sl@0
  3270
RA3FDevSoundToneCapsTest::RA3FDevSoundToneCapsTest(const TDesC& aTestName)
sl@0
  3271
	:	RA3FDevSoundTestBase(aTestName), iExCapRate(0), iExCapChannels(0)
sl@0
  3272
	{
sl@0
  3273
	}
sl@0
  3274
sl@0
  3275
RA3FDevSoundToneCapsTest* RA3FDevSoundToneCapsTest::NewL(const TDesC& aTestName)
sl@0
  3276
	{
sl@0
  3277
	RA3FDevSoundToneCapsTest * self = new(ELeave)RA3FDevSoundToneCapsTest(aTestName);
sl@0
  3278
	return self;
sl@0
  3279
	}
sl@0
  3280
sl@0
  3281
void RA3FDevSoundToneCapsTest::DoKickoffTestL()
sl@0
  3282
	{
sl@0
  3283
	if (!GetIntFromConfig(iTestStepName, KExCapRate, iExCapRate))
sl@0
  3284
		{
sl@0
  3285
		ERR_PRINTF2(KMsgErrorGetParameter, &KSampleRate);
sl@0
  3286
		StopTest(KErrNotFound);
sl@0
  3287
		return;
sl@0
  3288
		}
sl@0
  3289
	if (!GetIntFromConfig(iTestStepName, KExCapChannels, iExCapChannels))
sl@0
  3290
		{
sl@0
  3291
		ERR_PRINTF2(KMsgErrorGetParameter, &KChannel);
sl@0
  3292
		StopTest(KErrNotFound);
sl@0
  3293
		return;
sl@0
  3294
		}
sl@0
  3295
	}
sl@0
  3296
sl@0
  3297
void RA3FDevSoundToneCapsTest::Fsm(TMmfDevSoundEvent aDevSoundEvent, TInt aError)
sl@0
  3298
	{
sl@0
  3299
	switch(iDevSoundState)
sl@0
  3300
		{
sl@0
  3301
		case EStateCreated:
sl@0
  3302
			{
sl@0
  3303
			__ASSERT_ALWAYS((aError == KErrNone), Panic(_L("RA3FDevSoundToneCapsTest"), EFsmIncorrectErrorPassed));
sl@0
  3304
			if (aDevSoundEvent == EEventInitialize)
sl@0
  3305
				{
sl@0
  3306
				INFO_PRINTF1(_L("Calling CMMFDevSound::InitializeL"));
sl@0
  3307
				TRAPD(err, iMMFDevSound->InitializeL(*this, EMMFStateTonePlaying));
sl@0
  3308
				if (err != KErrNone)
sl@0
  3309
					{
sl@0
  3310
					ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"), err);
sl@0
  3311
					StopTest(err);
sl@0
  3312
					break;
sl@0
  3313
					}
sl@0
  3314
				INFO_PRINTF1(_L("DevSound State: EStateInitializing"));
sl@0
  3315
				iDevSoundState = EStateInitializing;
sl@0
  3316
				}
sl@0
  3317
			else
sl@0
  3318
				{
sl@0
  3319
				ERR_PRINTF2(_L("DevSound EEventInitialize not received as expected. Received event: %d"), aDevSoundEvent);
sl@0
  3320
				StopTest(aError,  EFail);
sl@0
  3321
				}
sl@0
  3322
			break;
sl@0
  3323
			}
sl@0
  3324
		case EStateInitializing:
sl@0
  3325
			{
sl@0
  3326
			if (aDevSoundEvent == EEventInitComplete && aError == KErrNone)
sl@0
  3327
				{
sl@0
  3328
				TMMFCapabilities capabilities;
sl@0
  3329
				INFO_PRINTF1(_L("Calling CMMFDevSound::Capabilities"));
sl@0
  3330
				capabilities = iMMFDevSound->Capabilities();
sl@0
  3331
				PrintSupportedCapabilities(capabilities.iRate, capabilities.iChannels);
sl@0
  3332
				if(capabilities.iRate == iExCapRate)
sl@0
  3333
					{
sl@0
  3334
					INFO_PRINTF2(_L("The total of possible sample rate values is 0x%08x"), capabilities.iRate);
sl@0
  3335
					}
sl@0
  3336
				else
sl@0
  3337
					{
sl@0
  3338
					ERR_PRINTF2(_L("The total of possible sample rate values failed with 0x%08x"), capabilities.iRate);
sl@0
  3339
					ERR_PRINTF2(_L("Expected value = %d"), iExCapRate);
sl@0
  3340
					StopTest(aError, EFail);
sl@0
  3341
					}
sl@0
  3342
				if(capabilities.iChannels == iExCapChannels)
sl@0
  3343
					{
sl@0
  3344
					INFO_PRINTF2(_L("The total of possible channel values is 0x%08x"),capabilities.iChannels );
sl@0
  3345
					StopTest();
sl@0
  3346
					}
sl@0
  3347
				else
sl@0
  3348
					{
sl@0
  3349
					ERR_PRINTF2(_L("The total of possible channel values failed with 0x%08x"), capabilities.iChannels );
sl@0
  3350
					ERR_PRINTF2(_L("Expected value = %d"), iExCapChannels);
sl@0
  3351
					StopTest(aError, EFail);
sl@0
  3352
					}
sl@0
  3353
				}
sl@0
  3354
			else if (aDevSoundEvent == EEventInitComplete && aError != KErrNone)
sl@0
  3355
				{
sl@0
  3356
				ERR_PRINTF2(_L("DevSound called CMMFDevSound::InitializeComplete with error = %d"), aError);
sl@0
  3357
				StopTest(aError);
sl@0
  3358
				}
sl@0
  3359
			else
sl@0
  3360
				{
sl@0
  3361
				ERR_PRINTF2(_L("DevSound EEventInitComplete not received as expected. Received event: %d"), aDevSoundEvent);
sl@0
  3362
				StopTest(aError, EFail);
sl@0
  3363
				}
sl@0
  3364
			break;
sl@0
  3365
			}
sl@0
  3366
		default:
sl@0
  3367
			{
sl@0
  3368
			ERR_PRINTF2(_L("Invalid DevSound state received: %d"), iDevSoundState);
sl@0
  3369
			StopTest(aError, EFail);
sl@0
  3370
			}
sl@0
  3371
		}
sl@0
  3372
	}
sl@0
  3373
sl@0
  3374
/*
sl@0
  3375
 *========================================================================================================
sl@0
  3376
 * MM-A3F-DEVSOUND-CHRTZ-TONE-0025
sl@0
  3377
 */
sl@0
  3378
RA3FDevSoundToneConfigDefaultTest::RA3FDevSoundToneConfigDefaultTest(const TDesC& aTestName)
sl@0
  3379
	:	RA3FDevSoundTestBase(aTestName), iExCapRate(0),
sl@0
  3380
		iExCapChannels(0)
sl@0
  3381
	{
sl@0
  3382
	}
sl@0
  3383
sl@0
  3384
RA3FDevSoundToneConfigDefaultTest* RA3FDevSoundToneConfigDefaultTest::NewL(const TDesC& aTestName)
sl@0
  3385
	{
sl@0
  3386
	RA3FDevSoundToneConfigDefaultTest * self = new(ELeave)RA3FDevSoundToneConfigDefaultTest(aTestName);
sl@0
  3387
	return self;
sl@0
  3388
	}
sl@0
  3389
sl@0
  3390
void RA3FDevSoundToneConfigDefaultTest::DoKickoffTestL()
sl@0
  3391
	{
sl@0
  3392
	if (!GetIntFromConfig(iTestStepName, KExCapRate, iExCapRate))
sl@0
  3393
			{
sl@0
  3394
			ERR_PRINTF2(KMsgErrorGetParameter, &KExCapRate);
sl@0
  3395
			StopTest(KErrNotFound);
sl@0
  3396
			return;
sl@0
  3397
			}
sl@0
  3398
	if (!GetIntFromConfig(iTestStepName, KExCapChannels, iExCapChannels))
sl@0
  3399
		{
sl@0
  3400
		ERR_PRINTF2(KMsgErrorGetParameter, &KExCapChannels);
sl@0
  3401
		StopTest(KErrNotFound);
sl@0
  3402
		return;
sl@0
  3403
		}
sl@0
  3404
	}
sl@0
  3405
sl@0
  3406
void RA3FDevSoundToneConfigDefaultTest::Fsm(TMmfDevSoundEvent aDevSoundEvent, TInt aError)
sl@0
  3407
	{
sl@0
  3408
		switch(iDevSoundState)
sl@0
  3409
		{
sl@0
  3410
		case EStateCreated:
sl@0
  3411
			{
sl@0
  3412
			__ASSERT_ALWAYS((aError == KErrNone), Panic(_L("RA3FDevSoundToneConfigDefaultTest"), EFsmIncorrectErrorPassed));
sl@0
  3413
			if (aDevSoundEvent == EEventInitialize)
sl@0
  3414
				{
sl@0
  3415
				INFO_PRINTF1(_L("Calling CMMFDevSound::InitializeL"));
sl@0
  3416
				TRAPD(err, iMMFDevSound->InitializeL(*this, EMMFStateTonePlaying));
sl@0
  3417
				if (err != KErrNone)
sl@0
  3418
					{
sl@0
  3419
					ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"), err);
sl@0
  3420
					StopTest(err);
sl@0
  3421
					}
sl@0
  3422
				INFO_PRINTF1(_L("DevSound State: EStateInitializing"));
sl@0
  3423
				iDevSoundState=EStateInitializing;
sl@0
  3424
				}
sl@0
  3425
			else
sl@0
  3426
				{
sl@0
  3427
				ERR_PRINTF2(_L("DevSound EEventInitialize not received as expected. Received event: %d"), aDevSoundEvent);
sl@0
  3428
				StopTest(aError, EFail);
sl@0
  3429
				}
sl@0
  3430
			break;
sl@0
  3431
			}
sl@0
  3432
		case EStateInitializing:
sl@0
  3433
			{
sl@0
  3434
			if (aDevSoundEvent == EEventInitComplete && aError == KErrNone)
sl@0
  3435
				{
sl@0
  3436
				TMMFCapabilities capabilitiesGet;
sl@0
  3437
				TBuf<KMaxSampleRateStringLength> stringSampleRateGet;
sl@0
  3438
				TBuf<KMaxChannelsStringLength> stringChannelsGet;
sl@0
  3439
				TBuf<KMaxSampleRateStringLength> stringSampleRateExpected;
sl@0
  3440
				TBuf<KMaxChannelsStringLength> stringChannelsExpected;
sl@0
  3441
				INFO_PRINTF1(_L("Calling CMMFDevSound::Config"));
sl@0
  3442
				capabilitiesGet=iMMFDevSound->Config();
sl@0
  3443
				SampleRateFromTUintToString (capabilitiesGet.iRate, stringSampleRateGet);
sl@0
  3444
				ChannelsFromTUintToString (capabilitiesGet.iChannels, stringChannelsGet);
sl@0
  3445
				SampleRateFromTIntToTMMFSampleRate (iExCapRate, iExSampleRate);
sl@0
  3446
				SampleRateFromTUintToString (iExSampleRate, stringSampleRateExpected);
sl@0
  3447
				ChannelsFromTUintToString (iExCapChannels, stringChannelsExpected);
sl@0
  3448
				if (stringSampleRateExpected.Compare(stringSampleRateGet) == 0)
sl@0
  3449
					{
sl@0
  3450
					INFO_PRINTF2(_L("Sample rate value match default as expected with %S"), &stringSampleRateGet);
sl@0
  3451
					if (stringChannelsExpected.Compare(stringChannelsGet) == 0)
sl@0
  3452
						{
sl@0
  3453
						INFO_PRINTF2(_L("Channel mode value match default as expected with %S"), &stringChannelsGet);
sl@0
  3454
						StopTest();
sl@0
  3455
						}
sl@0
  3456
					else
sl@0
  3457
						{
sl@0
  3458
						INFO_PRINTF2(_L("Channel mode value failed with %S"), &stringChannelsGet);
sl@0
  3459
						ERR_PRINTF2(_L("Expected channel mode %S"), &stringChannelsExpected);
sl@0
  3460
						StopTest(aError, EFail);
sl@0
  3461
						}
sl@0
  3462
					}
sl@0
  3463
				else
sl@0
  3464
					{
sl@0
  3465
					ERR_PRINTF2(_L("Sample rate value failed with %S"), &stringSampleRateGet);
sl@0
  3466
					ERR_PRINTF2(_L("Expected sample rate %S"), &stringSampleRateExpected);
sl@0
  3467
					StopTest(aError, EFail);
sl@0
  3468
					}
sl@0
  3469
				}
sl@0
  3470
			else if (aDevSoundEvent == EEventInitComplete && aError != KErrNone)
sl@0
  3471
				{
sl@0
  3472
				ERR_PRINTF2(_L("DevSound called CMMFDevSound::InitializeComplete with error = %d"), aError);
sl@0
  3473
				StopTest(aError);
sl@0
  3474
				}
sl@0
  3475
			else
sl@0
  3476
				{
sl@0
  3477
				ERR_PRINTF2(_L("DevSound EEventInitComplete not received as expected. Received event: %d"), aDevSoundEvent);
sl@0
  3478
				StopTest(aError, EFail);
sl@0
  3479
				}
sl@0
  3480
			break;
sl@0
  3481
			}
sl@0
  3482
		default:
sl@0
  3483
			{
sl@0
  3484
			ERR_PRINTF2(_L("Invalid DevSound state received: %d"), iDevSoundState);
sl@0
  3485
			StopTest(aError, EFail);
sl@0
  3486
			}
sl@0
  3487
		}
sl@0
  3488
	}
sl@0
  3489
sl@0
  3490
/*
sl@0
  3491
 *========================================================================================================
sl@0
  3492
 * MM-A3F-DEVSOUND-CHRTZ-TONE-0026
sl@0
  3493
 */
sl@0
  3494
RA3FDevSoundToneMaxVolumeTest::RA3FDevSoundToneMaxVolumeTest(const TDesC& aTestName)
sl@0
  3495
	:	RA3FDevSoundTestBase(aTestName), iExVolume(0)
sl@0
  3496
	{
sl@0
  3497
	}
sl@0
  3498
sl@0
  3499
RA3FDevSoundToneMaxVolumeTest* RA3FDevSoundToneMaxVolumeTest::NewL(const TDesC& aTestName)
sl@0
  3500
	{
sl@0
  3501
	RA3FDevSoundToneMaxVolumeTest * self = new(ELeave)RA3FDevSoundToneMaxVolumeTest(aTestName);
sl@0
  3502
	return self;
sl@0
  3503
	}
sl@0
  3504
sl@0
  3505
void RA3FDevSoundToneMaxVolumeTest::DoKickoffTestL()
sl@0
  3506
	{
sl@0
  3507
	if (!GetIntFromConfig(iTestStepName, KExVolume, iExVolume))
sl@0
  3508
		{
sl@0
  3509
		ERR_PRINTF2(KMsgErrorGetParameter, &KExVolume);
sl@0
  3510
		StopTest(KErrNotFound);
sl@0
  3511
		return;
sl@0
  3512
		}
sl@0
  3513
	}
sl@0
  3514
sl@0
  3515
void RA3FDevSoundToneMaxVolumeTest::Fsm(TMmfDevSoundEvent aDevSoundEvent,  TInt aError)
sl@0
  3516
	{
sl@0
  3517
	switch(iDevSoundState)
sl@0
  3518
		{
sl@0
  3519
		case EStateCreated:
sl@0
  3520
			{
sl@0
  3521
			__ASSERT_ALWAYS((aError == KErrNone), Panic(_L("RA3FDevSoundToneMaxVolumeTest"), EFsmIncorrectErrorPassed));
sl@0
  3522
			if (aDevSoundEvent == EEventInitialize)
sl@0
  3523
				{
sl@0
  3524
				INFO_PRINTF1(_L("Calling CMMFDevSound::InitializeL"));
sl@0
  3525
				TRAPD(err, iMMFDevSound->InitializeL(*this, EMMFStateTonePlaying));
sl@0
  3526
				if (err != KErrNone)
sl@0
  3527
					{
sl@0
  3528
					ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"), err);
sl@0
  3529
					StopTest(err);
sl@0
  3530
					break;
sl@0
  3531
					}
sl@0
  3532
				INFO_PRINTF1(_L("DevSound State: EStateInitializing"));
sl@0
  3533
				iDevSoundState = EStateInitializing;
sl@0
  3534
				}
sl@0
  3535
			else
sl@0
  3536
				{
sl@0
  3537
				ERR_PRINTF2(_L("DevSound EEventInitialize not received as expected. Received event: %d"), aDevSoundEvent);
sl@0
  3538
				StopTest(aError, EFail);
sl@0
  3539
				}
sl@0
  3540
			break;
sl@0
  3541
			}
sl@0
  3542
		case EStateInitializing:
sl@0
  3543
			{
sl@0
  3544
			if (aDevSoundEvent == EEventInitComplete && aError == KErrNone)
sl@0
  3545
				{
sl@0
  3546
				INFO_PRINTF1(_L("Calling CMMFDevSound::MaxVolume"));
sl@0
  3547
				TInt maxVolumeGet = iMMFDevSound->MaxVolume();
sl@0
  3548
				if (maxVolumeGet == iExVolume)
sl@0
  3549
					{
sl@0
  3550
					INFO_PRINTF2(_L("The max device supported volume is %d."), maxVolumeGet);
sl@0
  3551
					StopTest();
sl@0
  3552
					}
sl@0
  3553
				else
sl@0
  3554
					{
sl@0
  3555
					INFO_PRINTF2(_L("The max device supported volume failed with %d."), maxVolumeGet);
sl@0
  3556
					ERR_PRINTF2(_L("Expected value = %d."), iExVolume);
sl@0
  3557
					StopTest(aError, EFail);
sl@0
  3558
					}
sl@0
  3559
				}
sl@0
  3560
			else if (aDevSoundEvent == EEventInitComplete && aError != KErrNone)
sl@0
  3561
				{
sl@0
  3562
				ERR_PRINTF2(_L("DevSound called CMMFDevSound::InitializeComplete with error = %d"), aError);
sl@0
  3563
				StopTest(aError);
sl@0
  3564
				}
sl@0
  3565
			else
sl@0
  3566
				{
sl@0
  3567
				ERR_PRINTF2(_L("DevSound EEventInitComplete not received as expected. Received event: %d"), aDevSoundEvent);
sl@0
  3568
				StopTest(aError, EFail);
sl@0
  3569
				}
sl@0
  3570
			break;
sl@0
  3571
			}
sl@0
  3572
		default:
sl@0
  3573
			{
sl@0
  3574
			ERR_PRINTF2(_L("Invalid DevSound state received: %d"), iDevSoundState);
sl@0
  3575
			StopTest(aError, EFail);
sl@0
  3576
			}
sl@0
  3577
		}
sl@0
  3578
	}
sl@0
  3579
sl@0
  3580
/*
sl@0
  3581
 *========================================================================================================
sl@0
  3582
 * MM-A3F-DEVSOUND-CHRTZ-TONE-0027
sl@0
  3583
 */
sl@0
  3584
RA3FDevSoundToneVolumeTest::RA3FDevSoundToneVolumeTest(const TDesC& aTestName)
sl@0
  3585
	:	RA3FDevSoundTestBase(aTestName), iExVolume(0)
sl@0
  3586
	{
sl@0
  3587
	}
sl@0
  3588
sl@0
  3589
RA3FDevSoundToneVolumeTest* RA3FDevSoundToneVolumeTest::NewL(const TDesC& aTestName)
sl@0
  3590
	{
sl@0
  3591
	RA3FDevSoundToneVolumeTest * self = new(ELeave)RA3FDevSoundToneVolumeTest(aTestName);
sl@0
  3592
	return self;
sl@0
  3593
	}
sl@0
  3594
sl@0
  3595
void RA3FDevSoundToneVolumeTest::DoKickoffTestL()
sl@0
  3596
	{
sl@0
  3597
	if (!GetIntFromConfig(iTestStepName, KExVolume, iExVolume))
sl@0
  3598
		{
sl@0
  3599
		ERR_PRINTF2(KMsgErrorGetParameter, &KExVolume);
sl@0
  3600
		StopTest(KErrNotFound);
sl@0
  3601
		return;
sl@0
  3602
		}
sl@0
  3603
	}
sl@0
  3604
sl@0
  3605
void RA3FDevSoundToneVolumeTest::Fsm(TMmfDevSoundEvent aDevSoundEvent, TInt aError)
sl@0
  3606
	{
sl@0
  3607
	switch (iDevSoundState)
sl@0
  3608
		{
sl@0
  3609
		case EStateCreated:
sl@0
  3610
			{
sl@0
  3611
			__ASSERT_ALWAYS((aError == KErrNone), Panic(_L("RA3FDevSoundToneVolumeTest"), EFsmIncorrectErrorPassed));
sl@0
  3612
			if (aDevSoundEvent == EEventInitialize)
sl@0
  3613
				{
sl@0
  3614
				INFO_PRINTF1(_L("Calling CMMFDevSound::InitializeL"));
sl@0
  3615
				TRAPD(err, iMMFDevSound->InitializeL(*this, EMMFStateTonePlaying));
sl@0
  3616
				if (err != KErrNone)
sl@0
  3617
					{
sl@0
  3618
					ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"), err);
sl@0
  3619
					StopTest(err);
sl@0
  3620
					break;
sl@0
  3621
					}
sl@0
  3622
				INFO_PRINTF1(_L("DevSound State: EStateInitializing"));
sl@0
  3623
				iDevSoundState = EStateInitializing;
sl@0
  3624
				}
sl@0
  3625
			else
sl@0
  3626
				{
sl@0
  3627
				ERR_PRINTF2(_L("DevSound EEventInitialize not received as expected. Received event: %d"), aDevSoundEvent);
sl@0
  3628
				StopTest(aError, EFail);
sl@0
  3629
				}
sl@0
  3630
			break;
sl@0
  3631
			}
sl@0
  3632
		case EStateInitializing:
sl@0
  3633
			{
sl@0
  3634
			if (aDevSoundEvent == EEventInitComplete && aError == KErrNone)
sl@0
  3635
				{
sl@0
  3636
				INFO_PRINTF1(_L("Calling CMMFDevSound::Volume"));
sl@0
  3637
				TInt volumeGet = iMMFDevSound->Volume();
sl@0
  3638
				if(volumeGet == iExVolume)
sl@0
  3639
					{
sl@0
  3640
					INFO_PRINTF2(_L("Default device volume succeeded with = %d"), volumeGet);
sl@0
  3641
					StopTest();
sl@0
  3642
					}
sl@0
  3643
				else
sl@0
  3644
					{
sl@0
  3645
					ERR_PRINTF2(_L("Default device volume failed with = %d"), volumeGet);
sl@0
  3646
					ERR_PRINTF2(_L("Expected value % d"), iExVolume);
sl@0
  3647
					StopTest(aError , EFail);
sl@0
  3648
					}
sl@0
  3649
				}
sl@0
  3650
			else if (aDevSoundEvent == EEventInitComplete && aError != KErrNone)
sl@0
  3651
				{
sl@0
  3652
				ERR_PRINTF2(_L("DevSound called CMMFDevSound::InitializeComplete with error = %d"), aError);
sl@0
  3653
				StopTest(aError);
sl@0
  3654
				}
sl@0
  3655
			else
sl@0
  3656
				{
sl@0
  3657
				ERR_PRINTF2(_L("DevSound EEventInitComplete not received as expected. Received event: %d"), aDevSoundEvent);
sl@0
  3658
				StopTest(aError, EFail);
sl@0
  3659
				}
sl@0
  3660
			break;
sl@0
  3661
			}
sl@0
  3662
		default:
sl@0
  3663
			{
sl@0
  3664
			ERR_PRINTF2(_L("Invalid DevSound state received: %d"), iDevSoundState);
sl@0
  3665
			StopTest(aError, EFail);
sl@0
  3666
			}
sl@0
  3667
		}
sl@0
  3668
	}
sl@0
  3669
sl@0
  3670
sl@0
  3671
/*
sl@0
  3672
 *========================================================================================================
sl@0
  3673
 * MM-A3F-DEVSOUND-CHRTZ-TONE-0028
sl@0
  3674
 */
sl@0
  3675
RA3FDevSoundToneQueryCapsWhilePlayingTest::RA3FDevSoundToneQueryCapsWhilePlayingTest(const TDesC& aTestName)
sl@0
  3676
	:	RA3FDevSoundTestBase(aTestName), iDuration(0),
sl@0
  3677
		iFrequencyTone1(0), iExCapRate(0), iExCapChannels(0)
sl@0
  3678
	{
sl@0
  3679
	}
sl@0
  3680
sl@0
  3681
RA3FDevSoundToneQueryCapsWhilePlayingTest* RA3FDevSoundToneQueryCapsWhilePlayingTest::NewL(const TDesC& aTestName)
sl@0
  3682
	{
sl@0
  3683
	RA3FDevSoundToneQueryCapsWhilePlayingTest * self = new(ELeave)RA3FDevSoundToneQueryCapsWhilePlayingTest(aTestName);
sl@0
  3684
	return self;
sl@0
  3685
	}
sl@0
  3686
sl@0
  3687
void RA3FDevSoundToneQueryCapsWhilePlayingTest::DoKickoffTestL()
sl@0
  3688
	{
sl@0
  3689
	if (!GetIntFromConfig(iTestStepName, KDuration, iDuration))
sl@0
  3690
		{
sl@0
  3691
		ERR_PRINTF2(KMsgErrorGetParameter, &KDuration);
sl@0
  3692
		StopTest(KErrNotFound);
sl@0
  3693
		return;
sl@0
  3694
		}
sl@0
  3695
	if (!GetIntFromConfig(iTestStepName, KFrequencyTone1, iFrequencyTone1))
sl@0
  3696
		{
sl@0
  3697
		ERR_PRINTF2(KMsgErrorGetParameter, &KFrequencyTone1);
sl@0
  3698
		StopTest(KErrNotFound);
sl@0
  3699
		return;
sl@0
  3700
		}
sl@0
  3701
	if (!GetIntFromConfig(iTestStepName, KExCapRate, iExCapRate))
sl@0
  3702
		{
sl@0
  3703
		ERR_PRINTF2(KMsgErrorGetParameter, &KSampleRate);
sl@0
  3704
		StopTest(KErrNotFound);
sl@0
  3705
		return;
sl@0
  3706
		}
sl@0
  3707
	if (!GetIntFromConfig(iTestStepName, KExCapChannels, iExCapChannels))
sl@0
  3708
		{
sl@0
  3709
		ERR_PRINTF2(KMsgErrorGetParameter, &KChannel);
sl@0
  3710
		StopTest(KErrNotFound);
sl@0
  3711
		return;
sl@0
  3712
		}
sl@0
  3713
	iTimer = CPeriodic::NewL(CActive::EPriorityHigh);
sl@0
  3714
	}
sl@0
  3715
sl@0
  3716
void RA3FDevSoundToneQueryCapsWhilePlayingTest::Fsm(TMmfDevSoundEvent aDevSoundEvent, TInt aError)
sl@0
  3717
	{
sl@0
  3718
	switch (iDevSoundState)
sl@0
  3719
		{
sl@0
  3720
		case EStateCreated:
sl@0
  3721
			{
sl@0
  3722
			__ASSERT_ALWAYS((aError == KErrNone), Panic(_L("RA3FDevSoundToneQueryCapsWhilePlayingTest"), EFsmIncorrectErrorPassed));
sl@0
  3723
			if (aDevSoundEvent == EEventInitialize)
sl@0
  3724
				{
sl@0
  3725
				INFO_PRINTF1(_L("Calling CMMFDevSound::InitializeL"));
sl@0
  3726
				TRAPD(err, iMMFDevSound->InitializeL(*this, EMMFStateTonePlaying));
sl@0
  3727
				if (err != KErrNone)
sl@0
  3728
					{
sl@0
  3729
					ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"), err);
sl@0
  3730
					StopTest(err);
sl@0
  3731
					break;
sl@0
  3732
					}
sl@0
  3733
				INFO_PRINTF1(_L("DevSound State: EStateInitializing"));
sl@0
  3734
				iDevSoundState = EStateInitializing;
sl@0
  3735
				}
sl@0
  3736
			else
sl@0
  3737
				{
sl@0
  3738
				ERR_PRINTF2(_L("DevSound EEventInitialize not received as expected. Received event: %d"), aDevSoundEvent);
sl@0
  3739
				StopTest(aError, EFail);
sl@0
  3740
				}
sl@0
  3741
			break;
sl@0
  3742
			}
sl@0
  3743
		case EStateInitializing:
sl@0
  3744
			{
sl@0
  3745
			if (aDevSoundEvent == EEventInitComplete && aError == KErrNone)
sl@0
  3746
				{
sl@0
  3747
				INFO_PRINTF3(_L("Calling CMMFDevSound::PlayToneL using %d Hz during %d secs "), iFrequencyTone1, iDuration);
sl@0
  3748
				TRAPD(err, iMMFDevSound->PlayToneL(iFrequencyTone1, iDuration*KMicroSecsInOneSec));
sl@0
  3749
				if (err != KErrNone)
sl@0
  3750
					{
sl@0
  3751
					ERR_PRINTF2(_L("CMMFDevSound::PlayToneL left with error : %d!"), err);
sl@0
  3752
					StopTest(err);
sl@0
  3753
					break;
sl@0
  3754
					}
sl@0
  3755
				StartTimer(KMicroSecsTwoSec);
sl@0
  3756
				INFO_PRINTF1(_L("DevSound State: EStatePlaying"));
sl@0
  3757
				iDevSoundState = EStatePlaying;
sl@0
  3758
				}
sl@0
  3759
			else if (aDevSoundEvent == EEventInitComplete && aError != KErrNone)
sl@0
  3760
				{
sl@0
  3761
				ERR_PRINTF2(_L("DevSound called CMMFDevSound::InitializeComplete with error = %d"), aError);
sl@0
  3762
				StopTest(aError);
sl@0
  3763
				}
sl@0
  3764
			else
sl@0
  3765
				{
sl@0
  3766
				ERR_PRINTF2(_L("DevSound EEventInitComplete not received as expected. Received event: %d"), aDevSoundEvent);
sl@0
  3767
				StopTest(aError, EFail);
sl@0
  3768
				}
sl@0
  3769
			break;
sl@0
  3770
			}
sl@0
  3771
		default:
sl@0
  3772
			{
sl@0
  3773
			ERR_PRINTF2(_L("Invalid DevSound state received: %d"), iDevSoundState);
sl@0
  3774
			StopTest(aError, EFail);
sl@0
  3775
			}
sl@0
  3776
		}
sl@0
  3777
	}
sl@0
  3778
sl@0
  3779
void RA3FDevSoundToneQueryCapsWhilePlayingTest::DoTimerCallback()
sl@0
  3780
	{
sl@0
  3781
	iTimer->Cancel();
sl@0
  3782
	INFO_PRINTF1(_L("DevSound Event: EEventTimerComplete"));
sl@0
  3783
	TMMFCapabilities capabilities;
sl@0
  3784
	INFO_PRINTF1(_L("Calling CMMFDevSound::Capabilities"));
sl@0
  3785
	capabilities = iMMFDevSound->Capabilities();
sl@0
  3786
	PrintSupportedCapabilities(capabilities.iRate, capabilities.iChannels);
sl@0
  3787
	if(capabilities.iRate == iExCapRate)
sl@0
  3788
		{
sl@0
  3789
		INFO_PRINTF2(_L("The total of possible sample rate values is 0x%08x"), capabilities.iRate);
sl@0
  3790
		}
sl@0
  3791
	else
sl@0
  3792
		{
sl@0
  3793
		ERR_PRINTF2(_L("The total of possible sample rate values failed with 0x%08x"), capabilities.iRate);
sl@0
  3794
		ERR_PRINTF2(_L("Expected value = %d"), iExCapRate);
sl@0
  3795
		StopTest(KErrNone, EFail);
sl@0
  3796
		}
sl@0
  3797
	if(capabilities.iChannels == iExCapChannels)
sl@0
  3798
		{
sl@0
  3799
		INFO_PRINTF2(_L("The total of possible channel values is 0x%08x"),capabilities.iChannels );
sl@0
  3800
		}
sl@0
  3801
	else
sl@0
  3802
		{
sl@0
  3803
		ERR_PRINTF2(_L("The total of possible channel values failed with 0x%08x"), capabilities.iChannels );
sl@0
  3804
		ERR_PRINTF2(_L("Expected value = %d"), iExCapChannels);
sl@0
  3805
		StopTest(KErrNone, EFail);
sl@0
  3806
		}
sl@0
  3807
	}
sl@0
  3808
sl@0
  3809
/*
sl@0
  3810
 *========================================================================================================
sl@0
  3811
 * MM-A3F-DEVSOUND-CHRTZ-TONE-0029
sl@0
  3812
 */
sl@0
  3813
RA3FDevSoundToneConfigWhilePlayingTest::RA3FDevSoundToneConfigWhilePlayingTest(const TDesC& aTestName)
sl@0
  3814
	:	RA3FDevSoundTestBase(aTestName), iDuration(0),
sl@0
  3815
		iFrequencyTone1(0)
sl@0
  3816
	{
sl@0
  3817
	}
sl@0
  3818
RA3FDevSoundToneConfigWhilePlayingTest* RA3FDevSoundToneConfigWhilePlayingTest::NewL(const TDesC& aTestName)
sl@0
  3819
	{
sl@0
  3820
	RA3FDevSoundToneConfigWhilePlayingTest * self = new(ELeave)RA3FDevSoundToneConfigWhilePlayingTest(aTestName);
sl@0
  3821
	return self;
sl@0
  3822
	}
sl@0
  3823
sl@0
  3824
void RA3FDevSoundToneConfigWhilePlayingTest::DoKickoffTestL()
sl@0
  3825
	{
sl@0
  3826
	if (!GetIntFromConfig(iTestStepName, KDuration, iDuration))
sl@0
  3827
		{
sl@0
  3828
		ERR_PRINTF2(KMsgErrorGetParameter, &KDuration);
sl@0
  3829
		StopTest(KErrNotFound);
sl@0
  3830
		return;
sl@0
  3831
		}
sl@0
  3832
	if (!GetIntFromConfig(iTestStepName, KFrequencyTone1, iFrequencyTone1))
sl@0
  3833
		{
sl@0
  3834
		ERR_PRINTF2(KMsgErrorGetParameter, &KFrequencyTone1);
sl@0
  3835
		StopTest(KErrNotFound);
sl@0
  3836
		return;
sl@0
  3837
		}
sl@0
  3838
	if (!GetIntFromConfig(iTestStepName, KExCapRate, iExCapRate))
sl@0
  3839
			{
sl@0
  3840
			ERR_PRINTF2(KMsgErrorGetParameter, &KExCapRate);
sl@0
  3841
			StopTest(KErrNotFound);
sl@0
  3842
			return;
sl@0
  3843
			}
sl@0
  3844
	if (!GetIntFromConfig(iTestStepName, KExCapChannels, iExCapChannels))
sl@0
  3845
		{
sl@0
  3846
		ERR_PRINTF2(KMsgErrorGetParameter, &KExCapChannels);
sl@0
  3847
		StopTest(KErrNotFound);
sl@0
  3848
		return;
sl@0
  3849
		}
sl@0
  3850
	iTimer = CPeriodic::NewL(CActive::EPriorityHigh);
sl@0
  3851
	}
sl@0
  3852
sl@0
  3853
void RA3FDevSoundToneConfigWhilePlayingTest::Fsm(TMmfDevSoundEvent aDevSoundEvent, TInt aError)
sl@0
  3854
	{
sl@0
  3855
	switch(iDevSoundState)
sl@0
  3856
		{
sl@0
  3857
		case EStateCreated:
sl@0
  3858
			{
sl@0
  3859
			__ASSERT_ALWAYS((aError == KErrNone), Panic(_L("RA3FDevSoundToneConfigWhilePlayingTest"), EFsmIncorrectErrorPassed));
sl@0
  3860
			if (aDevSoundEvent == EEventInitialize)
sl@0
  3861
				{
sl@0
  3862
				INFO_PRINTF1(_L("Calling CMMFDevSound::InitializeL"));
sl@0
  3863
				TRAPD(err, iMMFDevSound->InitializeL(*this, EMMFStateTonePlaying));
sl@0
  3864
				if (err != KErrNone)
sl@0
  3865
					{
sl@0
  3866
					ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"), err);
sl@0
  3867
					StopTest(err);
sl@0
  3868
					break;
sl@0
  3869
					}
sl@0
  3870
				INFO_PRINTF1(_L("DevSound State: EStateInitializing"));
sl@0
  3871
				iDevSoundState = EStateInitializing;
sl@0
  3872
				}
sl@0
  3873
			else
sl@0
  3874
				{
sl@0
  3875
				ERR_PRINTF2(_L("DevSound EEventInitialize not received as expected. Received event: %d"), aDevSoundEvent);
sl@0
  3876
				StopTest(aError, EFail);
sl@0
  3877
				}
sl@0
  3878
			break;
sl@0
  3879
			}
sl@0
  3880
		case EStateInitializing:
sl@0
  3881
			{
sl@0
  3882
			if (aDevSoundEvent == EEventInitComplete && aError == KErrNone)
sl@0
  3883
				{
sl@0
  3884
				iStartTime.HomeTime();
sl@0
  3885
				INFO_PRINTF3(_L("Calling CMMFDevSound::PlayToneL using %d Hz during %d secs "), iFrequencyTone1, iDuration);
sl@0
  3886
				TRAPD(err, iMMFDevSound->PlayToneL(iFrequencyTone1, iDuration*KMicroSecsInOneSec));
sl@0
  3887
				if (err != KErrNone)
sl@0
  3888
					{
sl@0
  3889
					ERR_PRINTF2(_L("CMMFDevSound::PlayToneL left with error : %d!"),  err);
sl@0
  3890
					StopTest(err);
sl@0
  3891
					break;
sl@0
  3892
					}
sl@0
  3893
				StartTimer(KMicroSecsTwoSec);
sl@0
  3894
				INFO_PRINTF1(_L("DevSound State: EStatePlaying"));
sl@0
  3895
				iDevSoundState = EStatePlaying;
sl@0
  3896
				}
sl@0
  3897
			else if (aDevSoundEvent == EEventInitComplete && aError != KErrNone)
sl@0
  3898
				{
sl@0
  3899
				ERR_PRINTF2(_L("DevSound called CMMFDevSound::InitializeComplete with error = %d"), aError);
sl@0
  3900
				StopTest(aError);
sl@0
  3901
				}
sl@0
  3902
			else
sl@0
  3903
				{
sl@0
  3904
				ERR_PRINTF2(_L("DevSound EEventInitComplete not received as expected. Received event: %d"), aDevSoundEvent);
sl@0
  3905
				StopTest(aError, EFail);
sl@0
  3906
				}
sl@0
  3907
			break;
sl@0
  3908
			}
sl@0
  3909
		default:
sl@0
  3910
			{
sl@0
  3911
			ERR_PRINTF2(_L("Invalid DevSound state received: %d"), iDevSoundState);
sl@0
  3912
			StopTest(aError, EFail);
sl@0
  3913
			}
sl@0
  3914
		}
sl@0
  3915
	}
sl@0
  3916
sl@0
  3917
void RA3FDevSoundToneConfigWhilePlayingTest::DoTimerCallback()
sl@0
  3918
	{
sl@0
  3919
	iTimer->Cancel();
sl@0
  3920
	INFO_PRINTF1(_L("DevSound Event: EEventTimerComplete"));
sl@0
  3921
	TMMFCapabilities capabilitiesGet;
sl@0
  3922
	TBuf<KMaxSampleRateStringLength> stringSampleRateGet;
sl@0
  3923
	TBuf<KMaxChannelsStringLength> stringChannelsGet;
sl@0
  3924
	TBuf<KMaxSampleRateStringLength> stringSampleRateExpected;
sl@0
  3925
	TBuf<KMaxChannelsStringLength> stringChannelsExpected;
sl@0
  3926
	INFO_PRINTF1(_L("Calling CMMFDevSound::Config while playing"));
sl@0
  3927
	capabilitiesGet=iMMFDevSound->Config();
sl@0
  3928
	SampleRateFromTUintToString (capabilitiesGet.iRate, stringSampleRateGet);
sl@0
  3929
	ChannelsFromTUintToString (capabilitiesGet.iChannels, stringChannelsGet);
sl@0
  3930
	SampleRateFromTIntToTMMFSampleRate (iExCapRate, iExSampleRate);
sl@0
  3931
	SampleRateFromTUintToString (iExSampleRate, stringSampleRateExpected);
sl@0
  3932
	ChannelsFromTUintToString (iExCapChannels, stringChannelsExpected);
sl@0
  3933
	if (stringSampleRateExpected.Compare(stringSampleRateGet) == 0)
sl@0
  3934
		{
sl@0
  3935
		INFO_PRINTF2(_L("Sample rate value match default as expected with %S"), &stringSampleRateGet);
sl@0
  3936
		if (stringChannelsExpected.Compare(stringChannelsGet) == 0)
sl@0
  3937
			{
sl@0
  3938
			INFO_PRINTF2(_L("Channel mode value match default as expected with %S"), &stringChannelsGet);
sl@0
  3939
			StopTest();
sl@0
  3940
			}
sl@0
  3941
		else
sl@0
  3942
			{
sl@0
  3943
			INFO_PRINTF2(_L("Channel mode value failed with %S"), &stringChannelsGet);
sl@0
  3944
			ERR_PRINTF2(_L("Expected channel mode %S"), &stringChannelsExpected);
sl@0
  3945
			StopTest(KErrNone, EFail);
sl@0
  3946
			}
sl@0
  3947
		}
sl@0
  3948
	else
sl@0
  3949
		{
sl@0
  3950
		ERR_PRINTF2(_L("Sample rate value failed with %S"), &stringSampleRateGet);
sl@0
  3951
		ERR_PRINTF2(_L("Expected sample rate %S"), &stringSampleRateExpected);
sl@0
  3952
		StopTest(KErrNone, EFail);
sl@0
  3953
		}
sl@0
  3954
	}
sl@0
  3955
sl@0
  3956
void RA3FDevSoundToneConfigWhilePlayingTest::ToneFinished(TInt aError)
sl@0
  3957
	{
sl@0
  3958
	INFO_PRINTF1(_L("========== DevSound ToneFinished() callback =========="));
sl@0
  3959
	if (aError == KErrUnderflow)
sl@0
  3960
		{
sl@0
  3961
		iEndTime.HomeTime();
sl@0
  3962
		iPlayToneTime = iEndTime.MicroSecondsFrom(iStartTime);
sl@0
  3963
		TInt totalExpectedReproductionTime = iDuration * KMicroSecsInOneSec;
sl@0
  3964
		if(iPlayToneTime < totalExpectedReproductionTime + KPlayVarianceTime && iPlayToneTime > totalExpectedReproductionTime - KPlayVarianceTime)
sl@0
  3965
			{
sl@0
  3966
			INFO_PRINTF2(_L("Play time is %Ld microseconds"), iPlayToneTime.Int64());
sl@0
  3967
			StopTest();
sl@0
  3968
			}
sl@0
  3969
		else
sl@0
  3970
			{
sl@0
  3971
			ERR_PRINTF3(_L("Play time is %Ld microseconds and it should have been %d microseconds"), iPlayToneTime.Int64(), totalExpectedReproductionTime);
sl@0
  3972
			StopTest(KErrNone, EFail);
sl@0
  3973
			}
sl@0
  3974
		}
sl@0
  3975
	else
sl@0
  3976
		{
sl@0
  3977
		ERR_PRINTF2(_L("DevSound called ToneFinished with error = %d"), aError);
sl@0
  3978
		ERR_PRINTF2(_L("Expected error = %d"), KErrUnderflow);
sl@0
  3979
		StopTest(aError, EFail);
sl@0
  3980
		}
sl@0
  3981
	}
sl@0
  3982
sl@0
  3983
/*
sl@0
  3984
 *========================================================================================================
sl@0
  3985
 * MM-A3F-DEVSOUND-CHRTZ-TONE-0030
sl@0
  3986
 */
sl@0
  3987
RA3FDevSoundToneMaxVolumeWhilePlayingTest::RA3FDevSoundToneMaxVolumeWhilePlayingTest(const TDesC& aTestName)
sl@0
  3988
	:	RA3FDevSoundTestBase(aTestName), iDuration(0),
sl@0
  3989
		iFrequencyTone1(0), iExVolume(0)
sl@0
  3990
	{
sl@0
  3991
	}
sl@0
  3992
sl@0
  3993
RA3FDevSoundToneMaxVolumeWhilePlayingTest* RA3FDevSoundToneMaxVolumeWhilePlayingTest::NewL(const TDesC& aTestName)
sl@0
  3994
	{
sl@0
  3995
	RA3FDevSoundToneMaxVolumeWhilePlayingTest * self = new(ELeave)RA3FDevSoundToneMaxVolumeWhilePlayingTest(aTestName);
sl@0
  3996
	return self;
sl@0
  3997
	}
sl@0
  3998
sl@0
  3999
void RA3FDevSoundToneMaxVolumeWhilePlayingTest::DoKickoffTestL()
sl@0
  4000
	{
sl@0
  4001
	if (!GetIntFromConfig(iTestStepName, KExVolume, iExVolume))
sl@0
  4002
		{
sl@0
  4003
		ERR_PRINTF2(KMsgErrorGetParameter, &KExVolume);
sl@0
  4004
		StopTest(KErrNotFound);
sl@0
  4005
		return;
sl@0
  4006
		}
sl@0
  4007
	if (!GetIntFromConfig(iTestStepName, KDuration, iDuration))
sl@0
  4008
		{
sl@0
  4009
		ERR_PRINTF2(KMsgErrorGetParameter, &KDuration);
sl@0
  4010
		StopTest(KErrNotFound);
sl@0
  4011
		return;
sl@0
  4012
		}
sl@0
  4013
	if (!GetIntFromConfig(iTestStepName, KFrequencyTone1, iFrequencyTone1))
sl@0
  4014
		{
sl@0
  4015
		ERR_PRINTF2(KMsgErrorGetParameter, &KFrequencyTone1);
sl@0
  4016
		StopTest(KErrNotFound);
sl@0
  4017
		return;
sl@0
  4018
		}
sl@0
  4019
	iTimer = CPeriodic::NewL(CActive::EPriorityHigh);
sl@0
  4020
	}
sl@0
  4021
sl@0
  4022
void RA3FDevSoundToneMaxVolumeWhilePlayingTest::Fsm(TMmfDevSoundEvent aDevSoundEvent, TInt aError)
sl@0
  4023
	{
sl@0
  4024
	switch (iDevSoundState)
sl@0
  4025
		{
sl@0
  4026
		case EStateCreated:
sl@0
  4027
			{
sl@0
  4028
			__ASSERT_ALWAYS((aError == KErrNone), Panic(_L("RA3FDevSoundToneMaxVolumeWhilePlayingTest"), EFsmIncorrectErrorPassed));
sl@0
  4029
			if (aDevSoundEvent == EEventInitialize)
sl@0
  4030
				{
sl@0
  4031
				INFO_PRINTF1(_L("Calling CMMFDevSound::InitializeL"));
sl@0
  4032
				TRAPD(err, iMMFDevSound->InitializeL(*this, EMMFStateTonePlaying));
sl@0
  4033
				if (err != KErrNone)
sl@0
  4034
					{
sl@0
  4035
					ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"), err);
sl@0
  4036
					StopTest(err);
sl@0
  4037
					break;
sl@0
  4038
					}
sl@0
  4039
				INFO_PRINTF1(_L("DevSound State: EStateInitializing"));
sl@0
  4040
				iDevSoundState = EStateInitializing;
sl@0
  4041
				}
sl@0
  4042
			else
sl@0
  4043
				{
sl@0
  4044
				ERR_PRINTF2(_L("DevSound EEventInitialize not received as expected. Received event: %d"), aDevSoundEvent);
sl@0
  4045
				StopTest(aError, EFail);
sl@0
  4046
				}
sl@0
  4047
			break;
sl@0
  4048
			}
sl@0
  4049
		case EStateInitializing:
sl@0
  4050
			{
sl@0
  4051
			if (aDevSoundEvent == EEventInitComplete && aError == KErrNone)
sl@0
  4052
				{
sl@0
  4053
				iMMFDevSound->SetVolume(iMMFDevSound->MaxVolume());
sl@0
  4054
				iStartTime.HomeTime();
sl@0
  4055
				INFO_PRINTF3(_L("Calling CMMFDevSound::PlayToneL using %d Hz during %d secs "), iFrequencyTone1, iDuration);
sl@0
  4056
				TRAPD(err, iMMFDevSound->PlayToneL(iFrequencyTone1, iDuration*KMicroSecsInOneSec));
sl@0
  4057
				if (err != KErrNone)
sl@0
  4058
					{
sl@0
  4059
					ERR_PRINTF2(_L("CMMFDevSound::PlayToneL left with error : %d!"),  err);
sl@0
  4060
					StopTest(err);
sl@0
  4061
					break;
sl@0
  4062
					}
sl@0
  4063
				StartTimer(KMicroSecsTwoSec);
sl@0
  4064
				INFO_PRINTF1(_L("DevSound State: EStatePlaying"));
sl@0
  4065
				iDevSoundState = EStatePlaying;
sl@0
  4066
				}
sl@0
  4067
			else if (aDevSoundEvent == EEventInitComplete && aError != KErrNone)
sl@0
  4068
				{
sl@0
  4069
				ERR_PRINTF2(_L("DevSound called CMMFDevSound::InitializeComplete with error = %d"), aError);
sl@0
  4070
				StopTest(aError);
sl@0
  4071
				}
sl@0
  4072
			else
sl@0
  4073
				{
sl@0
  4074
				ERR_PRINTF2(_L("DevSound EEventInitComplete not received as expected. Received event: %d"), aDevSoundEvent);
sl@0
  4075
				StopTest(aError, EFail);
sl@0
  4076
				}
sl@0
  4077
			break;
sl@0
  4078
			}
sl@0
  4079
		default:
sl@0
  4080
			{
sl@0
  4081
			ERR_PRINTF2(_L("Invalid DevSound state received: %d"), iDevSoundState);
sl@0
  4082
			StopTest(aError, EFail);
sl@0
  4083
			}
sl@0
  4084
		}
sl@0
  4085
	}
sl@0
  4086
sl@0
  4087
void RA3FDevSoundToneMaxVolumeWhilePlayingTest::DoTimerCallback()
sl@0
  4088
	{
sl@0
  4089
	iTimer->Cancel();
sl@0
  4090
	INFO_PRINTF1(_L("DevSound Event: EEventTimerComplete"));
sl@0
  4091
	INFO_PRINTF1(_L("Calling CMMFDevSound::MaxVolume"));
sl@0
  4092
	TInt maxVolumeGet = iMMFDevSound->MaxVolume();
sl@0
  4093
	if (maxVolumeGet == iExVolume)
sl@0
  4094
		{
sl@0
  4095
		INFO_PRINTF2(_L("The max device supported volume is %d."), maxVolumeGet);
sl@0
  4096
		}
sl@0
  4097
	else
sl@0
  4098
		{
sl@0
  4099
		INFO_PRINTF2(_L("The max device supported volume failed with %d."), maxVolumeGet);
sl@0
  4100
		ERR_PRINTF2(_L("Expected value = %d."), iExVolume);
sl@0
  4101
		StopTest(KErrNone, EFail);
sl@0
  4102
		}
sl@0
  4103
	}
sl@0
  4104
sl@0
  4105
void RA3FDevSoundToneMaxVolumeWhilePlayingTest::ToneFinished(TInt aError)
sl@0
  4106
	{
sl@0
  4107
	INFO_PRINTF1(_L("========== DevSound ToneFinished() callback =========="));
sl@0
  4108
	if (aError == KErrUnderflow)
sl@0
  4109
		{
sl@0
  4110
		iEndTime.HomeTime();
sl@0
  4111
		iPlayToneTime = iEndTime.MicroSecondsFrom(iStartTime);
sl@0
  4112
		TInt totalExpectedReproductionTime = iDuration * KMicroSecsInOneSec;
sl@0
  4113
		if(iPlayToneTime < totalExpectedReproductionTime + KPlayVarianceTime && iPlayToneTime > totalExpectedReproductionTime - KPlayVarianceTime)
sl@0
  4114
			{
sl@0
  4115
			INFO_PRINTF2(_L("Play time is %Ld microseconds"), iPlayToneTime.Int64());
sl@0
  4116
			StopTest();
sl@0
  4117
			}
sl@0
  4118
		else
sl@0
  4119
			{
sl@0
  4120
			ERR_PRINTF3(_L("Play time is %Ld microseconds and it should have been %d microseconds"), iPlayToneTime.Int64(), totalExpectedReproductionTime);
sl@0
  4121
			StopTest(KErrNone, EFail);
sl@0
  4122
			}
sl@0
  4123
		}
sl@0
  4124
	else
sl@0
  4125
		{
sl@0
  4126
		ERR_PRINTF2(_L("DevSound called ToneFinished with error = %d"), aError);
sl@0
  4127
		ERR_PRINTF2(_L("Expected error = %d"), KErrUnderflow);
sl@0
  4128
		StopTest(aError, EFail);
sl@0
  4129
		}
sl@0
  4130
	}
sl@0
  4131
sl@0
  4132
/*
sl@0
  4133
 *========================================================================================================
sl@0
  4134
 * MM-A3F-DEVSOUND-CHRTZ-TONE-0031
sl@0
  4135
 */
sl@0
  4136
RA3FDevSoundToneVolumeWhilePlayingTest::RA3FDevSoundToneVolumeWhilePlayingTest(const TDesC& aTestName)
sl@0
  4137
	:	RA3FDevSoundTestBase(aTestName), iDuration(0),
sl@0
  4138
		iFrequencyTone1(0), iExVolume(0)
sl@0
  4139
	{
sl@0
  4140
	}
sl@0
  4141
sl@0
  4142
RA3FDevSoundToneVolumeWhilePlayingTest* RA3FDevSoundToneVolumeWhilePlayingTest::NewL(const TDesC& aTestName)
sl@0
  4143
	{
sl@0
  4144
	RA3FDevSoundToneVolumeWhilePlayingTest * self = new(ELeave)RA3FDevSoundToneVolumeWhilePlayingTest(aTestName);
sl@0
  4145
	return self;
sl@0
  4146
	}
sl@0
  4147
sl@0
  4148
void RA3FDevSoundToneVolumeWhilePlayingTest::DoKickoffTestL()
sl@0
  4149
	{
sl@0
  4150
	if (!GetIntFromConfig(iTestStepName, KExVolume, iExVolume))
sl@0
  4151
		{
sl@0
  4152
		ERR_PRINTF2(KMsgErrorGetParameter, &KExVolume);
sl@0
  4153
		StopTest(KErrNotFound);
sl@0
  4154
		return;
sl@0
  4155
		}
sl@0
  4156
	if (!GetIntFromConfig(iTestStepName, KDuration, iDuration))
sl@0
  4157
		{
sl@0
  4158
		ERR_PRINTF2(KMsgErrorGetParameter, &KDuration);
sl@0
  4159
		StopTest(KErrNotFound);
sl@0
  4160
		return;
sl@0
  4161
		}
sl@0
  4162
	if (!GetIntFromConfig(iTestStepName, KFrequencyTone1, iFrequencyTone1))
sl@0
  4163
		{
sl@0
  4164
		ERR_PRINTF2(KMsgErrorGetParameter, &KFrequencyTone1);
sl@0
  4165
		StopTest(KErrNotFound);
sl@0
  4166
		return;
sl@0
  4167
		}
sl@0
  4168
	iTimer = CPeriodic::NewL(CActive::EPriorityHigh);
sl@0
  4169
	}
sl@0
  4170
sl@0
  4171
void RA3FDevSoundToneVolumeWhilePlayingTest::Fsm(TMmfDevSoundEvent aDevSoundEvent, TInt aError)
sl@0
  4172
	{
sl@0
  4173
	switch (iDevSoundState)
sl@0
  4174
		{
sl@0
  4175
		case EStateCreated:
sl@0
  4176
			{
sl@0
  4177
			__ASSERT_ALWAYS((aError == KErrNone), Panic(_L("RA3FDevSoundToneVolumeWhilePlayingTest"), EFsmIncorrectErrorPassed));
sl@0
  4178
			if (aDevSoundEvent == EEventInitialize)
sl@0
  4179
				{
sl@0
  4180
				INFO_PRINTF1(_L("Calling CMMFDevSound::InitializeL"));
sl@0
  4181
				TRAPD(err, iMMFDevSound->InitializeL(*this, EMMFStateTonePlaying));
sl@0
  4182
				if (err != KErrNone)
sl@0
  4183
					{
sl@0
  4184
					ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"), err);
sl@0
  4185
					StopTest(err);
sl@0
  4186
					break;
sl@0
  4187
					}
sl@0
  4188
				INFO_PRINTF1(_L("DevSound State: EStateInitializing"));
sl@0
  4189
				iDevSoundState = EStateInitializing;
sl@0
  4190
				}
sl@0
  4191
			else
sl@0
  4192
				{
sl@0
  4193
				ERR_PRINTF2(_L("DevSound EEventInitialize not received as expected. Received event: %d"), aDevSoundEvent);
sl@0
  4194
				StopTest(aError, EFail);
sl@0
  4195
				}
sl@0
  4196
			break;
sl@0
  4197
			}
sl@0
  4198
		case EStateInitializing:
sl@0
  4199
			{
sl@0
  4200
			if (aDevSoundEvent == EEventInitComplete && aError == KErrNone)
sl@0
  4201
				{
sl@0
  4202
				iStartTime.HomeTime();
sl@0
  4203
				INFO_PRINTF3(_L("Calling CMMFDevSound::PlayToneL using %d Hz during %d secs "), iFrequencyTone1, iDuration);
sl@0
  4204
				TRAPD(err, iMMFDevSound->PlayToneL(iFrequencyTone1, iDuration*KMicroSecsInOneSec));
sl@0
  4205
				if (err != KErrNone)
sl@0
  4206
					{
sl@0
  4207
					ERR_PRINTF2(_L("CMMFDevSound::PlayToneL left with error : %d!"), err);
sl@0
  4208
					StopTest(err);
sl@0
  4209
					break;
sl@0
  4210
					}
sl@0
  4211
				StartTimer(KMicroSecsTwoSec);
sl@0
  4212
				INFO_PRINTF1(_L("DevSound State: EStatePlaying"));
sl@0
  4213
				iDevSoundState = EStatePlaying;
sl@0
  4214
				}
sl@0
  4215
			else if (aDevSoundEvent == EEventInitComplete && aError != KErrNone)
sl@0
  4216
				{
sl@0
  4217
				ERR_PRINTF2(_L("DevSound called CMMFDevSound::InitializeComplete with error = %d"), aError);
sl@0
  4218
				StopTest(aError);
sl@0
  4219
				}
sl@0
  4220
			else
sl@0
  4221
				{
sl@0
  4222
				ERR_PRINTF2(_L("DevSound EEventInitComplete not received as expected. Received event: %d"), aDevSoundEvent);
sl@0
  4223
				StopTest(aError, EFail);
sl@0
  4224
				}
sl@0
  4225
			break;
sl@0
  4226
			}
sl@0
  4227
		default:
sl@0
  4228
			{
sl@0
  4229
			ERR_PRINTF2(_L("Invalid DevSound state received: %d"), iDevSoundState);
sl@0
  4230
			StopTest(aError, EFail);
sl@0
  4231
			}
sl@0
  4232
		}
sl@0
  4233
	}
sl@0
  4234
sl@0
  4235
void RA3FDevSoundToneVolumeWhilePlayingTest::DoTimerCallback()
sl@0
  4236
	{
sl@0
  4237
	iTimer->Cancel();
sl@0
  4238
	INFO_PRINTF1(_L("DevSound Event: EEventTimerComplete"));
sl@0
  4239
	INFO_PRINTF1(_L("Calling CMMFDevSound::Volume"));
sl@0
  4240
	TInt maxVolumeGet = iMMFDevSound->Volume();
sl@0
  4241
	if (maxVolumeGet == iExVolume)
sl@0
  4242
		{
sl@0
  4243
		INFO_PRINTF2(_L("The device default supported volume value is %d."), maxVolumeGet);
sl@0
  4244
		}
sl@0
  4245
	else
sl@0
  4246
		{
sl@0
  4247
		INFO_PRINTF2(_L("The device default supported volume value failed with %d."), maxVolumeGet);
sl@0
  4248
		ERR_PRINTF2(_L("Expected value = %d."), iExVolume);
sl@0
  4249
		StopTest(KErrNone, EFail);
sl@0
  4250
		}
sl@0
  4251
	}
sl@0
  4252
sl@0
  4253
void RA3FDevSoundToneVolumeWhilePlayingTest::ToneFinished(TInt aError)
sl@0
  4254
	{
sl@0
  4255
	INFO_PRINTF1(_L("========== DevSound ToneFinished() callback =========="));
sl@0
  4256
	if (aError == KErrUnderflow)
sl@0
  4257
		{
sl@0
  4258
		iEndTime.HomeTime();
sl@0
  4259
		iPlayToneTime = iEndTime.MicroSecondsFrom(iStartTime);
sl@0
  4260
		TInt totalExpectedReproductionTime = iDuration * KMicroSecsInOneSec;
sl@0
  4261
		if(iPlayToneTime < totalExpectedReproductionTime + KPlayVarianceTime && iPlayToneTime > totalExpectedReproductionTime - KPlayVarianceTime)
sl@0
  4262
			{
sl@0
  4263
			INFO_PRINTF2(_L("Play time is %Ld microseconds"), iPlayToneTime.Int64());
sl@0
  4264
			StopTest();
sl@0
  4265
			}
sl@0
  4266
		else
sl@0
  4267
			{
sl@0
  4268
			ERR_PRINTF3(_L("Play time is %Ld microseconds and it should have been %d microseconds"), iPlayToneTime.Int64(), totalExpectedReproductionTime);
sl@0
  4269
			StopTest(KErrNone, EFail);
sl@0
  4270
			}
sl@0
  4271
		}
sl@0
  4272
	else
sl@0
  4273
		{
sl@0
  4274
		ERR_PRINTF2(_L("DevSound called ToneFinished with error = %d"), aError);
sl@0
  4275
		ERR_PRINTF2(_L("Expected error = %d"), KErrUnderflow);
sl@0
  4276
		StopTest(aError, EFail);
sl@0
  4277
		}
sl@0
  4278
	}
sl@0
  4279
sl@0
  4280
/*
sl@0
  4281
 *========================================================================================================
sl@0
  4282
 * MM-A3F-DEVSOUND-CHRTZ-TONE-0032
sl@0
  4283
 */
sl@0
  4284
RA3FDevSoundToneQueryCapsWhilePausePlayingTest::RA3FDevSoundToneQueryCapsWhilePausePlayingTest(const TDesC& aTestName)
sl@0
  4285
	:	RA3FDevSoundTestBase(aTestName), iDuration(0),
sl@0
  4286
		iFrequencyTone1(0), iExCapRate(0), iExCapChannels(0),
sl@0
  4287
		iTimeToEnterPauseElapsed(EFalse)
sl@0
  4288
	{
sl@0
  4289
	}
sl@0
  4290
sl@0
  4291
RA3FDevSoundToneQueryCapsWhilePausePlayingTest* RA3FDevSoundToneQueryCapsWhilePausePlayingTest::NewL(const TDesC& aTestName)
sl@0
  4292
	{
sl@0
  4293
	RA3FDevSoundToneQueryCapsWhilePausePlayingTest * self = new(ELeave)RA3FDevSoundToneQueryCapsWhilePausePlayingTest(aTestName);
sl@0
  4294
	return self;
sl@0
  4295
	}
sl@0
  4296
sl@0
  4297
void RA3FDevSoundToneQueryCapsWhilePausePlayingTest::DoKickoffTestL()
sl@0
  4298
	{
sl@0
  4299
	if (!GetIntFromConfig(iTestStepName, KDuration, iDuration))
sl@0
  4300
		{
sl@0
  4301
		ERR_PRINTF2(KMsgErrorGetParameter, &KDuration);
sl@0
  4302
		StopTest(KErrNotFound);
sl@0
  4303
		return;
sl@0
  4304
		}
sl@0
  4305
	if (!GetIntFromConfig(iTestStepName, KFrequencyTone1, iFrequencyTone1))
sl@0
  4306
		{
sl@0
  4307
		ERR_PRINTF2(KMsgErrorGetParameter, &KFrequencyTone1);
sl@0
  4308
		StopTest(KErrNotFound);
sl@0
  4309
		return;
sl@0
  4310
		}
sl@0
  4311
	if (!GetIntFromConfig(iTestStepName, KExCapRate, iExCapRate))
sl@0
  4312
		{
sl@0
  4313
		ERR_PRINTF2(KMsgErrorGetParameter, &KSampleRate);
sl@0
  4314
		StopTest(KErrNotFound);
sl@0
  4315
		return;
sl@0
  4316
		}
sl@0
  4317
	if (!GetIntFromConfig(iTestStepName, KExCapChannels, iExCapChannels))
sl@0
  4318
		{
sl@0
  4319
		ERR_PRINTF2(KMsgErrorGetParameter, &KChannel);
sl@0
  4320
		StopTest(KErrNotFound);
sl@0
  4321
		return;
sl@0
  4322
		}
sl@0
  4323
	iTimer = CPeriodic::NewL(CActive::EPriorityHigh);
sl@0
  4324
	}
sl@0
  4325
sl@0
  4326
void RA3FDevSoundToneQueryCapsWhilePausePlayingTest::Fsm(TMmfDevSoundEvent aDevSoundEvent, TInt aError)
sl@0
  4327
	{
sl@0
  4328
	switch (iDevSoundState)
sl@0
  4329
		{
sl@0
  4330
		case EStateCreated:
sl@0
  4331
			{
sl@0
  4332
			__ASSERT_ALWAYS((aError == KErrNone), Panic(_L("RA3FDevSoundToneQueryCapsWhilePausePlayingTest"), EFsmIncorrectErrorPassed));
sl@0
  4333
			if (aDevSoundEvent == EEventInitialize)
sl@0
  4334
				{
sl@0
  4335
				INFO_PRINTF1(_L("Calling CMMFDevSound::InitializeL"));
sl@0
  4336
				TRAPD(err, iMMFDevSound->InitializeL(*this, EMMFStateTonePlaying));
sl@0
  4337
				if (err != KErrNone)
sl@0
  4338
					{
sl@0
  4339
					ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"), err);
sl@0
  4340
					StopTest(err);
sl@0
  4341
					break;
sl@0
  4342
					}
sl@0
  4343
				INFO_PRINTF1(_L("DevSound State: EStateInitializing"));
sl@0
  4344
				iDevSoundState = EStateInitializing;
sl@0
  4345
				}
sl@0
  4346
			else
sl@0
  4347
				{
sl@0
  4348
				ERR_PRINTF2(_L("DevSound EEventInitialize not received as expected. Received event: %d"), aDevSoundEvent);
sl@0
  4349
				StopTest(aError, EFail);
sl@0
  4350
				}
sl@0
  4351
			break;
sl@0
  4352
			}
sl@0
  4353
		case EStateInitializing:
sl@0
  4354
			{
sl@0
  4355
			if (aDevSoundEvent == EEventInitComplete && aError == KErrNone)
sl@0
  4356
				{
sl@0
  4357
				iMMFDevSound->SetVolume(iMMFDevSound->MaxVolume());
sl@0
  4358
				INFO_PRINTF3(_L("Calling CMMFDevSound::PlayToneL using %d Hz during %d secs "), iFrequencyTone1, iDuration);
sl@0
  4359
				TRAPD(err, iMMFDevSound->PlayToneL(iFrequencyTone1, iDuration*KMicroSecsInOneSec));
sl@0
  4360
				if (err != KErrNone)
sl@0
  4361
					{
sl@0
  4362
					ERR_PRINTF2(_L("CMMFDevSound::PlayToneL left with error : %d!"), err);
sl@0
  4363
					StopTest(err);
sl@0
  4364
					break;
sl@0
  4365
					}
sl@0
  4366
				StartTimer(KMicroSecsTwoSec);
sl@0
  4367
				INFO_PRINTF1(_L("DevSound State: EStatePlaying"));
sl@0
  4368
				iDevSoundState = EStatePlaying;
sl@0
  4369
				}
sl@0
  4370
			else if (aDevSoundEvent == EEventInitComplete && aError != KErrNone)
sl@0
  4371
				{
sl@0
  4372
				ERR_PRINTF2(_L("DevSound called CMMFDevSound::InitializeComplete with error = %d"), aError);
sl@0
  4373
				StopTest(aError);
sl@0
  4374
				}
sl@0
  4375
			else
sl@0
  4376
				{
sl@0
  4377
				ERR_PRINTF2(_L("DevSound EEventInitComplete not received as expected. Received event: %d"), aDevSoundEvent);
sl@0
  4378
				StopTest(aError, EFail);
sl@0
  4379
				}
sl@0
  4380
			break;
sl@0
  4381
			}
sl@0
  4382
		case EStatePlaying:
sl@0
  4383
			{
sl@0
  4384
			if(aDevSoundEvent == EEventTimerComplete)
sl@0
  4385
				{
sl@0
  4386
				INFO_PRINTF1(_L("Calling CMMFDevSound::Pause"));
sl@0
  4387
				iMMFDevSound->Pause();
sl@0
  4388
				INFO_PRINTF1(_L("DevSound State: EStatePause"));
sl@0
  4389
				iDevSoundState = EStatePause;
sl@0
  4390
				}
sl@0
  4391
			else
sl@0
  4392
				{
sl@0
  4393
				ERR_PRINTF2(_L("DevSound EEventTimerComplete not received as expected. Received event: %d"), aDevSoundEvent);
sl@0
  4394
				StopTest(aError, EFail);
sl@0
  4395
				}
sl@0
  4396
			break;
sl@0
  4397
			}
sl@0
  4398
		case EStatePause:
sl@0
  4399
			{
sl@0
  4400
			if(aDevSoundEvent == EEventTimerComplete)
sl@0
  4401
				{
sl@0
  4402
				TMMFCapabilities capabilities;
sl@0
  4403
				INFO_PRINTF1(_L("Calling CMMFDevSound::Capabilities"));
sl@0
  4404
				capabilities = iMMFDevSound->Capabilities();
sl@0
  4405
				PrintSupportedCapabilities(capabilities.iRate, capabilities.iChannels);
sl@0
  4406
				if(capabilities.iRate == iExCapRate)
sl@0
  4407
					{
sl@0
  4408
					INFO_PRINTF2(_L("The total of possible sample rate values is 0x%08x"), capabilities.iRate);
sl@0
  4409
					if(capabilities.iChannels == iExCapChannels)
sl@0
  4410
						{
sl@0
  4411
						INFO_PRINTF2(_L("The total of possible channel values is 0x%08x"),capabilities.iChannels );
sl@0
  4412
						StopTest();
sl@0
  4413
						}
sl@0
  4414
					else
sl@0
  4415
						{
sl@0
  4416
						ERR_PRINTF2(_L("The total of possible channel values failed with 0x%08x"), capabilities.iChannels );
sl@0
  4417
						ERR_PRINTF2(_L("Expected value = %d"), iExCapChannels);
sl@0
  4418
						StopTest(aError, EFail);
sl@0
  4419
						}
sl@0
  4420
					}
sl@0
  4421
				else
sl@0
  4422
					{
sl@0
  4423
					ERR_PRINTF2(_L("The total of possible sample rate values failed with 0x%08x"), capabilities.iRate);
sl@0
  4424
					ERR_PRINTF2(_L("Expected value = %d"), iExCapRate);
sl@0
  4425
					StopTest(aError, EFail);
sl@0
  4426
					}
sl@0
  4427
				}
sl@0
  4428
			else
sl@0
  4429
				{
sl@0
  4430
				ERR_PRINTF2(_L("DevSound EEventTimerComplete not received as expected. Received event: %d"), aDevSoundEvent);
sl@0
  4431
				StopTest(aError, EFail);
sl@0
  4432
				}
sl@0
  4433
			break;
sl@0
  4434
			}
sl@0
  4435
		default:
sl@0
  4436
			{
sl@0
  4437
			ERR_PRINTF2(_L("Invalid DevSound state received: %d"), iDevSoundState);
sl@0
  4438
			StopTest(aError, EFail);
sl@0
  4439
			}
sl@0
  4440
		}
sl@0
  4441
	}
sl@0
  4442
sl@0
  4443
void RA3FDevSoundToneQueryCapsWhilePausePlayingTest::DoTimerCallback()
sl@0
  4444
	{
sl@0
  4445
	INFO_PRINTF1(_L("TimerEvent called"));
sl@0
  4446
	if(!iTimeToEnterPauseElapsed)
sl@0
  4447
		{
sl@0
  4448
		iTimeToEnterPauseElapsed = ETrue;
sl@0
  4449
		INFO_PRINTF1(_L("DevSound Event: EEventTimerComplete"));
sl@0
  4450
		Fsm(EEventTimerComplete, KErrNone);
sl@0
  4451
		iTimeToEnterPauseElapsed = ETrue;
sl@0
  4452
		}
sl@0
  4453
	else
sl@0
  4454
		{
sl@0
  4455
		iTimer->Cancel();
sl@0
  4456
		INFO_PRINTF1(_L("DevSound Event: EEventTimerComplete"));
sl@0
  4457
		Fsm(EEventTimerComplete, KErrNone);
sl@0
  4458
		}
sl@0
  4459
	}
sl@0
  4460
sl@0
  4461
void RA3FDevSoundToneQueryCapsWhilePausePlayingTest::ToneFinished(TInt aError)
sl@0
  4462
	{
sl@0
  4463
	INFO_PRINTF1(_L("========== DevSound ToneFinished() callback =========="));
sl@0
  4464
	ERR_PRINTF1(_L("DevSound should not have called ToneFinished because it is supposed to be paused then stopped"));
sl@0
  4465
	StopTest(aError, EFail);
sl@0
  4466
	}
sl@0
  4467
sl@0
  4468
sl@0
  4469
/*
sl@0
  4470
 *========================================================================================================
sl@0
  4471
 * MM-A3F-DEVSOUND-CHRTZ-TONE-0033
sl@0
  4472
 */
sl@0
  4473
RA3FDevSoundToneConfigWhilePausePlayingTest::RA3FDevSoundToneConfigWhilePausePlayingTest(const TDesC& aTestName)
sl@0
  4474
	:	RA3FDevSoundTestBase(aTestName), iDuration(0),
sl@0
  4475
		iFrequencyTone1(0), iTimeToEnterPauseElapsed(EFalse),
sl@0
  4476
		iExCapRate(0), iExCapChannels(0)
sl@0
  4477
	{
sl@0
  4478
	}
sl@0
  4479
sl@0
  4480
RA3FDevSoundToneConfigWhilePausePlayingTest* RA3FDevSoundToneConfigWhilePausePlayingTest::NewL(const TDesC& aTestName)
sl@0
  4481
	{
sl@0
  4482
	RA3FDevSoundToneConfigWhilePausePlayingTest * self = new(ELeave)RA3FDevSoundToneConfigWhilePausePlayingTest(aTestName);
sl@0
  4483
	return self;
sl@0
  4484
	}
sl@0
  4485
sl@0
  4486
void RA3FDevSoundToneConfigWhilePausePlayingTest::DoKickoffTestL()
sl@0
  4487
	{
sl@0
  4488
	if (!GetIntFromConfig(iTestStepName, KDuration, iDuration))
sl@0
  4489
		{
sl@0
  4490
		ERR_PRINTF2(KMsgErrorGetParameter, &KDuration);
sl@0
  4491
		StopTest(KErrNotFound);
sl@0
  4492
		return;
sl@0
  4493
		}
sl@0
  4494
	if (!GetIntFromConfig(iTestStepName, KFrequencyTone1, iFrequencyTone1))
sl@0
  4495
		{
sl@0
  4496
		ERR_PRINTF2(KMsgErrorGetParameter, &KFrequencyTone1);
sl@0
  4497
		StopTest(KErrNotFound);
sl@0
  4498
		return;
sl@0
  4499
		}
sl@0
  4500
	if (!GetIntFromConfig(iTestStepName, KExCapRate, iExCapRate))
sl@0
  4501
			{
sl@0
  4502
			ERR_PRINTF2(KMsgErrorGetParameter, &KExCapRate);
sl@0
  4503
			StopTest(KErrNotFound);
sl@0
  4504
			return;
sl@0
  4505
			}
sl@0
  4506
	if (!GetIntFromConfig(iTestStepName, KExCapChannels, iExCapChannels))
sl@0
  4507
		{
sl@0
  4508
		ERR_PRINTF2(KMsgErrorGetParameter, &KExCapChannels);
sl@0
  4509
		StopTest(KErrNotFound);
sl@0
  4510
		return;
sl@0
  4511
		}
sl@0
  4512
	iTimer = CPeriodic::NewL(CActive::EPriorityHigh);
sl@0
  4513
	}
sl@0
  4514
sl@0
  4515
void RA3FDevSoundToneConfigWhilePausePlayingTest::Fsm(TMmfDevSoundEvent aDevSoundEvent, TInt aError)
sl@0
  4516
	{
sl@0
  4517
	switch (iDevSoundState)
sl@0
  4518
		{
sl@0
  4519
		case EStateCreated:
sl@0
  4520
			{
sl@0
  4521
			__ASSERT_ALWAYS((aError == KErrNone), Panic(_L("RA3FDevSoundToneConfigWhilePausePlayingTest"), EFsmIncorrectErrorPassed));
sl@0
  4522
			if (aDevSoundEvent == EEventInitialize)
sl@0
  4523
				{
sl@0
  4524
				INFO_PRINTF1(_L("Calling CMMFDevSound::InitializeL"));
sl@0
  4525
				TRAPD(err, iMMFDevSound->InitializeL(*this, EMMFStateTonePlaying));
sl@0
  4526
				if (err != KErrNone)
sl@0
  4527
					{
sl@0
  4528
					ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"), err);
sl@0
  4529
					StopTest(err);
sl@0
  4530
					break;
sl@0
  4531
					}
sl@0
  4532
				INFO_PRINTF1(_L("DevSound State: EStateInitializing"));
sl@0
  4533
				iDevSoundState = EStateInitializing;
sl@0
  4534
				}
sl@0
  4535
			else
sl@0
  4536
				{
sl@0
  4537
				ERR_PRINTF2(_L("DevSound EEventInitialize not received as expected. Received event: %d"), aDevSoundEvent);
sl@0
  4538
				StopTest(aError, EFail);
sl@0
  4539
				}
sl@0
  4540
			break;
sl@0
  4541
			}
sl@0
  4542
		case EStateInitializing:
sl@0
  4543
			{
sl@0
  4544
			if (aDevSoundEvent == EEventInitComplete && aError == KErrNone)
sl@0
  4545
				{
sl@0
  4546
				iMMFDevSound->SetVolume(iMMFDevSound->MaxVolume());
sl@0
  4547
				INFO_PRINTF3(_L("Calling CMMFDevSound::PlayToneL using %d Hz during %d secs "), iFrequencyTone1, iDuration);
sl@0
  4548
				TRAPD(err, iMMFDevSound->PlayToneL(iFrequencyTone1, iDuration*KMicroSecsInOneSec));
sl@0
  4549
				if (err != KErrNone)
sl@0
  4550
					{
sl@0
  4551
					ERR_PRINTF2(_L("CMMFDevSound::PlayToneL left with error : %d!"), err);
sl@0
  4552
					StopTest(err);
sl@0
  4553
					break;
sl@0
  4554
					}
sl@0
  4555
				StartTimer(KMicroSecsTwoSec);
sl@0
  4556
				INFO_PRINTF1(_L("DevSound State: EStatePlaying"));
sl@0
  4557
				iDevSoundState = EStatePlaying;
sl@0
  4558
				}
sl@0
  4559
			else if (aDevSoundEvent == EEventInitComplete && aError != KErrNone)
sl@0
  4560
				{
sl@0
  4561
				ERR_PRINTF2(_L("DevSound called CMMFDevSound::InitializeComplete with error = %d"), aError);
sl@0
  4562
				StopTest(aError);
sl@0
  4563
				}
sl@0
  4564
			else
sl@0
  4565
				{
sl@0
  4566
				ERR_PRINTF2(_L("DevSound EEventInitComplete not received as expected. Received event: %d"), aDevSoundEvent);
sl@0
  4567
				StopTest(aError, EFail);
sl@0
  4568
				}
sl@0
  4569
			break;
sl@0
  4570
			}
sl@0
  4571
		case EStatePlaying:
sl@0
  4572
			{
sl@0
  4573
			if(aDevSoundEvent == EEventTimerComplete)
sl@0
  4574
				{
sl@0
  4575
				INFO_PRINTF1(_L("Calling CMMFDevSound::Pause"));
sl@0
  4576
				iMMFDevSound->Pause();
sl@0
  4577
				INFO_PRINTF1(_L("DevSound State: EStatePause"));
sl@0
  4578
				iDevSoundState = EStatePause;
sl@0
  4579
				}
sl@0
  4580
			else
sl@0
  4581
				{
sl@0
  4582
				ERR_PRINTF2(_L("DevSound EEventTimerComplete not received as expected. Received event: %d"), aDevSoundEvent);
sl@0
  4583
				StopTest(aError, EFail);
sl@0
  4584
				}
sl@0
  4585
			break;
sl@0
  4586
			}
sl@0
  4587
		case EStatePause:
sl@0
  4588
			{
sl@0
  4589
			if(aDevSoundEvent == EEventTimerComplete)
sl@0
  4590
				{
sl@0
  4591
				TMMFCapabilities capabilitiesGet;
sl@0
  4592
				TBuf<KMaxSampleRateStringLength> stringSampleRateGet;
sl@0
  4593
				TBuf<KMaxChannelsStringLength> stringChannelsGet;
sl@0
  4594
				TBuf<KMaxSampleRateStringLength> stringSampleRateExpected;
sl@0
  4595
				TBuf<KMaxChannelsStringLength> stringChannelsExpected;
sl@0
  4596
				INFO_PRINTF1(_L("Calling CMMFDevSound::Config while playing"));
sl@0
  4597
				capabilitiesGet=iMMFDevSound->Config();
sl@0
  4598
				SampleRateFromTUintToString (capabilitiesGet.iRate, stringSampleRateGet);
sl@0
  4599
				ChannelsFromTUintToString (capabilitiesGet.iChannels, stringChannelsGet);
sl@0
  4600
				SampleRateFromTIntToTMMFSampleRate (iExCapRate, iExSampleRate);
sl@0
  4601
				SampleRateFromTUintToString (iExSampleRate, stringSampleRateExpected);
sl@0
  4602
				ChannelsFromTUintToString (iExCapChannels, stringChannelsExpected);
sl@0
  4603
				if (stringSampleRateExpected.Compare(stringSampleRateGet) == 0)
sl@0
  4604
					{
sl@0
  4605
					INFO_PRINTF2(_L("Sample rate value match default as expected with %S"), &stringSampleRateGet);
sl@0
  4606
					if (stringChannelsExpected.Compare(stringChannelsGet) == 0)
sl@0
  4607
						{
sl@0
  4608
						INFO_PRINTF2(_L("Channel mode value match default as expected with %S"), &stringChannelsGet);
sl@0
  4609
						StopTest();
sl@0
  4610
						}
sl@0
  4611
					else
sl@0
  4612
						{
sl@0
  4613
						INFO_PRINTF2(_L("Channel mode value failed with %S"), &stringChannelsGet);
sl@0
  4614
						ERR_PRINTF2(_L("Expected channel mode %S"), &stringChannelsExpected);
sl@0
  4615
						StopTest(aError, EFail);
sl@0
  4616
						}
sl@0
  4617
					}
sl@0
  4618
				else
sl@0
  4619
					{
sl@0
  4620
					ERR_PRINTF2(_L("Sample rate value failed with %S"), &stringSampleRateGet);
sl@0
  4621
					ERR_PRINTF2(_L("Expected sample rate %S"), &stringSampleRateExpected);
sl@0
  4622
					StopTest(aError, EFail);
sl@0
  4623
					}
sl@0
  4624
				}
sl@0
  4625
			else
sl@0
  4626
				{
sl@0
  4627
				ERR_PRINTF2(_L("DevSound EEventTimerComplete not received as expected. Received event: %d"), aDevSoundEvent);
sl@0
  4628
				StopTest(aError, EFail);
sl@0
  4629
				}
sl@0
  4630
			break;
sl@0
  4631
			}
sl@0
  4632
		default:
sl@0
  4633
			{
sl@0
  4634
			ERR_PRINTF2(_L("Invalid DevSound state received: %d"), iDevSoundState);
sl@0
  4635
			StopTest(aError, EFail);
sl@0
  4636
			}
sl@0
  4637
		}
sl@0
  4638
	}
sl@0
  4639
sl@0
  4640
void RA3FDevSoundToneConfigWhilePausePlayingTest::DoTimerCallback()
sl@0
  4641
	{
sl@0
  4642
	INFO_PRINTF1(_L("TimerEvent called"));
sl@0
  4643
	if(!iTimeToEnterPauseElapsed)
sl@0
  4644
		{
sl@0
  4645
		iTimeToEnterPauseElapsed = ETrue;
sl@0
  4646
		INFO_PRINTF1(_L("DevSound Event: EEventTimerComplete"));
sl@0
  4647
		Fsm(EEventTimerComplete, KErrNone);
sl@0
  4648
		iTimeToEnterPauseElapsed = ETrue;
sl@0
  4649
		}
sl@0
  4650
	else
sl@0
  4651
		{
sl@0
  4652
		iTimer->Cancel();
sl@0
  4653
		INFO_PRINTF1(_L("DevSound Event: EEventTimerComplete"));
sl@0
  4654
		Fsm(EEventTimerComplete, KErrNone);
sl@0
  4655
		}
sl@0
  4656
	}
sl@0
  4657
sl@0
  4658
void RA3FDevSoundToneConfigWhilePausePlayingTest::ToneFinished(TInt aError)
sl@0
  4659
	{
sl@0
  4660
	INFO_PRINTF1(_L("========== DevSound ToneFinished() callback =========="));
sl@0
  4661
	ERR_PRINTF1(_L("DevSound should not have called ToneFinished because it is supposed to be paused then stopped"));
sl@0
  4662
	StopTest(aError, EFail);
sl@0
  4663
	}
sl@0
  4664
sl@0
  4665
sl@0
  4666
/*
sl@0
  4667
 *========================================================================================================
sl@0
  4668
 * MM-A3F-DEVSOUND-CHRTZ-TONE-0034
sl@0
  4669
 */
sl@0
  4670
RA3FDevSoundToneMaxVolumeWhilePausePlayingTest::RA3FDevSoundToneMaxVolumeWhilePausePlayingTest(const TDesC& aTestName)
sl@0
  4671
	:	RA3FDevSoundTestBase(aTestName), iDuration(0),
sl@0
  4672
		iFrequencyTone1(0), iExVolume(0),
sl@0
  4673
		iTimeToEnterPauseElapsed(EFalse)
sl@0
  4674
	{
sl@0
  4675
	}
sl@0
  4676
sl@0
  4677
RA3FDevSoundToneMaxVolumeWhilePausePlayingTest* RA3FDevSoundToneMaxVolumeWhilePausePlayingTest::NewL(const TDesC& aTestName)
sl@0
  4678
	{
sl@0
  4679
	RA3FDevSoundToneMaxVolumeWhilePausePlayingTest * self = new(ELeave)RA3FDevSoundToneMaxVolumeWhilePausePlayingTest(aTestName);
sl@0
  4680
	return self;
sl@0
  4681
	}
sl@0
  4682
sl@0
  4683
void RA3FDevSoundToneMaxVolumeWhilePausePlayingTest::DoKickoffTestL()
sl@0
  4684
	{
sl@0
  4685
	if (!GetIntFromConfig(iTestStepName, KDuration, iDuration))
sl@0
  4686
		{
sl@0
  4687
		ERR_PRINTF2(KMsgErrorGetParameter, &KDuration);
sl@0
  4688
		StopTest(KErrNotFound);
sl@0
  4689
		return;
sl@0
  4690
		}
sl@0
  4691
	if (!GetIntFromConfig(iTestStepName, KFrequencyTone1, iFrequencyTone1))
sl@0
  4692
		{
sl@0
  4693
		ERR_PRINTF2(KMsgErrorGetParameter, &KFrequencyTone1);
sl@0
  4694
		StopTest(KErrNotFound);
sl@0
  4695
		return;
sl@0
  4696
		}
sl@0
  4697
	if (!GetIntFromConfig(iTestStepName, KExVolume, iExVolume))
sl@0
  4698
		{
sl@0
  4699
		ERR_PRINTF2(KMsgErrorGetParameter, &KExVolume);
sl@0
  4700
		StopTest(KErrNotFound);
sl@0
  4701
		return;
sl@0
  4702
		}
sl@0
  4703
	iTimer = CPeriodic::NewL(CActive::EPriorityHigh);
sl@0
  4704
	}
sl@0
  4705
sl@0
  4706
void RA3FDevSoundToneMaxVolumeWhilePausePlayingTest::Fsm(TMmfDevSoundEvent aDevSoundEvent, TInt aError)
sl@0
  4707
	{
sl@0
  4708
	switch (iDevSoundState)
sl@0
  4709
		{
sl@0
  4710
		case EStateCreated:
sl@0
  4711
			{
sl@0
  4712
			__ASSERT_ALWAYS((aError == KErrNone), Panic(_L("RA3FDevSoundToneMaxVolumeWhilePausePlayingTest"), EFsmIncorrectErrorPassed));
sl@0
  4713
			if (aDevSoundEvent == EEventInitialize)
sl@0
  4714
				{
sl@0
  4715
				INFO_PRINTF1(_L("Calling CMMFDevSound::InitializeL"));
sl@0
  4716
				TRAPD(err, iMMFDevSound->InitializeL(*this, EMMFStateTonePlaying));
sl@0
  4717
				if (err != KErrNone)
sl@0
  4718
					{
sl@0
  4719
					ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"), err);
sl@0
  4720
					StopTest(err);
sl@0
  4721
					break;
sl@0
  4722
					}
sl@0
  4723
				INFO_PRINTF1(_L("DevSound State: EStateInitializing"));
sl@0
  4724
				iDevSoundState = EStateInitializing;
sl@0
  4725
				}
sl@0
  4726
			else
sl@0
  4727
				{
sl@0
  4728
				ERR_PRINTF2(_L("DevSound EEventInitialize not received as expected. Received event: %d"), aDevSoundEvent);
sl@0
  4729
				StopTest(aError, EFail);
sl@0
  4730
				}
sl@0
  4731
			break;
sl@0
  4732
			}
sl@0
  4733
		case EStateInitializing:
sl@0
  4734
			{
sl@0
  4735
			if (aDevSoundEvent == EEventInitComplete && aError == KErrNone)
sl@0
  4736
				{
sl@0
  4737
				iMMFDevSound->SetVolume(iMMFDevSound->MaxVolume());
sl@0
  4738
				INFO_PRINTF3(_L("Calling CMMFDevSound::PlayToneL using %d Hz during %d secs "), iFrequencyTone1, iDuration);
sl@0
  4739
				TRAPD(err, iMMFDevSound->PlayToneL(iFrequencyTone1, iDuration*KMicroSecsInOneSec));
sl@0
  4740
				if (err != KErrNone)
sl@0
  4741
					{
sl@0
  4742
					ERR_PRINTF2(_L("CMMFDevSound::PlayToneL left with error : %d!"), err);
sl@0
  4743
					StopTest(err);
sl@0
  4744
					break;
sl@0
  4745
					}
sl@0
  4746
				StartTimer(KMicroSecsTwoSec);
sl@0
  4747
				INFO_PRINTF1(_L("DevSound State: EStatePlaying"));
sl@0
  4748
				iDevSoundState = EStatePlaying;
sl@0
  4749
				}
sl@0
  4750
			else if (aDevSoundEvent == EEventInitComplete && aError != KErrNone)
sl@0
  4751
				{
sl@0
  4752
				ERR_PRINTF2(_L("DevSound called CMMFDevSound::InitializeComplete with error = %d"), aError);
sl@0
  4753
				StopTest(aError);
sl@0
  4754
				}
sl@0
  4755
			else
sl@0
  4756
				{
sl@0
  4757
				ERR_PRINTF2(_L("DevSound EEventInitComplete not received as expected. Received event: %d"), aDevSoundEvent);
sl@0
  4758
				StopTest(aError, EFail);
sl@0
  4759
				}
sl@0
  4760
			break;
sl@0
  4761
			}
sl@0
  4762
		case EStatePlaying:
sl@0
  4763
			{
sl@0
  4764
			if(aDevSoundEvent == EEventTimerComplete)
sl@0
  4765
				{
sl@0
  4766
				INFO_PRINTF1(_L("Calling CMMFDevSound::Pause"));
sl@0
  4767
				iMMFDevSound->Pause();
sl@0
  4768
				INFO_PRINTF1(_L("DevSound State: EStatePause"));
sl@0
  4769
				iDevSoundState = EStatePause;
sl@0
  4770
				}
sl@0
  4771
			else
sl@0
  4772
				{
sl@0
  4773
				ERR_PRINTF2(_L("DevSound EEventTimerComplete not received as expected. Received event: %d"), aDevSoundEvent);
sl@0
  4774
				StopTest(aError, EFail);
sl@0
  4775
				}
sl@0
  4776
			break;
sl@0
  4777
			}
sl@0
  4778
		case EStatePause:
sl@0
  4779
			{
sl@0
  4780
			if(aDevSoundEvent == EEventTimerComplete)
sl@0
  4781
				{
sl@0
  4782
				INFO_PRINTF1(_L("Calling CMMFDevSound::MaxVolume"));
sl@0
  4783
				TInt maxVolumeGet = iMMFDevSound->MaxVolume();
sl@0
  4784
				if (maxVolumeGet == iExVolume)
sl@0
  4785
					{
sl@0
  4786
					INFO_PRINTF2(_L("The max device supported volume is %d."), maxVolumeGet);
sl@0
  4787
					StopTest();
sl@0
  4788
					}
sl@0
  4789
				else
sl@0
  4790
					{
sl@0
  4791
					INFO_PRINTF2(_L("The max device supported volume failed with %d."), maxVolumeGet);
sl@0
  4792
					ERR_PRINTF2(_L("Expected value = %d."), iExVolume);
sl@0
  4793
					StopTest(aError, EFail);
sl@0
  4794
					}
sl@0
  4795
				}
sl@0
  4796
			else
sl@0
  4797
				{
sl@0
  4798
				ERR_PRINTF2(_L("DevSound EEventTimerComplete not received as expected. Received event: %d"), aDevSoundEvent);
sl@0
  4799
				StopTest(aError, EFail);
sl@0
  4800
				}
sl@0
  4801
			break;
sl@0
  4802
			}
sl@0
  4803
		default:
sl@0
  4804
			{
sl@0
  4805
			ERR_PRINTF2(_L("Invalid DevSound state received: %d"), iDevSoundState);
sl@0
  4806
			StopTest(aError, EFail);
sl@0
  4807
			}
sl@0
  4808
		}
sl@0
  4809
	}
sl@0
  4810
sl@0
  4811
void RA3FDevSoundToneMaxVolumeWhilePausePlayingTest::DoTimerCallback()
sl@0
  4812
	{
sl@0
  4813
	INFO_PRINTF1(_L("TimerEvent called"));
sl@0
  4814
	if(!iTimeToEnterPauseElapsed)
sl@0
  4815
		{
sl@0
  4816
		iTimeToEnterPauseElapsed = ETrue;
sl@0
  4817
		INFO_PRINTF1(_L("DevSound Event: EEventTimerComplete"));
sl@0
  4818
		Fsm(EEventTimerComplete, KErrNone);
sl@0
  4819
		iTimeToEnterPauseElapsed = ETrue;
sl@0
  4820
		}
sl@0
  4821
	else
sl@0
  4822
		{
sl@0
  4823
		iTimer->Cancel();
sl@0
  4824
		INFO_PRINTF1(_L("DevSound Event: EEventTimerComplete"));
sl@0
  4825
		Fsm(EEventTimerComplete, KErrNone);
sl@0
  4826
		}
sl@0
  4827
	}
sl@0
  4828
sl@0
  4829
void RA3FDevSoundToneMaxVolumeWhilePausePlayingTest::ToneFinished(TInt aError)
sl@0
  4830
	{
sl@0
  4831
	INFO_PRINTF1(_L("========== DevSound ToneFinished() callback =========="));
sl@0
  4832
	ERR_PRINTF1(_L("DevSound should not have called ToneFinished because it is supposed to be paused then stopped"));
sl@0
  4833
	StopTest(aError, EFail);
sl@0
  4834
	}
sl@0
  4835
sl@0
  4836
/*
sl@0
  4837
 *========================================================================================================
sl@0
  4838
 * MM-A3F-DEVSOUND-CHRTZ-TONE-0035
sl@0
  4839
 */
sl@0
  4840
RA3FDevSoundToneVolumeWhilePausePlayingTest::RA3FDevSoundToneVolumeWhilePausePlayingTest(const TDesC& aTestName)
sl@0
  4841
	:	RA3FDevSoundTestBase(aTestName), iDuration(0),
sl@0
  4842
		iFrequencyTone1(0), iExVolume(0),
sl@0
  4843
		iTimeToEnterPauseElapsed(EFalse)
sl@0
  4844
	{
sl@0
  4845
	}
sl@0
  4846
sl@0
  4847
RA3FDevSoundToneVolumeWhilePausePlayingTest* RA3FDevSoundToneVolumeWhilePausePlayingTest::NewL(const TDesC& aTestName)
sl@0
  4848
	{
sl@0
  4849
	RA3FDevSoundToneVolumeWhilePausePlayingTest * self = new(ELeave)RA3FDevSoundToneVolumeWhilePausePlayingTest(aTestName);
sl@0
  4850
	return self;
sl@0
  4851
	}
sl@0
  4852
sl@0
  4853
void RA3FDevSoundToneVolumeWhilePausePlayingTest::DoKickoffTestL()
sl@0
  4854
	{
sl@0
  4855
	if (!GetIntFromConfig(iTestStepName, KDuration, iDuration))
sl@0
  4856
		{
sl@0
  4857
		ERR_PRINTF2(KMsgErrorGetParameter, &KDuration);
sl@0
  4858
		StopTest(KErrNotFound);
sl@0
  4859
		return;
sl@0
  4860
		}
sl@0
  4861
	if (!GetIntFromConfig(iTestStepName, KFrequencyTone1, iFrequencyTone1))
sl@0
  4862
		{
sl@0
  4863
		ERR_PRINTF2(KMsgErrorGetParameter, &KFrequencyTone1);
sl@0
  4864
		StopTest(KErrNotFound);
sl@0
  4865
		return;
sl@0
  4866
		}
sl@0
  4867
	if (!GetIntFromConfig(iTestStepName, KExVolume, iExVolume))
sl@0
  4868
		{
sl@0
  4869
		ERR_PRINTF2(KMsgErrorGetParameter, &KExVolume);
sl@0
  4870
		StopTest(KErrNotFound);
sl@0
  4871
		return;
sl@0
  4872
		}
sl@0
  4873
	iTimer = CPeriodic::NewL(CActive::EPriorityHigh);
sl@0
  4874
	}
sl@0
  4875
sl@0
  4876
void RA3FDevSoundToneVolumeWhilePausePlayingTest::Fsm(TMmfDevSoundEvent aDevSoundEvent, TInt aError)
sl@0
  4877
	{
sl@0
  4878
	switch (iDevSoundState)
sl@0
  4879
		{
sl@0
  4880
		case EStateCreated:
sl@0
  4881
			{
sl@0
  4882
			__ASSERT_ALWAYS((aError == KErrNone), Panic(_L("RA3FDevSoundToneVolumeWhilePausePlayingTest"), EFsmIncorrectErrorPassed));
sl@0
  4883
			if (aDevSoundEvent == EEventInitialize)
sl@0
  4884
				{
sl@0
  4885
				INFO_PRINTF1(_L("Calling CMMFDevSound::InitializeL"));
sl@0
  4886
				TRAPD(err, iMMFDevSound->InitializeL(*this, EMMFStateTonePlaying));
sl@0
  4887
				if (err != KErrNone)
sl@0
  4888
					{
sl@0
  4889
					ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"), err);
sl@0
  4890
					StopTest(err);
sl@0
  4891
					break;
sl@0
  4892
					}
sl@0
  4893
				INFO_PRINTF1(_L("DevSound State: EStateInitializing"));
sl@0
  4894
				iDevSoundState = EStateInitializing;
sl@0
  4895
				}
sl@0
  4896
			else
sl@0
  4897
				{
sl@0
  4898
				ERR_PRINTF2(_L("DevSound EEventInitialize not received as expected. Received event: %d"), aDevSoundEvent);
sl@0
  4899
				StopTest(aError, EFail);
sl@0
  4900
				}
sl@0
  4901
			break;
sl@0
  4902
			}
sl@0
  4903
		case EStateInitializing:
sl@0
  4904
			{
sl@0
  4905
			if (aDevSoundEvent == EEventInitComplete && aError == KErrNone)
sl@0
  4906
				{
sl@0
  4907
				INFO_PRINTF3(_L("Calling CMMFDevSound::PlayToneL using %d Hz during %d secs "), iFrequencyTone1, iDuration);
sl@0
  4908
				TRAPD(err, iMMFDevSound->PlayToneL(iFrequencyTone1, iDuration*KMicroSecsInOneSec));
sl@0
  4909
				if (err != KErrNone)
sl@0
  4910
					{
sl@0
  4911
					ERR_PRINTF2(_L("CMMFDevSound::PlayToneL left with error : %d!"), err);
sl@0
  4912
					StopTest(err);
sl@0
  4913
					break;
sl@0
  4914
					}
sl@0
  4915
				StartTimer(KMicroSecsTwoSec);
sl@0
  4916
				INFO_PRINTF1(_L("DevSound State: EStatePlaying"));
sl@0
  4917
				iDevSoundState = EStatePlaying;
sl@0
  4918
				}
sl@0
  4919
			else if (aDevSoundEvent == EEventInitComplete && aError != KErrNone)
sl@0
  4920
				{
sl@0
  4921
				ERR_PRINTF2(_L("DevSound called CMMFDevSound::InitializeComplete with error = %d"), aError);
sl@0
  4922
				StopTest(aError);
sl@0
  4923
				}
sl@0
  4924
			else
sl@0
  4925
				{
sl@0
  4926
				ERR_PRINTF2(_L("DevSound EEventInitComplete not received as expected. Received event: %d"), aDevSoundEvent);
sl@0
  4927
				StopTest(aError, EFail);
sl@0
  4928
				}
sl@0
  4929
			break;
sl@0
  4930
			}
sl@0
  4931
		case EStatePlaying:
sl@0
  4932
			{
sl@0
  4933
			if(aDevSoundEvent == EEventTimerComplete)
sl@0
  4934
				{
sl@0
  4935
				INFO_PRINTF1(_L("Calling CMMFDevSound::Pause"));
sl@0
  4936
				iMMFDevSound->Pause();
sl@0
  4937
				INFO_PRINTF1(_L("DevSound State: EStatePause"));
sl@0
  4938
				iDevSoundState = EStatePause;
sl@0
  4939
				}
sl@0
  4940
			else
sl@0
  4941
				{
sl@0
  4942
				ERR_PRINTF2(_L("DevSound EEventTimerComplete not received as expected. Received event: %d"), aDevSoundEvent);
sl@0
  4943
				StopTest(aError, EFail);
sl@0
  4944
				}
sl@0
  4945
			break;
sl@0
  4946
			}
sl@0
  4947
		case EStatePause:
sl@0
  4948
			{
sl@0
  4949
			if(aDevSoundEvent == EEventTimerComplete)
sl@0
  4950
				{
sl@0
  4951
				INFO_PRINTF1(_L("Calling CMMFDevSound::Volume"));
sl@0
  4952
				TInt maxVolumeGet = iMMFDevSound->Volume();
sl@0
  4953
				if (maxVolumeGet == iExVolume)
sl@0
  4954
					{
sl@0
  4955
					INFO_PRINTF2(_L("The device default supported volume value is %d."), maxVolumeGet);
sl@0
  4956
					StopTest();
sl@0
  4957
					}
sl@0
  4958
				else
sl@0
  4959
					{
sl@0
  4960
					INFO_PRINTF2(_L("The device default supported volume value failed with %d."), maxVolumeGet);
sl@0
  4961
					ERR_PRINTF2(_L("Expected value = %d."), iExVolume);
sl@0
  4962
					StopTest(aError, EFail);
sl@0
  4963
					}
sl@0
  4964
				}
sl@0
  4965
			else
sl@0
  4966
				{
sl@0
  4967
				ERR_PRINTF2(_L("DevSound EEventTimerComplete not received as expected. Received event: %d"), aDevSoundEvent);
sl@0
  4968
				StopTest(aError, EFail);
sl@0
  4969
				}
sl@0
  4970
			break;
sl@0
  4971
			}
sl@0
  4972
		default:
sl@0
  4973
			{
sl@0
  4974
			ERR_PRINTF2(_L("Invalid DevSound state received: %d"), iDevSoundState);
sl@0
  4975
			StopTest(aError, EFail);
sl@0
  4976
			}
sl@0
  4977
		}
sl@0
  4978
	}
sl@0
  4979
sl@0
  4980
void RA3FDevSoundToneVolumeWhilePausePlayingTest::DoTimerCallback()
sl@0
  4981
	{
sl@0
  4982
	INFO_PRINTF1(_L("TimerEvent called"));
sl@0
  4983
	if(!iTimeToEnterPauseElapsed)
sl@0
  4984
		{
sl@0
  4985
		iTimeToEnterPauseElapsed = ETrue;
sl@0
  4986
		INFO_PRINTF1(_L("DevSound Event: EEventTimerComplete"));
sl@0
  4987
		Fsm(EEventTimerComplete, KErrNone);
sl@0
  4988
		iTimeToEnterPauseElapsed = ETrue;
sl@0
  4989
		}
sl@0
  4990
	else
sl@0
  4991
		{
sl@0
  4992
		iTimer->Cancel();
sl@0
  4993
		INFO_PRINTF1(_L("DevSound Event: EEventTimerComplete"));
sl@0
  4994
		Fsm(EEventTimerComplete, KErrNone);
sl@0
  4995
		}
sl@0
  4996
	}
sl@0
  4997
sl@0
  4998
void RA3FDevSoundToneVolumeWhilePausePlayingTest::ToneFinished(TInt aError)
sl@0
  4999
	{
sl@0
  5000
	INFO_PRINTF1(_L("========== DevSound ToneFinished() callback =========="));
sl@0
  5001
	ERR_PRINTF1(_L("DevSound should not have called ToneFinished because it is supposed to be paused then stopped"));
sl@0
  5002
	StopTest(aError, EFail);
sl@0
  5003
	}
sl@0
  5004
sl@0
  5005
/*
sl@0
  5006
 *========================================================================================================
sl@0
  5007
 * MM-A3F-DEVSOUND-CHRTZ-TONE-0036
sl@0
  5008
 */
sl@0
  5009
RA3FDevSoundTonePlayToneOnceTest::RA3FDevSoundTonePlayToneOnceTest(const TDesC& aTestName)
sl@0
  5010
	:	RA3FDevSoundTestBase(aTestName),
sl@0
  5011
		iDuration(0), iFrequencyTone1(0)
sl@0
  5012
	{
sl@0
  5013
	}
sl@0
  5014
sl@0
  5015
RA3FDevSoundTonePlayToneOnceTest* RA3FDevSoundTonePlayToneOnceTest::NewL(const TDesC& aTestName)
sl@0
  5016
	{
sl@0
  5017
	RA3FDevSoundTonePlayToneOnceTest * self = new(ELeave)RA3FDevSoundTonePlayToneOnceTest(aTestName);
sl@0
  5018
	return self;
sl@0
  5019
	}
sl@0
  5020
sl@0
  5021
void RA3FDevSoundTonePlayToneOnceTest::DoKickoffTestL()
sl@0
  5022
	{
sl@0
  5023
	if (!GetIntFromConfig(iTestStepName, KDuration, iDuration))
sl@0
  5024
		{
sl@0
  5025
		ERR_PRINTF2(KMsgErrorGetParameter, &KDuration);
sl@0
  5026
		StopTest(KErrNotFound);
sl@0
  5027
		return;
sl@0
  5028
		}
sl@0
  5029
	if (!GetIntFromConfig(iTestStepName, KFrequencyTone1, iFrequencyTone1))
sl@0
  5030
		{
sl@0
  5031
		ERR_PRINTF2(KMsgErrorGetParameter, &KFrequencyTone1);
sl@0
  5032
		StopTest(KErrNotFound);
sl@0
  5033
		return;
sl@0
  5034
		}
sl@0
  5035
	}
sl@0
  5036
sl@0
  5037
void RA3FDevSoundTonePlayToneOnceTest::Fsm(TMmfDevSoundEvent aDevSoundEvent, TInt aError)
sl@0
  5038
	{
sl@0
  5039
	switch (iDevSoundState)
sl@0
  5040
		{
sl@0
  5041
		case EStateCreated:
sl@0
  5042
			{
sl@0
  5043
			__ASSERT_ALWAYS((aError == KErrNone), Panic(_L("RA3FDevSoundTonePlayToneOnceTest"), EFsmIncorrectErrorPassed));
sl@0
  5044
			if (aDevSoundEvent == EEventInitialize)
sl@0
  5045
				{
sl@0
  5046
				INFO_PRINTF1(_L("Calling CMMFDevSound::InitializeL"));
sl@0
  5047
				TRAPD(err, iMMFDevSound->InitializeL(*this, EMMFStateTonePlaying));
sl@0
  5048
				if (err != KErrNone)
sl@0
  5049
					{
sl@0
  5050
					ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"), err);
sl@0
  5051
					StopTest(err);
sl@0
  5052
					break;
sl@0
  5053
					}
sl@0
  5054
				INFO_PRINTF1(_L("DevSound State: EStateInitializing"));
sl@0
  5055
				iDevSoundState = EStateInitializing;
sl@0
  5056
				}
sl@0
  5057
			else
sl@0
  5058
				{
sl@0
  5059
				ERR_PRINTF2(_L("DevSound EEventInitialize not received as expected. Received event: %d"), aDevSoundEvent);
sl@0
  5060
				StopTest(aError, EFail);
sl@0
  5061
				}
sl@0
  5062
			break;
sl@0
  5063
			}
sl@0
  5064
		case EStateInitializing:
sl@0
  5065
			{
sl@0
  5066
			if (aDevSoundEvent == EEventInitComplete && aError == KErrNone)
sl@0
  5067
				{
sl@0
  5068
				iMMFDevSound->SetVolume(iMMFDevSound->MaxVolume());
sl@0
  5069
				INFO_PRINTF3(_L("Calling CMMFDevSound::PlayToneL using %d Hz  during %d secs "), iFrequencyTone1, iDuration);
sl@0
  5070
				iStartTime.HomeTime();
sl@0
  5071
				TRAPD(err, iMMFDevSound->PlayToneL(iFrequencyTone1, iDuration*KMicroSecsInOneSec));
sl@0
  5072
				if (err != KErrNone)
sl@0
  5073
					{
sl@0
  5074
					ERR_PRINTF2(_L("CMMFDevSound::PlayToneL failed with error : %d!"), err);
sl@0
  5075
					StopTest(err);
sl@0
  5076
					}
sl@0
  5077
				INFO_PRINTF1(_L("DevSound State: EStatePlaying"));
sl@0
  5078
				iDevSoundState = EStatePlaying;
sl@0
  5079
				}
sl@0
  5080
			else if (aDevSoundEvent == EEventInitComplete && aError != KErrNone)
sl@0
  5081
				{
sl@0
  5082
				ERR_PRINTF2(_L("DevSound called CMMFDevSound::InitializeComplete with error = %d"), aError);
sl@0
  5083
				StopTest(aError);
sl@0
  5084
				}
sl@0
  5085
			else
sl@0
  5086
				{
sl@0
  5087
				ERR_PRINTF2(_L("DevSound EEventInitComplete not received as expected. Received event: %d"), aDevSoundEvent);
sl@0
  5088
				StopTest(aError, EFail);
sl@0
  5089
				}
sl@0
  5090
			break;
sl@0
  5091
			}
sl@0
  5092
		default:
sl@0
  5093
			{
sl@0
  5094
			ERR_PRINTF2(_L("Invalid DevSound state received: %d"), iDevSoundState);
sl@0
  5095
			StopTest(aError, EFail);
sl@0
  5096
			}
sl@0
  5097
		}
sl@0
  5098
	}
sl@0
  5099
sl@0
  5100
void RA3FDevSoundTonePlayToneOnceTest::ToneFinished(TInt aError)
sl@0
  5101
	{
sl@0
  5102
	INFO_PRINTF1(_L("========== DevSound ToneFinished() callback =========="));
sl@0
  5103
	if (aError == KErrUnderflow)
sl@0
  5104
		{
sl@0
  5105
		iEndTime.HomeTime();
sl@0
  5106
		iPlayToneTime = iEndTime.MicroSecondsFrom(iStartTime);
sl@0
  5107
		TInt totalExpectedReproductionTime = iDuration * KMicroSecsInOneSec;
sl@0
  5108
		if(iPlayToneTime < totalExpectedReproductionTime + KPlayVarianceTime && iPlayToneTime > totalExpectedReproductionTime - KPlayVarianceTime)
sl@0
  5109
			{
sl@0
  5110
			INFO_PRINTF2(_L("Play time is %Ld microseconds"), iPlayToneTime.Int64());
sl@0
  5111
			StopTest();
sl@0
  5112
			}
sl@0
  5113
		else
sl@0
  5114
			{
sl@0
  5115
			ERR_PRINTF3(_L("Play time is %Ld microseconds and it should have been %d microseconds"), iPlayToneTime.Int64(), totalExpectedReproductionTime);
sl@0
  5116
			StopTest(KErrNone, EFail);
sl@0
  5117
			}
sl@0
  5118
		}
sl@0
  5119
	else
sl@0
  5120
		{
sl@0
  5121
		ERR_PRINTF2(_L("DevSound called ToneFinished with error = %d"), aError);
sl@0
  5122
		ERR_PRINTF2(_L("Expected error = %d"), KErrUnderflow);
sl@0
  5123
		StopTest(aError, EFail);
sl@0
  5124
		}
sl@0
  5125
	}
sl@0
  5126
sl@0
  5127
/*
sl@0
  5128
 *========================================================================================================
sl@0
  5129
 * MM-A3F-DEVSOUND-CHRTZ-TONE-0037
sl@0
  5130
 */
sl@0
  5131
RA3FDevSoundTonePlayDualToneTest::RA3FDevSoundTonePlayDualToneTest(const TDesC& aTestName)
sl@0
  5132
	:	RA3FDevSoundTestBase(aTestName),
sl@0
  5133
		iDuration(0), iFrequencyTone1(0),
sl@0
  5134
		iFrequencyTone2(0)
sl@0
  5135
	{
sl@0
  5136
	}
sl@0
  5137
RA3FDevSoundTonePlayDualToneTest* RA3FDevSoundTonePlayDualToneTest::NewL(const TDesC& aTestName)
sl@0
  5138
	{
sl@0
  5139
	RA3FDevSoundTonePlayDualToneTest * self = new(ELeave)RA3FDevSoundTonePlayDualToneTest(aTestName);
sl@0
  5140
	return self;
sl@0
  5141
	}
sl@0
  5142
void RA3FDevSoundTonePlayDualToneTest::DoKickoffTestL()
sl@0
  5143
	{
sl@0
  5144
	if (!GetIntFromConfig(iTestStepName, KDuration, iDuration))
sl@0
  5145
		{
sl@0
  5146
		ERR_PRINTF2(KMsgErrorGetParameter, &KDuration);
sl@0
  5147
		StopTest(KErrNotFound);
sl@0
  5148
		return;
sl@0
  5149
		}
sl@0
  5150
	if (!GetIntFromConfig(iTestStepName, KFrequencyTone1, iFrequencyTone1))
sl@0
  5151
		{
sl@0
  5152
		ERR_PRINTF2(KMsgErrorGetParameter, &KFrequencyTone1);
sl@0
  5153
		StopTest(KErrNotFound);
sl@0
  5154
		return;
sl@0
  5155
		}
sl@0
  5156
	if (!GetIntFromConfig(iTestStepName, KFrequencyTone2, iFrequencyTone2))
sl@0
  5157
		{
sl@0
  5158
		ERR_PRINTF2(KMsgErrorGetParameter, &KFrequencyTone2);
sl@0
  5159
		StopTest(KErrNotFound);
sl@0
  5160
		return;
sl@0
  5161
		}
sl@0
  5162
	}
sl@0
  5163
sl@0
  5164
void RA3FDevSoundTonePlayDualToneTest::Fsm(TMmfDevSoundEvent aDevSoundEvent, TInt aError)
sl@0
  5165
	{
sl@0
  5166
	switch (iDevSoundState)
sl@0
  5167
		{
sl@0
  5168
		case EStateCreated:
sl@0
  5169
			{
sl@0
  5170
			__ASSERT_ALWAYS((aError == KErrNone), Panic(_L("RA3FDevSoundTonePlayDualToneTest"), EFsmIncorrectErrorPassed));
sl@0
  5171
			if (aDevSoundEvent == EEventInitialize)
sl@0
  5172
				{
sl@0
  5173
				INFO_PRINTF1(_L("Calling CMMFDevSound::InitializeL"));
sl@0
  5174
				TRAPD(err, iMMFDevSound->InitializeL(*this, EMMFStateTonePlaying));
sl@0
  5175
				if (err != KErrNone)
sl@0
  5176
					{
sl@0
  5177
					ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"), err);
sl@0
  5178
					StopTest(err);
sl@0
  5179
					break;
sl@0
  5180
					}
sl@0
  5181
				INFO_PRINTF1(_L("DevSound State: EStateInitializing"));
sl@0
  5182
				iDevSoundState = EStateInitializing;
sl@0
  5183
				}
sl@0
  5184
			else
sl@0
  5185
				{
sl@0
  5186
				ERR_PRINTF2(_L("DevSound EEventInitialize not received as expected. Received event: %d"), aDevSoundEvent);
sl@0
  5187
				StopTest(aError, EFail);
sl@0
  5188
				}
sl@0
  5189
			break;
sl@0
  5190
			}
sl@0
  5191
		case EStateInitializing:
sl@0
  5192
			{
sl@0
  5193
			if (aDevSoundEvent == EEventInitComplete && aError == KErrNone)
sl@0
  5194
				{
sl@0
  5195
				iMMFDevSound->SetVolume(iMMFDevSound->MaxVolume());
sl@0
  5196
				iStartTime.HomeTime();
sl@0
  5197
				INFO_PRINTF4(_L("Calling CMMFDevSound::PlayDualToneL using %d Hz %d Hz during %d secs "), iFrequencyTone1, iFrequencyTone2, iDuration);
sl@0
  5198
				TRAPD(err, iMMFDevSound->PlayDualToneL(iFrequencyTone1, iFrequencyTone2, iDuration*KMicroSecsInOneSec));
sl@0
  5199
				if (err != KErrNone)
sl@0
  5200
					{
sl@0
  5201
					ERR_PRINTF2(_L("CMMFDevSound::PlayDualToneL left with error : %d!"),  err);
sl@0
  5202
					StopTest(err);
sl@0
  5203
					break;
sl@0
  5204
					}
sl@0
  5205
				INFO_PRINTF1(_L("DevSound State: EStatePlaying"));
sl@0
  5206
				iDevSoundState = EStatePlaying;
sl@0
  5207
				}
sl@0
  5208
			else if (aDevSoundEvent == EEventInitComplete && aError != KErrNone)
sl@0
  5209
				{
sl@0
  5210
				ERR_PRINTF2(_L("DevSound called CMMFDevSound::InitializeComplete with error = %d"), aError);
sl@0
  5211
				StopTest(aError);
sl@0
  5212
				}
sl@0
  5213
			else
sl@0
  5214
				{
sl@0
  5215
				ERR_PRINTF2(_L("DevSound EEventInitComplete not received as expected. Received event: %d"), aDevSoundEvent);
sl@0
  5216
				StopTest(aError, EFail);
sl@0
  5217
				}
sl@0
  5218
			break;
sl@0
  5219
			}
sl@0
  5220
		default:
sl@0
  5221
			{
sl@0
  5222
			ERR_PRINTF2(_L("Invalid DevSound state received: %d"), iDevSoundState);
sl@0
  5223
			StopTest(aError, EFail);
sl@0
  5224
			}
sl@0
  5225
		}
sl@0
  5226
	}
sl@0
  5227
sl@0
  5228
void RA3FDevSoundTonePlayDualToneTest::ToneFinished(TInt aError)
sl@0
  5229
	{
sl@0
  5230
	INFO_PRINTF1(_L("========== DevSound ToneFinished() callback =========="));
sl@0
  5231
	if (aError == KErrUnderflow)
sl@0
  5232
		{
sl@0
  5233
		iEndTime.HomeTime();
sl@0
  5234
		iPlayToneTime = iEndTime.MicroSecondsFrom(iStartTime);
sl@0
  5235
		TInt totalExpectedReproductionTime = iDuration * KMicroSecsInOneSec;
sl@0
  5236
		if(iPlayToneTime < totalExpectedReproductionTime + KPlayVarianceTime && iPlayToneTime > totalExpectedReproductionTime - KPlayVarianceTime)
sl@0
  5237
			{
sl@0
  5238
			INFO_PRINTF2(_L("Play time is %Ld microseconds"), iPlayToneTime.Int64());
sl@0
  5239
			StopTest();
sl@0
  5240
			}
sl@0
  5241
		else
sl@0
  5242
			{
sl@0
  5243
			ERR_PRINTF3(_L("Play time is %Ld microseconds and it should have been %d microseconds"), iPlayToneTime.Int64(), totalExpectedReproductionTime);
sl@0
  5244
			StopTest(KErrNone, EFail);
sl@0
  5245
			}
sl@0
  5246
		}
sl@0
  5247
	else
sl@0
  5248
		{
sl@0
  5249
		ERR_PRINTF2(_L("DevSound called ToneFinished with error = %d"), aError);
sl@0
  5250
		ERR_PRINTF2(_L("Expected error = %d"), KErrUnderflow);
sl@0
  5251
		StopTest(aError, EFail);
sl@0
  5252
		}
sl@0
  5253
	}
sl@0
  5254
sl@0
  5255
/*
sl@0
  5256
 *========================================================================================================
sl@0
  5257
 * MM-A3F-DEVSOUND-CHRTZ-TONE-0038
sl@0
  5258
 */
sl@0
  5259
RA3FDevSoundTonePlayDTMFToneTest::RA3FDevSoundTonePlayDTMFToneTest(const TDesC& aTestName)
sl@0
  5260
	:	RA3FDevSoundTestBase(aTestName),iDTMFString(KNullDesC),
sl@0
  5261
		iDTMFPauses(0), iDTMFTones(0)
sl@0
  5262
sl@0
  5263
	{
sl@0
  5264
	}
sl@0
  5265
sl@0
  5266
RA3FDevSoundTonePlayDTMFToneTest* RA3FDevSoundTonePlayDTMFToneTest::NewL(const TDesC& aTestName)
sl@0
  5267
	{
sl@0
  5268
	RA3FDevSoundTonePlayDTMFToneTest * self = new(ELeave)RA3FDevSoundTonePlayDTMFToneTest(aTestName);
sl@0
  5269
	return self;
sl@0
  5270
	}
sl@0
  5271
sl@0
  5272
void RA3FDevSoundTonePlayDTMFToneTest::DoKickoffTestL()
sl@0
  5273
	{
sl@0
  5274
	TPtrC DTMF;
sl@0
  5275
	if (!GetStringFromConfig(iTestStepName, KDTMFString, DTMF))
sl@0
  5276
		{
sl@0
  5277
		ERR_PRINTF2(KMsgErrorGetParameter, &KDTMFString);
sl@0
  5278
		StopTest(KErrNotFound);
sl@0
  5279
		return;
sl@0
  5280
		}
sl@0
  5281
	iDTMFString.Copy(DTMF);
sl@0
  5282
	for(TInt i =0 ; i< iDTMFString.Length() ; i++)
sl@0
  5283
		{
sl@0
  5284
		if (iDTMFString[i] == ',')
sl@0
  5285
			{
sl@0
  5286
			iDTMFPauses++;
sl@0
  5287
			}
sl@0
  5288
		else
sl@0
  5289
			{
sl@0
  5290
			iDTMFTones++;
sl@0
  5291
			}
sl@0
  5292
		}
sl@0
  5293
	}
sl@0
  5294
sl@0
  5295
void RA3FDevSoundTonePlayDTMFToneTest::Fsm(TMmfDevSoundEvent aDevSoundEvent, TInt aError)
sl@0
  5296
	{
sl@0
  5297
	switch (iDevSoundState)
sl@0
  5298
		{
sl@0
  5299
		case EStateCreated:
sl@0
  5300
			{
sl@0
  5301
			__ASSERT_ALWAYS((aError == KErrNone), Panic(_L("RA3FDevSoundTonePlayDTMFToneTest"), EFsmIncorrectErrorPassed));
sl@0
  5302
			if (aDevSoundEvent == EEventInitialize)
sl@0
  5303
				{
sl@0
  5304
				INFO_PRINTF1(_L("Calling CMMFDevSound::InitializeL"));
sl@0
  5305
				TRAPD(err, iMMFDevSound->InitializeL(*this, EMMFStateTonePlaying));
sl@0
  5306
				if (err != KErrNone)
sl@0
  5307
					{
sl@0
  5308
					ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"),  err);
sl@0
  5309
					StopTest(err);
sl@0
  5310
					break;
sl@0
  5311
					}
sl@0
  5312
				INFO_PRINTF1(_L("DevSound State: EStateInitializing"));
sl@0
  5313
				iDevSoundState = EStateInitializing;
sl@0
  5314
				}
sl@0
  5315
			else
sl@0
  5316
				{
sl@0
  5317
				ERR_PRINTF2(_L("DevSound EEventInitialize not received as expected. Received event: %d"), aDevSoundEvent);
sl@0
  5318
				StopTest(aError,  EFail);
sl@0
  5319
				}
sl@0
  5320
			break;
sl@0
  5321
			}
sl@0
  5322
		case EStateInitializing:
sl@0
  5323
			{
sl@0
  5324
			if (aDevSoundEvent == EEventInitComplete && aError == KErrNone)
sl@0
  5325
				{
sl@0
  5326
				iMMFDevSound->SetVolume(iMMFDevSound->MaxVolume());
sl@0
  5327
				iStartTime.HomeTime();
sl@0
  5328
				INFO_PRINTF2(_L("Calling CMMFDevSound::PlayDTMFStringL %S"), &iDTMFString);
sl@0
  5329
				TRAPD(err, iMMFDevSound->PlayDTMFStringL(iDTMFString));
sl@0
  5330
				if (err != KErrNone)
sl@0
  5331
					{
sl@0
  5332
					ERR_PRINTF2(_L("CMMFDevSound::PlayDTMFStringL left with error : %d!"), err);
sl@0
  5333
					StopTest(err);
sl@0
  5334
					break;
sl@0
  5335
					}
sl@0
  5336
				INFO_PRINTF1(_L("DevSound State: EStatePlaying"));
sl@0
  5337
				iDevSoundState = EStatePlaying;
sl@0
  5338
				}
sl@0
  5339
			else if (aDevSoundEvent == EEventInitComplete && aError != KErrNone)
sl@0
  5340
				{
sl@0
  5341
				ERR_PRINTF2(_L("DevSound called CMMFDevSound::InitializeComplete with error = %d"), aError);
sl@0
  5342
				StopTest(aError);
sl@0
  5343
				}
sl@0
  5344
			else
sl@0
  5345
				{
sl@0
  5346
				ERR_PRINTF2(_L("DevSound EEventInitComplete not received as expected. Received event: %d"), aDevSoundEvent);
sl@0
  5347
				StopTest(aError, EFail);
sl@0
  5348
				}
sl@0
  5349
			break;
sl@0
  5350
			}
sl@0
  5351
		default:
sl@0
  5352
			{
sl@0
  5353
			ERR_PRINTF2(_L("Invalid DevSound state received: %d"), iDevSoundState);
sl@0
  5354
			StopTest(aError, EFail);
sl@0
  5355
			}
sl@0
  5356
		}
sl@0
  5357
	}
sl@0
  5358
sl@0
  5359
void RA3FDevSoundTonePlayDTMFToneTest::ToneFinished(TInt aError)
sl@0
  5360
	{
sl@0
  5361
	INFO_PRINTF1(_L("========== DevSound ToneFinished() callback =========="));
sl@0
  5362
	if (aError == KErrUnderflow)
sl@0
  5363
		{
sl@0
  5364
		iEndTime.HomeTime();
sl@0
  5365
		iPlayToneTime = iEndTime.MicroSecondsFrom(iStartTime);
sl@0
  5366
		TInt defaultToneOn = 250000;
sl@0
  5367
		TInt defaultToneOff = 50000;
sl@0
  5368
		TInt defaultPauseLength = 250000;
sl@0
  5369
		TInt totalExpectedReproductionTime = defaultToneOn*iDTMFTones + defaultToneOff * iDTMFTones + iDTMFPauses * defaultPauseLength;
sl@0
  5370
		if (iPlayToneTime < totalExpectedReproductionTime + KPlayVarianceTime && iPlayToneTime > totalExpectedReproductionTime - KPlayVarianceTime)
sl@0
  5371
			{
sl@0
  5372
			INFO_PRINTF2(_L("Play time is %Ld microseconds"), iPlayToneTime.Int64());
sl@0
  5373
			StopTest();
sl@0
  5374
			}
sl@0
  5375
		else
sl@0
  5376
			{
sl@0
  5377
			ERR_PRINTF2(_L("Calling CMMFDevSound::PlayDTMFStringL failed with %Ld"), iPlayToneTime.Int64());
sl@0
  5378
			ERR_PRINTF2(_L("Expected time %d"), totalExpectedReproductionTime);
sl@0
  5379
			StopTest(KErrNone, EFail);
sl@0
  5380
			}
sl@0
  5381
		}
sl@0
  5382
	else
sl@0
  5383
		{
sl@0
  5384
		ERR_PRINTF2(_L("DevSound called ToneFinished with error = %d"), aError);
sl@0
  5385
		ERR_PRINTF2(_L("Expected error = %d"), KErrUnderflow);
sl@0
  5386
		StopTest(aError, EFail);
sl@0
  5387
		}
sl@0
  5388
	}
sl@0
  5389
sl@0
  5390
/*
sl@0
  5391
 *========================================================================================================
sl@0
  5392
 * MM-A3F-DEVSOUND-CHRTZ-TONE-0039
sl@0
  5393
 */
sl@0
  5394
RA3FDevSoundTonePlayToneSequenceTest::RA3FDevSoundTonePlayToneSequenceTest(const TDesC& aTestName)
sl@0
  5395
	:	RA3FDevSoundTestBase(aTestName)
sl@0
  5396
	{
sl@0
  5397
	}
sl@0
  5398
sl@0
  5399
RA3FDevSoundTonePlayToneSequenceTest* RA3FDevSoundTonePlayToneSequenceTest::NewL(const TDesC& aTestName)
sl@0
  5400
	{
sl@0
  5401
	RA3FDevSoundTonePlayToneSequenceTest * self = new(ELeave)RA3FDevSoundTonePlayToneSequenceTest(aTestName);
sl@0
  5402
	return self;
sl@0
  5403
	}
sl@0
  5404
sl@0
  5405
void RA3FDevSoundTonePlayToneSequenceTest::DoKickoffTestL()
sl@0
  5406
	{
sl@0
  5407
	}
sl@0
  5408
sl@0
  5409
void RA3FDevSoundTonePlayToneSequenceTest::Fsm(TMmfDevSoundEvent aDevSoundEvent, TInt aError)
sl@0
  5410
	{
sl@0
  5411
	switch(iDevSoundState)
sl@0
  5412
		{
sl@0
  5413
		case EStateCreated:
sl@0
  5414
			{
sl@0
  5415
			__ASSERT_ALWAYS((aError == KErrNone), Panic(_L("RA3FDevSoundTonePlayToneSequenceTest"), EFsmIncorrectErrorPassed));
sl@0
  5416
			if (aDevSoundEvent == EEventInitialize)
sl@0
  5417
				{
sl@0
  5418
				INFO_PRINTF1(_L("Calling MMFDevSound::InitializeL"));
sl@0
  5419
				TRAPD(err, iMMFDevSound->InitializeL(*this,  EMMFStateTonePlaying));
sl@0
  5420
				if (err != KErrNone)
sl@0
  5421
					{
sl@0
  5422
					ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"), err);
sl@0
  5423
					StopTest(err);
sl@0
  5424
					break;
sl@0
  5425
					}
sl@0
  5426
				INFO_PRINTF1(_L("DevSound State: EStateInitializing"));
sl@0
  5427
				iDevSoundState = EStateInitializing;
sl@0
  5428
				}
sl@0
  5429
			else
sl@0
  5430
				{
sl@0
  5431
				ERR_PRINTF2(_L("DevSound EEventInitialize not received as expected. Received event: %d"), aDevSoundEvent);
sl@0
  5432
				StopTest(aError, EFail);
sl@0
  5433
				}
sl@0
  5434
			break;
sl@0
  5435
			}
sl@0
  5436
		case EStateInitializing:
sl@0
  5437
			{
sl@0
  5438
			if (aDevSoundEvent == EEventInitComplete && aError == KErrNone)
sl@0
  5439
				{
sl@0
  5440
				iMMFDevSound->SetVolume(iMMFDevSound->MaxVolume());
sl@0
  5441
				TUint8* tablePointer = const_cast<TUint8*>(&(KFixedSequenceTestSequenceDataX[0]));
sl@0
  5442
				TPtrC8 KFixedSequenceData(tablePointer, sizeof(KFixedSequenceTestSequenceDataX));
sl@0
  5443
				INFO_PRINTF1(_L("Calling CMMFDevSound::PlayToneSequenceL"));
sl@0
  5444
				TRAPD(err, iMMFDevSound->PlayToneSequenceL(KFixedSequenceData));
sl@0
  5445
				if (err != KErrNone)
sl@0
  5446
					{
sl@0
  5447
					ERR_PRINTF2(_L("Play tone sequence failed with error = %d!"), err);
sl@0
  5448
					StopTest(err);
sl@0
  5449
					break;
sl@0
  5450
					}
sl@0
  5451
				INFO_PRINTF1(_L("DevSound State: EStatePlaying"));
sl@0
  5452
				iDevSoundState = EStatePlaying;
sl@0
  5453
				}
sl@0
  5454
			else if (aDevSoundEvent == EEventInitComplete && aError != KErrNone)
sl@0
  5455
				{
sl@0
  5456
				ERR_PRINTF2(_L("DevSound called CMMFDevSound::InitializeComplete with error = %d"), aError);
sl@0
  5457
				StopTest(aError);
sl@0
  5458
				}
sl@0
  5459
			else
sl@0
  5460
				{
sl@0
  5461
				ERR_PRINTF2(_L("DevSound EEventInitComplete not received as expected. Received event: %d"), aDevSoundEvent);
sl@0
  5462
				StopTest(aError, EFail);
sl@0
  5463
				}
sl@0
  5464
			break;
sl@0
  5465
			}
sl@0
  5466
		default:
sl@0
  5467
			{
sl@0
  5468
			ERR_PRINTF2(_L("Invalid DevSound state received: %d"), iDevSoundState);
sl@0
  5469
			StopTest(aError, EFail);
sl@0
  5470
			}
sl@0
  5471
		}
sl@0
  5472
	}
sl@0
  5473
sl@0
  5474
/*
sl@0
  5475
 *========================================================================================================
sl@0
  5476
 * MM-A3F-DEVSOUND-CHRTZ-TONE-0040
sl@0
  5477
 */
sl@0
  5478
RA3FDevSoundToneNewToneRequestWhilePlayingTest::RA3FDevSoundToneNewToneRequestWhilePlayingTest(const TDesC& aTestName)
sl@0
  5479
	:	RA3FDevSoundTestBase(aTestName),
sl@0
  5480
		iDuration(0), iFrequencyTone1(0)
sl@0
  5481
	{
sl@0
  5482
	}
sl@0
  5483
sl@0
  5484
RA3FDevSoundToneNewToneRequestWhilePlayingTest* RA3FDevSoundToneNewToneRequestWhilePlayingTest::NewL(const TDesC& aTestName)
sl@0
  5485
	{
sl@0
  5486
	RA3FDevSoundToneNewToneRequestWhilePlayingTest * self = new(ELeave)RA3FDevSoundToneNewToneRequestWhilePlayingTest(aTestName);
sl@0
  5487
	return self;
sl@0
  5488
	}
sl@0
  5489
sl@0
  5490
void RA3FDevSoundToneNewToneRequestWhilePlayingTest::DoKickoffTestL()
sl@0
  5491
	{
sl@0
  5492
	if (!GetIntFromConfig(iTestStepName, KDuration, iDuration))
sl@0
  5493
		{
sl@0
  5494
		ERR_PRINTF2(KMsgErrorGetParameter, &KDuration);
sl@0
  5495
		StopTest(KErrNotFound);
sl@0
  5496
		return;
sl@0
  5497
		}
sl@0
  5498
	if (!GetIntFromConfig(iTestStepName, KFrequencyTone1, iFrequencyTone1))
sl@0
  5499
		{
sl@0
  5500
		ERR_PRINTF2(KMsgErrorGetParameter, &KFrequencyTone1);
sl@0
  5501
		StopTest(KErrNotFound);
sl@0
  5502
		return;
sl@0
  5503
		}
sl@0
  5504
	iTimer = CPeriodic::NewL(CActive::EPriorityHigh);
sl@0
  5505
	}
sl@0
  5506
sl@0
  5507
void RA3FDevSoundToneNewToneRequestWhilePlayingTest::Fsm(TMmfDevSoundEvent aDevSoundEvent, TInt aError)
sl@0
  5508
	{
sl@0
  5509
	switch (iDevSoundState)
sl@0
  5510
		{
sl@0
  5511
		case EStateCreated:
sl@0
  5512
			{
sl@0
  5513
			if (aDevSoundEvent == EEventInitialize)
sl@0
  5514
				{
sl@0
  5515
				__ASSERT_ALWAYS((aError == KErrNone), Panic(_L("RA3FDevSoundToneNewToneRequestWhilePlayingTest"), EFsmIncorrectErrorPassed));
sl@0
  5516
				INFO_PRINTF1(_L("Calling CMMFDevSound::InitializeL"));
sl@0
  5517
				TRAPD(err, iMMFDevSound->InitializeL(*this, EMMFStateTonePlaying));
sl@0
  5518
				if (err != KErrNone)
sl@0
  5519
					{
sl@0
  5520
					ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"), err);
sl@0
  5521
					StopTest(err);
sl@0
  5522
					break;
sl@0
  5523
					}
sl@0
  5524
				INFO_PRINTF1(_L("DevSound State: EStateInitializing"));
sl@0
  5525
				iDevSoundState = EStateInitializing;
sl@0
  5526
				}
sl@0
  5527
			else
sl@0
  5528
				{
sl@0
  5529
				ERR_PRINTF2(_L("DevSound EEventInitialize not received as expected. Received event: %d"), aDevSoundEvent);
sl@0
  5530
				StopTest(aError, EFail);
sl@0
  5531
				}
sl@0
  5532
			break;
sl@0
  5533
			}
sl@0
  5534
		case EStateInitializing:
sl@0
  5535
			{
sl@0
  5536
			if (aDevSoundEvent == EEventInitComplete && aError == KErrNone)
sl@0
  5537
				{
sl@0
  5538
				iMMFDevSound->SetVolume(iMMFDevSound->MaxVolume());
sl@0
  5539
				iStartTime.HomeTime();
sl@0
  5540
				INFO_PRINTF3(_L("Calling CMMFDevSound::PlayToneL using %d Hz during %d secs "), iFrequencyTone1, iDuration);
sl@0
  5541
				TRAPD(err, iMMFDevSound->PlayToneL(iFrequencyTone1, iDuration*KMicroSecsInOneSec));
sl@0
  5542
				if (err != KErrNone)
sl@0
  5543
					{
sl@0
  5544
					ERR_PRINTF2(_L("CMMFDevSound::PlayToneL left with error : %d!"), err);
sl@0
  5545
					StopTest(err);
sl@0
  5546
					break;
sl@0
  5547
					}
sl@0
  5548
				StartTimer(KMicroSecsTwoSec);
sl@0
  5549
				INFO_PRINTF1(_L("DevSound State: EStatePlaying"));
sl@0
  5550
				iDevSoundState = EStatePlaying;
sl@0
  5551
				}
sl@0
  5552
			else if (aDevSoundEvent == EEventInitComplete && aError != KErrNone)
sl@0
  5553
				{
sl@0
  5554
				ERR_PRINTF2(_L("DevSound called CMMFDevSound::InitializeComplete with error = %d"), aError);
sl@0
  5555
				StopTest(aError);
sl@0
  5556
				}
sl@0
  5557
			else
sl@0
  5558
				{
sl@0
  5559
				ERR_PRINTF2(_L("DevSound EEventInitComplete not received as expected. Received event: %d"), aDevSoundEvent);
sl@0
  5560
				StopTest(aError, EFail);
sl@0
  5561
				}
sl@0
  5562
			break;
sl@0
  5563
			}
sl@0
  5564
		case EStatePlaying:
sl@0
  5565
			{
sl@0
  5566
			if(aDevSoundEvent == EEventTimerComplete)
sl@0
  5567
				{
sl@0
  5568
				INFO_PRINTF3(_L("Calling CMMFDevSound::PlayToneL using %d Hz during %d secs "), iFrequencyTone1, iDuration);
sl@0
  5569
				TRAPD(err, iMMFDevSound->PlayToneL(iFrequencyTone1, iDuration*KMicroSecsInOneSec));
sl@0
  5570
				if (err == KErrNone)
sl@0
  5571
					{
sl@0
  5572
					INFO_PRINTF2(_L("CMMFDevSound::PlayToneL left with the expected error = %d"), err);
sl@0
  5573
					}
sl@0
  5574
				else
sl@0
  5575
					{
sl@0
  5576
					ERR_PRINTF2(_L("CMMFDevSound::PlayToneL left with error = %d"), err);
sl@0
  5577
					ERR_PRINTF2(_L("Expected error value = %d!"), KErrNotReady);
sl@0
  5578
					StopTest(err);
sl@0
  5579
					break;
sl@0
  5580
					}
sl@0
  5581
				}
sl@0
  5582
			break;
sl@0
  5583
			}
sl@0
  5584
		default:
sl@0
  5585
			{
sl@0
  5586
			ERR_PRINTF2(_L("Invalid DevSound state received: %d"), iDevSoundState);
sl@0
  5587
			StopTest(aError, EFail);
sl@0
  5588
			}
sl@0
  5589
		}
sl@0
  5590
	}
sl@0
  5591
sl@0
  5592
void RA3FDevSoundToneNewToneRequestWhilePlayingTest::DoTimerCallback()
sl@0
  5593
	{
sl@0
  5594
	INFO_PRINTF1(_L("TimerEvent called"));
sl@0
  5595
	iTimer->Cancel();
sl@0
  5596
	INFO_PRINTF1(_L("DevSound Event: EEventTimerComplete"));
sl@0
  5597
	Fsm(EEventTimerComplete, KErrNone);
sl@0
  5598
	}
sl@0
  5599
sl@0
  5600
void RA3FDevSoundToneNewToneRequestWhilePlayingTest::ToneFinished(TInt aError)
sl@0
  5601
	{
sl@0
  5602
	INFO_PRINTF1(_L("========== DevSound ToneFinished() callback =========="));
sl@0
  5603
	if (aError == KErrUnderflow)
sl@0
  5604
		{
sl@0
  5605
		iEndTime.HomeTime();
sl@0
  5606
		iPlayToneTime = iEndTime.MicroSecondsFrom(iStartTime);
sl@0
  5607
		TInt totalExpectedReproductionTime = iDuration * KMicroSecsInOneSec;
sl@0
  5608
		if(iPlayToneTime < totalExpectedReproductionTime + KPlayVarianceTime && iPlayToneTime > totalExpectedReproductionTime - KPlayVarianceTime)
sl@0
  5609
			{
sl@0
  5610
			INFO_PRINTF2(_L("Play time is %Ld microseconds"), iPlayToneTime.Int64());
sl@0
  5611
			StopTest();
sl@0
  5612
			}
sl@0
  5613
		else
sl@0
  5614
			{
sl@0
  5615
			ERR_PRINTF3(_L("Play time is %Ld microseconds and it should have been %d microseconds"), iPlayToneTime.Int64(), totalExpectedReproductionTime);
sl@0
  5616
			StopTest(KErrNone, EFail);
sl@0
  5617
			}
sl@0
  5618
		}
sl@0
  5619
	else
sl@0
  5620
		{
sl@0
  5621
		ERR_PRINTF2(_L("DevSound called ToneFinished with error = %d"), aError);
sl@0
  5622
		ERR_PRINTF2(_L("Expected error = %d"), KErrUnderflow);
sl@0
  5623
		StopTest(aError, EFail);
sl@0
  5624
		}
sl@0
  5625
	}
sl@0
  5626
sl@0
  5627
/*
sl@0
  5628
 *========================================================================================================
sl@0
  5629
 * MM-A3F-DEVSOUND-CHRTZ-TONE-0041
sl@0
  5630
 */
sl@0
  5631
RA3FDevSoundTonePreemptionTest::RA3FDevSoundTonePreemptionTest(const TDesC& aTestName)
sl@0
  5632
	:	RA3FDevSoundTestBase(aTestName),
sl@0
  5633
		iDuration(0), iFrequencyTone1(0)
sl@0
  5634
	{
sl@0
  5635
	}
sl@0
  5636
sl@0
  5637
RA3FDevSoundTonePreemptionTest* RA3FDevSoundTonePreemptionTest::NewL(const TDesC& aTestName)
sl@0
  5638
	{
sl@0
  5639
	RA3FDevSoundTonePreemptionTest * self = new(ELeave)RA3FDevSoundTonePreemptionTest(aTestName);
sl@0
  5640
	return self;
sl@0
  5641
	}
sl@0
  5642
sl@0
  5643
void RA3FDevSoundTonePreemptionTest::DoKickoffTestL()
sl@0
  5644
	{
sl@0
  5645
	if (!GetIntFromConfig(iTestStepName, KDuration, iDuration))
sl@0
  5646
		{
sl@0
  5647
		ERR_PRINTF2(KMsgErrorGetParameter, &KDuration);
sl@0
  5648
		StopTest(KErrNotFound);
sl@0
  5649
		return;
sl@0
  5650
		}
sl@0
  5651
	if (!GetIntFromConfig(iTestStepName, KFrequencyTone1, iFrequencyTone1))
sl@0
  5652
		{
sl@0
  5653
		ERR_PRINTF2(KMsgErrorGetParameter, &KFrequencyTone1);
sl@0
  5654
		StopTest(KErrNotFound);
sl@0
  5655
		return;
sl@0
  5656
		}
sl@0
  5657
	iTimer = CPeriodic::NewL(CActive::EPriorityHigh);
sl@0
  5658
	iDevsoundToneClient = CA3FDevSoundToneClient::NewL(*this);
sl@0
  5659
	}
sl@0
  5660
sl@0
  5661
void RA3FDevSoundTonePreemptionTest::Fsm(TMmfDevSoundEvent aDevSoundEvent, TInt aError)
sl@0
  5662
	{
sl@0
  5663
	switch (iDevSoundState)
sl@0
  5664
		{
sl@0
  5665
		case EStateCreated:
sl@0
  5666
			{
sl@0
  5667
			if (aDevSoundEvent == EEventInitialize)
sl@0
  5668
				{
sl@0
  5669
				__ASSERT_ALWAYS((aError == KErrNone), Panic(_L("RA3FDevSoundTonePreemptionTest"), EFsmIncorrectErrorPassed));
sl@0
  5670
				INFO_PRINTF1(_L("Calling CMMFDevSound::InitializeL"));
sl@0
  5671
				TRAPD(err, iMMFDevSound->InitializeL(*this, EMMFStateTonePlaying));
sl@0
  5672
				if (err != KErrNone)
sl@0
  5673
					{
sl@0
  5674
					ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"), err);
sl@0
  5675
					StopTest(err);
sl@0
  5676
					break;
sl@0
  5677
					}
sl@0
  5678
				INFO_PRINTF1(_L("DevSound State: EStateInitializing"));
sl@0
  5679
				iDevSoundState = EStateInitializing;
sl@0
  5680
				}
sl@0
  5681
			else
sl@0
  5682
				{
sl@0
  5683
				ERR_PRINTF2(_L("DevSound EEventInitialize not received as expected. Received event: %d"), aDevSoundEvent);
sl@0
  5684
				StopTest(aError, EFail);
sl@0
  5685
				}
sl@0
  5686
			break;
sl@0
  5687
			}
sl@0
  5688
		case EStateInitializing:
sl@0
  5689
			{
sl@0
  5690
			if (aDevSoundEvent == EEventInitComplete && aError == KErrNone)
sl@0
  5691
				{
sl@0
  5692
				iMMFDevSound->SetVolume(iMMFDevSound->MaxVolume());
sl@0
  5693
				TMMFPrioritySettings prioritySettings;
sl@0
  5694
				prioritySettings.iPriority = KMinimumPriority;
sl@0
  5695
				prioritySettings.iPref = EMdaPriorityPreferenceTime;
sl@0
  5696
				prioritySettings.iState = EMMFStateIdle;
sl@0
  5697
				iMMFDevSound->SetPrioritySettings(prioritySettings);
sl@0
  5698
				INFO_PRINTF3(_L("Calling CMMFDevSound::PlayToneL using %d Hz during %d secs "), iFrequencyTone1, iDuration);
sl@0
  5699
				TRAPD(err, iMMFDevSound->PlayToneL(iFrequencyTone1, iDuration*KMicroSecsInOneSec));
sl@0
  5700
				if (err != KErrNone)
sl@0
  5701
					{
sl@0
  5702
					ERR_PRINTF2(_L("CMMFDevSound::PlayToneL left with error : %d!"), err);
sl@0
  5703
					StopTest(err);
sl@0
  5704
					break;
sl@0
  5705
					}
sl@0
  5706
				StartTimer(KMicroSecsTwoSec);
sl@0
  5707
				INFO_PRINTF1(_L("DevSound State: EStatePlaying"));
sl@0
  5708
				iDevSoundState = EStatePlaying;
sl@0
  5709
				}
sl@0
  5710
			else if (aDevSoundEvent == EEventInitComplete && aError != KErrNone)
sl@0
  5711
				{
sl@0
  5712
				ERR_PRINTF2(_L("DevSound called CMMFDevSound::InitializeComplete with error = %d"), aError);
sl@0
  5713
				StopTest(aError);
sl@0
  5714
				}
sl@0
  5715
			else
sl@0
  5716
				{
sl@0
  5717
				ERR_PRINTF2(_L("DevSound EEventInitComplete not received as expected. Received event: %d"), aDevSoundEvent);
sl@0
  5718
				StopTest(aError, EFail);
sl@0
  5719
				}
sl@0
  5720
			break;
sl@0
  5721
			}
sl@0
  5722
		case EStatePlaying:
sl@0
  5723
			{
sl@0
  5724
			if(aDevSoundEvent == EEventTimerComplete)
sl@0
  5725
				{
sl@0
  5726
				INFO_PRINTF1(_L("Starting lower priority devsound client"));
sl@0
  5727
				iDevsoundToneClient->SetPriority(KMaximumPriority);
sl@0
  5728
				TInt err = iDevsoundToneClient->InitTonePlay(iFrequencyTone1, iDuration*KMicroSecsInOneSec);
sl@0
  5729
				if(err != KErrNone)
sl@0
  5730
					{
sl@0
  5731
					ERR_PRINTF1(_L("Initialization to play tone thru second devsound client failed"));
sl@0
  5732
					StopTest(err);
sl@0
  5733
					}
sl@0
  5734
				}
sl@0
  5735
			break;
sl@0
  5736
			}
sl@0
  5737
		default:
sl@0
  5738
			{
sl@0
  5739
			ERR_PRINTF2(_L("Invalid DevSound state received: %d"), iDevSoundState);
sl@0
  5740
			StopTest(aError, EFail);
sl@0
  5741
			}
sl@0
  5742
		}
sl@0
  5743
	}
sl@0
  5744
sl@0
  5745
void RA3FDevSoundTonePreemptionTest::DoTimerCallback()
sl@0
  5746
	{
sl@0
  5747
	INFO_PRINTF1(_L("TimerEvent called"));
sl@0
  5748
	iTimer->Cancel();
sl@0
  5749
	INFO_PRINTF1(_L("DevSound Event: EEventTimerComplete"));
sl@0
  5750
	Fsm(EEventTimerComplete, KErrNone);
sl@0
  5751
	}
sl@0
  5752
sl@0
  5753
void RA3FDevSoundTonePreemptionTest::ToneFinished(TInt aError)
sl@0
  5754
	{
sl@0
  5755
	INFO_PRINTF1(_L("========== DevSound ToneFinished() callback =========="));
sl@0
  5756
	if (aError == KErrInUse || aError == KErrDied || aError == KErrAccessDenied)
sl@0
  5757
		{
sl@0
  5758
		INFO_PRINTF1(_L("========== Preempting 1st DevSound Instance=========="));
sl@0
  5759
		}
sl@0
  5760
	else
sl@0
  5761
		{
sl@0
  5762
		ERR_PRINTF2(_L("First DevSound client called ToneFinished() and failed with error = %d "), aError);
sl@0
  5763
		ERR_PRINTF4(_L("Expected posibilities %d %d %d "), KErrInUse, KErrDied, KErrAccessDenied);
sl@0
  5764
		StopTest(aError, EFail);
sl@0
  5765
		}
sl@0
  5766
	}
sl@0
  5767
sl@0
  5768
sl@0
  5769
void RA3FDevSoundTonePreemptionTest::ClientInitializeCompleteCallback(TInt aError)
sl@0
  5770
	{
sl@0
  5771
	INFO_PRINTF1(_L("========== Second Client DevSound InitializeComplete() callback =========="));
sl@0
  5772
	if (aError != KErrNone)
sl@0
  5773
		{
sl@0
  5774
		ERR_PRINTF2(_L("Second Devsound InitializeComplete received an error = %d"), aError);
sl@0
  5775
		StopTest(aError);
sl@0
  5776
		}
sl@0
  5777
	else
sl@0
  5778
		{
sl@0
  5779
		INFO_PRINTF1(_L("Starting to play audio thru second devsound client"));
sl@0
  5780
		TInt err = iDevsoundToneClient->PlayTone();
sl@0
  5781
		if (err != KErrNone)
sl@0
  5782
			{
sl@0
  5783
			ERR_PRINTF2(_L("Starting to play tones thru second devsound client left with error = %d"), err);
sl@0
  5784
			StopTest(err);
sl@0
  5785
			}
sl@0
  5786
		}
sl@0
  5787
	}
sl@0
  5788
sl@0
  5789
void RA3FDevSoundTonePreemptionTest::ClientToneFinishedCallback(TInt aError)
sl@0
  5790
	{
sl@0
  5791
	INFO_PRINTF1(_L("========== DevSound ToneFinished() callback =========="));
sl@0
  5792
		if (aError == KErrUnderflow)
sl@0
  5793
			{
sl@0
  5794
			INFO_PRINTF2(_L("Second DevSound instance called ToneFinished with error = %d"), aError);
sl@0
  5795
			StopTest(aError,EPass);
sl@0
  5796
			}
sl@0
  5797
		else
sl@0
  5798
			{
sl@0
  5799
			ERR_PRINTF2(_L("Second DevSound instance called ToneFinished with error = %d that was NOT expected"), aError);
sl@0
  5800
			ERR_PRINTF2(_L("Expected error = %d"), aError);
sl@0
  5801
			StopTest(aError);
sl@0
  5802
			}
sl@0
  5803
	}
sl@0
  5804
sl@0
  5805
/*
sl@0
  5806
 *========================================================================================================
sl@0
  5807
 * MM-A3F-DEVSOUND-CHRTZ-TONE-0042
sl@0
  5808
 */
sl@0
  5809
RA3FDevSoundToneRejectionTest::RA3FDevSoundToneRejectionTest(const TDesC& aTestName)
sl@0
  5810
	:	RA3FDevSoundTestBase(aTestName),
sl@0
  5811
		iDuration(0), iFrequencyTone1(0)
sl@0
  5812
	{
sl@0
  5813
	}
sl@0
  5814
sl@0
  5815
RA3FDevSoundToneRejectionTest* RA3FDevSoundToneRejectionTest::NewL(const TDesC& aTestName)
sl@0
  5816
	{
sl@0
  5817
	RA3FDevSoundToneRejectionTest * self = new(ELeave)RA3FDevSoundToneRejectionTest(aTestName);
sl@0
  5818
	return self;
sl@0
  5819
	}
sl@0
  5820
sl@0
  5821
void RA3FDevSoundToneRejectionTest::DoKickoffTestL()
sl@0
  5822
	{
sl@0
  5823
	if (!GetIntFromConfig(iTestStepName, KDuration, iDuration))
sl@0
  5824
		{
sl@0
  5825
		ERR_PRINTF2(KMsgErrorGetParameter, &KDuration);
sl@0
  5826
		StopTest(KErrNotFound);
sl@0
  5827
		return;
sl@0
  5828
		}
sl@0
  5829
	if (!GetIntFromConfig(iTestStepName, KFrequencyTone1, iFrequencyTone1))
sl@0
  5830
		{
sl@0
  5831
		ERR_PRINTF2(KMsgErrorGetParameter, &KFrequencyTone1);
sl@0
  5832
		StopTest(KErrNotFound);
sl@0
  5833
		return;
sl@0
  5834
		}
sl@0
  5835
	iTimer = CPeriodic::NewL(CActive::EPriorityHigh);
sl@0
  5836
	iDevsoundToneClient = CA3FDevSoundToneClient::NewL(*this);
sl@0
  5837
	}
sl@0
  5838
sl@0
  5839
void RA3FDevSoundToneRejectionTest::Fsm(TMmfDevSoundEvent aDevSoundEvent, TInt aError)
sl@0
  5840
	{
sl@0
  5841
	switch (iDevSoundState)
sl@0
  5842
		{
sl@0
  5843
		case EStateCreated:
sl@0
  5844
			{
sl@0
  5845
			if (aDevSoundEvent == EEventInitialize)
sl@0
  5846
				{
sl@0
  5847
				__ASSERT_ALWAYS((aError == KErrNone), Panic(_L("RA3FDevSoundToneRejectionTest"), EFsmIncorrectErrorPassed));
sl@0
  5848
				INFO_PRINTF1(_L("Calling CMMFDevSound::InitializeL"));
sl@0
  5849
				TRAPD(err, iMMFDevSound->InitializeL(*this, EMMFStateTonePlaying));
sl@0
  5850
				if (err != KErrNone)
sl@0
  5851
					{
sl@0
  5852
					ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"), err);
sl@0
  5853
					StopTest(err);
sl@0
  5854
					break;
sl@0
  5855
					}
sl@0
  5856
				INFO_PRINTF1(_L("DevSound State: EStateInitializing"));
sl@0
  5857
				iDevSoundState = EStateInitializing;
sl@0
  5858
				}
sl@0
  5859
			else
sl@0
  5860
				{
sl@0
  5861
				ERR_PRINTF2(_L("DevSound EEventInitialize not received as expected. Received event: %d"), aDevSoundEvent);
sl@0
  5862
				StopTest(aError, EFail);
sl@0
  5863
				}
sl@0
  5864
			break;
sl@0
  5865
			}
sl@0
  5866
		case EStateInitializing:
sl@0
  5867
			{
sl@0
  5868
			if (aDevSoundEvent == EEventInitComplete && aError == KErrNone)
sl@0
  5869
				{
sl@0
  5870
				iMMFDevSound->SetVolume(iMMFDevSound->MaxVolume());
sl@0
  5871
				TMMFPrioritySettings prioritySettings;
sl@0
  5872
				prioritySettings.iPriority = KMinimumPriority;
sl@0
  5873
				prioritySettings.iPref = EMdaPriorityPreferenceTime;
sl@0
  5874
				prioritySettings.iState = EMMFStateIdle;
sl@0
  5875
				iMMFDevSound->SetPrioritySettings(prioritySettings);
sl@0
  5876
				INFO_PRINTF3(_L("Calling CMMFDevSound::PlayToneL using %d Hz during %d secs "), iFrequencyTone1, iDuration);
sl@0
  5877
				TRAPD(err, iMMFDevSound->PlayToneL(iFrequencyTone1, iDuration*KMicroSecsInOneSec));
sl@0
  5878
				if (err != KErrNone)
sl@0
  5879
					{
sl@0
  5880
					ERR_PRINTF2(_L("CMMFDevSound::PlayToneL left with error : %d!"), err);
sl@0
  5881
					StopTest(err);
sl@0
  5882
					break;
sl@0
  5883
					}
sl@0
  5884
				StartTimer(KMicroSecsTwoSec);
sl@0
  5885
				INFO_PRINTF1(_L("DevSound State: EStatePlaying"));
sl@0
  5886
				iDevSoundState = EStatePlaying;
sl@0
  5887
				}
sl@0
  5888
			else if (aDevSoundEvent == EEventInitComplete && aError != KErrNone)
sl@0
  5889
				{
sl@0
  5890
				ERR_PRINTF2(_L("DevSound called CMMFDevSound::InitializeComplete with error = %d"), aError);
sl@0
  5891
				StopTest(aError);
sl@0
  5892
				}
sl@0
  5893
			else
sl@0
  5894
				{
sl@0
  5895
				ERR_PRINTF2(_L("DevSound EEventInitComplete not received as expected. Received event: %d"), aDevSoundEvent);
sl@0
  5896
				StopTest(aError, EFail);
sl@0
  5897
				}
sl@0
  5898
			break;
sl@0
  5899
			}
sl@0
  5900
		case EStatePlaying:
sl@0
  5901
			{
sl@0
  5902
			if(aDevSoundEvent == EEventTimerComplete)
sl@0
  5903
				{
sl@0
  5904
				INFO_PRINTF1(_L("Starting lower priority devsound client"));
sl@0
  5905
				iDevsoundToneClient->SetPriority(KMinimumPriority);
sl@0
  5906
				TInt err = iDevsoundToneClient->InitTonePlay(iFrequencyTone1, iDuration*KMicroSecsInOneSec);
sl@0
  5907
				if(err != KErrNone)
sl@0
  5908
					{
sl@0
  5909
					ERR_PRINTF1(_L("Initialization to play tone thru second devsound client failed"));
sl@0
  5910
					StopTest(err);
sl@0
  5911
					}
sl@0
  5912
				}
sl@0
  5913
			break;
sl@0
  5914
			}
sl@0
  5915
		default:
sl@0
  5916
			{
sl@0
  5917
			ERR_PRINTF2(_L("Invalid DevSound state received: %d"), iDevSoundState);
sl@0
  5918
			StopTest(aError, EFail);
sl@0
  5919
			}
sl@0
  5920
		}
sl@0
  5921
	}
sl@0
  5922
sl@0
  5923
void RA3FDevSoundToneRejectionTest::DoTimerCallback()
sl@0
  5924
	{
sl@0
  5925
	INFO_PRINTF1(_L("TimerEvent called"));
sl@0
  5926
	iTimer->Cancel();
sl@0
  5927
	INFO_PRINTF1(_L("DevSound Event: EEventTimerComplete"));
sl@0
  5928
	Fsm(EEventTimerComplete, KErrNone);
sl@0
  5929
	}
sl@0
  5930
sl@0
  5931
void RA3FDevSoundToneRejectionTest::ToneFinished(TInt aError)
sl@0
  5932
	{
sl@0
  5933
	INFO_PRINTF1(_L("========== DevSound ToneFinished() callback =========="));
sl@0
  5934
	if (aError == KErrUnderflow)
sl@0
  5935
		{
sl@0
  5936
		INFO_PRINTF2(_L("First DevSound instance called ToneFinished with error = %d"), aError);
sl@0
  5937
		StopTest(aError,EPass);
sl@0
  5938
		}
sl@0
  5939
	else
sl@0
  5940
		{
sl@0
  5941
		ERR_PRINTF2(_L("First DevSound instance called ToneFinished with error = %d that was NOT expected"), aError);
sl@0
  5942
		ERR_PRINTF2(_L("Expected error = %d"), aError);
sl@0
  5943
		StopTest(aError, EFail);
sl@0
  5944
		}
sl@0
  5945
	}
sl@0
  5946
sl@0
  5947
sl@0
  5948
void RA3FDevSoundToneRejectionTest::ClientInitializeCompleteCallback(TInt aError)
sl@0
  5949
	{
sl@0
  5950
	INFO_PRINTF1(_L("========== Second Client DevSound InitializeComplete() callback =========="));
sl@0
  5951
	if (aError != KErrNone)
sl@0
  5952
		{
sl@0
  5953
		ERR_PRINTF2(_L("Second Devsound InitializeComplete received an error = %d"), aError);
sl@0
  5954
		StopTest(aError);
sl@0
  5955
		}
sl@0
  5956
	else
sl@0
  5957
		{
sl@0
  5958
		INFO_PRINTF1(_L("Starting to play audio thru second devsound client"));
sl@0
  5959
		TInt err = iDevsoundToneClient->PlayTone();
sl@0
  5960
		if (err != KErrNone)
sl@0
  5961
			{
sl@0
  5962
			ERR_PRINTF2(_L("Starting to play tones thru second devsound client left with error = %d"), err);
sl@0
  5963
			StopTest(err);
sl@0
  5964
			}
sl@0
  5965
		}
sl@0
  5966
	}
sl@0
  5967
sl@0
  5968
void RA3FDevSoundToneRejectionTest::ClientToneFinishedCallback(TInt aError)
sl@0
  5969
	{
sl@0
  5970
	INFO_PRINTF1(_L("========== DevSound ToneFinished() callback =========="));
sl@0
  5971
	if (aError == KErrInUse || aError == KErrDied || aError == KErrAccessDenied)
sl@0
  5972
		{
sl@0
  5973
		INFO_PRINTF1(_L("========== Rejection 2nd DevSound Instance=========="));
sl@0
  5974
		}
sl@0
  5975
	else
sl@0
  5976
		{
sl@0
  5977
		ERR_PRINTF2(_L("Second DevSound client called ToneFinished() and failed with error = %d "), aError);
sl@0
  5978
		ERR_PRINTF4(_L("Expected posibilities %d %d %d "), KErrInUse, KErrDied, KErrAccessDenied);
sl@0
  5979
		StopTest(aError, EFail);
sl@0
  5980
		}
sl@0
  5981
	}
sl@0
  5982
sl@0
  5983
/*
sl@0
  5984
 *========================================================================================================
sl@0
  5985
 * MM-A3F-DEVSOUND-CHRTZ-TONE-0043
sl@0
  5986
 */
sl@0
  5987
RA3FDevSoundTonePlayToneOnceAndStopTest::RA3FDevSoundTonePlayToneOnceAndStopTest(const TDesC& aTestName)
sl@0
  5988
	:	RA3FDevSoundTestBase(aTestName),
sl@0
  5989
		iDuration(0), iFrequencyTone1(0),
sl@0
  5990
		iToneStopped(EFalse)
sl@0
  5991
	{
sl@0
  5992
	}
sl@0
  5993
sl@0
  5994
RA3FDevSoundTonePlayToneOnceAndStopTest* RA3FDevSoundTonePlayToneOnceAndStopTest::NewL(const TDesC& aTestName)
sl@0
  5995
	{
sl@0
  5996
	RA3FDevSoundTonePlayToneOnceAndStopTest * self = new(ELeave)RA3FDevSoundTonePlayToneOnceAndStopTest(aTestName);
sl@0
  5997
	return self;
sl@0
  5998
	}
sl@0
  5999
sl@0
  6000
void RA3FDevSoundTonePlayToneOnceAndStopTest::DoKickoffTestL()
sl@0
  6001
	{
sl@0
  6002
	if (!GetIntFromConfig(iTestStepName, KDuration, iDuration))
sl@0
  6003
		{
sl@0
  6004
		ERR_PRINTF2(KMsgErrorGetParameter, &KDuration);
sl@0
  6005
		StopTest(KErrNotFound);
sl@0
  6006
		return;
sl@0
  6007
		}
sl@0
  6008
	if (!GetIntFromConfig(iTestStepName, KFrequencyTone1, iFrequencyTone1))
sl@0
  6009
		{
sl@0
  6010
		ERR_PRINTF2(KMsgErrorGetParameter, &KFrequencyTone1);
sl@0
  6011
		StopTest(KErrNotFound);
sl@0
  6012
		return;
sl@0
  6013
		}
sl@0
  6014
	iTimer = CPeriodic::NewL(CActive::EPriorityHigh);
sl@0
  6015
	}
sl@0
  6016
sl@0
  6017
void RA3FDevSoundTonePlayToneOnceAndStopTest::Fsm(TMmfDevSoundEvent aDevSoundEvent, TInt aError)
sl@0
  6018
	{
sl@0
  6019
	switch (iDevSoundState)
sl@0
  6020
		{
sl@0
  6021
		case EStateCreated:
sl@0
  6022
			{
sl@0
  6023
			__ASSERT_ALWAYS((aError == KErrNone), Panic(_L("RA3FDevSoundTonePlayToneOnceAndStopTest"), EFsmIncorrectErrorPassed));
sl@0
  6024
			if (aDevSoundEvent == EEventInitialize)
sl@0
  6025
				{
sl@0
  6026
				INFO_PRINTF1(_L("Calling CMMFDevSound::InitializeL"));
sl@0
  6027
				TRAPD(err, iMMFDevSound->InitializeL(*this,  EMMFStateTonePlaying));
sl@0
  6028
				if (err != KErrNone)
sl@0
  6029
					{
sl@0
  6030
					ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"),  err);
sl@0
  6031
					StopTest(err);
sl@0
  6032
					break;
sl@0
  6033
					}
sl@0
  6034
				INFO_PRINTF1(_L("DevSound State: EStateInitializing"));
sl@0
  6035
				iDevSoundState = EStateInitializing;
sl@0
  6036
				}
sl@0
  6037
			else
sl@0
  6038
				{
sl@0
  6039
				ERR_PRINTF2(_L("DevSound EEventInitialize not received as expected. Received event: %d"), aDevSoundEvent);
sl@0
  6040
				StopTest(aError, EFail);
sl@0
  6041
				}
sl@0
  6042
			break;
sl@0
  6043
			}
sl@0
  6044
		case EStateInitializing:
sl@0
  6045
			{
sl@0
  6046
			if (aDevSoundEvent == EEventInitComplete && aError == KErrNone)
sl@0
  6047
				{
sl@0
  6048
				if (!iToneStopped)
sl@0
  6049
					{
sl@0
  6050
					iMMFDevSound->SetVolume(iMMFDevSound->MaxVolume());
sl@0
  6051
					INFO_PRINTF3(_L("Calling CMMFDevSound::PlayToneL using %d Hz during %d secs "), iFrequencyTone1, iDuration);
sl@0
  6052
					TRAPD(err, iMMFDevSound->PlayToneL(iFrequencyTone1, iDuration*KMicroSecsInOneSec));
sl@0
  6053
					if (err != KErrNone)
sl@0
  6054
						{
sl@0
  6055
						ERR_PRINTF2(_L("CMMFDevSound::PlayToneL left with error : %d!"), err);
sl@0
  6056
						StopTest(err);
sl@0
  6057
						break;
sl@0
  6058
						}
sl@0
  6059
					StartTimer(KMicroSecsTwoSec);
sl@0
  6060
					INFO_PRINTF1(_L("DevSound State: EStatePlaying"));
sl@0
  6061
					iDevSoundState = EStatePlaying;
sl@0
  6062
					}
sl@0
  6063
				else
sl@0
  6064
					{
sl@0
  6065
					INFO_PRINTF1(_L("Calling CMMFDevSound::Stop succeeded"));
sl@0
  6066
					StopTest(aError);
sl@0
  6067
					}
sl@0
  6068
				}
sl@0
  6069
			else if (aDevSoundEvent == EEventInitComplete && aError != KErrNone)
sl@0
  6070
				{
sl@0
  6071
				ERR_PRINTF2(_L("DevSound called CMMFDevSound::InitializeComplete with error = %d"), aError);
sl@0
  6072
				StopTest(aError);
sl@0
  6073
				}
sl@0
  6074
			else
sl@0
  6075
				{
sl@0
  6076
				ERR_PRINTF2(_L("DevSound EEventInitComplete not received as expected. Received event: %d"), aDevSoundEvent);
sl@0
  6077
				StopTest(aError, EFail);
sl@0
  6078
				}
sl@0
  6079
			break;
sl@0
  6080
			}
sl@0
  6081
		case EStatePlaying:
sl@0
  6082
			{
sl@0
  6083
			if(aDevSoundEvent == EEventTimerComplete)
sl@0
  6084
				{
sl@0
  6085
				INFO_PRINTF1(_L("Calling CMMFDevSound::Stop"));
sl@0
  6086
				iMMFDevSound->Stop();
sl@0
  6087
				}
sl@0
  6088
			else
sl@0
  6089
				{
sl@0
  6090
				ERR_PRINTF2(_L("DevSound EEventTimerComplete not received as expected. Received event: %d"), aDevSoundEvent);
sl@0
  6091
				StopTest(aError, EFail);
sl@0
  6092
				}
sl@0
  6093
			break;
sl@0
  6094
			}
sl@0
  6095
		default:
sl@0
  6096
			{
sl@0
  6097
			ERR_PRINTF2(_L("Invalid DevSound state received: %d"), iDevSoundState);
sl@0
  6098
			StopTest(aError, EFail);
sl@0
  6099
			}
sl@0
  6100
		}
sl@0
  6101
sl@0
  6102
	}
sl@0
  6103
sl@0
  6104
void RA3FDevSoundTonePlayToneOnceAndStopTest::DoTimerCallback()
sl@0
  6105
	{
sl@0
  6106
	INFO_PRINTF1(_L("TimerEvent called"));
sl@0
  6107
	INFO_PRINTF1(_L("DevSound Event: EEventTimerComplete"));
sl@0
  6108
	if(!iToneStopped)
sl@0
  6109
		{
sl@0
  6110
		Fsm(EEventTimerComplete, KErrNone);
sl@0
  6111
		iToneStopped = ETrue;
sl@0
  6112
		}
sl@0
  6113
	else
sl@0
  6114
		{
sl@0
  6115
		iTimer->Cancel();
sl@0
  6116
		INFO_PRINTF1(_L("Calling CMMFDevSound::InitializeL"));
sl@0
  6117
		TRAPD(err, iMMFDevSound->InitializeL(*this, EMMFStateTonePlaying));
sl@0
  6118
		if (err != KErrNone)
sl@0
  6119
			{
sl@0
  6120
			ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"),  err);
sl@0
  6121
			ERR_PRINTF2(_L("Expected error = %d"), KErrNone);
sl@0
  6122
			StopTest(err);
sl@0
  6123
			}
sl@0
  6124
		INFO_PRINTF1(_L("DevSound State: EStateInitializing"));
sl@0
  6125
		iDevSoundState = EStateInitializing;
sl@0
  6126
		}
sl@0
  6127
	}
sl@0
  6128
sl@0
  6129
void RA3FDevSoundTonePlayToneOnceAndStopTest::ToneFinished(TInt aError)
sl@0
  6130
	{
sl@0
  6131
	INFO_PRINTF1(_L("========== DevSound ToneFinished() callback =========="));
sl@0
  6132
	ERR_PRINTF1(_L("DevSound should not have called ToneFinished because it is supposed to have been stopped"));
sl@0
  6133
	StopTest(aError, EFail);
sl@0
  6134
	}
sl@0
  6135
sl@0
  6136
sl@0
  6137
/*
sl@0
  6138
 *========================================================================================================
sl@0
  6139
 * MM-A3F-DEVSOUND-CHRTZ-TONE-0044
sl@0
  6140
 */
sl@0
  6141
RA3FDevSoundTonePlayDualToneOnceAndStopTest::RA3FDevSoundTonePlayDualToneOnceAndStopTest(const TDesC& aTestName)
sl@0
  6142
	:	RA3FDevSoundTestBase(aTestName),
sl@0
  6143
		iDuration(0), iFrequencyTone1(0),
sl@0
  6144
		iFrequencyTone2(0), iToneStopped(EFalse)
sl@0
  6145
	{
sl@0
  6146
	}
sl@0
  6147
sl@0
  6148
RA3FDevSoundTonePlayDualToneOnceAndStopTest* RA3FDevSoundTonePlayDualToneOnceAndStopTest::NewL(const TDesC& aTestName)
sl@0
  6149
	{
sl@0
  6150
	RA3FDevSoundTonePlayDualToneOnceAndStopTest * self = new(ELeave)RA3FDevSoundTonePlayDualToneOnceAndStopTest(aTestName);
sl@0
  6151
	return self;
sl@0
  6152
	}
sl@0
  6153
sl@0
  6154
void RA3FDevSoundTonePlayDualToneOnceAndStopTest::DoKickoffTestL()
sl@0
  6155
	{
sl@0
  6156
	if (!GetIntFromConfig(iTestStepName, KDuration, iDuration))
sl@0
  6157
		{
sl@0
  6158
		ERR_PRINTF2(KMsgErrorGetParameter, &KDuration);
sl@0
  6159
		StopTest(KErrNotFound);
sl@0
  6160
		return;
sl@0
  6161
		}
sl@0
  6162
	if (!GetIntFromConfig(iTestStepName, KFrequencyTone1, iFrequencyTone1))
sl@0
  6163
		{
sl@0
  6164
		ERR_PRINTF2(KMsgErrorGetParameter, &KFrequencyTone1);
sl@0
  6165
		StopTest(KErrNotFound);
sl@0
  6166
		return;
sl@0
  6167
		}
sl@0
  6168
	if (!GetIntFromConfig(iTestStepName, KFrequencyTone2, iFrequencyTone2))
sl@0
  6169
		{
sl@0
  6170
		ERR_PRINTF2(KMsgErrorGetParameter, &KFrequencyTone2);
sl@0
  6171
		StopTest(KErrNotFound);
sl@0
  6172
		return;
sl@0
  6173
		}
sl@0
  6174
	iTimer = CPeriodic::NewL(CActive::EPriorityHigh);
sl@0
  6175
	}
sl@0
  6176
sl@0
  6177
void RA3FDevSoundTonePlayDualToneOnceAndStopTest::Fsm(TMmfDevSoundEvent aDevSoundEvent, TInt aError)
sl@0
  6178
	{
sl@0
  6179
	switch (iDevSoundState)
sl@0
  6180
		{
sl@0
  6181
		case EStateCreated:
sl@0
  6182
			{
sl@0
  6183
			__ASSERT_ALWAYS((aError == KErrNone), Panic(_L("RA3FDevSoundTonePlayDualToneOnceAndStopTest"), EFsmIncorrectErrorPassed));
sl@0
  6184
			if (aDevSoundEvent == EEventInitialize)
sl@0
  6185
				{
sl@0
  6186
				INFO_PRINTF1(_L("Calling CMMFDevSound::InitializeL"));
sl@0
  6187
				TRAPD(err, iMMFDevSound->InitializeL(*this, EMMFStateTonePlaying));
sl@0
  6188
				if (err != KErrNone)
sl@0
  6189
					{
sl@0
  6190
					ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"),  err);
sl@0
  6191
					StopTest(err);
sl@0
  6192
					break;
sl@0
  6193
					}
sl@0
  6194
				INFO_PRINTF1(_L("DevSound State: EStateInitializing"));
sl@0
  6195
				iDevSoundState = EStateInitializing;
sl@0
  6196
				}
sl@0
  6197
			else
sl@0
  6198
				{
sl@0
  6199
				ERR_PRINTF2(_L("DevSound EEventInitialize not received as expected. Received event: %d"), aDevSoundEvent);
sl@0
  6200
				StopTest(aError, EFail);
sl@0
  6201
				}
sl@0
  6202
			break;
sl@0
  6203
			}
sl@0
  6204
		case EStateInitializing:
sl@0
  6205
			{
sl@0
  6206
			if (aDevSoundEvent == EEventInitComplete && aError == KErrNone)
sl@0
  6207
				{
sl@0
  6208
				if (!iToneStopped)
sl@0
  6209
					{
sl@0
  6210
					iMMFDevSound->SetVolume(iMMFDevSound->MaxVolume());
sl@0
  6211
					INFO_PRINTF4(_L("Calling CMMFDevSound::PlayDualToneL using %d Hz %d Hz during %d secs "), iFrequencyTone1, iFrequencyTone2, iDuration);
sl@0
  6212
					TRAPD(err, iMMFDevSound->PlayDualToneL(iFrequencyTone1, iFrequencyTone2, iDuration*KMicroSecsInOneSec));
sl@0
  6213
					if (err != KErrNone)
sl@0
  6214
						{
sl@0
  6215
						ERR_PRINTF2(_L("CMMFDevSound::PlayDualToneL left with error = %d!"),  err);
sl@0
  6216
						StopTest(err);
sl@0
  6217
						break;
sl@0
  6218
						}
sl@0
  6219
					StartTimer(KMicroSecsTwoSec);
sl@0
  6220
					INFO_PRINTF1(_L("DevSound State: EStatePlaying"));
sl@0
  6221
					iDevSoundState = EStatePlaying;
sl@0
  6222
					}
sl@0
  6223
				else
sl@0
  6224
					{
sl@0
  6225
					INFO_PRINTF1(_L("Calling CMMFDevSound::Stop succeeded"));
sl@0
  6226
					StopTest(aError);
sl@0
  6227
					}
sl@0
  6228
				}
sl@0
  6229
			else if (aDevSoundEvent == EEventInitComplete && aError != KErrNone)
sl@0
  6230
				{
sl@0
  6231
				ERR_PRINTF2(_L("DevSound called CMMFDevSound::InitializeComplete with error = %d"), aError);
sl@0
  6232
				StopTest(aError);
sl@0
  6233
				}
sl@0
  6234
			else
sl@0
  6235
				{
sl@0
  6236
				ERR_PRINTF2(_L("DevSound EEventInitComplete not received as expected. Received event: %d"), aDevSoundEvent);
sl@0
  6237
				StopTest(aError, EFail);
sl@0
  6238
				}
sl@0
  6239
			break;
sl@0
  6240
			}
sl@0
  6241
		case EStatePlaying:
sl@0
  6242
			{
sl@0
  6243
			if(aDevSoundEvent == EEventTimerComplete)
sl@0
  6244
				{
sl@0
  6245
				INFO_PRINTF1(_L("Calling CMMFDevSound::Stop"));
sl@0
  6246
				iMMFDevSound->Stop();
sl@0
  6247
				}
sl@0
  6248
			else
sl@0
  6249
				{
sl@0
  6250
				ERR_PRINTF2(_L("DevSound EEventTimerComplete not received as expected. Received event: %d"), aDevSoundEvent);
sl@0
  6251
				StopTest(aError, EFail);
sl@0
  6252
				}
sl@0
  6253
			break;
sl@0
  6254
			}
sl@0
  6255
		default:
sl@0
  6256
			{
sl@0
  6257
			ERR_PRINTF2(_L("Invalid DevSound state received: %d"), iDevSoundState);
sl@0
  6258
			StopTest(aError, EFail);
sl@0
  6259
			}
sl@0
  6260
		}
sl@0
  6261
	}
sl@0
  6262
sl@0
  6263
void RA3FDevSoundTonePlayDualToneOnceAndStopTest::DoTimerCallback()
sl@0
  6264
	{
sl@0
  6265
	INFO_PRINTF1(_L("TimerEvent called"));
sl@0
  6266
	INFO_PRINTF1(_L("DevSound Event: EEventTimerComplete"));
sl@0
  6267
	if(!iToneStopped)
sl@0
  6268
		{
sl@0
  6269
		Fsm(EEventTimerComplete, KErrNone);
sl@0
  6270
		iToneStopped = ETrue;
sl@0
  6271
		}
sl@0
  6272
	else
sl@0
  6273
		{
sl@0
  6274
		iTimer->Cancel();
sl@0
  6275
		INFO_PRINTF1(_L("Calling CMMFDevSound::InitializeL"));
sl@0
  6276
		TRAPD(err, iMMFDevSound->InitializeL(*this, EMMFStateTonePlaying));
sl@0
  6277
		if (err != KErrNone)
sl@0
  6278
			{
sl@0
  6279
			ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"),  err);
sl@0
  6280
			ERR_PRINTF2(_L("Expected error = %d"), KErrNone);
sl@0
  6281
			StopTest(err);
sl@0
  6282
			}
sl@0
  6283
		INFO_PRINTF1(_L("DevSound State: EStateInitializing"));
sl@0
  6284
		iDevSoundState = EStateInitializing;
sl@0
  6285
		}
sl@0
  6286
	}
sl@0
  6287
sl@0
  6288
void RA3FDevSoundTonePlayDualToneOnceAndStopTest::ToneFinished(TInt aError)
sl@0
  6289
	{
sl@0
  6290
	INFO_PRINTF1(_L("========== DevSound ToneFinished() callback =========="));
sl@0
  6291
	ERR_PRINTF1(_L("DevSound should not have called ToneFinished because it is supposed to have been stopped"));
sl@0
  6292
	StopTest(aError, EFail);
sl@0
  6293
	}
sl@0
  6294
sl@0
  6295
/*
sl@0
  6296
 *========================================================================================================
sl@0
  6297
 * MM-A3F-DEVSOUND-CHRTZ-TONE-0045
sl@0
  6298
 */
sl@0
  6299
RA3FDevSoundTonePlayDTMFStringOnceAndStopTest::RA3FDevSoundTonePlayDTMFStringOnceAndStopTest(const TDesC& aTestName)
sl@0
  6300
	:	RA3FDevSoundTestBase(aTestName),iDTMFString(KNullDesC),
sl@0
  6301
		iToneStopped(EFalse)
sl@0
  6302
	{
sl@0
  6303
	}
sl@0
  6304
sl@0
  6305
RA3FDevSoundTonePlayDTMFStringOnceAndStopTest* RA3FDevSoundTonePlayDTMFStringOnceAndStopTest::NewL(const TDesC& aTestName)
sl@0
  6306
	{
sl@0
  6307
	RA3FDevSoundTonePlayDTMFStringOnceAndStopTest * self = new(ELeave)RA3FDevSoundTonePlayDTMFStringOnceAndStopTest(aTestName);
sl@0
  6308
	return self;
sl@0
  6309
	}
sl@0
  6310
sl@0
  6311
void RA3FDevSoundTonePlayDTMFStringOnceAndStopTest::DoKickoffTestL()
sl@0
  6312
	{
sl@0
  6313
	TPtrC DTMF;
sl@0
  6314
	if ( !GetStringFromConfig(iTestStepName, KDTMFString, DTMF) )
sl@0
  6315
		{
sl@0
  6316
		ERR_PRINTF2(KMsgErrorGetParameter, &KDTMFString);
sl@0
  6317
		StopTest(KErrNotFound);
sl@0
  6318
		return;
sl@0
  6319
		}
sl@0
  6320
	iDTMFString.Copy(DTMF);
sl@0
  6321
	iTimer = CPeriodic::NewL(CActive::EPriorityHigh);
sl@0
  6322
	}
sl@0
  6323
sl@0
  6324
void RA3FDevSoundTonePlayDTMFStringOnceAndStopTest::Fsm(TMmfDevSoundEvent aDevSoundEvent, TInt aError)
sl@0
  6325
	{
sl@0
  6326
	switch(iDevSoundState)
sl@0
  6327
		{
sl@0
  6328
		case EStateCreated:
sl@0
  6329
			{
sl@0
  6330
			__ASSERT_ALWAYS((aError == KErrNone), Panic(_L("RA3FDevSoundTonePlayDTMFStringOnceAndStopTest"), EFsmIncorrectErrorPassed));
sl@0
  6331
			if (aDevSoundEvent == EEventInitialize)
sl@0
  6332
				{
sl@0
  6333
				INFO_PRINTF1(_L("Calling CMMFDevSound::InitializeL"));
sl@0
  6334
				TRAPD(err, iMMFDevSound->InitializeL(*this, EMMFStateTonePlaying));
sl@0
  6335
				if (err != KErrNone)
sl@0
  6336
					{
sl@0
  6337
					ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"), err);
sl@0
  6338
					StopTest(err);
sl@0
  6339
					break;
sl@0
  6340
					}
sl@0
  6341
				INFO_PRINTF1(_L("DevSound State: EStateInitializing"));
sl@0
  6342
				iDevSoundState = EStateInitializing;
sl@0
  6343
				}
sl@0
  6344
			else
sl@0
  6345
				{
sl@0
  6346
				ERR_PRINTF2(_L("DevSound EEventInitialize not received as expected. Received event: %d"), aDevSoundEvent);
sl@0
  6347
				StopTest(aError, EFail);
sl@0
  6348
				}
sl@0
  6349
			break;
sl@0
  6350
			}
sl@0
  6351
		case EStateInitializing:
sl@0
  6352
			{
sl@0
  6353
			if (aDevSoundEvent == EEventInitComplete && aError == KErrNone)
sl@0
  6354
				{
sl@0
  6355
				if (!iToneStopped)
sl@0
  6356
					{
sl@0
  6357
					iMMFDevSound->SetVolume(iMMFDevSound->MaxVolume());
sl@0
  6358
					INFO_PRINTF2(_L("Calling CMMFDevSound::PlayDTMFStringL %S"), &iDTMFString);
sl@0
  6359
					TRAPD(err, iMMFDevSound->PlayDTMFStringL(iDTMFString));
sl@0
  6360
					if (err != KErrNone)
sl@0
  6361
						{
sl@0
  6362
						ERR_PRINTF2(_L("CMMFDevSound::PlayDTMFStringL left with error = %d"), err);
sl@0
  6363
						StopTest(err);
sl@0
  6364
						break;
sl@0
  6365
						}
sl@0
  6366
					StartTimer(KMicroSecsTwoSec);
sl@0
  6367
					INFO_PRINTF1(_L("DevSound State: EStatePlaying"));
sl@0
  6368
					iDevSoundState = EStatePlaying;
sl@0
  6369
					}
sl@0
  6370
				else
sl@0
  6371
					{
sl@0
  6372
					INFO_PRINTF1(_L("Calling CMMFDevSound::Stop succeeded"));
sl@0
  6373
					StopTest(aError);
sl@0
  6374
					}
sl@0
  6375
				}
sl@0
  6376
			else if (aDevSoundEvent == EEventInitComplete && aError != KErrNone)
sl@0
  6377
				{
sl@0
  6378
				ERR_PRINTF2(_L("DevSound called CMMFDevSound::InitializeComplete with error = %d"), aError);
sl@0
  6379
				StopTest(aError);
sl@0
  6380
				}
sl@0
  6381
			else
sl@0
  6382
				{
sl@0
  6383
				ERR_PRINTF2(_L("DevSound EEventInitComplete not received as expected. Received event: %d"), aDevSoundEvent);
sl@0
  6384
				StopTest(aError, EFail);
sl@0
  6385
				}
sl@0
  6386
			break;
sl@0
  6387
			}
sl@0
  6388
		case EStatePlaying:
sl@0
  6389
			{
sl@0
  6390
			if(aDevSoundEvent == EEventTimerComplete)
sl@0
  6391
				{
sl@0
  6392
				INFO_PRINTF1(_L("Calling CMMFDevSound::Stop"));
sl@0
  6393
				iMMFDevSound->Stop();
sl@0
  6394
				}
sl@0
  6395
			else
sl@0
  6396
				{
sl@0
  6397
				ERR_PRINTF2(_L("DevSound EEventTimerComplete not received as expected. Received event: %d"), aDevSoundEvent);
sl@0
  6398
				StopTest(aError, EFail);
sl@0
  6399
				}
sl@0
  6400
			break;
sl@0
  6401
			}
sl@0
  6402
		default:
sl@0
  6403
			{
sl@0
  6404
			ERR_PRINTF2(_L("Invalid DevSound state received: %d"), iDevSoundState);
sl@0
  6405
			StopTest(aError, EFail);
sl@0
  6406
			}
sl@0
  6407
		}
sl@0
  6408
	}
sl@0
  6409
sl@0
  6410
void RA3FDevSoundTonePlayDTMFStringOnceAndStopTest::DoTimerCallback()
sl@0
  6411
	{
sl@0
  6412
	INFO_PRINTF1(_L("TimerEvent called"));
sl@0
  6413
	INFO_PRINTF1(_L("DevSound Event: EEventTimerComplete"));
sl@0
  6414
	if(!iToneStopped)
sl@0
  6415
		{
sl@0
  6416
		Fsm(EEventTimerComplete, KErrNone);
sl@0
  6417
		iToneStopped = ETrue;
sl@0
  6418
		}
sl@0
  6419
	else
sl@0
  6420
		{
sl@0
  6421
		iTimer->Cancel();
sl@0
  6422
		INFO_PRINTF1(_L("Calling CMMFDevSound::InitializeL"));
sl@0
  6423
		TRAPD(err, iMMFDevSound->InitializeL(*this, EMMFStateTonePlaying));
sl@0
  6424
		if (err != KErrNone)
sl@0
  6425
			{
sl@0
  6426
			ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"),  err);
sl@0
  6427
			ERR_PRINTF2(_L("Expected error = %d"), KErrNone);
sl@0
  6428
			StopTest(err);
sl@0
  6429
			}
sl@0
  6430
		INFO_PRINTF1(_L("DevSound State: EStateInitializing"));
sl@0
  6431
		iDevSoundState = EStateInitializing;
sl@0
  6432
		}
sl@0
  6433
	}
sl@0
  6434
sl@0
  6435
void RA3FDevSoundTonePlayDTMFStringOnceAndStopTest::ToneFinished(TInt aError)
sl@0
  6436
	{
sl@0
  6437
	INFO_PRINTF1(_L("========== DevSound ToneFinished() callback =========="));
sl@0
  6438
	ERR_PRINTF1(_L("DevSound should not have called ToneFinished because it is supposed to have been stopped"));
sl@0
  6439
	StopTest(aError, EFail);
sl@0
  6440
	}
sl@0
  6441
/*
sl@0
  6442
 *========================================================================================================
sl@0
  6443
 * MM-A3F-DEVSOUND-CHRTZ-TONE-0046
sl@0
  6444
 */
sl@0
  6445
RA3FDevSoundTonePlayToneSequenceOnceAndStopTest::RA3FDevSoundTonePlayToneSequenceOnceAndStopTest(const TDesC& aTestName)
sl@0
  6446
	:	RA3FDevSoundTestBase(aTestName), iToneStopped(EFalse)
sl@0
  6447
	{
sl@0
  6448
	}
sl@0
  6449
sl@0
  6450
RA3FDevSoundTonePlayToneSequenceOnceAndStopTest* RA3FDevSoundTonePlayToneSequenceOnceAndStopTest::NewL(const TDesC& aTestName)
sl@0
  6451
	{
sl@0
  6452
	RA3FDevSoundTonePlayToneSequenceOnceAndStopTest * self = new(ELeave)RA3FDevSoundTonePlayToneSequenceOnceAndStopTest(aTestName);
sl@0
  6453
	return self;
sl@0
  6454
	}
sl@0
  6455
sl@0
  6456
void RA3FDevSoundTonePlayToneSequenceOnceAndStopTest::DoKickoffTestL()
sl@0
  6457
	{
sl@0
  6458
	iTimer = CPeriodic::NewL(CActive::EPriorityHigh);
sl@0
  6459
	}
sl@0
  6460
sl@0
  6461
void RA3FDevSoundTonePlayToneSequenceOnceAndStopTest::Fsm(TMmfDevSoundEvent aDevSoundEvent, TInt aError)
sl@0
  6462
	{
sl@0
  6463
	switch (iDevSoundState)
sl@0
  6464
		{
sl@0
  6465
		case EStateCreated:
sl@0
  6466
			{
sl@0
  6467
			__ASSERT_ALWAYS((aError == KErrNone), Panic(_L("RA3FDevSoundTonePlayToneSequenceOnceAndStopTest"), EFsmIncorrectErrorPassed));
sl@0
  6468
			if (aDevSoundEvent == EEventInitialize)
sl@0
  6469
				{
sl@0
  6470
				INFO_PRINTF1(_L("Calling CMMFDevSound::InitializeL"));
sl@0
  6471
				TRAPD(err, iMMFDevSound->InitializeL(*this, EMMFStateTonePlaying));
sl@0
  6472
				if (err != KErrNone)
sl@0
  6473
					{
sl@0
  6474
					ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"),  err);
sl@0
  6475
					StopTest(err);
sl@0
  6476
					break;
sl@0
  6477
					}
sl@0
  6478
				INFO_PRINTF1(_L("DevSound State: EStateInitializing"));
sl@0
  6479
				iDevSoundState = EStateInitializing;
sl@0
  6480
				}
sl@0
  6481
			else
sl@0
  6482
				{
sl@0
  6483
				ERR_PRINTF2(_L("DevSound EEventInitialize not received as expected. Received event: %d"), aDevSoundEvent);
sl@0
  6484
				StopTest(aError, EFail);
sl@0
  6485
				}
sl@0
  6486
			break;
sl@0
  6487
			}
sl@0
  6488
		case EStateInitializing:
sl@0
  6489
			{
sl@0
  6490
			if (aDevSoundEvent == EEventInitComplete && aError == KErrNone)
sl@0
  6491
				{
sl@0
  6492
				if (!iToneStopped)
sl@0
  6493
					{
sl@0
  6494
					iMMFDevSound->SetVolume(iMMFDevSound->MaxVolume());
sl@0
  6495
					TUint8* tablePointer = const_cast<TUint8*>( &(KFixedSequenceTestSequenceDataX[0]));
sl@0
  6496
					TPtrC8 KFixedSequenceData(tablePointer,  sizeof(KFixedSequenceTestSequenceDataX));
sl@0
  6497
					INFO_PRINTF1(_L("Calling CMMFDevSound::PlayToneSequenceL"));
sl@0
  6498
					TRAPD(err, iMMFDevSound->PlayToneSequenceL(KFixedSequenceData));
sl@0
  6499
					if (err != KErrNone)
sl@0
  6500
						{
sl@0
  6501
						ERR_PRINTF2(_L("CMMFDevSound::PlayToneSequenceL left with error = %d!"), err);
sl@0
  6502
						StopTest(err);
sl@0
  6503
						break;
sl@0
  6504
						}
sl@0
  6505
					StartTimer(KMicroSecsTwoSec);
sl@0
  6506
					INFO_PRINTF1(_L("DevSound State: EStatePlaying"));
sl@0
  6507
					iDevSoundState = EStatePlaying;
sl@0
  6508
					}
sl@0
  6509
				else
sl@0
  6510
					{
sl@0
  6511
					INFO_PRINTF1(_L("Calling CMMFDevSound::Stop succeeded"));
sl@0
  6512
					StopTest(aError);
sl@0
  6513
					}
sl@0
  6514
sl@0
  6515
				}
sl@0
  6516
			else if (aDevSoundEvent == EEventInitComplete && aError != KErrNone)
sl@0
  6517
				{
sl@0
  6518
				ERR_PRINTF2(_L("DevSound called CMMFDevSound::InitializeComplete with error = %d"), aError);
sl@0
  6519
				StopTest(aError);
sl@0
  6520
				}
sl@0
  6521
			else
sl@0
  6522
				{
sl@0
  6523
				ERR_PRINTF2(_L("DevSound EEventInitComplete not received as expected. Received event: %d"), aDevSoundEvent);
sl@0
  6524
				StopTest(aError, EFail);
sl@0
  6525
				}
sl@0
  6526
			break;
sl@0
  6527
			}
sl@0
  6528
		case EStatePlaying:
sl@0
  6529
			{
sl@0
  6530
			if(aDevSoundEvent == EEventTimerComplete)
sl@0
  6531
				{
sl@0
  6532
				INFO_PRINTF1(_L("Calling CMMFDevSound::Stop"));
sl@0
  6533
				iMMFDevSound->Stop();
sl@0
  6534
				}
sl@0
  6535
			else
sl@0
  6536
				{
sl@0
  6537
				ERR_PRINTF2(_L("DevSound EEventTimerComplete not received as expected. Received event: %d"), aDevSoundEvent);
sl@0
  6538
				StopTest(aError, EFail);
sl@0
  6539
				}
sl@0
  6540
			break;
sl@0
  6541
			}
sl@0
  6542
		default:
sl@0
  6543
			{
sl@0
  6544
			ERR_PRINTF2(_L("Invalid DevSound state received: %d"),  iDevSoundState);
sl@0
  6545
			StopTest(aError, EFail);
sl@0
  6546
			}
sl@0
  6547
		}
sl@0
  6548
	}
sl@0
  6549
sl@0
  6550
void RA3FDevSoundTonePlayToneSequenceOnceAndStopTest::DoTimerCallback()
sl@0
  6551
	{
sl@0
  6552
	INFO_PRINTF1(_L("TimerEvent called"));
sl@0
  6553
	INFO_PRINTF1(_L("DevSound Event: EEventTimerComplete"));
sl@0
  6554
	if(!iToneStopped)
sl@0
  6555
		{
sl@0
  6556
		Fsm(EEventTimerComplete, KErrNone);
sl@0
  6557
		iToneStopped = ETrue;
sl@0
  6558
		}
sl@0
  6559
	else
sl@0
  6560
		{
sl@0
  6561
		iTimer->Cancel();
sl@0
  6562
		INFO_PRINTF1(_L("Calling CMMFDevSound::InitializeL"));
sl@0
  6563
		TRAPD(err, iMMFDevSound->InitializeL(*this, EMMFStateTonePlaying));
sl@0
  6564
		if (err != KErrNone)
sl@0
  6565
			{
sl@0
  6566
			ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"),  err);
sl@0
  6567
			ERR_PRINTF2(_L("Expected error = %d"), KErrNone);
sl@0
  6568
			StopTest(err);
sl@0
  6569
			}
sl@0
  6570
		INFO_PRINTF1(_L("DevSound State: EStateInitializing"));
sl@0
  6571
		iDevSoundState = EStateInitializing;
sl@0
  6572
		}
sl@0
  6573
	}
sl@0
  6574
sl@0
  6575
void RA3FDevSoundTonePlayToneSequenceOnceAndStopTest::ToneFinished(TInt aError)
sl@0
  6576
	{
sl@0
  6577
	INFO_PRINTF1(_L("========== DevSound ToneFinished() callback =========="));
sl@0
  6578
	ERR_PRINTF1(_L("DevSound should not have called ToneFinished because it is supposed to have been stopped"));
sl@0
  6579
	StopTest(aError, EFail);
sl@0
  6580
	}
sl@0
  6581
sl@0
  6582
/*
sl@0
  6583
 *========================================================================================================
sl@0
  6584
 * MM-A3F-DEVSOUND-CHRTZ-TONE-0047
sl@0
  6585
 */
sl@0
  6586
RA3FDevSoundTonePlayToneOncePauseTest::RA3FDevSoundTonePlayToneOncePauseTest(const TDesC& aTestName)
sl@0
  6587
	:	RA3FDevSoundTestBase(aTestName),iDuration(0),
sl@0
  6588
		iFrequencyTone1(0), iPaused(EFalse),
sl@0
  6589
		iSamplesPlayedPaused(0)
sl@0
  6590
	{
sl@0
  6591
	}
sl@0
  6592
sl@0
  6593
RA3FDevSoundTonePlayToneOncePauseTest* RA3FDevSoundTonePlayToneOncePauseTest::NewL(const TDesC& aTestName)
sl@0
  6594
	{
sl@0
  6595
	RA3FDevSoundTonePlayToneOncePauseTest * self = new(ELeave)RA3FDevSoundTonePlayToneOncePauseTest(aTestName);
sl@0
  6596
	return self;
sl@0
  6597
	}
sl@0
  6598
sl@0
  6599
void RA3FDevSoundTonePlayToneOncePauseTest::DoKickoffTestL()
sl@0
  6600
	{
sl@0
  6601
	if (!GetIntFromConfig(iTestStepName, KDuration, iDuration))
sl@0
  6602
		{
sl@0
  6603
		ERR_PRINTF2(KMsgErrorGetParameter, &KDuration);
sl@0
  6604
		StopTest(KErrNotFound);
sl@0
  6605
		return;
sl@0
  6606
		}
sl@0
  6607
	if (!GetIntFromConfig(iTestStepName, KFrequencyTone1, iFrequencyTone1))
sl@0
  6608
		{
sl@0
  6609
		ERR_PRINTF2(KMsgErrorGetParameter, &KFrequencyTone1);
sl@0
  6610
		StopTest(KErrNotFound);
sl@0
  6611
		return;
sl@0
  6612
		}
sl@0
  6613
	iTimer = CPeriodic::NewL(CActive::EPriorityHigh);
sl@0
  6614
	}
sl@0
  6615
sl@0
  6616
void RA3FDevSoundTonePlayToneOncePauseTest::Fsm(TMmfDevSoundEvent aDevSoundEvent,  TInt aError)
sl@0
  6617
	{
sl@0
  6618
	switch (iDevSoundState)
sl@0
  6619
		{
sl@0
  6620
		case EStateCreated:
sl@0
  6621
			{
sl@0
  6622
			__ASSERT_ALWAYS((aError == KErrNone), Panic(_L("RA3FDevSoundTonePlayToneOncePauseTest"), EFsmIncorrectErrorPassed));
sl@0
  6623
			if (aDevSoundEvent == EEventInitialize)
sl@0
  6624
				{
sl@0
  6625
				INFO_PRINTF1(_L("Calling CMMFDevSound::InitializeL"));
sl@0
  6626
				TRAPD(err, iMMFDevSound->InitializeL(*this, EMMFStateTonePlaying));
sl@0
  6627
				if (err != KErrNone)
sl@0
  6628
					{
sl@0
  6629
					ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"),  err);
sl@0
  6630
					StopTest(err);
sl@0
  6631
					break;
sl@0
  6632
					}
sl@0
  6633
				INFO_PRINTF1(_L("DevSound State: EStateInitializing"));
sl@0
  6634
				iDevSoundState = EStateInitializing;
sl@0
  6635
				}
sl@0
  6636
			else
sl@0
  6637
				{
sl@0
  6638
				ERR_PRINTF2(_L("DevSound EEventInitialize not received as expected. Received event: %d"), aDevSoundEvent);
sl@0
  6639
				StopTest(aError, EFail);
sl@0
  6640
				}
sl@0
  6641
			break;
sl@0
  6642
			}
sl@0
  6643
		case EStateInitializing:
sl@0
  6644
			{
sl@0
  6645
			if (aDevSoundEvent == EEventInitComplete && aError == KErrNone)
sl@0
  6646
				{
sl@0
  6647
				iMMFDevSound->SetVolume(iMMFDevSound->MaxVolume());
sl@0
  6648
				INFO_PRINTF3(_L("Calling CMMFDevSound::PlayToneL using %d Hz during %d secs "), iFrequencyTone1, iDuration);
sl@0
  6649
				TRAPD(err, iMMFDevSound->PlayToneL(iFrequencyTone1, iDuration*KMicroSecsInOneSec));
sl@0
  6650
				if (err != KErrNone)
sl@0
  6651
					{
sl@0
  6652
					ERR_PRINTF2(_L("CMMFDevSound::PlayToneL left with error = %d!"),  err);
sl@0
  6653
					StopTest(err);
sl@0
  6654
					break;
sl@0
  6655
					}
sl@0
  6656
				StartTimer(KMicroSecsTwoSec);
sl@0
  6657
				INFO_PRINTF1(_L("DevSound State: EStatePlaying"));
sl@0
  6658
				iDevSoundState = EStatePlaying;
sl@0
  6659
				}
sl@0
  6660
			else if (aDevSoundEvent == EEventInitComplete && aError != KErrNone)
sl@0
  6661
				{
sl@0
  6662
				ERR_PRINTF2(_L("DevSound called CMMFDevSound::InitializeComplete with error = %d"), aError);
sl@0
  6663
				StopTest(aError);
sl@0
  6664
				}
sl@0
  6665
			else
sl@0
  6666
				{
sl@0
  6667
				ERR_PRINTF2(_L("DevSound EEventInitComplete not received as expected. Received event: %d"),  aDevSoundEvent);
sl@0
  6668
				StopTest(aError, EFail);
sl@0
  6669
				}
sl@0
  6670
			break;
sl@0
  6671
			}
sl@0
  6672
		case EStatePlaying:
sl@0
  6673
			{
sl@0
  6674
			if(aDevSoundEvent == EEventTimerComplete)
sl@0
  6675
				{
sl@0
  6676
				INFO_PRINTF1(_L("Calling CMMFDevSound::Pause"));
sl@0
  6677
				iMMFDevSound->Pause();
sl@0
  6678
				INFO_PRINTF1(_L("DevSound State: EStatePause"));
sl@0
  6679
				iDevSoundState = EStatePause;
sl@0
  6680
				INFO_PRINTF1(_L("Calling CMMFDevSound::SamplesPlayed"));
sl@0
  6681
				iSamplesPlayedPaused = iMMFDevSound->SamplesPlayed();
sl@0
  6682
				INFO_PRINTF2(_L("The number of samples played is %d"), iSamplesPlayedPaused);
sl@0
  6683
				}
sl@0
  6684
			else
sl@0
  6685
				{
sl@0
  6686
				ERR_PRINTF2(_L("DevSound EEventTimerComplete not received as expected. Received event: %d"), aDevSoundEvent);
sl@0
  6687
				StopTest(aError, EFail);
sl@0
  6688
				}
sl@0
  6689
			break;
sl@0
  6690
			}
sl@0
  6691
		case EStatePause:
sl@0
  6692
			{
sl@0
  6693
			if (aDevSoundEvent == EEventTimerComplete)
sl@0
  6694
				{
sl@0
  6695
				TInt samplesPlayed = iMMFDevSound->SamplesPlayed();
sl@0
  6696
				if(iSamplesPlayedPaused == samplesPlayed)
sl@0
  6697
					{
sl@0
  6698
					INFO_PRINTF2(_L("After waiting a couple of seconds, the samples played are still being the same %d"), iSamplesPlayedPaused);
sl@0
  6699
					StopTest();
sl@0
  6700
					}
sl@0
  6701
				else
sl@0
  6702
					{
sl@0
  6703
					ERR_PRINTF2(_L("After waiting a couple of seconds, the samples played are not the same %d"), samplesPlayed);
sl@0
  6704
					ERR_PRINTF2(_L("Expected samples played = %d"), iSamplesPlayedPaused);
sl@0
  6705
					StopTest(aError,EFail);
sl@0
  6706
					}
sl@0
  6707
				}
sl@0
  6708
			else
sl@0
  6709
				{
sl@0
  6710
				ERR_PRINTF2(_L("EEventTimerComplete not received as expected. Received event: %d"), aDevSoundEvent);
sl@0
  6711
				StopTest(aError, EFail);
sl@0
  6712
				}
sl@0
  6713
			break;
sl@0
  6714
			}
sl@0
  6715
		default:
sl@0
  6716
			{
sl@0
  6717
			ERR_PRINTF2(_L("Invalid DevSound state received: %d"), iDevSoundState);
sl@0
  6718
			StopTest(aError, EFail);
sl@0
  6719
			}
sl@0
  6720
		}
sl@0
  6721
	}
sl@0
  6722
sl@0
  6723
void RA3FDevSoundTonePlayToneOncePauseTest::DoTimerCallback()
sl@0
  6724
	{
sl@0
  6725
	INFO_PRINTF1(_L("TimerEvent called"));
sl@0
  6726
	if (!iPaused)
sl@0
  6727
		{
sl@0
  6728
		INFO_PRINTF1(_L("DevSound Event: EEventTimerComplete"));
sl@0
  6729
		Fsm(EEventTimerComplete, KErrNone);
sl@0
  6730
		iPaused = ETrue;
sl@0
  6731
		}
sl@0
  6732
	else
sl@0
  6733
		{
sl@0
  6734
		iTimer->Cancel();
sl@0
  6735
		INFO_PRINTF1(_L("DevSound Event: EEventTimerComplete"));
sl@0
  6736
		Fsm(EEventTimerComplete, KErrNone);
sl@0
  6737
		}
sl@0
  6738
	}
sl@0
  6739
sl@0
  6740
void RA3FDevSoundTonePlayToneOncePauseTest::ToneFinished(TInt aError)
sl@0
  6741
	{
sl@0
  6742
	INFO_PRINTF1(_L("========== DevSound ToneFinished() callback =========="));
sl@0
  6743
	ERR_PRINTF1(_L("DevSound should not have called ToneFinished because it is supposed to be paused"));
sl@0
  6744
	StopTest(aError, EFail);
sl@0
  6745
	}
sl@0
  6746
sl@0
  6747
/*
sl@0
  6748
 *========================================================================================================
sl@0
  6749
 * MM-A3F-DEVSOUND-CHRTZ-TONE-0048
sl@0
  6750
 */
sl@0
  6751
RA3FDevSoundTonePlayDualToneOncePauseTest::RA3FDevSoundTonePlayDualToneOncePauseTest(const TDesC& aTestName)
sl@0
  6752
	:	RA3FDevSoundTestBase(aTestName),
sl@0
  6753
		iDuration(0),iFrequencyTone1(0),
sl@0
  6754
		iFrequencyTone2(0), iPaused(EFalse),
sl@0
  6755
		iSamplesPlayedPaused(0)
sl@0
  6756
	{
sl@0
  6757
	}
sl@0
  6758
sl@0
  6759
RA3FDevSoundTonePlayDualToneOncePauseTest* RA3FDevSoundTonePlayDualToneOncePauseTest::NewL(const TDesC& aTestName)
sl@0
  6760
	{
sl@0
  6761
	RA3FDevSoundTonePlayDualToneOncePauseTest * self = new(ELeave)RA3FDevSoundTonePlayDualToneOncePauseTest(aTestName);
sl@0
  6762
	return self;
sl@0
  6763
	}
sl@0
  6764
sl@0
  6765
void RA3FDevSoundTonePlayDualToneOncePauseTest::DoKickoffTestL()
sl@0
  6766
	{
sl@0
  6767
	if (!GetIntFromConfig(iTestStepName, KDuration, iDuration))
sl@0
  6768
		{
sl@0
  6769
		ERR_PRINTF2(KMsgErrorGetParameter, &KDuration);
sl@0
  6770
		StopTest(KErrNotFound);
sl@0
  6771
		return;
sl@0
  6772
		}
sl@0
  6773
	if (!GetIntFromConfig(iTestStepName, KFrequencyTone1, iFrequencyTone1))
sl@0
  6774
		{
sl@0
  6775
		ERR_PRINTF2(KMsgErrorGetParameter, &KFrequencyTone1);
sl@0
  6776
		StopTest(KErrNotFound);
sl@0
  6777
		return;
sl@0
  6778
		}
sl@0
  6779
	if (!GetIntFromConfig(iTestStepName, KFrequencyTone2, iFrequencyTone2))
sl@0
  6780
		{
sl@0
  6781
		ERR_PRINTF2(KMsgErrorGetParameter, &KFrequencyTone2);
sl@0
  6782
		StopTest(KErrNotFound);
sl@0
  6783
		return;
sl@0
  6784
		}
sl@0
  6785
	iTimer = CPeriodic::NewL(CActive::EPriorityHigh);
sl@0
  6786
	}
sl@0
  6787
sl@0
  6788
void RA3FDevSoundTonePlayDualToneOncePauseTest::Fsm(TMmfDevSoundEvent aDevSoundEvent, TInt aError)
sl@0
  6789
	{
sl@0
  6790
	switch (iDevSoundState)
sl@0
  6791
		{
sl@0
  6792
		case EStateCreated:
sl@0
  6793
			{
sl@0
  6794
			__ASSERT_ALWAYS((aError == KErrNone), Panic(_L("RA3FDevSoundTonePlayDualToneOncePauseTest"), EFsmIncorrectErrorPassed));
sl@0
  6795
			if (aDevSoundEvent == EEventInitialize)
sl@0
  6796
				{
sl@0
  6797
				INFO_PRINTF1(_L("Calling CMMFDevSound::InitializeL"));
sl@0
  6798
				TRAPD(err, iMMFDevSound->InitializeL(*this,  EMMFStateTonePlaying));
sl@0
  6799
				if (err != KErrNone)
sl@0
  6800
					{
sl@0
  6801
					ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"), err);
sl@0
  6802
					StopTest(err);
sl@0
  6803
					break;
sl@0
  6804
					}
sl@0
  6805
				INFO_PRINTF1(_L("DevSound State: EStateInitializing"));
sl@0
  6806
				iDevSoundState = EStateInitializing;
sl@0
  6807
				}
sl@0
  6808
			else
sl@0
  6809
				{
sl@0
  6810
				ERR_PRINTF2(_L("DevSound EEventInitialize not received as expected. Received event: %d"), aDevSoundEvent);
sl@0
  6811
				StopTest(aError, EFail);
sl@0
  6812
				}
sl@0
  6813
			break;
sl@0
  6814
			}
sl@0
  6815
		case EStateInitializing:
sl@0
  6816
			{
sl@0
  6817
			if (aDevSoundEvent == EEventInitComplete && aError == KErrNone)
sl@0
  6818
				{
sl@0
  6819
				iMMFDevSound->SetVolume(iMMFDevSound->MaxVolume());
sl@0
  6820
				INFO_PRINTF4(_L("Calling CMMFDevSound::PlayDualToneL using %d Hz %d Hz during %d secs "), iFrequencyTone1, iFrequencyTone2, iDuration);
sl@0
  6821
				TRAPD(err, iMMFDevSound->PlayDualToneL(iFrequencyTone1, iFrequencyTone2, iDuration*KMicroSecsInOneSec));
sl@0
  6822
				if (err != KErrNone)
sl@0
  6823
					{
sl@0
  6824
					ERR_PRINTF2(_L("CMMFDevSound::PlayDualToneL left with error : %d!"),  err);
sl@0
  6825
					StopTest(err);
sl@0
  6826
					break;
sl@0
  6827
					}
sl@0
  6828
				StartTimer(KMicroSecsTwoSec);
sl@0
  6829
				INFO_PRINTF1(_L("DevSound State: EStatePlaying"));
sl@0
  6830
				iDevSoundState = EStatePlaying;
sl@0
  6831
				}
sl@0
  6832
			else if (aDevSoundEvent == EEventInitComplete && aError != KErrNone)
sl@0
  6833
				{
sl@0
  6834
				ERR_PRINTF2(_L("DevSound called CMMFDevSound::InitializeComplete with error = %d"), aError);
sl@0
  6835
				StopTest(aError);
sl@0
  6836
				}
sl@0
  6837
			else
sl@0
  6838
				{
sl@0
  6839
				ERR_PRINTF2(_L("DevSound EEventInitComplete not received as expected. Received event: %d"), aDevSoundEvent);
sl@0
  6840
				StopTest(aError, EFail);
sl@0
  6841
				}
sl@0
  6842
			break;
sl@0
  6843
			}
sl@0
  6844
		case EStatePlaying:
sl@0
  6845
			{
sl@0
  6846
			if(aDevSoundEvent == EEventTimerComplete)
sl@0
  6847
				{
sl@0
  6848
				INFO_PRINTF1(_L("Calling CMMFDevSound::Pause"));
sl@0
  6849
				iMMFDevSound->Pause();
sl@0
  6850
				INFO_PRINTF1(_L("DevSound State: EStatePause"));
sl@0
  6851
				iDevSoundState = EStatePause;
sl@0
  6852
				INFO_PRINTF1(_L("Calling CMMFDevSound::SamplesPlayed"));
sl@0
  6853
				iSamplesPlayedPaused = iMMFDevSound->SamplesPlayed();
sl@0
  6854
				INFO_PRINTF2(_L("The number of samples played is %d"), iSamplesPlayedPaused);
sl@0
  6855
				StopTest();
sl@0
  6856
				}
sl@0
  6857
			else
sl@0
  6858
				{
sl@0
  6859
				ERR_PRINTF2(_L("DevSound EEventTimerComplete not received as expected. Received event: %d"), aDevSoundEvent);
sl@0
  6860
				StopTest(aError, EFail);
sl@0
  6861
				}
sl@0
  6862
			break;
sl@0
  6863
			}
sl@0
  6864
		case EStatePause:
sl@0
  6865
			{
sl@0
  6866
			if (aDevSoundEvent == EEventTimerComplete)
sl@0
  6867
				{
sl@0
  6868
				TInt samplesPlayed = iMMFDevSound->SamplesPlayed();
sl@0
  6869
				if(iSamplesPlayedPaused == samplesPlayed)
sl@0
  6870
					{
sl@0
  6871
					INFO_PRINTF2(_L("After waiting a couple of seconds, the samples played are still being the same %d"), iSamplesPlayedPaused);
sl@0
  6872
					StopTest();
sl@0
  6873
					}
sl@0
  6874
				else
sl@0
  6875
					{
sl@0
  6876
					ERR_PRINTF2(_L("After waiting a couple of seconds, the samples played are not the same %d"), samplesPlayed);
sl@0
  6877
					ERR_PRINTF2(_L("Expected samples played = %d"), iSamplesPlayedPaused);
sl@0
  6878
					StopTest(aError,EFail);
sl@0
  6879
					}
sl@0
  6880
				}
sl@0
  6881
			else
sl@0
  6882
				{
sl@0
  6883
				ERR_PRINTF2(_L("EEventTimerComplete not received as expected. Received event: %d"), aDevSoundEvent);
sl@0
  6884
				StopTest(aError, EFail);
sl@0
  6885
				}
sl@0
  6886
			break;
sl@0
  6887
			}
sl@0
  6888
		default:
sl@0
  6889
			{
sl@0
  6890
			ERR_PRINTF2(_L("Invalid DevSound state received: %d"), iDevSoundState);
sl@0
  6891
			StopTest(aError, EFail);
sl@0
  6892
			}
sl@0
  6893
		}
sl@0
  6894
	}
sl@0
  6895
sl@0
  6896
void RA3FDevSoundTonePlayDualToneOncePauseTest::DoTimerCallback()
sl@0
  6897
	{
sl@0
  6898
	INFO_PRINTF1(_L("TimerEvent called"));
sl@0
  6899
	if (!iPaused)
sl@0
  6900
		{
sl@0
  6901
		INFO_PRINTF1(_L("DevSound Event: EEventTimerComplete"));
sl@0
  6902
		Fsm(EEventTimerComplete, KErrNone);
sl@0
  6903
		iPaused = ETrue;
sl@0
  6904
		}
sl@0
  6905
	else
sl@0
  6906
		{
sl@0
  6907
		iTimer->Cancel();
sl@0
  6908
		INFO_PRINTF1(_L("DevSound Event: EEventTimerComplete"));
sl@0
  6909
		Fsm(EEventTimerComplete, KErrNone);
sl@0
  6910
		}
sl@0
  6911
	}
sl@0
  6912
sl@0
  6913
void RA3FDevSoundTonePlayDualToneOncePauseTest::ToneFinished(TInt aError)
sl@0
  6914
	{
sl@0
  6915
	INFO_PRINTF1(_L("========== DevSound ToneFinished() callback =========="));
sl@0
  6916
	ERR_PRINTF1(_L("DevSound should not have called ToneFinished because it is supposed to be paused"));
sl@0
  6917
	StopTest(aError, EFail);
sl@0
  6918
	}
sl@0
  6919
sl@0
  6920
/*
sl@0
  6921
 *========================================================================================================
sl@0
  6922
 * MM-A3F-DEVSOUND-CHRTZ-TONE-0049
sl@0
  6923
 */
sl@0
  6924
RA3FDevSoundTonePlayDTMFStringOncePauseTest::RA3FDevSoundTonePlayDTMFStringOncePauseTest(const TDesC& aTestName)
sl@0
  6925
	:	RA3FDevSoundTestBase(aTestName),
sl@0
  6926
		iDTMFString(KNullDesC),iPaused(EFalse),
sl@0
  6927
		iSamplesPlayedPaused(0),iDTMFPauses(0),
sl@0
  6928
		iDTMFTones(0)
sl@0
  6929
	{
sl@0
  6930
	}
sl@0
  6931
sl@0
  6932
RA3FDevSoundTonePlayDTMFStringOncePauseTest* RA3FDevSoundTonePlayDTMFStringOncePauseTest::NewL(const TDesC& aTestName)
sl@0
  6933
	{
sl@0
  6934
	RA3FDevSoundTonePlayDTMFStringOncePauseTest * self = new(ELeave)RA3FDevSoundTonePlayDTMFStringOncePauseTest(aTestName);
sl@0
  6935
	return self;
sl@0
  6936
	}
sl@0
  6937
sl@0
  6938
void RA3FDevSoundTonePlayDTMFStringOncePauseTest::DoKickoffTestL()
sl@0
  6939
	{
sl@0
  6940
	TPtrC DTMF;
sl@0
  6941
	if ( !GetStringFromConfig(iTestStepName, KDTMFString, DTMF) )
sl@0
  6942
		{
sl@0
  6943
		ERR_PRINTF2(KMsgErrorGetParameter, &KDTMFString);
sl@0
  6944
		StopTest(KErrNotFound);
sl@0
  6945
		return;
sl@0
  6946
		}
sl@0
  6947
	iDTMFString.Copy(DTMF);
sl@0
  6948
	for(TInt i =0 ; i< iDTMFString.Length() ; i++)
sl@0
  6949
		{
sl@0
  6950
		if (iDTMFString[i] == ',')
sl@0
  6951
			{
sl@0
  6952
			iDTMFPauses++;
sl@0
  6953
			}
sl@0
  6954
		else
sl@0
  6955
			{
sl@0
  6956
			iDTMFTones++;
sl@0
  6957
			}
sl@0
  6958
		}
sl@0
  6959
	iTimer = CPeriodic::NewL(CActive::EPriorityHigh);
sl@0
  6960
	}
sl@0
  6961
sl@0
  6962
void RA3FDevSoundTonePlayDTMFStringOncePauseTest::Fsm(TMmfDevSoundEvent aDevSoundEvent, TInt aError)
sl@0
  6963
	{
sl@0
  6964
	switch (iDevSoundState)
sl@0
  6965
		{
sl@0
  6966
		case EStateCreated:
sl@0
  6967
			{
sl@0
  6968
			__ASSERT_ALWAYS((aError == KErrNone), Panic(_L("RA3FDevSoundTonePlayDTMFStringOncePauseTest"), EFsmIncorrectErrorPassed));
sl@0
  6969
			if (aDevSoundEvent == EEventInitialize)
sl@0
  6970
				{
sl@0
  6971
				INFO_PRINTF1(_L("Calling CMMFDevSound::InitializeL"));
sl@0
  6972
				TRAPD(err, iMMFDevSound->InitializeL(*this, EMMFStateTonePlaying));
sl@0
  6973
				if (err != KErrNone)
sl@0
  6974
					{
sl@0
  6975
					ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"), err);
sl@0
  6976
					StopTest(err);
sl@0
  6977
					break;
sl@0
  6978
					}
sl@0
  6979
				INFO_PRINTF1(_L("DevSound State: EStateInitializing"));
sl@0
  6980
				iDevSoundState = EStateInitializing;
sl@0
  6981
				}
sl@0
  6982
			else
sl@0
  6983
				{
sl@0
  6984
				ERR_PRINTF2(_L("DevSound EEventInitialize not received as expected. Received event: %d"), aDevSoundEvent);
sl@0
  6985
				StopTest(aError, EFail);
sl@0
  6986
				}
sl@0
  6987
			break;
sl@0
  6988
			}
sl@0
  6989
		case EStateInitializing:
sl@0
  6990
			{
sl@0
  6991
			if (aDevSoundEvent == EEventInitComplete && aError == KErrNone)
sl@0
  6992
				{
sl@0
  6993
				iMMFDevSound->SetVolume(iMMFDevSound->MaxVolume());
sl@0
  6994
				INFO_PRINTF2(_L("Calling CMMFDevSound::PlayDTMFStringL %S"),  &iDTMFString);
sl@0
  6995
				TRAPD(err, iMMFDevSound->PlayDTMFStringL(iDTMFString));
sl@0
  6996
				if (err != KErrNone)
sl@0
  6997
					{
sl@0
  6998
					ERR_PRINTF2(_L("CMMFDevSound::PlayDTMFStringL left with error : %d!"),  err);
sl@0
  6999
					StopTest(err);
sl@0
  7000
					}
sl@0
  7001
				StartTimer(KMicroSecsTwoSec);
sl@0
  7002
				INFO_PRINTF1(_L("DevSound State: EStatePlaying"));
sl@0
  7003
				iDevSoundState = EStatePlaying;
sl@0
  7004
				}
sl@0
  7005
			else if (aDevSoundEvent == EEventInitComplete && aError != KErrNone)
sl@0
  7006
				{
sl@0
  7007
				ERR_PRINTF2(_L("DevSound called CMMFDevSound::InitializeComplete with error = %d"), aError);
sl@0
  7008
				StopTest(aError);
sl@0
  7009
				}
sl@0
  7010
			else
sl@0
  7011
				{
sl@0
  7012
				ERR_PRINTF2(_L("DevSound EEventInitComplete not received as expected. Received event: %d"), aDevSoundEvent);
sl@0
  7013
				StopTest(aError, EFail);
sl@0
  7014
				}
sl@0
  7015
			break;
sl@0
  7016
			}
sl@0
  7017
		case EStatePlaying:
sl@0
  7018
			{
sl@0
  7019
			if(aDevSoundEvent == EEventTimerComplete)
sl@0
  7020
				{
sl@0
  7021
				INFO_PRINTF1(_L("Calling CMMFDevSound::Pause"));
sl@0
  7022
				iMMFDevSound->Pause();
sl@0
  7023
				INFO_PRINTF1(_L("DevSound State: EStatePause"));
sl@0
  7024
				iDevSoundState = EStatePause;
sl@0
  7025
				INFO_PRINTF1(_L("Calling CMMFDevSound::SamplesPlayed"));
sl@0
  7026
				iSamplesPlayedPaused = iMMFDevSound->SamplesPlayed();
sl@0
  7027
				INFO_PRINTF2(_L("The number of samples played is %d"), iSamplesPlayedPaused);
sl@0
  7028
				}
sl@0
  7029
			else
sl@0
  7030
				{
sl@0
  7031
				ERR_PRINTF2(_L("DevSound EEventTimerComplete not received as expected. Received event: %d"), aDevSoundEvent);
sl@0
  7032
				StopTest(aError, EFail);
sl@0
  7033
				}
sl@0
  7034
			break;
sl@0
  7035
			}
sl@0
  7036
		case EStatePause:
sl@0
  7037
			{
sl@0
  7038
			if (aDevSoundEvent == EEventTimerComplete)
sl@0
  7039
				{
sl@0
  7040
				TInt samplesPlayed = iMMFDevSound->SamplesPlayed();
sl@0
  7041
				if(iSamplesPlayedPaused == samplesPlayed)
sl@0
  7042
					{
sl@0
  7043
					INFO_PRINTF2(_L("After waiting a couple of seconds, the samples played are still being the same %d"), iSamplesPlayedPaused);
sl@0
  7044
					StopTest();
sl@0
  7045
					}
sl@0
  7046
				else
sl@0
  7047
					{
sl@0
  7048
					ERR_PRINTF2(_L("After waiting a couple of seconds, the samples played are not the same %d"), samplesPlayed);
sl@0
  7049
					ERR_PRINTF2(_L("Expected samples played = %d"), iSamplesPlayedPaused);
sl@0
  7050
					StopTest(aError,EFail);
sl@0
  7051
					}
sl@0
  7052
				}
sl@0
  7053
			else
sl@0
  7054
				{
sl@0
  7055
				ERR_PRINTF2(_L("EEventTimerComplete not received as expected. Received event: %d"), aDevSoundEvent);
sl@0
  7056
				StopTest(aError, EFail);
sl@0
  7057
				}
sl@0
  7058
			break;
sl@0
  7059
			}
sl@0
  7060
		default:
sl@0
  7061
			{
sl@0
  7062
			ERR_PRINTF2(_L("Invalid DevSound state received: %d"), iDevSoundState);
sl@0
  7063
			StopTest(aError, EFail);
sl@0
  7064
			}
sl@0
  7065
		}
sl@0
  7066
	}
sl@0
  7067
sl@0
  7068
void RA3FDevSoundTonePlayDTMFStringOncePauseTest::DoTimerCallback()
sl@0
  7069
	{
sl@0
  7070
	INFO_PRINTF1(_L("TimerEvent called"));
sl@0
  7071
	if (!iPaused)
sl@0
  7072
		{
sl@0
  7073
		INFO_PRINTF1(_L("DevSound Event: EEventTimerComplete"));
sl@0
  7074
		Fsm(EEventTimerComplete, KErrNone);
sl@0
  7075
		iPaused = ETrue;
sl@0
  7076
		}
sl@0
  7077
	else
sl@0
  7078
		{
sl@0
  7079
		iTimer->Cancel();
sl@0
  7080
		INFO_PRINTF1(_L("DevSound Event: EEventTimerComplete"));
sl@0
  7081
		Fsm(EEventTimerComplete, KErrNone);
sl@0
  7082
		}
sl@0
  7083
	}
sl@0
  7084
sl@0
  7085
void RA3FDevSoundTonePlayDTMFStringOncePauseTest::ToneFinished(TInt aError)
sl@0
  7086
	{
sl@0
  7087
	INFO_PRINTF1(_L("========== DevSound ToneFinished() callback =========="));
sl@0
  7088
	ERR_PRINTF1(_L("DevSound should not have called ToneFinished because it is supposed to be paused"));
sl@0
  7089
	StopTest(aError, EFail);
sl@0
  7090
	}
sl@0
  7091
sl@0
  7092
/*
sl@0
  7093
 *========================================================================================================
sl@0
  7094
 * MM-A3F-DEVSOUND-CHRTZ-TONE-0050
sl@0
  7095
 */
sl@0
  7096
RA3FDevSoundTonePlayToneSequenceOncePauseTest::RA3FDevSoundTonePlayToneSequenceOncePauseTest(const TDesC& aTestName)
sl@0
  7097
	:	RA3FDevSoundTestBase(aTestName), iPaused(EFalse),
sl@0
  7098
		iSamplesPlayedPaused(0)
sl@0
  7099
	{
sl@0
  7100
	}
sl@0
  7101
sl@0
  7102
RA3FDevSoundTonePlayToneSequenceOncePauseTest* RA3FDevSoundTonePlayToneSequenceOncePauseTest::NewL(const TDesC& aTestName)
sl@0
  7103
	{
sl@0
  7104
	RA3FDevSoundTonePlayToneSequenceOncePauseTest * self = new(ELeave)RA3FDevSoundTonePlayToneSequenceOncePauseTest(aTestName);
sl@0
  7105
	return self;
sl@0
  7106
	}
sl@0
  7107
sl@0
  7108
void RA3FDevSoundTonePlayToneSequenceOncePauseTest::DoKickoffTestL()
sl@0
  7109
	{
sl@0
  7110
	iTimer = CPeriodic::NewL(CActive::EPriorityHigh);
sl@0
  7111
	}
sl@0
  7112
sl@0
  7113
void RA3FDevSoundTonePlayToneSequenceOncePauseTest::Fsm(TMmfDevSoundEvent aDevSoundEvent, TInt aError)
sl@0
  7114
	{
sl@0
  7115
	switch(iDevSoundState)
sl@0
  7116
		{
sl@0
  7117
		case EStateCreated:
sl@0
  7118
			{
sl@0
  7119
			__ASSERT_ALWAYS((aError == KErrNone), Panic(_L("RA3FDevSoundTonePlayToneSequenceOncePauseTest"), EFsmIncorrectErrorPassed));
sl@0
  7120
			if (aDevSoundEvent == EEventInitialize)
sl@0
  7121
				{
sl@0
  7122
				INFO_PRINTF1(_L("Calling CMMFDevSound::InitializeL"));
sl@0
  7123
				TRAPD(err, iMMFDevSound->InitializeL(*this, EMMFStateTonePlaying));
sl@0
  7124
				if (err != KErrNone)
sl@0
  7125
					{
sl@0
  7126
					ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"), err);
sl@0
  7127
					StopTest(err);
sl@0
  7128
					break;
sl@0
  7129
					}
sl@0
  7130
				INFO_PRINTF1(_L("DevSound State: EStateInitializing"));
sl@0
  7131
				iDevSoundState = EStateInitializing;
sl@0
  7132
				}
sl@0
  7133
			else
sl@0
  7134
				{
sl@0
  7135
				ERR_PRINTF2(_L("DevSound EEventInitialize not received as expected. Received event: %d"), aDevSoundEvent);
sl@0
  7136
				StopTest(aError, EFail);
sl@0
  7137
				}
sl@0
  7138
			break;
sl@0
  7139
			}
sl@0
  7140
		case EStateInitializing:
sl@0
  7141
			{
sl@0
  7142
			if (aDevSoundEvent == EEventInitComplete && aError == KErrNone)
sl@0
  7143
				{
sl@0
  7144
				TUint8* tablePointer = const_cast<TUint8*>( &(KFixedSequenceTestSequenceDataX[0] ) );
sl@0
  7145
				TPtrC8 KFixedSequenceData(tablePointer, sizeof(KFixedSequenceTestSequenceDataX));
sl@0
  7146
				INFO_PRINTF1(_L("Calling CMMFDevSound::PlayToneSequenceL"));
sl@0
  7147
				TRAPD(err, iMMFDevSound->PlayToneSequenceL(KFixedSequenceData));
sl@0
  7148
				if (err != KErrNone)
sl@0
  7149
					{
sl@0
  7150
					ERR_PRINTF2(_L("CMMFDevSound::PlayToneSequenceL left  with error : %d!"),  err);
sl@0
  7151
					StopTest(err);
sl@0
  7152
					break;
sl@0
  7153
					}
sl@0
  7154
				StartTimer(KMicroSecsTwoSec);
sl@0
  7155
				INFO_PRINTF1(_L("DevSound State: EStatePlaying"));
sl@0
  7156
				iDevSoundState = EStatePlaying;
sl@0
  7157
				}
sl@0
  7158
			else if (aDevSoundEvent == EEventInitComplete && aError != KErrNone)
sl@0
  7159
				{
sl@0
  7160
				ERR_PRINTF2(_L("DevSound called CMMFDevSound::InitializeComplete with error = %d"), aError);
sl@0
  7161
				StopTest(aError);
sl@0
  7162
				}
sl@0
  7163
			else
sl@0
  7164
				{
sl@0
  7165
				ERR_PRINTF2(_L("DevSound EEventInitComplete not received as expected. Received event: %d"), aDevSoundEvent);
sl@0
  7166
				StopTest(aError, EFail);
sl@0
  7167
				}
sl@0
  7168
			break;
sl@0
  7169
			}
sl@0
  7170
		case EStatePlaying:
sl@0
  7171
			{
sl@0
  7172
			if(aDevSoundEvent == EEventTimerComplete)
sl@0
  7173
				{
sl@0
  7174
				INFO_PRINTF1(_L("Calling CMMFDevSound::Pause"));
sl@0
  7175
				iMMFDevSound->Pause();
sl@0
  7176
				INFO_PRINTF1(_L("DevSound State: EStatePause"));
sl@0
  7177
				iDevSoundState = EStatePause;
sl@0
  7178
				INFO_PRINTF1(_L("Calling CMMFDevSound::SamplesPlayed"));
sl@0
  7179
				iSamplesPlayedPaused = iMMFDevSound->SamplesPlayed();
sl@0
  7180
				INFO_PRINTF2(_L("The number of samples played is %d"), iSamplesPlayedPaused);
sl@0
  7181
				}
sl@0
  7182
			else
sl@0
  7183
				{
sl@0
  7184
				ERR_PRINTF2(_L("DevSound EEventTimerComplete not received as expected. Received event: %d"), aDevSoundEvent);
sl@0
  7185
				StopTest(aError, EFail);
sl@0
  7186
				}
sl@0
  7187
			break;
sl@0
  7188
			}
sl@0
  7189
		case EStatePause:
sl@0
  7190
			{
sl@0
  7191
			if (aDevSoundEvent == EEventTimerComplete)
sl@0
  7192
				{
sl@0
  7193
				TInt samplesPlayed = iMMFDevSound->SamplesPlayed();
sl@0
  7194
				if(iSamplesPlayedPaused == samplesPlayed)
sl@0
  7195
					{
sl@0
  7196
					INFO_PRINTF2(_L("After waiting a couple of seconds, the samples played are still being the same %d"), iSamplesPlayedPaused);
sl@0
  7197
					StopTest();
sl@0
  7198
					}
sl@0
  7199
				else
sl@0
  7200
					{
sl@0
  7201
					ERR_PRINTF2(_L("After waiting a couple of seconds, the samples played are not the same %d"), samplesPlayed);
sl@0
  7202
					ERR_PRINTF2(_L("Expected samples played = %d"), iSamplesPlayedPaused);
sl@0
  7203
					StopTest(aError,EFail);
sl@0
  7204
					}
sl@0
  7205
				}
sl@0
  7206
			else
sl@0
  7207
				{
sl@0
  7208
				ERR_PRINTF2(_L("EEventTimerComplete not received as expected. Received event: %d"), aDevSoundEvent);
sl@0
  7209
				StopTest(aError, EFail);
sl@0
  7210
				}
sl@0
  7211
			break;
sl@0
  7212
			}
sl@0
  7213
		default:
sl@0
  7214
			{
sl@0
  7215
			ERR_PRINTF2(_L("Invalid DevSound state received: %d"), iDevSoundState);
sl@0
  7216
			StopTest(aError, EFail);
sl@0
  7217
			}
sl@0
  7218
		}
sl@0
  7219
	}
sl@0
  7220
sl@0
  7221
void RA3FDevSoundTonePlayToneSequenceOncePauseTest::DoTimerCallback()
sl@0
  7222
	{
sl@0
  7223
	INFO_PRINTF1(_L("TimerEvent called"));
sl@0
  7224
	if (!iPaused)
sl@0
  7225
		{
sl@0
  7226
		INFO_PRINTF1(_L("DevSound Event: EEventTimerComplete"));
sl@0
  7227
		Fsm(EEventTimerComplete, KErrNone);
sl@0
  7228
		iPaused = ETrue;
sl@0
  7229
		}
sl@0
  7230
	else
sl@0
  7231
		{
sl@0
  7232
		iTimer->Cancel();
sl@0
  7233
		INFO_PRINTF1(_L("DevSound Event: EEventTimerComplete"));
sl@0
  7234
		Fsm(EEventTimerComplete, KErrNone);
sl@0
  7235
		}
sl@0
  7236
	}
sl@0
  7237
sl@0
  7238
void RA3FDevSoundTonePlayToneSequenceOncePauseTest::ToneFinished(TInt aError)
sl@0
  7239
	{
sl@0
  7240
	INFO_PRINTF1(_L("========== DevSound ToneFinished() callback =========="));
sl@0
  7241
	ERR_PRINTF1(_L("DevSound should not have called ToneFinished because it is supposed to be paused"));
sl@0
  7242
	StopTest(aError, EFail);
sl@0
  7243
	}
sl@0
  7244
sl@0
  7245
/*
sl@0
  7246
 *========================================================================================================
sl@0
  7247
 * MM-A3F-DEVSOUND-CHRTZ-TONE-0051
sl@0
  7248
 */
sl@0
  7249
RA3FDevSoundTonePlayToneOnceInitializedToPlayAudioTest::RA3FDevSoundTonePlayToneOnceInitializedToPlayAudioTest(const TDesC& aTestName)
sl@0
  7250
	:	RA3FDevSoundTestBase(aTestName), iDuration(0),
sl@0
  7251
		iFrequencyTone1(0)
sl@0
  7252
	{
sl@0
  7253
	}
sl@0
  7254
sl@0
  7255
RA3FDevSoundTonePlayToneOnceInitializedToPlayAudioTest* RA3FDevSoundTonePlayToneOnceInitializedToPlayAudioTest::NewL(const TDesC& aTestName)
sl@0
  7256
	{
sl@0
  7257
	RA3FDevSoundTonePlayToneOnceInitializedToPlayAudioTest * self = new(ELeave)RA3FDevSoundTonePlayToneOnceInitializedToPlayAudioTest(aTestName);
sl@0
  7258
	return self;
sl@0
  7259
	}
sl@0
  7260
sl@0
  7261
void RA3FDevSoundTonePlayToneOnceInitializedToPlayAudioTest::DoKickoffTestL()
sl@0
  7262
	{
sl@0
  7263
	if (!GetIntFromConfig(iTestStepName, KDuration, iDuration))
sl@0
  7264
		{
sl@0
  7265
		ERR_PRINTF2(KMsgErrorGetParameter, &KDuration);
sl@0
  7266
		StopTest(KErrNotFound);
sl@0
  7267
		return;
sl@0
  7268
		}
sl@0
  7269
	if (!GetIntFromConfig(iTestStepName, KFrequencyTone1, iFrequencyTone1))
sl@0
  7270
		{
sl@0
  7271
		ERR_PRINTF2(KMsgErrorGetParameter, &KFrequencyTone1);
sl@0
  7272
		StopTest(KErrNotFound);
sl@0
  7273
		return;
sl@0
  7274
		}
sl@0
  7275
	}
sl@0
  7276
sl@0
  7277
void RA3FDevSoundTonePlayToneOnceInitializedToPlayAudioTest::Fsm(TMmfDevSoundEvent aDevSoundEvent, TInt aError)
sl@0
  7278
	{
sl@0
  7279
	switch (iDevSoundState)
sl@0
  7280
		{
sl@0
  7281
		case EStateCreated:
sl@0
  7282
			{
sl@0
  7283
			__ASSERT_ALWAYS((aError == KErrNone), Panic(_L("RA3FDevSoundTonePlayToneOnceInitializedToPlayAudioTest"), EFsmIncorrectErrorPassed));
sl@0
  7284
			if (aDevSoundEvent == EEventInitialize)
sl@0
  7285
				{
sl@0
  7286
				INFO_PRINTF1(_L("Calling CMMFDevSound::InitializeL for playing audio files"));
sl@0
  7287
				TRAPD(err, iMMFDevSound->InitializeL(*this, EMMFStatePlaying));
sl@0
  7288
				if (err != KErrNone)
sl@0
  7289
					{
sl@0
  7290
					ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"), err);
sl@0
  7291
					StopTest(err);
sl@0
  7292
					break;
sl@0
  7293
					}
sl@0
  7294
				INFO_PRINTF1(_L("DevSound State: EStateInitializing"));
sl@0
  7295
				iDevSoundState = EStateInitializing;
sl@0
  7296
				}
sl@0
  7297
			else
sl@0
  7298
				{
sl@0
  7299
				ERR_PRINTF2(_L("DevSound EEventInitialize not received as expected. Received event: %d"), aDevSoundEvent);
sl@0
  7300
				StopTest(aError,  EFail);
sl@0
  7301
				}
sl@0
  7302
			break;
sl@0
  7303
			}
sl@0
  7304
		case EStateInitializing:
sl@0
  7305
			{
sl@0
  7306
			if (aDevSoundEvent == EEventInitComplete && aError == KErrNone)
sl@0
  7307
				{
sl@0
  7308
				INFO_PRINTF3(_L("Calling CMMFDevSound::PlayToneL using %d Hz during %d secs"), iFrequencyTone1, iDuration);
sl@0
  7309
				TRAPD(err, iMMFDevSound->PlayToneL(iFrequencyTone1, iDuration*KMicroSecsInOneSec));
sl@0
  7310
				if (err	== KErrNotSupported)
sl@0
  7311
					{
sl@0
  7312
					ERR_PRINTF2(_L("CMMFDevSound::PlayToneL left with KErrNotSupported %d which is the expected error"), err);
sl@0
  7313
					StopTest();
sl@0
  7314
					}
sl@0
  7315
				else
sl@0
  7316
					{
sl@0
  7317
					ERR_PRINTF2(_L("CMMFDevSound::PlayToneL left with error = %d"), err);
sl@0
  7318
					ERR_PRINTF2(_L("Expected error = %d"), KErrNotSupported);
sl@0
  7319
					StopTest(err, EFail);
sl@0
  7320
					}
sl@0
  7321
				}
sl@0
  7322
			else if (aDevSoundEvent == EEventInitComplete && aError != KErrNone)
sl@0
  7323
				{
sl@0
  7324
				ERR_PRINTF2(_L("DevSound called CMMFDevSound::InitializeComplete with error = %d"), aError);
sl@0
  7325
				StopTest(aError);
sl@0
  7326
				}
sl@0
  7327
			else
sl@0
  7328
				{
sl@0
  7329
				ERR_PRINTF2(_L("DevSound EEventInitComplete not received as expected. Received event: %d"), aDevSoundEvent);
sl@0
  7330
				StopTest(aError, EFail);
sl@0
  7331
				}
sl@0
  7332
			break;
sl@0
  7333
			}
sl@0
  7334
		default:
sl@0
  7335
			{
sl@0
  7336
			ERR_PRINTF2(_L("Invalid DevSound state received: %d"), iDevSoundState);
sl@0
  7337
			StopTest(aError, EFail);
sl@0
  7338
			}
sl@0
  7339
		}
sl@0
  7340
	}
sl@0
  7341
sl@0
  7342
/*
sl@0
  7343
 *========================================================================================================
sl@0
  7344
 * MM-A3F-DEVSOUND-CHRTZ-TONE-0052
sl@0
  7345
 */
sl@0
  7346
RA3FDevSoundTonePlayDualToneOnceInitializedToPlayAudioTest::RA3FDevSoundTonePlayDualToneOnceInitializedToPlayAudioTest(const TDesC& aTestName)
sl@0
  7347
	:	RA3FDevSoundTestBase(aTestName), iDuration(0),
sl@0
  7348
		iFrequencyTone1(0), iFrequencyTone2(0)
sl@0
  7349
	{
sl@0
  7350
	}
sl@0
  7351
sl@0
  7352
RA3FDevSoundTonePlayDualToneOnceInitializedToPlayAudioTest* RA3FDevSoundTonePlayDualToneOnceInitializedToPlayAudioTest::NewL(const TDesC& aTestName)
sl@0
  7353
	{
sl@0
  7354
	RA3FDevSoundTonePlayDualToneOnceInitializedToPlayAudioTest * self = new(ELeave)RA3FDevSoundTonePlayDualToneOnceInitializedToPlayAudioTest(aTestName);
sl@0
  7355
	return self;
sl@0
  7356
	}
sl@0
  7357
sl@0
  7358
void RA3FDevSoundTonePlayDualToneOnceInitializedToPlayAudioTest::DoKickoffTestL()
sl@0
  7359
	{
sl@0
  7360
	if (!GetIntFromConfig(iTestStepName, KDuration, iDuration))
sl@0
  7361
		{
sl@0
  7362
		ERR_PRINTF2(KMsgErrorGetParameter, &KDuration);
sl@0
  7363
		StopTest(KErrNotFound);
sl@0
  7364
		return;
sl@0
  7365
		}
sl@0
  7366
	if (!GetIntFromConfig(iTestStepName, KFrequencyTone1, iFrequencyTone1))
sl@0
  7367
		{
sl@0
  7368
		ERR_PRINTF2(KMsgErrorGetParameter, &KFrequencyTone1);
sl@0
  7369
		StopTest(KErrNotFound);
sl@0
  7370
		return;
sl@0
  7371
		}
sl@0
  7372
	if (!GetIntFromConfig(iTestStepName, KFrequencyTone2, iFrequencyTone2))
sl@0
  7373
		{
sl@0
  7374
		ERR_PRINTF2(KMsgErrorGetParameter, &KFrequencyTone2);
sl@0
  7375
		StopTest(KErrNotFound);
sl@0
  7376
		return;
sl@0
  7377
		}
sl@0
  7378
	}
sl@0
  7379
sl@0
  7380
void RA3FDevSoundTonePlayDualToneOnceInitializedToPlayAudioTest::Fsm(TMmfDevSoundEvent aDevSoundEvent, TInt aError)
sl@0
  7381
	{
sl@0
  7382
	switch(iDevSoundState)
sl@0
  7383
		{
sl@0
  7384
		case EStateCreated:
sl@0
  7385
			{
sl@0
  7386
			__ASSERT_ALWAYS((aError == KErrNone), Panic(_L("RA3FDevSoundTonePlayDualToneOnceInitializedToPlayAudioTest"), EFsmIncorrectErrorPassed));
sl@0
  7387
			if (aDevSoundEvent == EEventInitialize)
sl@0
  7388
				{
sl@0
  7389
				INFO_PRINTF1(_L("Calling CMMFDevSound::InitializeL for playing audio files"));
sl@0
  7390
				TRAPD(err, iMMFDevSound->InitializeL(*this, EMMFStatePlaying));
sl@0
  7391
				if (err != KErrNone)
sl@0
  7392
					{
sl@0
  7393
					ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"), err);
sl@0
  7394
					StopTest(err);
sl@0
  7395
					break;
sl@0
  7396
					}
sl@0
  7397
				INFO_PRINTF1(_L("DevSound State: EStateInitializing"));
sl@0
  7398
				iDevSoundState = EStateInitializing;
sl@0
  7399
				}
sl@0
  7400
			else
sl@0
  7401
				{
sl@0
  7402
				ERR_PRINTF2(_L("DevSound EEventInitialize not received as expected. Received event: %d"), aDevSoundEvent);
sl@0
  7403
				StopTest(aError, EFail);
sl@0
  7404
				}
sl@0
  7405
			break;
sl@0
  7406
			}
sl@0
  7407
		case EStateInitializing:
sl@0
  7408
			{
sl@0
  7409
			if (aDevSoundEvent == EEventInitComplete && aError == KErrNone)
sl@0
  7410
				{
sl@0
  7411
				INFO_PRINTF4(_L("Calling CMMFDevSound::PlayDualToneL using %d Hz %d Hz during %d secs "), iFrequencyTone1, iFrequencyTone2, iDuration);
sl@0
  7412
				TRAPD(err, iMMFDevSound->PlayDualToneL(iFrequencyTone1, iFrequencyTone2, iDuration*KMicroSecsInOneSec));
sl@0
  7413
				if (err	== KErrNotSupported)
sl@0
  7414
					{
sl@0
  7415
					ERR_PRINTF2(_L("CMMFDevSound::PlayDualToneL left with KErrNotSupported %d which is the expected error"), err);
sl@0
  7416
					StopTest(err, EPass);
sl@0
  7417
					}
sl@0
  7418
				else
sl@0
  7419
					{
sl@0
  7420
					ERR_PRINTF2(_L("CMMFDevSound::PlayDualToneL left with error = %d"), err);
sl@0
  7421
					ERR_PRINTF2(_L("Expected error = %d"), KErrNotSupported);
sl@0
  7422
					StopTest(err, EFail);
sl@0
  7423
					}
sl@0
  7424
				}
sl@0
  7425
			else if (aDevSoundEvent == EEventInitComplete && aError != KErrNone)
sl@0
  7426
				{
sl@0
  7427
				ERR_PRINTF2(_L("DevSound called CMMFDevSound::InitializeComplete with error = %d"), aError);
sl@0
  7428
				StopTest(aError);
sl@0
  7429
				}
sl@0
  7430
			else
sl@0
  7431
				{
sl@0
  7432
				ERR_PRINTF2(_L("DevSound EEventInitComplete not received as expected. Received event: %d"), aDevSoundEvent);
sl@0
  7433
				StopTest(aError, EFail);
sl@0
  7434
				}
sl@0
  7435
			break;
sl@0
  7436
			}
sl@0
  7437
		default:
sl@0
  7438
			{
sl@0
  7439
			ERR_PRINTF2(_L("Invalid DevSound state received: %d"), iDevSoundState);
sl@0
  7440
			StopTest(aError, EFail);
sl@0
  7441
			}
sl@0
  7442
		}
sl@0
  7443
	}
sl@0
  7444
sl@0
  7445
/*
sl@0
  7446
 *========================================================================================================
sl@0
  7447
 * MM-A3F-DEVSOUND-CHRTZ-TONE-0053
sl@0
  7448
 */
sl@0
  7449
RA3FDevSoundTonePlayDTMFStringOnceInitializedToPlayAudioTest::RA3FDevSoundTonePlayDTMFStringOnceInitializedToPlayAudioTest(const TDesC& aTestName)
sl@0
  7450
	:	RA3FDevSoundTestBase(aTestName), iDTMFString(KNullDesC)
sl@0
  7451
	{
sl@0
  7452
	}
sl@0
  7453
sl@0
  7454
RA3FDevSoundTonePlayDTMFStringOnceInitializedToPlayAudioTest* RA3FDevSoundTonePlayDTMFStringOnceInitializedToPlayAudioTest::NewL(const TDesC& aTestName)
sl@0
  7455
	{
sl@0
  7456
	RA3FDevSoundTonePlayDTMFStringOnceInitializedToPlayAudioTest * self = new(ELeave)RA3FDevSoundTonePlayDTMFStringOnceInitializedToPlayAudioTest(aTestName);
sl@0
  7457
	return self;
sl@0
  7458
	}
sl@0
  7459
sl@0
  7460
void RA3FDevSoundTonePlayDTMFStringOnceInitializedToPlayAudioTest::DoKickoffTestL()
sl@0
  7461
	{
sl@0
  7462
	TPtrC DTMF;
sl@0
  7463
	if (!GetStringFromConfig(iTestStepName, KDTMFString, DTMF))
sl@0
  7464
		{
sl@0
  7465
		ERR_PRINTF2(KMsgErrorGetParameter, &KDTMFString);
sl@0
  7466
		StopTest(KErrNotFound);
sl@0
  7467
		return;
sl@0
  7468
		}
sl@0
  7469
	iDTMFString.Copy(DTMF);
sl@0
  7470
	}
sl@0
  7471
sl@0
  7472
void RA3FDevSoundTonePlayDTMFStringOnceInitializedToPlayAudioTest::Fsm(TMmfDevSoundEvent aDevSoundEvent, TInt aError)
sl@0
  7473
	{
sl@0
  7474
	switch(iDevSoundState)
sl@0
  7475
	{
sl@0
  7476
		case EStateCreated:
sl@0
  7477
			{
sl@0
  7478
			__ASSERT_ALWAYS((aError == KErrNone), Panic(_L("RA3FDevSoundTonePlayDTMFStringOnceInitializedToPlayAudioTest"), EFsmIncorrectErrorPassed));
sl@0
  7479
			if (aDevSoundEvent == EEventInitialize)
sl@0
  7480
				{
sl@0
  7481
				INFO_PRINTF1(_L("Calling iMMFDevSound::InitializeL for playing audio files"));
sl@0
  7482
				TRAPD(err, iMMFDevSound->InitializeL(*this, EMMFStatePlaying));
sl@0
  7483
				if (err != KErrNone)
sl@0
  7484
					{
sl@0
  7485
					ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"), err);
sl@0
  7486
					StopTest(err);
sl@0
  7487
					break;
sl@0
  7488
					}
sl@0
  7489
				INFO_PRINTF1(_L("DevSound State: EStateInitializing"));
sl@0
  7490
				iDevSoundState = EStateInitializing;
sl@0
  7491
				}
sl@0
  7492
			else
sl@0
  7493
				{
sl@0
  7494
				ERR_PRINTF2(_L("DevSound EEventInitialize not received as expected. Received event: %d"), aDevSoundEvent);
sl@0
  7495
				StopTest(aError, EFail);
sl@0
  7496
				}
sl@0
  7497
			break;
sl@0
  7498
			}
sl@0
  7499
		case EStateInitializing:
sl@0
  7500
			{
sl@0
  7501
			if (aDevSoundEvent == EEventInitComplete && aError == KErrNone)
sl@0
  7502
				{
sl@0
  7503
				INFO_PRINTF2(_L("Calling CMMFDevSound::PlayDTMFStringL %S "), &iDTMFString);
sl@0
  7504
				TRAPD(err, iMMFDevSound->PlayDTMFStringL(iDTMFString));
sl@0
  7505
				if (err	== KErrNotSupported)
sl@0
  7506
					{
sl@0
  7507
					ERR_PRINTF2(_L("CMMFDevSound::PlayDTMFStringL left with KErrNotSupported %d which is the expected error"), err);
sl@0
  7508
					StopTest();
sl@0
  7509
					}
sl@0
  7510
				else
sl@0
  7511
					{
sl@0
  7512
					ERR_PRINTF2(_L("CMMFDevSound::PlayDTMFStringL left with error = %d"), err);
sl@0
  7513
					ERR_PRINTF2(_L("Expected error = %d"), KErrNotSupported);
sl@0
  7514
					StopTest(err, EFail);
sl@0
  7515
					}
sl@0
  7516
				}
sl@0
  7517
			else if (aDevSoundEvent == EEventInitComplete && aError != KErrNone)
sl@0
  7518
				{
sl@0
  7519
				ERR_PRINTF2(_L("DevSound called CMMFDevSound::InitializeComplete with error = %d"), aError);
sl@0
  7520
				StopTest(aError);
sl@0
  7521
				}
sl@0
  7522
			else
sl@0
  7523
				{
sl@0
  7524
				ERR_PRINTF2(_L("DevSound EEventInitComplete not received as expected. Received event: %d"), aDevSoundEvent);
sl@0
  7525
				StopTest(aError, EFail);
sl@0
  7526
				}
sl@0
  7527
			break;
sl@0
  7528
			}
sl@0
  7529
		default:
sl@0
  7530
			{
sl@0
  7531
			ERR_PRINTF2(_L("Invalid DevSound state received: %d"), iDevSoundState);
sl@0
  7532
			StopTest(aError, EFail);
sl@0
  7533
			}
sl@0
  7534
		}
sl@0
  7535
	}
sl@0
  7536
sl@0
  7537
/*
sl@0
  7538
 *========================================================================================================
sl@0
  7539
 * MM-A3F-DEVSOUND-CHRTZ-TONE-0054
sl@0
  7540
 */
sl@0
  7541
RA3FDevSoundTonePlayToneSequenceOnceInitializedToPlayAudioTest::RA3FDevSoundTonePlayToneSequenceOnceInitializedToPlayAudioTest(const TDesC& aTestName)
sl@0
  7542
	:	RA3FDevSoundTestBase(aTestName)
sl@0
  7543
	{
sl@0
  7544
	}
sl@0
  7545
sl@0
  7546
RA3FDevSoundTonePlayToneSequenceOnceInitializedToPlayAudioTest* RA3FDevSoundTonePlayToneSequenceOnceInitializedToPlayAudioTest::NewL(const TDesC& aTestName)
sl@0
  7547
	{
sl@0
  7548
	RA3FDevSoundTonePlayToneSequenceOnceInitializedToPlayAudioTest * self = new(ELeave)RA3FDevSoundTonePlayToneSequenceOnceInitializedToPlayAudioTest(aTestName);
sl@0
  7549
	return self;
sl@0
  7550
	}
sl@0
  7551
void RA3FDevSoundTonePlayToneSequenceOnceInitializedToPlayAudioTest::DoKickoffTestL()
sl@0
  7552
	{
sl@0
  7553
	}
sl@0
  7554
sl@0
  7555
void RA3FDevSoundTonePlayToneSequenceOnceInitializedToPlayAudioTest::Fsm(TMmfDevSoundEvent aDevSoundEvent,  TInt aError)
sl@0
  7556
	{
sl@0
  7557
	switch(iDevSoundState)
sl@0
  7558
		{
sl@0
  7559
		case EStateCreated:
sl@0
  7560
			{
sl@0
  7561
			__ASSERT_ALWAYS((aError == KErrNone), Panic(_L("RA3FDevSoundTonePlayToneSequenceOnceInitializedToPlayAudioTest"), EFsmIncorrectErrorPassed));
sl@0
  7562
			if (aDevSoundEvent == EEventInitialize)
sl@0
  7563
				{
sl@0
  7564
				INFO_PRINTF1(_L("Calling iMMFDevSound::InitializeL for playing audio files"));
sl@0
  7565
				TRAPD(err, iMMFDevSound->InitializeL(*this,  EMMFStatePlaying));
sl@0
  7566
				if (err != KErrNone)
sl@0
  7567
					{
sl@0
  7568
					ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"), err);
sl@0
  7569
					StopTest(err);
sl@0
  7570
					break;
sl@0
  7571
					}
sl@0
  7572
				INFO_PRINTF1(_L("DevSound State: EStateInitializing"));
sl@0
  7573
				iDevSoundState = EStateInitializing;
sl@0
  7574
				}
sl@0
  7575
			else
sl@0
  7576
				{
sl@0
  7577
				ERR_PRINTF2(_L("DevSound EEventInitialize not received as expected. Received event: %d"), aDevSoundEvent);
sl@0
  7578
				StopTest(aError, EFail);
sl@0
  7579
				}
sl@0
  7580
			break;
sl@0
  7581
			}
sl@0
  7582
		case EStateInitializing:
sl@0
  7583
			{
sl@0
  7584
			if (aDevSoundEvent == EEventInitComplete && aError == KErrNone)
sl@0
  7585
				{
sl@0
  7586
				TUint8* tablePointer = const_cast<TUint8*>( &(KFixedSequenceTestSequenceDataX[0] ) );
sl@0
  7587
				TPtrC8 KFixedSequenceData(tablePointer,  sizeof(KFixedSequenceTestSequenceDataX));
sl@0
  7588
				INFO_PRINTF1(_L("Calling CMMFDevSound::PlayToneSequenceL"));
sl@0
  7589
				TRAPD(err,  iMMFDevSound->PlayToneSequenceL(KFixedSequenceData));
sl@0
  7590
				if (err == KErrNotSupported)
sl@0
  7591
					{
sl@0
  7592
					ERR_PRINTF2(_L("CMMFDevSound::PlayToneSequenceL left with KErrNotSupported %d which is the expected error"), err);
sl@0
  7593
					StopTest(err, EPass);
sl@0
  7594
					}
sl@0
  7595
				else
sl@0
  7596
					{
sl@0
  7597
					ERR_PRINTF2(_L("Play  dual tone failed with error = %d"),  err);
sl@0
  7598
					ERR_PRINTF2(_L("Expected error = %d"), KErrNotSupported);
sl@0
  7599
					StopTest(err, EFail);
sl@0
  7600
					}
sl@0
  7601
				}
sl@0
  7602
			else if (aDevSoundEvent == EEventInitComplete && aError != KErrNone)
sl@0
  7603
				{
sl@0
  7604
				ERR_PRINTF2(_L("DevSound called CMMFDevSound::InitializeComplete with error = %d"), aError);
sl@0
  7605
				StopTest(aError);
sl@0
  7606
				}
sl@0
  7607
			else
sl@0
  7608
				{
sl@0
  7609
				ERR_PRINTF2(_L("DevSound EEventInitComplete not received as expected. Received event: %d"), aDevSoundEvent);
sl@0
  7610
				StopTest(aError, EFail);
sl@0
  7611
				}
sl@0
  7612
			break;
sl@0
  7613
			}
sl@0
  7614
		default:
sl@0
  7615
			{
sl@0
  7616
			ERR_PRINTF2(_L("Invalid DevSound state received: %d"), iDevSoundState);
sl@0
  7617
			StopTest(aError, EFail);
sl@0
  7618
			}
sl@0
  7619
		}
sl@0
  7620
	}
sl@0
  7621
sl@0
  7622
/*
sl@0
  7623
 *========================================================================================================
sl@0
  7624
 * MM-A3F-DEVSOUND-CHRTZ-TONE-0055
sl@0
  7625
 */
sl@0
  7626
RA3FDevSoundTonePlayToneOnceInitializedToRecordAudioTest::RA3FDevSoundTonePlayToneOnceInitializedToRecordAudioTest(const TDesC& aTestName)
sl@0
  7627
	:	RA3FDevSoundTestBase(aTestName), iDuration(0),
sl@0
  7628
		iFrequencyTone1(0)
sl@0
  7629
	{
sl@0
  7630
	}
sl@0
  7631
sl@0
  7632
RA3FDevSoundTonePlayToneOnceInitializedToRecordAudioTest* RA3FDevSoundTonePlayToneOnceInitializedToRecordAudioTest::NewL(const TDesC& aTestName)
sl@0
  7633
	{
sl@0
  7634
	RA3FDevSoundTonePlayToneOnceInitializedToRecordAudioTest * self = new(ELeave)RA3FDevSoundTonePlayToneOnceInitializedToRecordAudioTest(aTestName);
sl@0
  7635
	return self;
sl@0
  7636
	}
sl@0
  7637
sl@0
  7638
void RA3FDevSoundTonePlayToneOnceInitializedToRecordAudioTest::DoKickoffTestL()
sl@0
  7639
	{
sl@0
  7640
	if (!GetIntFromConfig(iTestStepName, KDuration, iDuration))
sl@0
  7641
		{
sl@0
  7642
		ERR_PRINTF2(KMsgErrorGetParameter, &KDuration);
sl@0
  7643
		StopTest(KErrNotFound);
sl@0
  7644
		return;
sl@0
  7645
		}
sl@0
  7646
	if (!GetIntFromConfig(iTestStepName, KFrequencyTone1, iFrequencyTone1))
sl@0
  7647
		{
sl@0
  7648
		ERR_PRINTF2(KMsgErrorGetParameter, &KFrequencyTone1);
sl@0
  7649
		StopTest(KErrNotFound);
sl@0
  7650
		return;
sl@0
  7651
		}
sl@0
  7652
	}
sl@0
  7653
sl@0
  7654
void RA3FDevSoundTonePlayToneOnceInitializedToRecordAudioTest::Fsm(TMmfDevSoundEvent aDevSoundEvent, TInt aError)
sl@0
  7655
	{
sl@0
  7656
	switch (iDevSoundState)
sl@0
  7657
		{
sl@0
  7658
		case EStateCreated:
sl@0
  7659
			{
sl@0
  7660
			__ASSERT_ALWAYS((aError == KErrNone), Panic(_L("RA3FDevSoundTonePlayToneOnceInitializedToRecordAudioTest"), EFsmIncorrectErrorPassed));
sl@0
  7661
			if (aDevSoundEvent == EEventInitialize)
sl@0
  7662
				{
sl@0
  7663
				INFO_PRINTF1(_L("Calling CMMFDevSound::InitializeL for recording audio files"));
sl@0
  7664
				TRAPD(err, iMMFDevSound->InitializeL(*this, EMMFStateRecording));
sl@0
  7665
				if (err != KErrNone)
sl@0
  7666
					{
sl@0
  7667
					ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"), err);
sl@0
  7668
					StopTest(err);
sl@0
  7669
					break;
sl@0
  7670
					}
sl@0
  7671
				INFO_PRINTF1(_L("DevSound State: EStateInitializing"));
sl@0
  7672
				iDevSoundState = EStateInitializing;
sl@0
  7673
				}
sl@0
  7674
			else
sl@0
  7675
				{
sl@0
  7676
				ERR_PRINTF2(_L("DevSound EEventInitialize not received as expected. Received event: %d"), aDevSoundEvent);
sl@0
  7677
				StopTest(aError,  EFail);
sl@0
  7678
				}
sl@0
  7679
			break;
sl@0
  7680
			}
sl@0
  7681
		case EStateInitializing:
sl@0
  7682
			{
sl@0
  7683
			if (aDevSoundEvent == EEventInitComplete && aError == KErrNone)
sl@0
  7684
				{
sl@0
  7685
				INFO_PRINTF3(_L("Calling CMMFDevSound::PlayToneL using %d Hz during %d secs"), iFrequencyTone1, iDuration);
sl@0
  7686
				TRAPD(err, iMMFDevSound->PlayToneL(iFrequencyTone1, iDuration*KMicroSecsInOneSec));
sl@0
  7687
				if (err	== KErrNotSupported)
sl@0
  7688
					{
sl@0
  7689
					ERR_PRINTF2(_L("CMMFDevSound::PlayToneL left with KErrNotSupported %d which is the expected error"), err);
sl@0
  7690
					StopTest();
sl@0
  7691
					}
sl@0
  7692
				else
sl@0
  7693
					{
sl@0
  7694
					ERR_PRINTF2(_L("CMMFDevSound::PlayToneL left with error = %d"), err);
sl@0
  7695
					ERR_PRINTF2(_L("Expected error = %d"), KErrNotSupported);
sl@0
  7696
					StopTest(err, EFail);
sl@0
  7697
					}
sl@0
  7698
				}
sl@0
  7699
			else if (aDevSoundEvent == EEventInitComplete && aError != KErrNone)
sl@0
  7700
				{
sl@0
  7701
				ERR_PRINTF2(_L("DevSound called CMMFDevSound::InitializeComplete with error = %d"), aError);
sl@0
  7702
				StopTest(aError);
sl@0
  7703
				}
sl@0
  7704
			else
sl@0
  7705
				{
sl@0
  7706
				ERR_PRINTF2(_L("DevSound EEventInitComplete not received as expected. Received event: %d"), aDevSoundEvent);
sl@0
  7707
				StopTest(aError, EFail);
sl@0
  7708
				}
sl@0
  7709
			break;
sl@0
  7710
			}
sl@0
  7711
		default:
sl@0
  7712
			{
sl@0
  7713
			ERR_PRINTF2(_L("Invalid DevSound state received: %d"), iDevSoundState);
sl@0
  7714
			StopTest(aError, EFail);
sl@0
  7715
			}
sl@0
  7716
		}
sl@0
  7717
	}
sl@0
  7718
sl@0
  7719
/*
sl@0
  7720
 *========================================================================================================
sl@0
  7721
 * MM-A3F-DEVSOUND-CHRTZ-TONE-0056
sl@0
  7722
 */
sl@0
  7723
RA3FDevSoundTonePlayDualToneOnceInitializedToRecordAudioTest::RA3FDevSoundTonePlayDualToneOnceInitializedToRecordAudioTest(const TDesC& aTestName)
sl@0
  7724
	:	RA3FDevSoundTestBase(aTestName), iDuration(0),
sl@0
  7725
		iFrequencyTone1(0), iFrequencyTone2(0)
sl@0
  7726
	{
sl@0
  7727
	}
sl@0
  7728
sl@0
  7729
RA3FDevSoundTonePlayDualToneOnceInitializedToRecordAudioTest* RA3FDevSoundTonePlayDualToneOnceInitializedToRecordAudioTest::NewL(const TDesC& aTestName)
sl@0
  7730
	{
sl@0
  7731
	RA3FDevSoundTonePlayDualToneOnceInitializedToRecordAudioTest * self = new(ELeave)RA3FDevSoundTonePlayDualToneOnceInitializedToRecordAudioTest(aTestName);
sl@0
  7732
	return self;
sl@0
  7733
	}
sl@0
  7734
sl@0
  7735
void RA3FDevSoundTonePlayDualToneOnceInitializedToRecordAudioTest::DoKickoffTestL()
sl@0
  7736
	{
sl@0
  7737
	if (!GetIntFromConfig(iTestStepName, KDuration, iDuration))
sl@0
  7738
		{
sl@0
  7739
		ERR_PRINTF2(KMsgErrorGetParameter, &KDuration);
sl@0
  7740
		StopTest(KErrNotFound);
sl@0
  7741
		return;
sl@0
  7742
		}
sl@0
  7743
	if (!GetIntFromConfig(iTestStepName, KFrequencyTone1, iFrequencyTone1))
sl@0
  7744
		{
sl@0
  7745
		ERR_PRINTF2(KMsgErrorGetParameter, &KFrequencyTone1);
sl@0
  7746
		StopTest(KErrNotFound);
sl@0
  7747
		return;
sl@0
  7748
		}
sl@0
  7749
	if (!GetIntFromConfig(iTestStepName, KFrequencyTone2, iFrequencyTone2))
sl@0
  7750
		{
sl@0
  7751
		ERR_PRINTF2(KMsgErrorGetParameter, &KFrequencyTone2);
sl@0
  7752
		StopTest(KErrNotFound);
sl@0
  7753
		return;
sl@0
  7754
		}
sl@0
  7755
	}
sl@0
  7756
sl@0
  7757
void RA3FDevSoundTonePlayDualToneOnceInitializedToRecordAudioTest::Fsm(TMmfDevSoundEvent aDevSoundEvent, TInt aError)
sl@0
  7758
	{
sl@0
  7759
	switch(iDevSoundState)
sl@0
  7760
		{
sl@0
  7761
		case EStateCreated:
sl@0
  7762
			{
sl@0
  7763
			__ASSERT_ALWAYS((aError == KErrNone), Panic(_L("RA3FDevSoundTonePlayDualToneOnceInitializedToRecordAudioTest"), EFsmIncorrectErrorPassed));
sl@0
  7764
			if (aDevSoundEvent == EEventInitialize)
sl@0
  7765
				{
sl@0
  7766
				INFO_PRINTF1(_L("Calling CMMFDevSound::InitializeL for recording audio files"));
sl@0
  7767
				TRAPD(err, iMMFDevSound->InitializeL(*this, EMMFStateRecording));
sl@0
  7768
				if (err != KErrNone)
sl@0
  7769
					{
sl@0
  7770
					ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"), err);
sl@0
  7771
					StopTest(err);
sl@0
  7772
					break;
sl@0
  7773
					}
sl@0
  7774
				INFO_PRINTF1(_L("DevSound State: EStateInitializing"));
sl@0
  7775
				iDevSoundState = EStateInitializing;
sl@0
  7776
				}
sl@0
  7777
			else
sl@0
  7778
				{
sl@0
  7779
				ERR_PRINTF2(_L("DevSound EEventInitialize not received as expected. Received event: %d"), aDevSoundEvent);
sl@0
  7780
				StopTest(aError, EFail);
sl@0
  7781
				}
sl@0
  7782
			break;
sl@0
  7783
			}
sl@0
  7784
		case EStateInitializing:
sl@0
  7785
			{
sl@0
  7786
			if (aDevSoundEvent == EEventInitComplete && aError == KErrNone)
sl@0
  7787
				{
sl@0
  7788
				INFO_PRINTF4(_L("Calling CMMFDevSound::PlayDualToneL using %d Hz %d Hz during %d secs "), iFrequencyTone1, iFrequencyTone2, iDuration);
sl@0
  7789
				TRAPD(err, iMMFDevSound->PlayDualToneL(iFrequencyTone1, iFrequencyTone2, iDuration*KMicroSecsInOneSec));
sl@0
  7790
				if (err	== KErrNotSupported)
sl@0
  7791
					{
sl@0
  7792
					ERR_PRINTF2(_L("CMMFDevSound::PlayDualToneL left with KErrNotSupported %d which is the expected error"), err);
sl@0
  7793
					StopTest(err, EPass);
sl@0
  7794
					}
sl@0
  7795
				else
sl@0
  7796
					{
sl@0
  7797
					ERR_PRINTF2(_L("CMMFDevSound::PlayDualToneL left with error = %d"), err);
sl@0
  7798
					ERR_PRINTF2(_L("Expected error = %d"), KErrNotSupported);
sl@0
  7799
					StopTest(err, EFail);
sl@0
  7800
					}
sl@0
  7801
				}
sl@0
  7802
			else if (aDevSoundEvent == EEventInitComplete && aError != KErrNone)
sl@0
  7803
				{
sl@0
  7804
				ERR_PRINTF2(_L("DevSound called CMMFDevSound::InitializeComplete with error = %d"), aError);
sl@0
  7805
				StopTest(aError);
sl@0
  7806
				}
sl@0
  7807
			else
sl@0
  7808
				{
sl@0
  7809
				ERR_PRINTF2(_L("DevSound EEventInitComplete not received as expected. Received event: %d"), aDevSoundEvent);
sl@0
  7810
				StopTest(aError, EFail);
sl@0
  7811
				}
sl@0
  7812
			break;
sl@0
  7813
			}
sl@0
  7814
		default:
sl@0
  7815
			{
sl@0
  7816
			ERR_PRINTF2(_L("Invalid DevSound state received: %d"), iDevSoundState);
sl@0
  7817
			StopTest(aError, EFail);
sl@0
  7818
			}
sl@0
  7819
		}
sl@0
  7820
	}
sl@0
  7821
sl@0
  7822
/*
sl@0
  7823
 *========================================================================================================
sl@0
  7824
 * MM-A3F-DEVSOUND-CHRTZ-TONE-0057
sl@0
  7825
 */
sl@0
  7826
RA3FDevSoundTonePlayDTMFStringOnceInitializedToRecordAudioTest::RA3FDevSoundTonePlayDTMFStringOnceInitializedToRecordAudioTest(const TDesC& aTestName)
sl@0
  7827
	:	RA3FDevSoundTestBase(aTestName), iDTMFString(KNullDesC)
sl@0
  7828
	{
sl@0
  7829
	}
sl@0
  7830
sl@0
  7831
RA3FDevSoundTonePlayDTMFStringOnceInitializedToRecordAudioTest* RA3FDevSoundTonePlayDTMFStringOnceInitializedToRecordAudioTest::NewL(const TDesC& aTestName)
sl@0
  7832
	{
sl@0
  7833
	RA3FDevSoundTonePlayDTMFStringOnceInitializedToRecordAudioTest * self = new(ELeave)RA3FDevSoundTonePlayDTMFStringOnceInitializedToRecordAudioTest(aTestName);
sl@0
  7834
	return self;
sl@0
  7835
	}
sl@0
  7836
sl@0
  7837
void RA3FDevSoundTonePlayDTMFStringOnceInitializedToRecordAudioTest::DoKickoffTestL()
sl@0
  7838
	{
sl@0
  7839
	TPtrC DTMF;
sl@0
  7840
	if (!GetStringFromConfig(iTestStepName, KDTMFString, DTMF))
sl@0
  7841
		{
sl@0
  7842
		ERR_PRINTF2(KMsgErrorGetParameter, &KDTMFString);
sl@0
  7843
		StopTest(KErrNotFound);
sl@0
  7844
		return;
sl@0
  7845
		}
sl@0
  7846
	iDTMFString.Copy(DTMF);
sl@0
  7847
	}
sl@0
  7848
sl@0
  7849
void RA3FDevSoundTonePlayDTMFStringOnceInitializedToRecordAudioTest::Fsm(TMmfDevSoundEvent aDevSoundEvent, TInt aError)
sl@0
  7850
	{
sl@0
  7851
	switch(iDevSoundState)
sl@0
  7852
	{
sl@0
  7853
		case EStateCreated:
sl@0
  7854
			{
sl@0
  7855
			__ASSERT_ALWAYS((aError == KErrNone), Panic(_L("RA3FDevSoundTonePlayDTMFStringOnceInitializedToRecordAudioTest"), EFsmIncorrectErrorPassed));
sl@0
  7856
			if (aDevSoundEvent == EEventInitialize)
sl@0
  7857
				{
sl@0
  7858
				INFO_PRINTF1(_L("Calling iMMFDevSound::InitializeL for recording audio files"));
sl@0
  7859
				TRAPD(err, iMMFDevSound->InitializeL(*this, EMMFStateRecording));
sl@0
  7860
				if (err != KErrNone)
sl@0
  7861
					{
sl@0
  7862
					ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"), err);
sl@0
  7863
					StopTest(err);
sl@0
  7864
					break;
sl@0
  7865
					}
sl@0
  7866
				INFO_PRINTF1(_L("DevSound State: EStateInitializing"));
sl@0
  7867
				iDevSoundState = EStateInitializing;
sl@0
  7868
				}
sl@0
  7869
			else
sl@0
  7870
				{
sl@0
  7871
				ERR_PRINTF2(_L("DevSound EEventInitialize not received as expected. Received event: %d"), aDevSoundEvent);
sl@0
  7872
				StopTest(aError, EFail);
sl@0
  7873
				}
sl@0
  7874
			break;
sl@0
  7875
			}
sl@0
  7876
		case EStateInitializing:
sl@0
  7877
			{
sl@0
  7878
			if (aDevSoundEvent == EEventInitComplete && aError == KErrNone)
sl@0
  7879
				{
sl@0
  7880
				INFO_PRINTF2(_L("Calling CMMFDevSound::PlayDTMFStringL %S "), &iDTMFString);
sl@0
  7881
				TRAPD(err, iMMFDevSound->PlayDTMFStringL(iDTMFString));
sl@0
  7882
				if (err	== KErrNotSupported)
sl@0
  7883
					{
sl@0
  7884
					ERR_PRINTF2(_L("CMMFDevSound::PlayDTMFStringL left with KErrNotSupported %d which is the expected error"), err);
sl@0
  7885
					StopTest();
sl@0
  7886
					}
sl@0
  7887
				else
sl@0
  7888
					{
sl@0
  7889
					ERR_PRINTF2(_L("CMMFDevSound::PlayDTMFStringL left with error = %d"), err);
sl@0
  7890
					ERR_PRINTF2(_L("Expected error = %d"), KErrNotSupported);
sl@0
  7891
					StopTest(err, EFail);
sl@0
  7892
					}
sl@0
  7893
				}
sl@0
  7894
			else if (aDevSoundEvent == EEventInitComplete && aError != KErrNone)
sl@0
  7895
				{
sl@0
  7896
				ERR_PRINTF2(_L("DevSound called CMMFDevSound::InitializeComplete with error = %d"), aError);
sl@0
  7897
				StopTest(aError);
sl@0
  7898
				}
sl@0
  7899
			else
sl@0
  7900
				{
sl@0
  7901
				ERR_PRINTF2(_L("DevSound EEventInitComplete not received as expected. Received event: %d"), aDevSoundEvent);
sl@0
  7902
				StopTest(aError, EFail);
sl@0
  7903
				}
sl@0
  7904
			break;
sl@0
  7905
			}
sl@0
  7906
		default:
sl@0
  7907
			{
sl@0
  7908
			ERR_PRINTF2(_L("Invalid DevSound state received: %d"), iDevSoundState);
sl@0
  7909
			StopTest(aError, EFail);
sl@0
  7910
			}
sl@0
  7911
		}
sl@0
  7912
	}
sl@0
  7913
sl@0
  7914
/*
sl@0
  7915
 *========================================================================================================
sl@0
  7916
 * MM-A3F-DEVSOUND-CHRTZ-TONE-0058
sl@0
  7917
 */
sl@0
  7918
RA3FDevSoundTonePlayToneSequenceOnceInitializedToRecordAudioTest::RA3FDevSoundTonePlayToneSequenceOnceInitializedToRecordAudioTest(const TDesC& aTestName)
sl@0
  7919
	:	RA3FDevSoundTestBase(aTestName)
sl@0
  7920
	{
sl@0
  7921
	}
sl@0
  7922
sl@0
  7923
RA3FDevSoundTonePlayToneSequenceOnceInitializedToRecordAudioTest* RA3FDevSoundTonePlayToneSequenceOnceInitializedToRecordAudioTest::NewL(const TDesC& aTestName)
sl@0
  7924
	{
sl@0
  7925
	RA3FDevSoundTonePlayToneSequenceOnceInitializedToRecordAudioTest * self = new(ELeave)RA3FDevSoundTonePlayToneSequenceOnceInitializedToRecordAudioTest(aTestName);
sl@0
  7926
	return self;
sl@0
  7927
	}
sl@0
  7928
void RA3FDevSoundTonePlayToneSequenceOnceInitializedToRecordAudioTest::DoKickoffTestL()
sl@0
  7929
	{
sl@0
  7930
	}
sl@0
  7931
sl@0
  7932
void RA3FDevSoundTonePlayToneSequenceOnceInitializedToRecordAudioTest::Fsm(TMmfDevSoundEvent aDevSoundEvent,  TInt aError)
sl@0
  7933
	{
sl@0
  7934
	switch(iDevSoundState)
sl@0
  7935
		{
sl@0
  7936
		case EStateCreated:
sl@0
  7937
			{
sl@0
  7938
			__ASSERT_ALWAYS((aError == KErrNone), Panic(_L("RA3FDevSoundTonePlayToneSequenceOnceInitializedToRecordAudioTest"), EFsmIncorrectErrorPassed));
sl@0
  7939
			if (aDevSoundEvent == EEventInitialize)
sl@0
  7940
				{
sl@0
  7941
				INFO_PRINTF1(_L("Calling iMMFDevSound::InitializeL for playing audio files"));
sl@0
  7942
				TRAPD(err, iMMFDevSound->InitializeL(*this,  EMMFStateRecording));
sl@0
  7943
				if (err != KErrNone)
sl@0
  7944
					{
sl@0
  7945
					ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"), err);
sl@0
  7946
					StopTest(err);
sl@0
  7947
					break;
sl@0
  7948
					}
sl@0
  7949
				INFO_PRINTF1(_L("DevSound State: EStateInitializing"));
sl@0
  7950
				iDevSoundState = EStateInitializing;
sl@0
  7951
				}
sl@0
  7952
			else
sl@0
  7953
				{
sl@0
  7954
				ERR_PRINTF2(_L("DevSound EEventInitialize not received as expected. Received event: %d"), aDevSoundEvent);
sl@0
  7955
				StopTest(aError, EFail);
sl@0
  7956
				}
sl@0
  7957
			break;
sl@0
  7958
			}
sl@0
  7959
		case EStateInitializing:
sl@0
  7960
			{
sl@0
  7961
			if (aDevSoundEvent == EEventInitComplete && aError == KErrNone)
sl@0
  7962
				{
sl@0
  7963
				TUint8* tablePointer = const_cast<TUint8*>( &(KFixedSequenceTestSequenceDataX[0] ) );
sl@0
  7964
				TPtrC8 KFixedSequenceData(tablePointer,  sizeof(KFixedSequenceTestSequenceDataX));
sl@0
  7965
				INFO_PRINTF1(_L("Calling CMMFDevSound::PlayToneSequenceL"));
sl@0
  7966
				TRAPD(err,  iMMFDevSound->PlayToneSequenceL(KFixedSequenceData));
sl@0
  7967
				if (err == KErrNotSupported)
sl@0
  7968
					{
sl@0
  7969
					ERR_PRINTF2(_L("CMMFDevSound::PlayToneSequenceL left with KErrNotSupported %d which is the expected error"), err);
sl@0
  7970
					StopTest(err, EPass);
sl@0
  7971
					}
sl@0
  7972
				else
sl@0
  7973
					{
sl@0
  7974
					ERR_PRINTF2(_L("Play  dual tone failed with error = %d"),  err);
sl@0
  7975
					ERR_PRINTF2(_L("Expected error = %d"), KErrNotSupported);
sl@0
  7976
					StopTest(err, EFail);
sl@0
  7977
					}
sl@0
  7978
				}
sl@0
  7979
			else if (aDevSoundEvent == EEventInitComplete && aError != KErrNone)
sl@0
  7980
				{
sl@0
  7981
				ERR_PRINTF2(_L("DevSound called CMMFDevSound::InitializeComplete with error = %d"), aError);
sl@0
  7982
				StopTest(aError);
sl@0
  7983
				}
sl@0
  7984
			else
sl@0
  7985
				{
sl@0
  7986
				ERR_PRINTF2(_L("DevSound EEventInitComplete not received as expected. Received event: %d"), aDevSoundEvent);
sl@0
  7987
				StopTest(aError, EFail);
sl@0
  7988
				}
sl@0
  7989
			break;
sl@0
  7990
			}
sl@0
  7991
		default:
sl@0
  7992
			{
sl@0
  7993
			ERR_PRINTF2(_L("Invalid DevSound state received: %d"), iDevSoundState);
sl@0
  7994
			StopTest(aError, EFail);
sl@0
  7995
			}
sl@0
  7996
		}
sl@0
  7997
	}
sl@0
  7998
sl@0
  7999
/*
sl@0
  8000
 *========================================================================================================
sl@0
  8001
 * MM-A3F-DEVSOUND-CHRTZ-TONE-0059
sl@0
  8002
 */
sl@0
  8003
RA3FDevSoundTonePlayToneWithoutCallingInitializeTest::RA3FDevSoundTonePlayToneWithoutCallingInitializeTest(const TDesC& aTestName)
sl@0
  8004
	:	RA3FDevSoundTestBase(aTestName), iDuration(0),
sl@0
  8005
		iFrequencyTone1(0)
sl@0
  8006
	{
sl@0
  8007
	}
sl@0
  8008
sl@0
  8009
RA3FDevSoundTonePlayToneWithoutCallingInitializeTest* RA3FDevSoundTonePlayToneWithoutCallingInitializeTest::NewL(const TDesC& aTestName)
sl@0
  8010
	{
sl@0
  8011
	RA3FDevSoundTonePlayToneWithoutCallingInitializeTest * self = new(ELeave)RA3FDevSoundTonePlayToneWithoutCallingInitializeTest(aTestName);
sl@0
  8012
	return self;
sl@0
  8013
	}
sl@0
  8014
sl@0
  8015
void RA3FDevSoundTonePlayToneWithoutCallingInitializeTest::DoKickoffTestL()
sl@0
  8016
	{
sl@0
  8017
	if (!GetIntFromConfig(iTestStepName, KDuration, iDuration))
sl@0
  8018
		{
sl@0
  8019
		ERR_PRINTF2(KMsgErrorGetParameter, &KDuration);
sl@0
  8020
		StopTest(KErrNotFound);
sl@0
  8021
		return;
sl@0
  8022
		}
sl@0
  8023
	if (!GetIntFromConfig(iTestStepName, KFrequencyTone1, iFrequencyTone1))
sl@0
  8024
		{
sl@0
  8025
		ERR_PRINTF2(KMsgErrorGetParameter, &KFrequencyTone1);
sl@0
  8026
		StopTest(KErrNotFound);
sl@0
  8027
		return;
sl@0
  8028
		}
sl@0
  8029
	}
sl@0
  8030
sl@0
  8031
void RA3FDevSoundTonePlayToneWithoutCallingInitializeTest::Fsm(TMmfDevSoundEvent aDevSoundEvent,  TInt aError)
sl@0
  8032
	{
sl@0
  8033
	switch (iDevSoundState)
sl@0
  8034
		{
sl@0
  8035
		case EStateCreated:
sl@0
  8036
			{
sl@0
  8037
			__ASSERT_ALWAYS((aError == KErrNone), Panic(_L("RA3FDevSoundTonePlayToneWithoutCallingInitializeTest"), EFsmIncorrectErrorPassed));
sl@0
  8038
			if (aDevSoundEvent == EEventInitialize)
sl@0
  8039
				{
sl@0
  8040
				INFO_PRINTF3(_L("Calling CMMFDevSound::PlayToneL using %d Hz during %d secs"), iFrequencyTone1, iDuration);
sl@0
  8041
				TRAPD(err, iMMFDevSound->PlayToneL(iFrequencyTone1, iDuration*KMicroSecsInOneSec));
sl@0
  8042
				if (err	== KErrNotReady)
sl@0
  8043
					{
sl@0
  8044
					ERR_PRINTF2(_L("CMMFDevSound::PlayToneL left with KErrNotReady %d which is the expected error"), err);
sl@0
  8045
					StopTest();
sl@0
  8046
					}
sl@0
  8047
				else
sl@0
  8048
					{
sl@0
  8049
					ERR_PRINTF2(_L("CMMFDevSound::PlayToneL left with error = %d"), err);
sl@0
  8050
					ERR_PRINTF2(_L("Expected error = %d"), KErrNotReady);
sl@0
  8051
					StopTest(err, EFail);
sl@0
  8052
					}
sl@0
  8053
				}
sl@0
  8054
			else if (aDevSoundEvent == EEventInitComplete && aError != KErrNone)
sl@0
  8055
				{
sl@0
  8056
				ERR_PRINTF2(_L("DevSound called CMMFDevSound::InitializeComplete with error = %d"), aError);
sl@0
  8057
				StopTest(aError);
sl@0
  8058
				}
sl@0
  8059
			else
sl@0
  8060
				{
sl@0
  8061
				ERR_PRINTF2(_L("DevSound EEventInitComplete not received as expected. Received event: %d"), aDevSoundEvent);
sl@0
  8062
				StopTest(aError, EFail);
sl@0
  8063
				}
sl@0
  8064
			break;
sl@0
  8065
			}
sl@0
  8066
		default:
sl@0
  8067
			{
sl@0
  8068
			ERR_PRINTF2(_L("Invalid DevSound state received: %d"),  iDevSoundState);
sl@0
  8069
			StopTest(aError, EFail);
sl@0
  8070
			}
sl@0
  8071
		}
sl@0
  8072
	}
sl@0
  8073
sl@0
  8074
/*
sl@0
  8075
 *========================================================================================================
sl@0
  8076
 * MM-A3F-DEVSOUND-CHRTZ-TONE-0060
sl@0
  8077
 */
sl@0
  8078
RA3FDevSoundTonePlayDualToneWithoutCallingInitializeTest::RA3FDevSoundTonePlayDualToneWithoutCallingInitializeTest(const TDesC& aTestName)
sl@0
  8079
	:	RA3FDevSoundTestBase(aTestName), iDuration(0),
sl@0
  8080
		iFrequencyTone1(0), iFrequencyTone2(0)
sl@0
  8081
	{
sl@0
  8082
	}
sl@0
  8083
sl@0
  8084
RA3FDevSoundTonePlayDualToneWithoutCallingInitializeTest* RA3FDevSoundTonePlayDualToneWithoutCallingInitializeTest::NewL(const TDesC& aTestName)
sl@0
  8085
	{
sl@0
  8086
	RA3FDevSoundTonePlayDualToneWithoutCallingInitializeTest * self = new(ELeave)RA3FDevSoundTonePlayDualToneWithoutCallingInitializeTest(aTestName);
sl@0
  8087
	return self;
sl@0
  8088
	}
sl@0
  8089
sl@0
  8090
void RA3FDevSoundTonePlayDualToneWithoutCallingInitializeTest::DoKickoffTestL()
sl@0
  8091
	{
sl@0
  8092
	if (!GetIntFromConfig(iTestStepName, KDuration, iDuration))
sl@0
  8093
		{
sl@0
  8094
		ERR_PRINTF2(KMsgErrorGetParameter, &KDuration);
sl@0
  8095
		StopTest(KErrNotFound);
sl@0
  8096
		return;
sl@0
  8097
		}
sl@0
  8098
	if (!GetIntFromConfig(iTestStepName, KFrequencyTone1, iFrequencyTone1))
sl@0
  8099
		{
sl@0
  8100
		ERR_PRINTF2(KMsgErrorGetParameter, &KFrequencyTone1);
sl@0
  8101
		StopTest(KErrNotFound);
sl@0
  8102
		return;
sl@0
  8103
		}
sl@0
  8104
	if (!GetIntFromConfig(iTestStepName, KFrequencyTone2, iFrequencyTone2))
sl@0
  8105
		{
sl@0
  8106
		ERR_PRINTF2(KMsgErrorGetParameter, &KFrequencyTone2);
sl@0
  8107
		StopTest(KErrNotFound);
sl@0
  8108
		return;
sl@0
  8109
		}
sl@0
  8110
	}
sl@0
  8111
sl@0
  8112
void RA3FDevSoundTonePlayDualToneWithoutCallingInitializeTest::Fsm(TMmfDevSoundEvent aDevSoundEvent, TInt aError)
sl@0
  8113
	{
sl@0
  8114
	switch (iDevSoundState)
sl@0
  8115
		{
sl@0
  8116
		case EStateCreated:
sl@0
  8117
			{
sl@0
  8118
			__ASSERT_ALWAYS((aError == KErrNone), Panic(_L("RA3FDevSoundTonePlayDualToneWithoutCallingInitializeTest"), EFsmIncorrectErrorPassed));
sl@0
  8119
			if (aDevSoundEvent == EEventInitialize)
sl@0
  8120
				{
sl@0
  8121
				INFO_PRINTF4(_L("Calling CMMFDevSound::PlayDualToneL using %d Hz %d Hz during %d secs "), iFrequencyTone1, iFrequencyTone2, iDuration);
sl@0
  8122
				TRAPD(err, iMMFDevSound->PlayDualToneL(iFrequencyTone1, iFrequencyTone2, iDuration*KMicroSecsInOneSec));
sl@0
  8123
				if (err == KErrNotReady)
sl@0
  8124
					{
sl@0
  8125
					ERR_PRINTF2(_L("CMMFDevSound::PlayDualToneL left with KErrNotReady %d which is the expected error"), err);
sl@0
  8126
					StopTest();
sl@0
  8127
					}
sl@0
  8128
				else
sl@0
  8129
					{
sl@0
  8130
					ERR_PRINTF2(_L("CMMFDevSound::PlayDualToneL left with error = %d"), err);
sl@0
  8131
					ERR_PRINTF2(_L("Expected error = %d"), KErrNotReady);
sl@0
  8132
					StopTest(err, EFail);
sl@0
  8133
					}
sl@0
  8134
				}
sl@0
  8135
			else if (aDevSoundEvent == EEventInitComplete && aError != KErrNone)
sl@0
  8136
				{
sl@0
  8137
				ERR_PRINTF2(_L("DevSound called CMMFDevSound::InitializeComplete with error = %d"), aError);
sl@0
  8138
				StopTest(aError);
sl@0
  8139
				}
sl@0
  8140
			else
sl@0
  8141
				{
sl@0
  8142
				ERR_PRINTF2(_L("DevSound EEventInitComplete not received as expected. Received event: %d"), aDevSoundEvent);
sl@0
  8143
				StopTest(aError, EFail);
sl@0
  8144
				}
sl@0
  8145
			break;
sl@0
  8146
			}
sl@0
  8147
		default:
sl@0
  8148
			{
sl@0
  8149
			ERR_PRINTF2(_L("Invalid DevSound state received: %d"), iDevSoundState);
sl@0
  8150
			StopTest(aError, EFail);
sl@0
  8151
			}
sl@0
  8152
		}
sl@0
  8153
	}
sl@0
  8154
sl@0
  8155
/*
sl@0
  8156
 *========================================================================================================
sl@0
  8157
 * MM-A3F-DEVSOUND-CHRTZ-TONE-0061
sl@0
  8158
 */
sl@0
  8159
RA3FDevSoundTonePlayDTMFStringWithoutCallingInitializeTest::RA3FDevSoundTonePlayDTMFStringWithoutCallingInitializeTest(const TDesC& aTestName)
sl@0
  8160
	:	RA3FDevSoundTestBase(aTestName), iDTMFString(KNullDesC)
sl@0
  8161
	{
sl@0
  8162
	}
sl@0
  8163
sl@0
  8164
RA3FDevSoundTonePlayDTMFStringWithoutCallingInitializeTest* RA3FDevSoundTonePlayDTMFStringWithoutCallingInitializeTest::NewL(const TDesC& aTestName)
sl@0
  8165
	{
sl@0
  8166
	RA3FDevSoundTonePlayDTMFStringWithoutCallingInitializeTest * self = new(ELeave)RA3FDevSoundTonePlayDTMFStringWithoutCallingInitializeTest(aTestName);
sl@0
  8167
	return self;
sl@0
  8168
	}
sl@0
  8169
sl@0
  8170
void RA3FDevSoundTonePlayDTMFStringWithoutCallingInitializeTest::DoKickoffTestL()
sl@0
  8171
	{
sl@0
  8172
	TPtrC DTMF;
sl@0
  8173
	if (!GetStringFromConfig(iTestStepName, KDTMFString, DTMF))
sl@0
  8174
		{
sl@0
  8175
		ERR_PRINTF2(KMsgErrorGetParameter, &KDTMFString);
sl@0
  8176
		StopTest(KErrNotFound);
sl@0
  8177
		return;
sl@0
  8178
		}
sl@0
  8179
	iDTMFString.Copy(DTMF);
sl@0
  8180
	}
sl@0
  8181
sl@0
  8182
void RA3FDevSoundTonePlayDTMFStringWithoutCallingInitializeTest::Fsm(TMmfDevSoundEvent aDevSoundEvent,  TInt aError)
sl@0
  8183
	{
sl@0
  8184
	switch (iDevSoundState)
sl@0
  8185
		{
sl@0
  8186
		case EStateCreated:
sl@0
  8187
			{
sl@0
  8188
			__ASSERT_ALWAYS((aError == KErrNone), Panic(_L("RA3FDevSoundTonePlayDTMFStringWithoutCallingInitializeTest"), EFsmIncorrectErrorPassed));
sl@0
  8189
			if (aDevSoundEvent == EEventInitialize)
sl@0
  8190
				{
sl@0
  8191
				INFO_PRINTF2(_L("Calling CMMFDevSound::PlayDTMFStringL %S"), &iDTMFString);
sl@0
  8192
				TRAPD(err, iMMFDevSound->PlayDTMFStringL(iDTMFString));
sl@0
  8193
				if (err == KErrNotReady)
sl@0
  8194
					{
sl@0
  8195
					ERR_PRINTF2(_L("CMMFDevSound::PlayDTMFStringL left with KErrNotReady %d which is the expected error"), err);
sl@0
  8196
					StopTest();
sl@0
  8197
					}
sl@0
  8198
				else
sl@0
  8199
					{
sl@0
  8200
					ERR_PRINTF2(_L("CMMFDevSound::PlayDTMFStringL left with error = %d"), err);
sl@0
  8201
					ERR_PRINTF2(_L("Expected error = %d"), KErrNotReady);
sl@0
  8202
					StopTest(err, EFail);
sl@0
  8203
					}
sl@0
  8204
				}
sl@0
  8205
			else if (aDevSoundEvent == EEventInitComplete && aError != KErrNone)
sl@0
  8206
				{
sl@0
  8207
				ERR_PRINTF2(_L("DevSound called CMMFDevSound::InitializeComplete with error = %d"), aError);
sl@0
  8208
				StopTest(aError);
sl@0
  8209
				}
sl@0
  8210
			else
sl@0
  8211
				{
sl@0
  8212
				ERR_PRINTF2(_L("DevSound EEventInitComplete not received as expected. Received event: %d"), aDevSoundEvent);
sl@0
  8213
				StopTest(aError, EFail);
sl@0
  8214
				}
sl@0
  8215
			break;
sl@0
  8216
			}
sl@0
  8217
		default:
sl@0
  8218
			{
sl@0
  8219
			ERR_PRINTF2(_L("Invalid DevSound state received: %d"), iDevSoundState);
sl@0
  8220
			StopTest(aError, EFail);
sl@0
  8221
			}
sl@0
  8222
		}
sl@0
  8223
	}
sl@0
  8224
sl@0
  8225
/*
sl@0
  8226
 *========================================================================================================
sl@0
  8227
 * MM-A3F-DEVSOUND-CHRTZ-TONE-0062
sl@0
  8228
 */
sl@0
  8229
RA3FDevSoundTonePlayToneSequenceWithoutCallingInitializeTest::RA3FDevSoundTonePlayToneSequenceWithoutCallingInitializeTest(const TDesC& aTestName)
sl@0
  8230
	:	RA3FDevSoundTestBase(aTestName)
sl@0
  8231
	{
sl@0
  8232
	}
sl@0
  8233
sl@0
  8234
RA3FDevSoundTonePlayToneSequenceWithoutCallingInitializeTest* RA3FDevSoundTonePlayToneSequenceWithoutCallingInitializeTest::NewL(const TDesC& aTestName)
sl@0
  8235
	{
sl@0
  8236
	RA3FDevSoundTonePlayToneSequenceWithoutCallingInitializeTest * self = new(ELeave)RA3FDevSoundTonePlayToneSequenceWithoutCallingInitializeTest(aTestName);
sl@0
  8237
	return self;
sl@0
  8238
	}
sl@0
  8239
sl@0
  8240
void RA3FDevSoundTonePlayToneSequenceWithoutCallingInitializeTest::DoKickoffTestL()
sl@0
  8241
	{
sl@0
  8242
	}
sl@0
  8243
sl@0
  8244
void RA3FDevSoundTonePlayToneSequenceWithoutCallingInitializeTest::Fsm(TMmfDevSoundEvent aDevSoundEvent, TInt aError)
sl@0
  8245
	{
sl@0
  8246
	switch (iDevSoundState)
sl@0
  8247
		{
sl@0
  8248
		case EStateCreated:
sl@0
  8249
			{
sl@0
  8250
			__ASSERT_ALWAYS((aError == KErrNone), Panic(_L("RA3FDevSoundTonePlayToneSequenceWithoutCallingInitializeTest"), EFsmIncorrectErrorPassed));
sl@0
  8251
			if (aDevSoundEvent == EEventInitialize)
sl@0
  8252
				{
sl@0
  8253
				TUint8* tablePointer = const_cast<TUint8*>( &(KFixedSequenceTestSequenceDataX[0] ) );
sl@0
  8254
				TPtrC8 KFixedSequenceData(tablePointer,  sizeof(KFixedSequenceTestSequenceDataX));
sl@0
  8255
				INFO_PRINTF1(_L("Calling CMMFDevSound::PlayToneSequenceL"));
sl@0
  8256
				TRAPD(err, iMMFDevSound->PlayToneSequenceL(KFixedSequenceData));
sl@0
  8257
				if (err == KErrNotReady)
sl@0
  8258
					{
sl@0
  8259
					ERR_PRINTF2(_L("CMMFDevSound::PlayToneSequenceL left with KErrNotReady %d which is the expected error"), err);
sl@0
  8260
					StopTest();
sl@0
  8261
					}
sl@0
  8262
				else
sl@0
  8263
					{
sl@0
  8264
					ERR_PRINTF2(_L("CMMFDevSound::PlayToneSequenceL left with error = %d"), err);
sl@0
  8265
					ERR_PRINTF2(_L("Expected error = %d"), KErrNotReady);
sl@0
  8266
					StopTest(err, EFail);
sl@0
  8267
					}
sl@0
  8268
				}
sl@0
  8269
			else if (aDevSoundEvent == EEventInitComplete && aError != KErrNone)
sl@0
  8270
				{
sl@0
  8271
				ERR_PRINTF2(_L("DevSound called CMMFDevSound::InitializeComplete with error = %d"), aError);
sl@0
  8272
				StopTest(aError);
sl@0
  8273
				}
sl@0
  8274
			else
sl@0
  8275
				{
sl@0
  8276
				ERR_PRINTF2(_L("DevSound EEventInitComplete not received as expected. Received event: %d"), aDevSoundEvent);
sl@0
  8277
				StopTest(aError, EFail);
sl@0
  8278
				}
sl@0
  8279
			break;
sl@0
  8280
			}
sl@0
  8281
		default:
sl@0
  8282
			{
sl@0
  8283
			ERR_PRINTF2(_L("Invalid DevSound state received: %d"), iDevSoundState);
sl@0
  8284
			StopTest(aError, EFail);
sl@0
  8285
			}
sl@0
  8286
		}
sl@0
  8287
	}
sl@0
  8288
sl@0
  8289
/*
sl@0
  8290
 *========================================================================================================
sl@0
  8291
 * MM-A3F-DEVSOUND-CHRTZ-TONE-0063
sl@0
  8292
 */
sl@0
  8293
RA3FDevSoundTonePlayToneSequenceUsingInvalidDescriptorTest::RA3FDevSoundTonePlayToneSequenceUsingInvalidDescriptorTest(const TDesC& aTestName)
sl@0
  8294
	:	RA3FDevSoundTestBase(aTestName), iInvalidToneSequence(KNullDesC8)
sl@0
  8295
	{
sl@0
  8296
	}
sl@0
  8297
sl@0
  8298
RA3FDevSoundTonePlayToneSequenceUsingInvalidDescriptorTest* RA3FDevSoundTonePlayToneSequenceUsingInvalidDescriptorTest::NewL(const TDesC& aTestName)
sl@0
  8299
	{
sl@0
  8300
	RA3FDevSoundTonePlayToneSequenceUsingInvalidDescriptorTest * self = new(ELeave)RA3FDevSoundTonePlayToneSequenceUsingInvalidDescriptorTest(aTestName);
sl@0
  8301
	return self;
sl@0
  8302
	}
sl@0
  8303
sl@0
  8304
void RA3FDevSoundTonePlayToneSequenceUsingInvalidDescriptorTest::DoKickoffTestL()
sl@0
  8305
	{
sl@0
  8306
	TPtrC TS;
sl@0
  8307
	if ( !GetStringFromConfig(iTestStepName, KInvalidToneSequence,  TS) )
sl@0
  8308
		{
sl@0
  8309
		ERR_PRINTF2(KMsgErrorGetParameter, &KInvalidToneSequence);
sl@0
  8310
		StopTest(KErrNotFound);
sl@0
  8311
		return;
sl@0
  8312
		}
sl@0
  8313
	iInvalidToneSequence.Copy(TS);
sl@0
  8314
	}
sl@0
  8315
sl@0
  8316
void RA3FDevSoundTonePlayToneSequenceUsingInvalidDescriptorTest::Fsm(TMmfDevSoundEvent aDevSoundEvent,  TInt aError)
sl@0
  8317
	{
sl@0
  8318
	switch (iDevSoundState)
sl@0
  8319
		{
sl@0
  8320
		case EStateCreated:
sl@0
  8321
			{
sl@0
  8322
			__ASSERT_ALWAYS((aError == KErrNone), Panic(_L("RA3FDevSoundTonePlayToneSequenceUsingInvalidDescriptorTest"), EFsmIncorrectErrorPassed));
sl@0
  8323
			if (aDevSoundEvent == EEventInitialize)
sl@0
  8324
				{
sl@0
  8325
				INFO_PRINTF1(_L("Calling iMMFDevSound::InitializeL"));
sl@0
  8326
				TRAPD(err, iMMFDevSound->InitializeL(*this, EMMFStateTonePlaying));
sl@0
  8327
				if (err != KErrNone)
sl@0
  8328
					{
sl@0
  8329
					ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"),  err);
sl@0
  8330
					StopTest(err);
sl@0
  8331
					break;
sl@0
  8332
					}
sl@0
  8333
				INFO_PRINTF1(_L("DevSound State: EStateInitializing"));
sl@0
  8334
				iDevSoundState = EStateInitializing;
sl@0
  8335
				}
sl@0
  8336
			else
sl@0
  8337
				{
sl@0
  8338
				ERR_PRINTF2(_L("DevSound EEventInitialize not received as expected. Received event: %d"), aDevSoundEvent);
sl@0
  8339
				StopTest(aError, EFail);
sl@0
  8340
				}
sl@0
  8341
			break;
sl@0
  8342
			}
sl@0
  8343
		case EStateInitializing:
sl@0
  8344
			{
sl@0
  8345
			if (aDevSoundEvent == EEventInitComplete && aError == KErrNone)
sl@0
  8346
				{
sl@0
  8347
				INFO_PRINTF1(_L("Calling iMMFDevSound->PlayToneSequenceL with an invalid descriptor as argument"));
sl@0
  8348
				TRAPD(err, iMMFDevSound->PlayToneSequenceL(iInvalidToneSequence));
sl@0
  8349
				if (err != KErrNone)
sl@0
  8350
					{
sl@0
  8351
					ERR_PRINTF2(_L("CMMFDevSound::PlayToneSequenceL left with error = %d and it should not leave"), err);
sl@0
  8352
					StopTest(err, EFail);
sl@0
  8353
					}
sl@0
  8354
				}
sl@0
  8355
			else if (aDevSoundEvent == EEventInitComplete && aError != KErrNone)
sl@0
  8356
				{
sl@0
  8357
				ERR_PRINTF2(_L("DevSound called CMMFDevSound::InitializeComplete with error = %d"), aError);
sl@0
  8358
				StopTest(aError);
sl@0
  8359
				}
sl@0
  8360
			else
sl@0
  8361
				{
sl@0
  8362
				ERR_PRINTF2(_L("DevSound EEventInitComplete not received as expected. Received event: %d"), aDevSoundEvent);
sl@0
  8363
				StopTest(aError, EFail);
sl@0
  8364
				}
sl@0
  8365
			break;
sl@0
  8366
			}
sl@0
  8367
		default:
sl@0
  8368
			{
sl@0
  8369
			ERR_PRINTF2(_L("Invalid DevSound state received: %d"), iDevSoundState);
sl@0
  8370
			StopTest(aError, EFail);
sl@0
  8371
			}
sl@0
  8372
		}
sl@0
  8373
	}
sl@0
  8374
sl@0
  8375
void RA3FDevSoundTonePlayToneSequenceUsingInvalidDescriptorTest::ToneFinished(TInt aError)
sl@0
  8376
	{
sl@0
  8377
	INFO_PRINTF1(_L("========== DevSound ToneFinished() callback =========="));
sl@0
  8378
	if (aError == KErrCorrupt)
sl@0
  8379
		{
sl@0
  8380
		INFO_PRINTF2(_L("ToneFinished called with KErrCorrupt %d which is the expected error"), aError);
sl@0
  8381
		StopTest();
sl@0
  8382
		}
sl@0
  8383
	else
sl@0
  8384
		{
sl@0
  8385
		ERR_PRINTF3(_L("ToneFinished called with error = %d, when the expected error is = %d"), aError, KErrCorrupt);
sl@0
  8386
		StopTest(aError, EFail);
sl@0
  8387
		}
sl@0
  8388
	}
sl@0
  8389