devsound/a3fcharacterisationtest/src/char_a3f_devsound_tonetest.cpp
author hgs
Fri, 09 Jul 2010 12:53:09 +0100
changeset 31 ae0addfe117e
parent 26 c36d67f77f75
child 38 4269ca484c7b
permissions -rw-r--r--
2010wk25_07
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
26
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
     1
// Copyright (c) 2008-2009 Nokia Corporation and/or its subsidiary(-ies).
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
     2
// All rights reserved.
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
     3
// This component and the accompanying materials are made available
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
     4
// under the terms of "Eclipse Public License v1.0"
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
     5
// which accompanies this distribution, and is available
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
     6
// at the URL "http://www.eclipse.org/legal/epl-v10.html".
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
     7
//
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
     8
// Initial Contributors:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
     9
// Nokia Corporation - initial contribution.
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
    10
//
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
    11
// Contributors:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
    12
//
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
    13
// Description:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
    14
//
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
    15
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
    16
#include "char_a3f_devsound_tonetest.h"
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
    17
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
    18
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
    19
/*
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
    20
 *========================================================================================================
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
    21
 * MM-A3F-DEVSOUND-CHRTZ-TONE-0001
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
    22
 */
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
    23
RA3FDevSoundToneSetConfigTest::RA3FDevSoundToneSetConfigTest(const TDesC& aTestName)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
    24
	:	RA3FDevSoundTestBase(aTestName), iSampleRate(0),
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
    25
		iChannels(0)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
    26
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
    27
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
    28
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
    29
RA3FDevSoundToneSetConfigTest* RA3FDevSoundToneSetConfigTest::NewL(const TDesC& aTestName)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
    30
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
    31
	RA3FDevSoundToneSetConfigTest * self = new(ELeave)RA3FDevSoundToneSetConfigTest(aTestName);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
    32
	return self; 
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
    33
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
    34
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
    35
void RA3FDevSoundToneSetConfigTest::DoKickoffTestL()
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
    36
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
    37
	if (!GetIntFromConfig(iTestStepName, KSampleRate, iSampleRate))
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
    38
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
    39
		ERR_PRINTF2(KMsgErrorGetParameter, &KSampleRate);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
    40
		StopTest(KErrNotFound);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
    41
		return;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
    42
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
    43
	if (!GetIntFromConfig(iTestStepName, KChannel, iChannels))
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
    44
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
    45
		ERR_PRINTF2(KMsgErrorGetParameter, &KChannel);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
    46
		StopTest(KErrNotFound);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
    47
		return;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
    48
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
    49
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
    50
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
    51
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
    52
void RA3FDevSoundToneSetConfigTest::Fsm(TMmfDevSoundEvent aDevSoundEvent, TInt aError)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
    53
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
    54
	switch(iDevSoundState)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
    55
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
    56
		case EStateCreated:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
    57
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
    58
			if(aDevSoundEvent == EEventInitialize)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
    59
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
    60
				__ASSERT_ALWAYS((aError == KErrNone), Panic(_L("RA3FDevSoundToneSetConfigTest"), EFsmIncorrectErrorPassed));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
    61
				INFO_PRINTF1(_L("Calling CMMFDevSound::InitializeL"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
    62
				TRAPD(err, iMMFDevSound->InitializeL(*this, EMMFStateTonePlaying));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
    63
				if (err != KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
    64
					{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
    65
					ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"), err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
    66
					StopTest(err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
    67
					break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
    68
					}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
    69
				INFO_PRINTF1(_L("DevSound State: EStateInitializing"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
    70
				iDevSoundState = EStateInitializing;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
    71
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
    72
			else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
    73
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
    74
				ERR_PRINTF2(_L("DevSound EEventInitialize not received as expected. Received event: %d"), aDevSoundEvent);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
    75
				StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
    76
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
    77
			break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
    78
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
    79
		case EStateInitializing:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
    80
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
    81
			if (aDevSoundEvent == EEventInitComplete && aError == KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
    82
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
    83
				TMMFCapabilities capabilitiesSet;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
    84
				TBuf<KMaxSampleRateStringLength> stringSampleRateSet;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
    85
				TBuf<KMaxChannelsStringLength> stringChannelsSet;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
    86
				TMMFSampleRate eSampleRate;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
    87
				SampleRateFromTIntToTMMFSampleRate (iSampleRate, eSampleRate);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
    88
				capabilitiesSet.iRate = eSampleRate;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
    89
				capabilitiesSet.iChannels = iChannels;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
    90
				SampleRateFromTUintToString (capabilitiesSet.iRate,	stringSampleRateSet);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
    91
				ChannelsFromTUintToString (capabilitiesSet.iChannels, stringChannelsSet);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
    92
				INFO_PRINTF3(_L("Calling CMMFDevSound::SetConfigL using sample rate = %S and channel mode =%S"), &stringSampleRateSet, &stringChannelsSet);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
    93
				TRAPD(err, iMMFDevSound->SetConfigL(capabilitiesSet));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
    94
				if (err != KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
    95
					{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
    96
					ERR_PRINTF2(_L("CMMFDevSound::SetConfigL left with error = %d"), err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
    97
					StopTest(err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
    98
					break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
    99
					}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   100
				TMMFCapabilities capabilitiesGet;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   101
				TBuf<KMaxSampleRateStringLength> stringSampleRateGet;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   102
				TBuf<KMaxChannelsStringLength> stringChannelsGet;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   103
				capabilitiesGet=iMMFDevSound->Config();
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   104
				SampleRateFromTUintToString (capabilitiesGet.iRate, stringSampleRateGet);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   105
				ChannelsFromTUintToString (capabilitiesGet.iChannels, stringChannelsGet);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   106
				if (capabilitiesGet.iRate != capabilitiesSet.iRate && capabilitiesGet.iChannels != capabilitiesSet.iChannels)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   107
					{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   108
					ERR_PRINTF3(_L("Retrieved sample rate and channel %S %S"), &stringSampleRateGet, &stringChannelsGet);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   109
					ERR_PRINTF3(_L("Expected %S %S"), &stringSampleRateSet, &stringChannelsSet);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   110
					StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   111
					break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   112
					}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   113
				INFO_PRINTF1(_L("========== Test Case Successfully Completed =========="));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   114
				StopTest();
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   115
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   116
			else if (aDevSoundEvent == EEventInitComplete && aError != KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   117
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   118
				ERR_PRINTF2(_L("DevSound called CMMFDevSound::InitializeComplete with error = %d"), aError);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   119
				StopTest(aError);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   120
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   121
			else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   122
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   123
				ERR_PRINTF2(_L("DevSound EEventInitComplete not received as expected. Received event: %d"), aDevSoundEvent);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   124
				StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   125
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   126
			break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   127
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   128
		default:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   129
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   130
			ERR_PRINTF2(_L("Invalid DevSound state received: %d"), iDevSoundState);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   131
			StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   132
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   133
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   134
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   135
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   136
/*
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   137
 *========================================================================================================
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   138
 * MM-A3F-DEVSOUND-CHRTZ-TONE-0002
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   139
 */
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   140
RA3FDevSoundToneSetPrioritySettingsTest::RA3FDevSoundToneSetPrioritySettingsTest(const TDesC& aTestName)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   141
	:	RA3FDevSoundTestBase(aTestName), iPriority(0)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   142
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   143
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   144
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   145
RA3FDevSoundToneSetPrioritySettingsTest* RA3FDevSoundToneSetPrioritySettingsTest::NewL(const TDesC& aTestName)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   146
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   147
	RA3FDevSoundToneSetPrioritySettingsTest * self = new(ELeave)RA3FDevSoundToneSetPrioritySettingsTest(aTestName);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   148
	return self;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   149
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   150
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   151
void RA3FDevSoundToneSetPrioritySettingsTest::DoKickoffTestL()
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   152
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   153
	if (!GetIntFromConfig(iTestStepName, KPriority, iPriority)) 
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   154
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   155
		ERR_PRINTF2(KMsgErrorGetParameter, &KPriority);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   156
		StopTest(KErrUnknown);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   157
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   158
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   159
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   160
void RA3FDevSoundToneSetPrioritySettingsTest::Fsm(TMmfDevSoundEvent aDevSoundEvent, TInt aError)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   161
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   162
	switch (iDevSoundState)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   163
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   164
		case EStateCreated:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   165
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   166
			if (aDevSoundEvent == EEventInitialize)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   167
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   168
				__ASSERT_ALWAYS((aError == KErrNone), Panic(_L("RA3FDevSoundToneSetPrioritySettingsTest"), EFsmIncorrectErrorPassed));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   169
				INFO_PRINTF1(_L("Calling CMMFDevSound::InitializeL"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   170
				TRAPD(err, iMMFDevSound->InitializeL(*this, EMMFStateTonePlaying));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   171
				if (err != KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   172
					{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   173
					ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"), err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   174
					StopTest(err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   175
					break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   176
					}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   177
				INFO_PRINTF1(_L("DevSound State: EStateInitializing"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   178
				iDevSoundState = EStateInitializing;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   179
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   180
			else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   181
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   182
				ERR_PRINTF2(_L("DevSound EEventInitialize not received as expected. Received event: %d"), aDevSoundEvent);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   183
				StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   184
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   185
			break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   186
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   187
		case EStateInitializing:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   188
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   189
			if (aDevSoundEvent == EEventInitComplete && aError == KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   190
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   191
				TMMFPrioritySettings priority;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   192
				priority.iPriority = iPriority;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   193
				INFO_PRINTF2(_L("Calling CMMFDevSound::SetPrioritySettings using a priority value = %d"), iPriority);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   194
				iMMFDevSound->SetPrioritySettings (priority);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   195
				INFO_PRINTF1(_L("========== Test Case Successfully Completed =========="));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   196
				StopTest();
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   197
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   198
			else if (aDevSoundEvent == EEventInitComplete && aError != KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   199
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   200
				ERR_PRINTF2(_L("DevSound called CMMFDevSound::InitializeComplete with error = %d"), aError);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   201
				StopTest(aError);	
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   202
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   203
			else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   204
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   205
				ERR_PRINTF2(_L("DevSound EEventInitComplete not received as expected. Received event: %d"), aDevSoundEvent);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   206
				StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   207
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   208
			break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   209
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   210
		default:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   211
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   212
			ERR_PRINTF2(_L("Invalid DevSound state received: %d"), iDevSoundState);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   213
			StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   214
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   215
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   216
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   217
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   218
/*
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   219
 *========================================================================================================
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   220
 * MM-A3F-DEVSOUND-CHRTZ-TONE-0003
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   221
 */
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   222
RA3FDevSoundToneSetVolumeTest::RA3FDevSoundToneSetVolumeTest(const TDesC& aTestName)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   223
	:	RA3FDevSoundTestBase(aTestName), iVolume(0)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   224
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   225
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   226
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   227
RA3FDevSoundToneSetVolumeTest* RA3FDevSoundToneSetVolumeTest::NewL(const TDesC& aTestName)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   228
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   229
	RA3FDevSoundToneSetVolumeTest * self = new(ELeave)RA3FDevSoundToneSetVolumeTest(aTestName);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   230
	return self;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   231
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   232
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   233
void RA3FDevSoundToneSetVolumeTest::DoKickoffTestL()
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   234
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   235
	if (!GetIntFromConfig(iTestStepName, KVolume, iVolume)) 
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   236
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   237
		ERR_PRINTF2(KMsgErrorGetParameter, &KVolume);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   238
		StopTest(KErrUnknown);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   239
		return;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   240
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   241
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   242
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   243
void RA3FDevSoundToneSetVolumeTest::Fsm(TMmfDevSoundEvent aDevSoundEvent, TInt aError)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   244
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   245
	switch (iDevSoundState)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   246
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   247
		case EStateCreated:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   248
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   249
			if (aDevSoundEvent == EEventInitialize)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   250
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   251
				__ASSERT_ALWAYS((aError == KErrNone), Panic(_L("RA3FDevSoundToneSetVolumeTest"), EFsmIncorrectErrorPassed));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   252
				INFO_PRINTF1(_L("Calling CMMFDevSound::InitializeL"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   253
				TRAPD(err, iMMFDevSound->InitializeL(*this, EMMFStateTonePlaying));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   254
				if (err != KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   255
					{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   256
					ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"), err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   257
					StopTest(err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   258
					break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   259
					}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   260
				INFO_PRINTF1(_L("DevSound State: EStateInitializing"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   261
				iDevSoundState = EStateInitializing;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   262
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   263
			else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   264
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   265
				ERR_PRINTF2(_L("DevSound EEventInitialize not received as expected. Received event: %d"), aDevSoundEvent);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   266
				StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   267
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   268
			break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   269
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   270
		case EStateInitializing:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   271
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   272
			if (aDevSoundEvent == EEventInitComplete && aError == KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   273
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   274
				INFO_PRINTF2(_L("Calling CMMFDevSound::SetVolume with volume value = %d"), iVolume);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   275
				iMMFDevSound->SetVolume(iVolume);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   276
				TInt volumeGet;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   277
				volumeGet=iMMFDevSound->Volume();
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   278
				if (volumeGet == iVolume)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   279
					{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   280
					INFO_PRINTF2(_L("CMMFDevSound::SetVolume succeeded with value = %d"), volumeGet);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   281
					StopTest();
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   282
					}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   283
				else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   284
					{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   285
					ERR_PRINTF2(_L("CMMFDevSound::SetVolume failed with value = %d"), volumeGet);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   286
					ERR_PRINTF2(_L("Expected value = %d"), iVolume);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   287
					StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   288
					}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   289
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   290
			else if (aDevSoundEvent == EEventInitComplete && aError != KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   291
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   292
				ERR_PRINTF2(_L("DevSound called CMMFDevSound::InitializeComplete with error = %d"), aError);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   293
				StopTest(aError);	
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   294
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   295
			else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   296
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   297
				ERR_PRINTF2(_L("DevSound EEventInitComplete not received as expected. Received event: %d"), aDevSoundEvent);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   298
				StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   299
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   300
			break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   301
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   302
		default:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   303
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   304
			ERR_PRINTF2(_L("Invalid DevSound state received: %d"), iDevSoundState);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   305
			StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   306
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   307
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   308
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   309
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   310
/*
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   311
 *========================================================================================================
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   312
 * MM-A3F-DEVSOUND-CHRTZ-TONE-0004
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   313
 */
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   314
RA3FDevSoundToneVolumeRampTest::RA3FDevSoundToneVolumeRampTest(const TDesC& aTestName)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   315
	:	RA3FDevSoundTestBase(aTestName), iVolumeRamp(0),
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   316
		iDuration(0), iFrequencyTone1(0)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   317
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   318
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   319
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   320
RA3FDevSoundToneVolumeRampTest* RA3FDevSoundToneVolumeRampTest::NewL(const TDesC& aTestName)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   321
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   322
	RA3FDevSoundToneVolumeRampTest * self = new(ELeave)RA3FDevSoundToneVolumeRampTest(aTestName);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   323
	return self;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   324
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   325
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   326
void RA3FDevSoundToneVolumeRampTest::DoKickoffTestL()
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   327
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   328
	if (!GetIntFromConfig(iTestStepName, KVolumeRamp, iVolumeRamp)) 
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   329
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   330
		ERR_PRINTF2(KMsgErrorGetParameter, &KVolumeRamp);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   331
		StopTest(KErrNotFound);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   332
		return;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   333
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   334
	if (!GetIntFromConfig(iTestStepName, KDuration, iDuration)) 
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   335
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   336
			ERR_PRINTF2(KMsgErrorGetParameter, &KDuration);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   337
			StopTest(KErrNotFound);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   338
			return;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   339
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   340
	if (!GetIntFromConfig(iTestStepName, KFrequencyTone1, iFrequencyTone1)) 
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   341
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   342
		ERR_PRINTF2(KMsgErrorGetParameter, &KFrequencyTone1);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   343
		StopTest(KErrNotFound);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   344
		return;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   345
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   346
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   347
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   348
void RA3FDevSoundToneVolumeRampTest::Fsm(TMmfDevSoundEvent aDevSoundEvent, TInt aError)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   349
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   350
	switch (iDevSoundState)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   351
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   352
		case EStateCreated:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   353
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   354
			if (aDevSoundEvent == EEventInitialize)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   355
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   356
				__ASSERT_ALWAYS((aError == KErrNone), Panic(_L("RA3FDevSoundToneVolumeRampTest"), EFsmIncorrectErrorPassed));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   357
				INFO_PRINTF1(_L("Calling CMMFDevSound::InitializeL"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   358
				TRAPD(err, iMMFDevSound->InitializeL(*this, EMMFStateTonePlaying));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   359
				if (err != KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   360
					{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   361
					ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"), err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   362
					StopTest(err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   363
					break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   364
					}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   365
				INFO_PRINTF1(_L("DevSound State: EStateInitializing"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   366
				iDevSoundState = EStateInitializing;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   367
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   368
			else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   369
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   370
				ERR_PRINTF2(_L("DevSound EEventInitialize not received as expected. Received event: %d"), aDevSoundEvent);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   371
				StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   372
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   373
			break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   374
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   375
		case EStateInitializing:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   376
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   377
			if (aDevSoundEvent == EEventInitComplete && aError == KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   378
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   379
				INFO_PRINTF2(_L("Calling CMMFDevSound::SetVolumeRamp using volume ramp time = %d"), iVolumeRamp);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   380
				iMMFDevSound->SetVolumeRamp(iVolumeRamp);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   381
				iStartTime.HomeTime();
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   382
				INFO_PRINTF3(_L("Calling CMMFDevSound::PlayToneL %d Hz during %d secs "), iFrequencyTone1, iDuration);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   383
				TRAPD(err, iMMFDevSound->PlayToneL(iFrequencyTone1, iDuration*KMicroSecsInOneSec));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   384
				if (err != KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   385
					{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   386
					ERR_PRINTF2(_L("CMMFDevSound::PlayToneL left with error : %d!"), err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   387
					StopTest(err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   388
					break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   389
					}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   390
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   391
			else if (aDevSoundEvent == EEventInitComplete && aError != KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   392
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   393
				ERR_PRINTF2(_L("DevSound called CMMFDevSound::InitializeComplete with error = %d"), aError);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   394
				StopTest(aError);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   395
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   396
			else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   397
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   398
				ERR_PRINTF2(_L("DevSound EEventInitComplete not received as expected. Received event: %d"), aDevSoundEvent);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   399
				StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   400
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   401
			break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   402
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   403
		default:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   404
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   405
			ERR_PRINTF2(_L("Invalid DevSound state received: %d"), iDevSoundState);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   406
			StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   407
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   408
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   409
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   410
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   411
void RA3FDevSoundToneVolumeRampTest::ToneFinished(TInt aError)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   412
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   413
	INFO_PRINTF1(_L("========== DevSound ToneFinished() callback =========="));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   414
	if (aError == KErrUnderflow)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   415
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   416
		iEndTime.HomeTime();
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   417
		iPlayToneTime = iEndTime.MicroSecondsFrom(iStartTime);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   418
		TInt totalExpectedReproductionTime = iDuration * KMicroSecsInOneSec;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   419
		if(iPlayToneTime < totalExpectedReproductionTime + KPlayVarianceTime && iPlayToneTime > totalExpectedReproductionTime - KPlayVarianceTime)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   420
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   421
			INFO_PRINTF2(_L("Play time is %Ld microseconds"), iPlayToneTime.Int64());
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   422
			StopTest();
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   423
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   424
		else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   425
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   426
			ERR_PRINTF3(_L("Play time is %Ld microseconds and it should have been %d microseconds"), iPlayToneTime.Int64(), totalExpectedReproductionTime);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   427
			StopTest(KErrNone, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   428
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   429
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   430
	else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   431
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   432
		ERR_PRINTF2(_L("DevSound called ToneFinished with error = %d"), aError);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   433
		ERR_PRINTF2(_L("Expected error = %d"), KErrUnderflow);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   434
		StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   435
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   436
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   437
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   438
/*
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   439
 *========================================================================================================
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   440
 * MM-A3F-DEVSOUND-CHRTZ-TONE-0005
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   441
 */
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   442
RA3FDevSoundToneSetToneRepeatsTest::RA3FDevSoundToneSetToneRepeatsTest(const TDesC& aTestName)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   443
	:	RA3FDevSoundTestBase(aTestName),
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   444
		iDuration(0),
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   445
		iFrequencyTone1(0),
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   446
		iRepeatTrailingSilence(0), 
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   447
		iRepeatCount(0)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   448
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   449
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   450
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   451
RA3FDevSoundToneSetToneRepeatsTest* RA3FDevSoundToneSetToneRepeatsTest::NewL(const TDesC& aTestName)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   452
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   453
	RA3FDevSoundToneSetToneRepeatsTest * self = new(ELeave)RA3FDevSoundToneSetToneRepeatsTest(aTestName);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   454
	return self;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   455
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   456
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   457
void RA3FDevSoundToneSetToneRepeatsTest::DoKickoffTestL()
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   458
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   459
	if (!GetIntFromConfig(iTestStepName, KRepeatCount, iRepeatCount)) 
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   460
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   461
		ERR_PRINTF2(KMsgErrorGetParameter, &KRepeatCount);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   462
		StopTest(KErrNotFound);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   463
		return;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   464
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   465
	if (!GetIntFromConfig(iTestStepName, KRepeatTrailingSilence, iRepeatTrailingSilence)) 
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   466
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   467
		ERR_PRINTF2(KMsgErrorGetParameter, &KRepeatTrailingSilence);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   468
		StopTest(KErrNotFound);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   469
		return;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   470
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   471
	if (!GetIntFromConfig(iTestStepName, KDuration, iDuration)) 
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   472
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   473
		ERR_PRINTF2(KMsgErrorGetParameter, &KDuration);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   474
		StopTest(KErrNotFound);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   475
		return;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   476
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   477
	if (!GetIntFromConfig(iTestStepName, KFrequencyTone1, iFrequencyTone1)) 
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   478
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   479
		ERR_PRINTF2(KMsgErrorGetParameter, &KFrequencyTone1);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   480
		StopTest(KErrNotFound);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   481
		return;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   482
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   483
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   484
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   485
void RA3FDevSoundToneSetToneRepeatsTest::Fsm(TMmfDevSoundEvent aDevSoundEvent, TInt aError)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   486
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   487
	switch (iDevSoundState)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   488
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   489
		case EStateCreated:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   490
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   491
			if (aDevSoundEvent == EEventInitialize)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   492
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   493
				__ASSERT_ALWAYS((aError == KErrNone), Panic(_L("RA3FDevSoundToneSetToneRepeatsTest"), EFsmIncorrectErrorPassed));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   494
				INFO_PRINTF1(_L("Calling CMMFDevSound::InitializeL"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   495
				TRAPD(err, iMMFDevSound->InitializeL(*this, EMMFStateTonePlaying));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   496
				if (err != KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   497
					{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   498
					ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"), err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   499
					StopTest(err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   500
					break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   501
					}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   502
				INFO_PRINTF1(_L("DevSound State: EStateInitializing"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   503
				iDevSoundState = EStateInitializing;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   504
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   505
			else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   506
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   507
				ERR_PRINTF2(_L("DevSound EEventInitialize not received as expected. Received event: %d"), aDevSoundEvent);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   508
				StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   509
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   510
			break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   511
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   512
		case EStateInitializing:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   513
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   514
			if (aDevSoundEvent == EEventInitComplete && aError == KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   515
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   516
				iMMFDevSound->SetVolume(iMMFDevSound->MaxVolume());
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   517
				iStartTime.HomeTime();
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   518
				INFO_PRINTF3(_L("Calling CMMFDevSound::SetToneRepeats using repeatCount = %d and trailingSilence = %d"), iRepeatCount, iRepeatTrailingSilence);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   519
				iMMFDevSound->SetToneRepeats(iRepeatCount, iRepeatTrailingSilence);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   520
				INFO_PRINTF3(_L("Calling CMMFDevSound::PlayToneL %d Hz during %d secs "), iFrequencyTone1, iDuration);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   521
				TRAPD(err, iMMFDevSound->PlayToneL(iFrequencyTone1, iDuration*KMicroSecsInOneSec));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   522
				if (err != KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   523
					{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   524
					ERR_PRINTF2(_L("CMMFDevSound::PlayToneL left with error : %d!"), err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   525
					StopTest(err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   526
					break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   527
					}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   528
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   529
			else if (aDevSoundEvent == EEventInitComplete && aError != KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   530
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   531
				ERR_PRINTF2(_L("DevSound called CMMFDevSound::InitializeComplete with error = %d"), aError);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   532
				StopTest(aError);	
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   533
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   534
			else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   535
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   536
				ERR_PRINTF2(_L("DevSound EEventInitComplete not received as expected. Received event: %d"), aDevSoundEvent);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   537
				StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   538
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   539
			break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   540
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   541
		default:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   542
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   543
			ERR_PRINTF2(_L("Invalid DevSound state received: %d"), iDevSoundState);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   544
			StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   545
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   546
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   547
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   548
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   549
void RA3FDevSoundToneSetToneRepeatsTest::ToneFinished(TInt aError)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   550
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   551
	INFO_PRINTF1(_L("========== DevSound ToneFinished() callback =========="));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   552
	if (aError == KErrUnderflow)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   553
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   554
		iEndTime.HomeTime();
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   555
		iPlayToneTime = iEndTime.MicroSecondsFrom(iStartTime);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   556
		TInt repeatTrailingSilenceToSecs = iRepeatTrailingSilence/KMicroSecsInOneSec;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   557
		TInt totalExpectedReproductionTime = (iRepeatCount * iDuration + iDuration + (repeatTrailingSilenceToSecs*iRepeatCount))*KMicroSecsInOneSec;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   558
		if(iPlayToneTime < totalExpectedReproductionTime + KPlayVarianceTime && iPlayToneTime > totalExpectedReproductionTime - KPlayVarianceTime)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   559
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   560
			INFO_PRINTF1(_L("Play tone repeats succeded."));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   561
			INFO_PRINTF2(_L("Play time is %Ld microseconds"), iPlayToneTime.Int64());
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   562
			StopTest();
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   563
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   564
		else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   565
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   566
			ERR_PRINTF1(_L("Play tone repeats did not work as planned."));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   567
			ERR_PRINTF3(_L("Play time is %Ld microseconds and it should have been %d microseconds"), iPlayToneTime.Int64(), totalExpectedReproductionTime);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   568
			StopTest(KErrNone, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   569
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   570
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   571
	else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   572
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   573
		ERR_PRINTF2(_L("DevSound called ToneFinished with error = %d"), aError);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   574
		ERR_PRINTF2(_L("Expected error = %d"), KErrUnderflow);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   575
		StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   576
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   577
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   578
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   579
/*
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   580
 *========================================================================================================
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   581
 * MM-A3F-DEVSOUND-CHRTZ-TONE-0006
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   582
 */
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   583
RA3FDevSoundToneSetDTMFLengthsTest::RA3FDevSoundToneSetDTMFLengthsTest(const TDesC& aTestName)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   584
	:	RA3FDevSoundTestBase(aTestName), iToneOnLength(0),
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   585
		iToneOffLength(0), iPauseLength(0), iDTMFPauses(0),
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   586
		iDTMFTones(0)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   587
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   588
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   589
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   590
RA3FDevSoundToneSetDTMFLengthsTest* RA3FDevSoundToneSetDTMFLengthsTest::NewL(const TDesC& aTestName)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   591
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   592
	RA3FDevSoundToneSetDTMFLengthsTest * self = new(ELeave)RA3FDevSoundToneSetDTMFLengthsTest(aTestName);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   593
	return self;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   594
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   595
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   596
void RA3FDevSoundToneSetDTMFLengthsTest::DoKickoffTestL()
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   597
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   598
	if (!GetIntFromConfig(iTestStepName, KToneOnLength, iToneOnLength))
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   599
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   600
		ERR_PRINTF2(KMsgErrorGetParameter, &KToneOnLength);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   601
		StopTest(KErrNotFound);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   602
		return;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   603
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   604
	if (!GetIntFromConfig(iTestStepName, KToneOffLength, iToneOffLength))
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   605
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   606
		ERR_PRINTF2(KMsgErrorGetParameter, &KToneOffLength);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   607
		StopTest(KErrNotFound);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   608
		return;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   609
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   610
	if (!GetIntFromConfig(iTestStepName, KPauseLength, iPauseLength))
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   611
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   612
		ERR_PRINTF2(KMsgErrorGetParameter, &KPauseLength);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   613
		StopTest(KErrNotFound);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   614
		return;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   615
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   616
	TPtrC DTMF;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   617
	if (!GetStringFromConfig(iTestStepName, KDTMFString, DTMF))
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   618
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   619
		ERR_PRINTF2(KMsgErrorGetParameter, &KDTMFString);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   620
		StopTest(KErrNotFound);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   621
		return;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   622
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   623
	iDTMFString.Copy(DTMF);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   624
	for(TInt i =0 ; i< iDTMFString.Length() ; i++)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   625
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   626
		if (iDTMFString[i] == ',')
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   627
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   628
			iDTMFPauses++;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   629
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   630
		else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   631
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   632
			iDTMFTones++;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   633
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   634
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   635
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   636
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   637
void RA3FDevSoundToneSetDTMFLengthsTest::Fsm(TMmfDevSoundEvent aDevSoundEvent, TInt aError)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   638
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   639
	switch (iDevSoundState)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   640
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   641
		case EStateCreated:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   642
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   643
			if (aDevSoundEvent == EEventInitialize)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   644
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   645
				__ASSERT_ALWAYS((aError == KErrNone), Panic(_L("RA3FDevSoundToneSetDTMFLengthsTest"), EFsmIncorrectErrorPassed));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   646
				INFO_PRINTF1(_L("Calling CMMFDevSound::InitializeL"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   647
				TRAPD(err, iMMFDevSound->InitializeL(*this, EMMFStateTonePlaying));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   648
				if (err != KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   649
					{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   650
					ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"), err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   651
					StopTest(err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   652
					break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   653
					}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   654
				INFO_PRINTF1(_L("DevSound State: EStateInitializing"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   655
				iDevSoundState = EStateInitializing;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   656
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   657
			else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   658
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   659
				ERR_PRINTF2(_L("DevSound EEventInitialize not received as expected. Received event: %d"), aDevSoundEvent);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   660
				StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   661
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   662
			break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   663
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   664
		case EStateInitializing:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   665
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   666
			if (aDevSoundEvent == EEventInitComplete && aError == KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   667
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   668
				iMMFDevSound->SetVolume(iMMFDevSound->MaxVolume());
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   669
				TTimeIntervalMicroSeconds32 ToneOnLength(iToneOnLength);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   670
				TTimeIntervalMicroSeconds32 ToneOffLength(iToneOffLength);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   671
				TTimeIntervalMicroSeconds32 PauseLength(iPauseLength);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   672
				INFO_PRINTF4(_L("Calling CMMFDevSound::SetDTMFLengths. ToneOnLength = %d, ToneOffLength = %d and PauseLength = %d"), ToneOnLength.Int(), ToneOffLength.Int(), PauseLength.Int());
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   673
				iMMFDevSound->SetDTMFLengths(ToneOnLength, ToneOffLength, PauseLength);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   674
				iStartTime.HomeTime();
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   675
				INFO_PRINTF2(_L("Calling CMMFDevSound::PlayDTMFStringL %S"), &iDTMFString);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   676
				TRAPD(err, iMMFDevSound->PlayDTMFStringL(iDTMFString));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   677
				if (err != KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   678
					{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   679
					ERR_PRINTF2(_L("CMMFDevSound::PlayDTMFStringL left with error : %d!"), err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   680
					StopTest(err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   681
					break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   682
					}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   683
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   684
			else if (aDevSoundEvent == EEventInitComplete && aError != KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   685
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   686
				ERR_PRINTF2(_L("DevSound called CMMFDevSound::InitializeComplete with error = %d"), aError);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   687
				StopTest(aError);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   688
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   689
			else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   690
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   691
				ERR_PRINTF2(_L("DevSound EEventInitComplete not received as expected. Received event: %d"), aDevSoundEvent);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   692
				StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   693
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   694
			break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   695
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   696
		default:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   697
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   698
			ERR_PRINTF2(_L("Invalid DevSound state received: %d"), iDevSoundState);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   699
			StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   700
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   701
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   702
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   703
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   704
void RA3FDevSoundToneSetDTMFLengthsTest::ToneFinished(TInt aError)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   705
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   706
	INFO_PRINTF1(_L("========== DevSound ToneFinished() callback =========="));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   707
	if (aError == KErrUnderflow)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   708
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   709
		iEndTime.HomeTime();
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   710
		iPlayToneTime = iEndTime.MicroSecondsFrom(iStartTime);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   711
		TInt totalExpectedReproductionTime = iToneOnLength*iDTMFTones + iToneOffLength * iDTMFTones + iDTMFPauses * iPauseLength;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   712
		if (iPlayToneTime.Int64() < totalExpectedReproductionTime + KPlayVarianceTime && iPlayToneTime.Int64() > totalExpectedReproductionTime - KPlayVarianceTime)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   713
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   714
			INFO_PRINTF1(_L("Calling CMMFDevSound::SetDTMFLengths succeded."));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   715
			INFO_PRINTF2(_L("Play time is %Ld microseconds"), iPlayToneTime.Int64());
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   716
			StopTest();
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   717
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   718
		else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   719
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   720
			ERR_PRINTF2(_L("Calling CMMFDevSound::SetDTMFLengths failed with %Ld"), iPlayToneTime.Int64());
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   721
			ERR_PRINTF2(_L("Expected time %d"), totalExpectedReproductionTime);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   722
			StopTest(KErrNone, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   723
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   724
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   725
	else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   726
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   727
		ERR_PRINTF2(_L("DevSound called ToneFinished with error = %d"), aError);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   728
		ERR_PRINTF2(_L("Expected error = %d"), KErrUnderflow);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   729
		StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   730
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   731
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   732
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   733
/*
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   734
 *========================================================================================================
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   735
 * MM-A3F-DEVSOUND-CHRTZ-TONE-0007
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   736
 */
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   737
RA3FDevSoundToneSetVolumeWhilePlayingTest::RA3FDevSoundToneSetVolumeWhilePlayingTest(const TDesC& aTestName)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   738
	:	RA3FDevSoundTestBase(aTestName), iDuration(0),
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   739
		iVolume(0), iFrequencyTone1(0)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   740
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   741
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   742
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   743
RA3FDevSoundToneSetVolumeWhilePlayingTest* RA3FDevSoundToneSetVolumeWhilePlayingTest::NewL(const TDesC& aTestName)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   744
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   745
	RA3FDevSoundToneSetVolumeWhilePlayingTest * self = new(ELeave)RA3FDevSoundToneSetVolumeWhilePlayingTest(aTestName);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   746
	return self;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   747
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   748
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   749
void RA3FDevSoundToneSetVolumeWhilePlayingTest::DoKickoffTestL()
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   750
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   751
	if (!GetIntFromConfig(iTestStepName, KVolume, iVolume)) 
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   752
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   753
		ERR_PRINTF2(KMsgErrorGetParameter, &KVolume);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   754
		StopTest(KErrNotFound);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   755
		return;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   756
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   757
	if (!GetIntFromConfig(iTestStepName, KDuration, iDuration)) 
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   758
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   759
		ERR_PRINTF2(KMsgErrorGetParameter, &KDuration);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   760
		StopTest(KErrNotFound);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   761
		return;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   762
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   763
	if (!GetIntFromConfig(iTestStepName, KFrequencyTone1, iFrequencyTone1)) 
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   764
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   765
		ERR_PRINTF2(KMsgErrorGetParameter, &KFrequencyTone1);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   766
		StopTest(KErrNotFound);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   767
		return;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   768
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   769
	iTimer = CPeriodic::NewL(CActive::EPriorityHigh);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   770
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   771
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   772
void RA3FDevSoundToneSetVolumeWhilePlayingTest::Fsm(TMmfDevSoundEvent aDevSoundEvent, TInt aError)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   773
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   774
	switch (iDevSoundState)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   775
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   776
		case EStateCreated:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   777
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   778
			if (aDevSoundEvent == EEventInitialize)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   779
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   780
				__ASSERT_ALWAYS((aError == KErrNone), Panic(_L("RA3FDevSoundToneSetVolumeWhilePlayingTest"), EFsmIncorrectErrorPassed));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   781
				INFO_PRINTF1(_L("Calling CMMFDevSound::InitializeL"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   782
				TRAPD(err, iMMFDevSound->InitializeL(*this, EMMFStateTonePlaying));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   783
				if (err != KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   784
					{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   785
					ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"), err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   786
					StopTest(err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   787
					break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   788
					}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   789
				INFO_PRINTF1(_L("DevSound State: EStateInitializing"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   790
				iDevSoundState = EStateInitializing;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   791
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   792
			else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   793
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   794
				ERR_PRINTF2(_L("DevSound EEventInitialize not received as expected. Received event: %d"), aDevSoundEvent);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   795
				StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   796
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   797
			break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   798
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   799
		case EStateInitializing:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   800
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   801
			if (aDevSoundEvent == EEventInitComplete && aError == KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   802
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   803
				iStartTime.HomeTime();
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   804
				INFO_PRINTF3(_L("Calling CMMFDevSound::PlayToneL using frequency = %d Hz and duration = %d secs "), iFrequencyTone1, iDuration);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   805
				TRAPD(err, iMMFDevSound->PlayToneL(iFrequencyTone1, iDuration*KMicroSecsInOneSec));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   806
				if (err != KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   807
					{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   808
					ERR_PRINTF2(_L("CMMFDevSound::PlayToneL left with error : %d!"), err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   809
					StopTest(err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   810
					break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   811
					}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   812
				StartTimer(KMicroSecsTwoSec);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   813
				INFO_PRINTF1(_L("DevSound State: EStatePlaying"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   814
				iDevSoundState = EStatePlaying;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   815
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   816
			else if (aDevSoundEvent == EEventInitComplete && aError != KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   817
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   818
				ERR_PRINTF2(_L("DevSound called CMMFDevSound::InitializeComplete with error = %d"), aError);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   819
				StopTest(aError);	
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   820
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   821
			else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   822
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   823
				ERR_PRINTF2(_L("DevSound EEventInitComplete not received as expected. Received event: %d"), aDevSoundEvent);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   824
				StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   825
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   826
			break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   827
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   828
		default:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   829
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   830
			ERR_PRINTF2(_L("Invalid DevSound state received: %d"), iDevSoundState);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   831
			StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   832
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   833
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   834
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   835
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   836
void RA3FDevSoundToneSetVolumeWhilePlayingTest::DoTimerCallback()
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   837
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   838
	iTimer->Cancel();
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   839
	INFO_PRINTF1(_L("DevSound Event: EEventTimerComplete"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   840
	INFO_PRINTF2(_L("Calling CMMFDevSound::SetVolume with volume value = %d"), iVolume);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   841
	iMMFDevSound->SetVolume(iVolume);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   842
	TInt volumeGet;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   843
	volumeGet=iMMFDevSound->Volume();
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   844
	if (volumeGet == iVolume)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   845
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   846
		INFO_PRINTF2(_L("CMMFDevSound::SetVolume succeeded with value = %d"), volumeGet);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   847
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   848
	else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   849
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   850
		ERR_PRINTF2(_L("CMMFDevSound::SetVolume failed with value = %d"), volumeGet);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   851
		ERR_PRINTF2(_L("Expected value = %d"), iVolume);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   852
		StopTest(KErrNone, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   853
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   854
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   855
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   856
void RA3FDevSoundToneSetVolumeWhilePlayingTest::ToneFinished(TInt aError)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   857
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   858
	INFO_PRINTF1(_L("========== DevSound ToneFinished() callback =========="));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   859
	if (aError == KErrUnderflow)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   860
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   861
		iEndTime.HomeTime();
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   862
		iPlayToneTime = iEndTime.MicroSecondsFrom(iStartTime);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   863
		TInt totalExpectedReproductionTime = iDuration * KMicroSecsInOneSec;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   864
		if(iPlayToneTime < totalExpectedReproductionTime + KPlayVarianceTime && iPlayToneTime > totalExpectedReproductionTime - KPlayVarianceTime)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   865
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   866
			INFO_PRINTF2(_L("Play time is %Ld microseconds"), iPlayToneTime.Int64());
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   867
			StopTest();
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   868
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   869
		else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   870
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   871
			ERR_PRINTF3(_L("Play time is %Ld microseconds and it should have been %d microseconds"), iPlayToneTime.Int64(), totalExpectedReproductionTime);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   872
			StopTest(KErrNone, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   873
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   874
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   875
	else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   876
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   877
		ERR_PRINTF2(_L("DevSound called ToneFinished with error = %d"), aError);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   878
		ERR_PRINTF2(_L("Expected error = %d"), KErrUnderflow);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   879
		StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   880
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   881
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   882
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   883
/*
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   884
 *========================================================================================================
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   885
 * MM-A3F-DEVSOUND-CHRTZ-TONE-0008
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   886
 */
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   887
RA3FDevSoundToneSetPlayBalanceWhilePlayingTest::RA3FDevSoundToneSetPlayBalanceWhilePlayingTest(const TDesC& aTestName)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   888
	:	RA3FDevSoundTestBase(aTestName), iDuration(0),
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   889
		iVolume(0), iFrequencyTone1(0), iLSpeakerBalance(0),
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   890
		iRSpeakerBalance(0)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   891
		
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   892
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   893
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   894
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   895
RA3FDevSoundToneSetPlayBalanceWhilePlayingTest* RA3FDevSoundToneSetPlayBalanceWhilePlayingTest::NewL(const TDesC& aTestName)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   896
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   897
	RA3FDevSoundToneSetPlayBalanceWhilePlayingTest * self = new(ELeave)RA3FDevSoundToneSetPlayBalanceWhilePlayingTest(aTestName);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   898
	return self;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   899
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   900
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   901
void RA3FDevSoundToneSetPlayBalanceWhilePlayingTest::DoKickoffTestL()
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   902
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   903
	if (!GetIntFromConfig(iTestStepName, KVolume, iVolume)) 
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   904
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   905
		ERR_PRINTF2(KMsgErrorGetParameter, &KVolume);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   906
		StopTest(KErrNotFound);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   907
		return;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   908
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   909
	if (!GetIntFromConfig(iTestStepName, KDuration, iDuration)) 
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   910
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   911
		ERR_PRINTF2(KMsgErrorGetParameter, &KDuration);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   912
		StopTest(KErrNotFound);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   913
		return;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   914
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   915
	if (!GetIntFromConfig(iTestStepName, KFrequencyTone1, iFrequencyTone1)) 
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   916
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   917
		ERR_PRINTF2(KMsgErrorGetParameter, &KFrequencyTone1);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   918
		StopTest(KErrNotFound);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   919
		return;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   920
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   921
	if (!GetIntFromConfig(iTestStepName, KLSpeakerBalance, iLSpeakerBalance)) 
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   922
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   923
		ERR_PRINTF2(KMsgErrorGetParameter, &KLSpeakerBalance);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   924
		StopTest(KErrNotFound);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   925
		return;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   926
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   927
	if (!GetIntFromConfig(iTestStepName, KRSpeakerBalance, iRSpeakerBalance)) 
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   928
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   929
		ERR_PRINTF2(KMsgErrorGetParameter, &KRSpeakerBalance);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   930
		StopTest(KErrNotFound);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   931
		return;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   932
		}	
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   933
	iTimer = CPeriodic::NewL(CActive::EPriorityHigh);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   934
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   935
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   936
void RA3FDevSoundToneSetPlayBalanceWhilePlayingTest::Fsm(TMmfDevSoundEvent aDevSoundEvent, TInt aError)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   937
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   938
	switch (iDevSoundState)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   939
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   940
		case EStateCreated:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   941
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   942
			if (aDevSoundEvent == EEventInitialize)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   943
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   944
				__ASSERT_ALWAYS((aError == KErrNone), Panic(_L("RA3FDevSoundToneSetPlayBalanceWhilePlayingTest"), EFsmIncorrectErrorPassed));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   945
				INFO_PRINTF1(_L("Calling CMMFDevSound::InitializeL"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   946
				TRAPD(err, iMMFDevSound->InitializeL(*this, EMMFStateTonePlaying));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   947
				if (err != KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   948
					{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   949
					ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"), err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   950
					StopTest(err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   951
					break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   952
					}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   953
				INFO_PRINTF1(_L("DevSound State: EStateInitializing"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   954
				iDevSoundState = EStateInitializing;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   955
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   956
			else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   957
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   958
				ERR_PRINTF2(_L("DevSound EEventInitialize not received as expected. Received event: %d"), aDevSoundEvent);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   959
				StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   960
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   961
			break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   962
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   963
		case EStateInitializing:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   964
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   965
			if (aDevSoundEvent == EEventInitComplete && aError == KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   966
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   967
				iStartTime.HomeTime();
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   968
				INFO_PRINTF3(_L("Calling CMMFDevSound::PlayToneL using frequency = %d Hz and duration = %d secs "), iFrequencyTone1, iDuration);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   969
				TRAPD(err, iMMFDevSound->PlayToneL(iFrequencyTone1, iDuration*KMicroSecsInOneSec));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   970
				if (err != KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   971
					{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   972
					ERR_PRINTF2(_L("CMMFDevSound::PlayToneL left with error : %d!"), err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   973
					StopTest(err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   974
					break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   975
					}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   976
				StartTimer(KMicroSecsTwoSec);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   977
				INFO_PRINTF1(_L("DevSound State: EStatePlaying"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   978
				iDevSoundState = EStatePlaying;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   979
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   980
			else if (aDevSoundEvent == EEventInitComplete && aError != KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   981
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   982
				ERR_PRINTF2(_L("DevSound called CMMFDevSound::InitializeComplete with error = %d"), aError);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   983
				StopTest(aError);	
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   984
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   985
			else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   986
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   987
				ERR_PRINTF2(_L("DevSound EEventInitComplete not received as expected. Received event: %d"), aDevSoundEvent);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   988
				StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   989
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   990
			break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   991
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   992
		default:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   993
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   994
			ERR_PRINTF2(_L("Invalid DevSound state received: %d"), iDevSoundState);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   995
			StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   996
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   997
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   998
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
   999
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1000
void RA3FDevSoundToneSetPlayBalanceWhilePlayingTest::DoTimerCallback()
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1001
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1002
	iTimer->Cancel();
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1003
	INFO_PRINTF1(_L("DevSound Event: EEventTimerComplete"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1004
	INFO_PRINTF3(_L("Calling CMMFDevSound::SetPlayBalanceL using left = %d right = %d"), iLSpeakerBalance, iRSpeakerBalance);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1005
	TRAPD(err, iMMFDevSound->SetPlayBalanceL(iLSpeakerBalance, iRSpeakerBalance));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1006
	if (err == KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1007
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1008
		TInt getBalanceL, getBalanceR;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1009
		TRAPD(err, iMMFDevSound->GetPlayBalanceL(getBalanceL, getBalanceR));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1010
		if (err == KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1011
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1012
			if(iLSpeakerBalance == getBalanceL && iRSpeakerBalance == getBalanceR)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1013
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1014
				INFO_PRINTF3(_L("Calling CMMFDevSound::SetPlayBalanceL to set balance values succeeded, left = %d right = %d"), getBalanceL, getBalanceR);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1015
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1016
			else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1017
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1018
				ERR_PRINTF3(_L("Calling CMMFDevSound::SetPlayBalanceL to set balance values failed, left = %d right = %d"), getBalanceL, getBalanceR);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1019
				ERR_PRINTF3(_L("Expected balances values for right and left respectively %d, %d"),iLSpeakerBalance, iRSpeakerBalance);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1020
				StopTest(err,EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1021
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1022
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1023
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1024
	else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1025
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1026
		ERR_PRINTF1(_L("Error in setting left and right play balance."));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1027
		StopTest (err, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1028
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1029
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1030
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1031
void RA3FDevSoundToneSetPlayBalanceWhilePlayingTest::ToneFinished(TInt aError)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1032
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1033
	INFO_PRINTF1(_L("========== DevSound ToneFinished() callback =========="));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1034
	if (aError == KErrUnderflow)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1035
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1036
		iEndTime.HomeTime();
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1037
		iPlayToneTime = iEndTime.MicroSecondsFrom(iStartTime);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1038
		TInt totalExpectedReproductionTime = iDuration * KMicroSecsInOneSec;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1039
		if(iPlayToneTime < totalExpectedReproductionTime + KPlayVarianceTime && iPlayToneTime > totalExpectedReproductionTime - KPlayVarianceTime)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1040
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1041
			INFO_PRINTF2(_L("Play time is %Ld microseconds"), iPlayToneTime.Int64());
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1042
			StopTest();
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1043
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1044
		else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1045
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1046
			ERR_PRINTF3(_L("Play time is %Ld microseconds and it should have been %d microseconds"), iPlayToneTime.Int64(), totalExpectedReproductionTime);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1047
			StopTest(KErrNone, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1048
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1049
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1050
	else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1051
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1052
		ERR_PRINTF2(_L("DevSound called ToneFinished with error = %d"), aError);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1053
		ERR_PRINTF2(_L("Expected error = %d"), KErrUnderflow);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1054
		StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1055
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1056
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1057
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1058
/*
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1059
 *  **========================================================================================================
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1060
 * MM-A3F-DEVSOUND-CHRTZ-TONE-0009
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1061
 */
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1062
RA3FDevSoundToneSetVolumeWhilePausePlayingTest::RA3FDevSoundToneSetVolumeWhilePausePlayingTest(const TDesC& aTestName)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1063
	:	RA3FDevSoundTestBase(aTestName), 
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1064
		iDuration(0), iVolume(0),
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1065
		iFrequencyTone1(0),
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1066
		iTimeToEnterPauseElapsed(EFalse)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1067
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1068
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1069
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1070
RA3FDevSoundToneSetVolumeWhilePausePlayingTest* RA3FDevSoundToneSetVolumeWhilePausePlayingTest::NewL(const TDesC& aTestName)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1071
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1072
	RA3FDevSoundToneSetVolumeWhilePausePlayingTest * self = new(ELeave)RA3FDevSoundToneSetVolumeWhilePausePlayingTest(aTestName);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1073
	return self;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1074
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1075
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1076
void RA3FDevSoundToneSetVolumeWhilePausePlayingTest::DoKickoffTestL()
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1077
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1078
	if (!GetIntFromConfig(iTestStepName, KVolume, iVolume))
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1079
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1080
		ERR_PRINTF2(KMsgErrorGetParameter, &KVolume);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1081
		StopTest(KErrNotFound);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1082
		return;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1083
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1084
	if (!GetIntFromConfig(iTestStepName, KDuration, iDuration))
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1085
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1086
		ERR_PRINTF2(KMsgErrorGetParameter, &KDuration);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1087
		StopTest(KErrNotFound);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1088
		return;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1089
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1090
	if (!GetIntFromConfig(iTestStepName, KFrequencyTone1, iFrequencyTone1))
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1091
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1092
		ERR_PRINTF2(KMsgErrorGetParameter, &KFrequencyTone1);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1093
		StopTest(KErrNotFound);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1094
		return;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1095
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1096
	iTimer = CPeriodic::NewL(CActive::EPriorityHigh);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1097
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1098
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1099
void RA3FDevSoundToneSetVolumeWhilePausePlayingTest::Fsm(TMmfDevSoundEvent aDevSoundEvent,  TInt aError)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1100
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1101
	switch (iDevSoundState)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1102
		{		
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1103
		case EStateCreated:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1104
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1105
			__ASSERT_ALWAYS((aError == KErrNone), Panic(_L("RA3FDevSoundToneSetVolumeWhilePausePlayingTest"), EFsmIncorrectErrorPassed));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1106
			if (aDevSoundEvent == EEventInitialize)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1107
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1108
				INFO_PRINTF1(_L("Calling CMMFDevSound::InitializeL"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1109
				TRAPD(err, iMMFDevSound->InitializeL(*this, EMMFStateTonePlaying));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1110
				if (err != KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1111
					{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1112
					ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"), err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1113
					StopTest(err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1114
					break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1115
					}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1116
				INFO_PRINTF1(_L("DevSound State: EStateInitializing"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1117
				iDevSoundState = EStateInitializing;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1118
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1119
			else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1120
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1121
				ERR_PRINTF2(_L("DevSound EEventInitialize not received as expected. Received event: %d"), aDevSoundEvent);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1122
				StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1123
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1124
			break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1125
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1126
		case EStateInitializing:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1127
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1128
			if (aDevSoundEvent == EEventInitComplete && aError == KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1129
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1130
				INFO_PRINTF3(_L("CMMFDevSound::PlayToneL %d Hz during %d secs "), iFrequencyTone1, iDuration);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1131
				TRAPD(err, iMMFDevSound->PlayToneL(iFrequencyTone1, iDuration*KMicroSecsInOneSec));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1132
				if (err != KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1133
					{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1134
					ERR_PRINTF2(_L("CMMFDevSound::PlayToneL left with error : %d!"), err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1135
					StopTest(err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1136
					break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1137
					}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1138
				StartTimer(KMicroSecsTwoSec);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1139
				INFO_PRINTF1(_L("DevSound State: EStatePlaying"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1140
				iDevSoundState = EStatePlaying;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1141
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1142
			else if (aDevSoundEvent == EEventInitComplete && aError != KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1143
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1144
				ERR_PRINTF2(_L("DevSound called CMMFDevSound::InitializeComplete with error = %d"), aError);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1145
				StopTest(aError);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1146
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1147
			else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1148
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1149
				ERR_PRINTF2(_L("DevSound EEventInitComplete not received as expected. Received event: %d"),  aDevSoundEvent);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1150
				StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1151
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1152
			break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1153
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1154
		case EStatePlaying:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1155
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1156
			if(aDevSoundEvent == EEventTimerComplete)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1157
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1158
				INFO_PRINTF1(_L("Calling CMMFDevSound::Pause"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1159
				iMMFDevSound->Pause();
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1160
				INFO_PRINTF1(_L("DevSound State: EStatePause"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1161
				iDevSoundState = EStatePause;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1162
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1163
			else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1164
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1165
				ERR_PRINTF2(_L("DevSound EEventTimerComplete not received as expected. Received event: %d"), aDevSoundEvent);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1166
				StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1167
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1168
			break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1169
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1170
		case EStatePause:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1171
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1172
			if(aDevSoundEvent == EEventTimerComplete)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1173
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1174
				INFO_PRINTF2(_L("Calling CMMFDevSound::SetVolume with volume value = %d"), iVolume);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1175
				iMMFDevSound->SetVolume(iVolume);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1176
				TInt volumeGet;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1177
				volumeGet=iMMFDevSound->Volume();
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1178
				if (volumeGet == iVolume)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1179
					{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1180
					INFO_PRINTF2(_L("CMMFDevSound::SetVolume succeeded with value = %d"), volumeGet);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1181
					StopTest();
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1182
					}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1183
				else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1184
					{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1185
					ERR_PRINTF2(_L("CMMFDevSound::SetVolume failed with value = %d"), volumeGet);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1186
					ERR_PRINTF2(_L("Expected value = %d"), iVolume);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1187
					StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1188
					}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1189
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1190
			else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1191
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1192
				ERR_PRINTF2(_L("DevSound EEventTimerComplete not received as expected. Received event: %d"), aDevSoundEvent);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1193
				StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1194
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1195
			break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1196
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1197
		default:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1198
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1199
			ERR_PRINTF2(_L("Invalid DevSound state received: %d"), iDevSoundState);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1200
			StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1201
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1202
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1203
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1204
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1205
void RA3FDevSoundToneSetVolumeWhilePausePlayingTest::DoTimerCallback()
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1206
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1207
	INFO_PRINTF1(_L("TimerEvent called"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1208
	if(!iTimeToEnterPauseElapsed)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1209
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1210
		iTimeToEnterPauseElapsed = ETrue;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1211
		INFO_PRINTF1(_L("DevSound Event: EEventTimerComplete"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1212
		Fsm(EEventTimerComplete, KErrNone);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1213
		iTimeToEnterPauseElapsed = ETrue;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1214
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1215
	else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1216
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1217
		iTimer->Cancel();
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1218
		INFO_PRINTF1(_L("DevSound Event: EEventTimerComplete"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1219
		Fsm(EEventTimerComplete, KErrNone);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1220
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1221
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1222
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1223
void RA3FDevSoundToneSetVolumeWhilePausePlayingTest::ToneFinished(TInt aError)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1224
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1225
	INFO_PRINTF1(_L("========== DevSound ToneFinished() callback =========="));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1226
	ERR_PRINTF1(_L("DevSound should not have called ToneFinished because it is supposed to be paused"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1227
	StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1228
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1229
/*
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1230
 *========================================================================================================
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1231
 * MM-A3F-DEVSOUND-CHRTZ-TONE-0010
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1232
 */
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1233
RA3FDevSoundToneSetVolumeThenInitializeToPlayAudioTest::RA3FDevSoundToneSetVolumeThenInitializeToPlayAudioTest(const TDesC& aTestName)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1234
	:	RA3FDevSoundTestBase(aTestName), iVolume(0),
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1235
		iReinitialized(EFalse)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1236
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1237
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1238
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1239
RA3FDevSoundToneSetVolumeThenInitializeToPlayAudioTest* RA3FDevSoundToneSetVolumeThenInitializeToPlayAudioTest::NewL(const TDesC& aTestName)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1240
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1241
	RA3FDevSoundToneSetVolumeThenInitializeToPlayAudioTest * self = new(ELeave)RA3FDevSoundToneSetVolumeThenInitializeToPlayAudioTest(aTestName);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1242
	return self;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1243
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1244
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1245
void RA3FDevSoundToneSetVolumeThenInitializeToPlayAudioTest::DoKickoffTestL()
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1246
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1247
	if (!GetIntFromConfig(iTestStepName, KVolume, iVolume))
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1248
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1249
		ERR_PRINTF2(KMsgErrorGetParameter, &KVolume);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1250
		StopTest(KErrNotFound);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1251
		return;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1252
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1253
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1254
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1255
void RA3FDevSoundToneSetVolumeThenInitializeToPlayAudioTest::Fsm(TMmfDevSoundEvent aDevSoundEvent,  TInt aError)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1256
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1257
	switch (iDevSoundState)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1258
		{		
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1259
		case EStateCreated:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1260
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1261
			__ASSERT_ALWAYS((aError == KErrNone), Panic(_L("RA3FDevSoundToneSetVolumeThenInitializeToPlayAudioTest"), EFsmIncorrectErrorPassed));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1262
			if (aDevSoundEvent == EEventInitialize)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1263
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1264
				INFO_PRINTF1(_L("Calling CMMFDevSound::InitializeL"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1265
				TRAPD(err, iMMFDevSound->InitializeL(*this, EMMFStateTonePlaying));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1266
				if (err != KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1267
					{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1268
					ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"), err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1269
					StopTest(err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1270
					break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1271
					}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1272
				INFO_PRINTF1(_L("DevSound State: EStateInitializing"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1273
				iDevSoundState = EStateInitializing;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1274
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1275
			else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1276
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1277
				ERR_PRINTF2(_L("DevSound EEventInitialize not received as expected. Received event: %d"), aDevSoundEvent);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1278
				StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1279
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1280
			break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1281
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1282
		case EStateInitializing:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1283
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1284
			if (aDevSoundEvent == EEventInitComplete && aError == KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1285
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1286
				if(!iReinitialized)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1287
					{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1288
					INFO_PRINTF1(_L("Calling CMMFDevSound::InitializeL"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1289
					TRAPD(err, iMMFDevSound->InitializeL(*this, EMMFStateTonePlaying));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1290
					if (err != KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1291
						{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1292
						ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"), err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1293
						StopTest(err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1294
						break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1295
						}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1296
					INFO_PRINTF1(_L("DevSound State: EStateInitializing"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1297
					iDevSoundState = EStateInitializing;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1298
					iReinitialized = ETrue;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1299
					INFO_PRINTF2(_L("Calling CMMFDevSound::SetVolume with volume value = %d"), iVolume);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1300
					iMMFDevSound->SetVolume(iVolume);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1301
					INFO_PRINTF1(_L("DevSound State: EStateInitializing"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1302
					iDevSoundState = EStateInitializing;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1303
					}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1304
				else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1305
					{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1306
					TInt volumeGet;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1307
					volumeGet=iMMFDevSound->Volume();
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1308
					if (volumeGet == iVolume)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1309
						{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1310
						INFO_PRINTF1(_L("After calling CMMFDevSound::InitializeL for playing audio, "));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1311
						INFO_PRINTF2(_L("the volume which was set when calling CMMFDevSound::InitializeL for playing tones is kept. Volume = %d"), volumeGet);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1312
						StopTest();
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1313
						}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1314
					else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1315
						{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1316
						INFO_PRINTF1(_L("After calling CMMFDevSound::InitializeL for playing audio, "));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1317
						INFO_PRINTF2(_L("the volume which was set when calling CMMFDevSound::InitializeL for playing tones is  NOT kept. Volume = %d"), volumeGet);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1318
						ERR_PRINTF2(_L("Expected value = %d"), iVolume);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1319
						StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1320
						}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1321
					}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1322
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1323
			else if (aDevSoundEvent == EEventInitComplete && aError != KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1324
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1325
				ERR_PRINTF2(_L("DevSound called CMMFDevSound::InitializeComplete with error = %d"), aError);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1326
				StopTest(aError);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1327
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1328
			else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1329
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1330
				ERR_PRINTF2(_L("DevSound EEventInitComplete not received as expected. Received event: %d"),  aDevSoundEvent);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1331
				StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1332
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1333
			break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1334
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1335
		default:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1336
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1337
			ERR_PRINTF2(_L("Invalid DevSound state received: %d"), iDevSoundState);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1338
			StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1339
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1340
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1341
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1342
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1343
/*
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1344
 *========================================================================================================
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1345
 * MM-A3F-DEVSOUND-CHRTZ-TONE-0011
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1346
 */
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1347
RA3FDevSoundToneSetVolumeRampWhilePlayingTest::RA3FDevSoundToneSetVolumeRampWhilePlayingTest(const TDesC& aTestName)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1348
	:	RA3FDevSoundTestBase(aTestName), iDuration(0),
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1349
		iVolume(0), iFrequencyTone1(0),iTonePlayedTwice(EFalse),
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1350
		iTimesToneFinishedCalled(0)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1351
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1352
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1353
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1354
RA3FDevSoundToneSetVolumeRampWhilePlayingTest* RA3FDevSoundToneSetVolumeRampWhilePlayingTest::NewL(const TDesC& aTestName)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1355
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1356
	RA3FDevSoundToneSetVolumeRampWhilePlayingTest * self = new(ELeave)RA3FDevSoundToneSetVolumeRampWhilePlayingTest(aTestName);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1357
	return self;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1358
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1359
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1360
void RA3FDevSoundToneSetVolumeRampWhilePlayingTest::DoKickoffTestL()
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1361
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1362
	if (!GetIntFromConfig(iTestStepName, KVolume, iVolume)) 
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1363
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1364
		ERR_PRINTF2(KMsgErrorGetParameter, &KVolume);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1365
		StopTest(KErrNotFound);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1366
		return;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1367
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1368
	if (!GetIntFromConfig(iTestStepName, KDuration, iDuration)) 
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1369
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1370
		ERR_PRINTF2(KMsgErrorGetParameter, &KDuration);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1371
		StopTest(KErrNotFound);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1372
		return;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1373
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1374
	if (!GetIntFromConfig(iTestStepName, KFrequencyTone1, iFrequencyTone1)) 
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1375
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1376
		ERR_PRINTF2(KMsgErrorGetParameter, &KFrequencyTone1);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1377
		StopTest(KErrNotFound);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1378
		return;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1379
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1380
	if (!GetIntFromConfig(iTestStepName, KVolumeRamp, iVolumeRamp)) 
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1381
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1382
			ERR_PRINTF2(KMsgErrorGetParameter, &KVolumeRamp);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1383
			StopTest(KErrNotFound);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1384
			return;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1385
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1386
	iTimer = CPeriodic::NewL(CActive::EPriorityHigh);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1387
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1388
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1389
void RA3FDevSoundToneSetVolumeRampWhilePlayingTest::Fsm(TMmfDevSoundEvent aDevSoundEvent,  TInt aError)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1390
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1391
	switch (iDevSoundState)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1392
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1393
		case EStateCreated:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1394
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1395
			if (aDevSoundEvent == EEventInitialize)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1396
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1397
				__ASSERT_ALWAYS((aError == KErrNone), Panic(_L("RA3FDevSoundToneSetVolumeRampWhilePlayingTest"), EFsmIncorrectErrorPassed));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1398
				INFO_PRINTF1(_L("Calling CMMFDevSound::InitializeL"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1399
				TRAPD(err, iMMFDevSound->InitializeL(*this, EMMFStateTonePlaying));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1400
				if (err != KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1401
					{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1402
					ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"),  err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1403
					StopTest(err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1404
					break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1405
					}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1406
				INFO_PRINTF1(_L("DevSound State: EStateInitializing"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1407
				iDevSoundState = EStateInitializing;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1408
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1409
			else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1410
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1411
				ERR_PRINTF2(_L("DevSound EEventInitialize not received as expected. Received event: %d"), aDevSoundEvent);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1412
				StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1413
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1414
			break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1415
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1416
		case EStateInitializing:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1417
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1418
			if (aDevSoundEvent == EEventInitComplete && aError == KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1419
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1420
				iMMFDevSound->SetVolume(iMMFDevSound->MaxVolume());
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1421
				iStartTime.HomeTime();
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1422
				INFO_PRINTF3(_L("Calling CMMFDevSound::PlayToneL using frequency = %d Hz and duration = %d secs "), iFrequencyTone1, iDuration);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1423
				TRAPD(err, iMMFDevSound->PlayToneL(iFrequencyTone1, iDuration*KMicroSecsInOneSec));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1424
				if (err != KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1425
					{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1426
					ERR_PRINTF2(_L("Play tone left with error : %d!"), err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1427
					StopTest(err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1428
					break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1429
					}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1430
				StartTimer(KMicroSecsTwoSec);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1431
				INFO_PRINTF1(_L("DevSound State: EStatePlaying"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1432
				iDevSoundState = EStatePlaying;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1433
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1434
			else if (aDevSoundEvent == EEventInitComplete && aError != KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1435
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1436
				ERR_PRINTF2(_L("DevSound called CMMFDevSound::InitializeComplete with error = %d"), aError);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1437
				StopTest(aError);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1438
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1439
			else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1440
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1441
				ERR_PRINTF2(_L("DevSound EEventInitComplete not received as expected. Received event: %d"), aDevSoundEvent);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1442
				StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1443
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1444
			break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1445
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1446
		default:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1447
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1448
			ERR_PRINTF2(_L("Invalid DevSound state received: %d"), iDevSoundState);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1449
			StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1450
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1451
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1452
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1453
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1454
void RA3FDevSoundToneSetVolumeRampWhilePlayingTest::DoTimerCallback()
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1455
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1456
	iTimer->Cancel();
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1457
	INFO_PRINTF1(_L("DevSound Event: EEventTimerComplete"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1458
	INFO_PRINTF2(_L("Calling CMMFDevSound::SetVolumeRamp using volume ramp time = %d"), iVolumeRamp);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1459
	iMMFDevSound->SetVolumeRamp(iVolumeRamp);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1460
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1461
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1462
void RA3FDevSoundToneSetVolumeRampWhilePlayingTest::ToneFinished(TInt aError)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1463
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1464
	INFO_PRINTF1(_L("========== DevSound ToneFinished() callback =========="));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1465
	if (aError == KErrUnderflow)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1466
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1467
		TInt totalExpectedReproductionTime;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1468
		iTimesToneFinishedCalled++;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1469
		totalExpectedReproductionTime = iDuration * iTimesToneFinishedCalled * KMicroSecsInOneSec;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1470
		iEndTime.HomeTime();
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1471
		iPlayToneTime = iEndTime.MicroSecondsFrom(iStartTime);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1472
		if(!iTonePlayedTwice)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1473
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1474
			INFO_PRINTF2(_L("DevSound called ToneFinished with error = %d"), aError);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1475
			INFO_PRINTF3(_L("Calling CMMFDevSound::PlayToneL using frequency = %d Hz and duration = %d secs "), iFrequencyTone1, iDuration);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1476
			TRAPD(err, iMMFDevSound->PlayToneL(iFrequencyTone1, iDuration*KMicroSecsInOneSec));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1477
			if (err != KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1478
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1479
				ERR_PRINTF2(_L("CMMFDevSound::PlayToneL with error : %d!"), err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1480
				StopTest(err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1481
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1482
			iTonePlayedTwice = ETrue;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1483
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1484
		else if (iPlayToneTime < totalExpectedReproductionTime + (2*KPlayVarianceTime) && iPlayToneTime > totalExpectedReproductionTime - (2*KPlayVarianceTime))
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1485
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1486
			INFO_PRINTF2(_L("DevSound called ToneFinished twice with error = %d"), aError);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1487
			INFO_PRINTF2(_L("Play time is %Ld microseconds"), iPlayToneTime.Int64());
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1488
			StopTest();
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1489
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1490
		else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1491
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1492
			ERR_PRINTF3(_L("Play time is %Ld microseconds and it should have been %d microseconds"), iPlayToneTime.Int64(), totalExpectedReproductionTime);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1493
			StopTest(KErrNone, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1494
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1495
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1496
	else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1497
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1498
		ERR_PRINTF2(_L("DevSound called ToneFinished with error = %d"), aError);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1499
		ERR_PRINTF2(_L("Expected error = %d"), KErrUnderflow);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1500
		StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1501
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1502
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1503
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1504
/*
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1505
 *========================================================================================================
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1506
 * MM-A3F-DEVSOUND-CHRTZ-TONE-0012
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1507
 */
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1508
RA3FDevSoundToneSetToneRepetitionsWhilePlayingTest::RA3FDevSoundToneSetToneRepetitionsWhilePlayingTest(const TDesC& aTestName)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1509
	:	RA3FDevSoundTestBase(aTestName), 
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1510
		iDuration(0),
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1511
		iFrequencyTone1(0),
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1512
		iRepeatTrailingSilence(0), 
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1513
		iRepeatCount(0)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1514
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1515
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1516
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1517
RA3FDevSoundToneSetToneRepetitionsWhilePlayingTest* RA3FDevSoundToneSetToneRepetitionsWhilePlayingTest::NewL(const TDesC& aTestName)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1518
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1519
	RA3FDevSoundToneSetToneRepetitionsWhilePlayingTest * self = new(ELeave)RA3FDevSoundToneSetToneRepetitionsWhilePlayingTest(aTestName);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1520
	return self;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1521
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1522
	
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1523
void RA3FDevSoundToneSetToneRepetitionsWhilePlayingTest::DoKickoffTestL()
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1524
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1525
	if (!GetIntFromConfig(iTestStepName, KRepeatCount, iRepeatCount)) 
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1526
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1527
		ERR_PRINTF2(KMsgErrorGetParameter, &KRepeatCount);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1528
		StopTest(KErrNotFound);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1529
		return;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1530
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1531
	if (!GetIntFromConfig(iTestStepName, KRepeatTrailingSilence, iRepeatTrailingSilence)) 
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1532
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1533
		ERR_PRINTF2(KMsgErrorGetParameter, &KRepeatTrailingSilence);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1534
		StopTest(KErrNotFound);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1535
		return;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1536
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1537
	if (!GetIntFromConfig(iTestStepName, KDuration, iDuration)) 
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1538
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1539
		ERR_PRINTF2(KMsgErrorGetParameter, &KDuration);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1540
		StopTest(KErrNotFound);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1541
		return;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1542
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1543
	if (!GetIntFromConfig(iTestStepName, KFrequencyTone1, iFrequencyTone1)) 
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1544
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1545
		ERR_PRINTF2(KMsgErrorGetParameter, &KFrequencyTone1);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1546
		StopTest(KErrNotFound);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1547
		return;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1548
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1549
	iTimer = CPeriodic::NewL(CActive::EPriorityHigh);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1550
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1551
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1552
void RA3FDevSoundToneSetToneRepetitionsWhilePlayingTest::Fsm(TMmfDevSoundEvent aDevSoundEvent, TInt aError)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1553
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1554
	switch (iDevSoundState)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1555
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1556
		case EStateCreated:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1557
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1558
			__ASSERT_ALWAYS((aError == KErrNone), Panic(_L("RA3FDevSoundToneSetToneRepetitionsWhilePlayingConfigurationTest"), EFsmIncorrectErrorPassed));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1559
			if(aDevSoundEvent == EEventInitialize)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1560
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1561
				INFO_PRINTF1(_L("Calling CMMFDevSound::InitializeL"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1562
				TRAPD(err, iMMFDevSound->InitializeL(*this, EMMFStateTonePlaying));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1563
				if (err != KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1564
					{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1565
					ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"), err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1566
					StopTest(err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1567
					break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1568
					}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1569
				INFO_PRINTF1(_L("DevSound State: EStateInitializing"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1570
				iDevSoundState = EStateInitializing;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1571
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1572
			else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1573
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1574
				ERR_PRINTF2(_L("DevSound EEventInitialize not received as expected. Received event: %d"), aDevSoundEvent);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1575
				StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1576
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1577
			break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1578
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1579
		case EStateInitializing:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1580
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1581
			if (aDevSoundEvent == EEventInitComplete && aError == KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1582
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1583
				iMMFDevSound->SetVolume(iMMFDevSound->MaxVolume());
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1584
				iStartTime.HomeTime();
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1585
				INFO_PRINTF3(_L("Calling CMMFDevSound::PlayToneL %d Hz during %d secs "), iFrequencyTone1, iDuration);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1586
				TRAPD(err, iMMFDevSound->PlayToneL(iFrequencyTone1, iDuration*KMicroSecsInOneSec));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1587
				if (err != KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1588
					{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1589
					ERR_PRINTF2(_L("CMMFDevSound::PlayToneL left with error : %d!"), err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1590
					StopTest(err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1591
					break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1592
					}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1593
				StartTimer(KMicroSecsTwoSec);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1594
				INFO_PRINTF1(_L("DevSound State: EStatePlaying"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1595
				iDevSoundState = EStatePlaying;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1596
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1597
			else if (aDevSoundEvent == EEventInitComplete && aError != KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1598
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1599
				ERR_PRINTF2(_L("DevSound called CMMFDevSound::InitializeComplete with error = %d"), aError);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1600
				StopTest(aError);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1601
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1602
			else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1603
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1604
				ERR_PRINTF2(_L("DevSound EEventInitComplete not received as expected. Received event: %d"), aDevSoundEvent);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1605
				StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1606
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1607
			break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1608
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1609
		default:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1610
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1611
			ERR_PRINTF2(_L("Invalid DevSound state received: %d"), iDevSoundState);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1612
			StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1613
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1614
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1615
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1616
	
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1617
void RA3FDevSoundToneSetToneRepetitionsWhilePlayingTest::DoTimerCallback()
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1618
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1619
	iTimer->Cancel();
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1620
	INFO_PRINTF1(_L("DevSound Event: EEventTimerComplete"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1621
	INFO_PRINTF3(_L("Calling CMMFDevSound::SetToneRepeats using RepeatCount = %d and RepeatTrailingSilence = %d microsecs"), iRepeatCount, iRepeatTrailingSilence);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1622
	iMMFDevSound->SetToneRepeats(iRepeatCount, iRepeatTrailingSilence);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1623
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1624
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1625
void RA3FDevSoundToneSetToneRepetitionsWhilePlayingTest::ToneFinished(TInt aError)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1626
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1627
	INFO_PRINTF1(_L("========== DevSound ToneFinished() callback =========="));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1628
	const TInt KtimesPlayToneIsCalled = 2;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1629
	if (aError == KErrUnderflow)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1630
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1631
		iEndTime.HomeTime();
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1632
		iPlayToneTime = iEndTime.MicroSecondsFrom(iStartTime);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1633
		TInt repeatTrailingSilenceToSecs = iRepeatTrailingSilence/KMicroSecsInOneSec;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1634
		TInt totalExpectedReproductionTime = (KtimesPlayToneIsCalled*iDuration+iRepeatCount*iDuration + (repeatTrailingSilenceToSecs*iRepeatCount))*KMicroSecsInOneSec;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1635
		if(iPlayToneTime < ((iDuration*KMicroSecsInOneSec) + KPlayVarianceTime)&& iPlayToneTime > (iDuration*KMicroSecsInOneSec) - KPlayVarianceTime)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1636
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1637
			INFO_PRINTF1(_L("First play tone succeded."));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1638
			INFO_PRINTF2(_L("Play time is %Ld microseconds"), iPlayToneTime.Int64());		
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1639
			TRAPD(err, iMMFDevSound->PlayToneL(iFrequencyTone1, iDuration*KMicroSecsInOneSec));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1640
			if (err != KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1641
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1642
				ERR_PRINTF2(_L("CMMFDevSound::PlayToneL failed with error : %d!"), err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1643
				StopTest(err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1644
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1645
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1646
		else if(iPlayToneTime < totalExpectedReproductionTime + KPlayVarianceTime && iPlayToneTime > totalExpectedReproductionTime - KPlayVarianceTime)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1647
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1648
			INFO_PRINTF1(_L("Play tone repeats succeded."));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1649
			INFO_PRINTF2(_L("Play time is %Ld microseconds"), iPlayToneTime.Int64());
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1650
			StopTest();
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1651
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1652
		else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1653
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1654
			ERR_PRINTF1(_L("Play tone repeats did not work as planned."));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1655
			ERR_PRINTF3(_L("Play time is %Ld microseconds and it should have been %d microseconds"), iPlayToneTime.Int64(), totalExpectedReproductionTime);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1656
			StopTest(KErrNone, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1657
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1658
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1659
	else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1660
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1661
		ERR_PRINTF2(_L("DevSound called ToneFinished with error = %d"), aError);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1662
		ERR_PRINTF2(_L("Expected error = %d"), KErrUnderflow);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1663
		StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1664
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1665
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1666
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1667
/*
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1668
 *========================================================================================================
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1669
 * MM-A3F-DEVSOUND-CHRTZ-TONE-0013
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1670
 */
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1671
RA3FDevSoundToneSetDTMFLengthsWhilePlayingTest::RA3FDevSoundToneSetDTMFLengthsWhilePlayingTest(const TDesC& aTestName)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1672
	:	RA3FDevSoundTestBase(aTestName), 
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1673
		iFirstToneFinishedCall(EFalse),
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1674
		iToneOnLength(0), iToneOffLength(0),
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1675
		iPauseLength(0), iDTMFString(KNullDesC),
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1676
		iDTMFPauses(0), iDTMFTones(0),
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1677
		iTotalExpectedPlayToneTime(0)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1678
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1679
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1680
RA3FDevSoundToneSetDTMFLengthsWhilePlayingTest* RA3FDevSoundToneSetDTMFLengthsWhilePlayingTest::NewL(const TDesC& aTestName)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1681
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1682
	RA3FDevSoundToneSetDTMFLengthsWhilePlayingTest * self = new(ELeave)RA3FDevSoundToneSetDTMFLengthsWhilePlayingTest(aTestName);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1683
	return self;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1684
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1685
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1686
void RA3FDevSoundToneSetDTMFLengthsWhilePlayingTest::DoKickoffTestL()
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1687
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1688
	if (!GetIntFromConfig(iTestStepName, KToneOnLength, iToneOnLength)) 
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1689
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1690
		ERR_PRINTF2(KMsgErrorGetParameter, &KToneOnLength);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1691
		StopTest(KErrNotFound);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1692
		return;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1693
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1694
	if (!GetIntFromConfig(iTestStepName, KToneOffLength, iToneOffLength)) 
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1695
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1696
		ERR_PRINTF2(KMsgErrorGetParameter, &KToneOffLength);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1697
		StopTest(KErrNotFound);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1698
		return;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1699
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1700
	if (!GetIntFromConfig(iTestStepName, KPauseLength, iPauseLength)) 
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1701
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1702
		ERR_PRINTF2(KMsgErrorGetParameter, &KPauseLength);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1703
		StopTest(KErrNotFound);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1704
		return;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1705
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1706
	TPtrC DTMF;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1707
	if (!GetStringFromConfig(iTestStepName, KDTMFString, DTMF))
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1708
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1709
		ERR_PRINTF2(KMsgErrorGetParameter, &KDTMFString);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1710
		StopTest(KErrNotFound);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1711
		return;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1712
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1713
	iDTMFString.Copy(DTMF);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1714
	for(TInt i =0 ; i< iDTMFString.Length() ; i++)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1715
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1716
		if (iDTMFString[i] == ',')
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1717
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1718
			iDTMFPauses++;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1719
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1720
		else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1721
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1722
			iDTMFTones++;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1723
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1724
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1725
	iTimer = CPeriodic::NewL(CActive::EPriorityHigh);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1726
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1727
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1728
void RA3FDevSoundToneSetDTMFLengthsWhilePlayingTest::Fsm(TMmfDevSoundEvent aDevSoundEvent, TInt aError)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1729
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1730
	switch (iDevSoundState)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1731
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1732
		case EStateCreated:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1733
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1734
			__ASSERT_ALWAYS((aError == KErrNone), Panic(_L("RA3FDevSoundToneSetDTMFToneRepetitionsWhilePlayingConfigurationTest"), EFsmIncorrectErrorPassed));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1735
			if(aDevSoundEvent == EEventInitialize)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1736
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1737
				INFO_PRINTF1(_L("Calling CMMFDevSound::InitializeL"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1738
				TRAPD(err, iMMFDevSound->InitializeL(*this, EMMFStateTonePlaying));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1739
				if (err != KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1740
					{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1741
					ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"), err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1742
					StopTest(err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1743
					break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1744
					}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1745
				INFO_PRINTF1(_L("DevSound State: EStateInitializing"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1746
				iDevSoundState = EStateInitializing;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1747
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1748
			else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1749
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1750
				ERR_PRINTF2(_L("DevSound EEventInitialize not received as expected. Received event: %d"), aDevSoundEvent);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1751
				StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1752
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1753
			break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1754
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1755
		case EStateInitializing:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1756
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1757
			if (aDevSoundEvent == EEventInitComplete && aError == KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1758
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1759
				iMMFDevSound->SetVolume(iMMFDevSound->MaxVolume());
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1760
				iStartTime.HomeTime();
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1761
				INFO_PRINTF2(_L("Calling CMMFDevSound::L %S"), &iDTMFString);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1762
				TRAPD(err, iMMFDevSound->PlayDTMFStringL(iDTMFString));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1763
				if (err != KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1764
					{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1765
					ERR_PRINTF2(_L("CMMFDevSound::PlayDTMFStringL left with error : %d!"), err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1766
					StopTest(err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1767
					break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1768
					}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1769
				StartTimer(KMicroSecsTwoSec);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1770
				INFO_PRINTF1(_L("DevSound State: EStatePlaying"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1771
				iDevSoundState=EStatePlaying;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1772
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1773
			else if (aDevSoundEvent == EEventInitComplete && aError != KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1774
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1775
				ERR_PRINTF2(_L("DevSound called CMMFDevSound::InitializeComplete with error = %d"), aError);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1776
				StopTest(aError);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1777
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1778
			else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1779
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1780
				ERR_PRINTF2(_L("DevSound EEventInitComplete not received as expected. Received event: %d"), aDevSoundEvent);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1781
				StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1782
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1783
			break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1784
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1785
		default:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1786
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1787
			ERR_PRINTF2(_L("Invalid DevSound state received: %d"), iDevSoundState);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1788
			StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1789
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1790
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1791
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1792
	
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1793
void RA3FDevSoundToneSetDTMFLengthsWhilePlayingTest::DoTimerCallback()
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1794
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1795
	iTimer->Cancel();
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1796
	INFO_PRINTF1(_L("DevSound Event: EEventTimerComplete"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1797
	TTimeIntervalMicroSeconds32 ToneOnLength(iToneOnLength);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1798
	TTimeIntervalMicroSeconds32 ToneOffLength(iToneOffLength);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1799
	TTimeIntervalMicroSeconds32 PauseLength(iPauseLength);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1800
	INFO_PRINTF4(_L("Calling CMMFDevSound::SetDTMFLengths. ToneOnLength = %d, ToneOffLength = %d and PauseLength = %d"), ToneOnLength.Int(), ToneOffLength.Int(), PauseLength.Int());
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1801
	iMMFDevSound->SetDTMFLengths(ToneOnLength, ToneOffLength, PauseLength);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1802
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1803
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1804
void RA3FDevSoundToneSetDTMFLengthsWhilePlayingTest::ToneFinished(TInt aError)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1805
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1806
	INFO_PRINTF1(_L("========== DevSound ToneFinished() callback =========="));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1807
	if (aError == KErrUnderflow)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1808
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1809
		iEndTime.HomeTime();
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1810
		iPlayToneTime = iEndTime.MicroSecondsFrom(iStartTime);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1811
		if (!iFirstToneFinishedCall)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1812
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1813
			INFO_PRINTF1(_L("First play tone succeded"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1814
			INFO_PRINTF2(_L("Play time is %Ld microseconds"), iPlayToneTime.Int64());
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1815
			iFirstToneFinishedCall = ETrue;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1816
			INFO_PRINTF2(_L("Calling CMMFDevSound::PlayDTMFStringL %S"), &iDTMFString);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1817
			TRAPD(err, iMMFDevSound->PlayDTMFStringL(iDTMFString));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1818
			if (err != KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1819
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1820
				ERR_PRINTF2(_L("CMMFDevSound::PlayDTMFStringL left with error = %d"), err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1821
				StopTest(err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1822
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1823
			iTotalExpectedPlayToneTime = iToneOnLength*iDTMFTones + iToneOffLength * iDTMFTones + iDTMFPauses * iPauseLength + iPlayToneTime.Int64();
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1824
			return;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1825
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1826
		if (iPlayToneTime.Int64() < iTotalExpectedPlayToneTime + KPlayVarianceTime && iPlayToneTime.Int64() > iTotalExpectedPlayToneTime - KPlayVarianceTime)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1827
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1828
			INFO_PRINTF1(_L("Calling CMMFDevSound::SetDTMFLengths succeded."));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1829
			INFO_PRINTF2(_L("Play time is %Ld microseconds"), iPlayToneTime.Int64());
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1830
			StopTest();
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1831
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1832
		else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1833
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1834
			ERR_PRINTF2(_L("Calling CMMFDevSound::SetDTMFLengths failed with %Ld"), iPlayToneTime.Int64());
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1835
			ERR_PRINTF2(_L("Expected time %d"), iTotalExpectedPlayToneTime);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1836
			StopTest(KErrNone, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1837
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1838
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1839
	else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1840
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1841
		ERR_PRINTF2(_L("DevSound called ToneFinished with error = %d"), aError);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1842
		ERR_PRINTF2(_L("Expected error = %Ld"), KErrUnderflow);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1843
		StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1844
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1845
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1846
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1847
/*
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1848
 *========================================================================================================
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1849
 * MM-A3F-DEVSOUND-CHRTZ-TONE-0014
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1850
 */
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1851
RA3FDevSoundToneSetToneRepetitionsNotPlayingTonesModeTest::RA3FDevSoundToneSetToneRepetitionsNotPlayingTonesModeTest(const TDesC& aTestName)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1852
	:	RA3FDevSoundTestBase(aTestName), iDuration(0),
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1853
		iFrequencyTone1(0),
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1854
		iRepeatTrailingSilence(0), iRepeatCount(0),
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1855
		iInitializedToPlayTones(EFalse)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1856
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1857
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1858
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1859
RA3FDevSoundToneSetToneRepetitionsNotPlayingTonesModeTest* RA3FDevSoundToneSetToneRepetitionsNotPlayingTonesModeTest::NewL(const TDesC& aTestName)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1860
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1861
	RA3FDevSoundToneSetToneRepetitionsNotPlayingTonesModeTest * self = new(ELeave)RA3FDevSoundToneSetToneRepetitionsNotPlayingTonesModeTest(aTestName);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1862
	return self;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1863
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1864
	
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1865
void RA3FDevSoundToneSetToneRepetitionsNotPlayingTonesModeTest::DoKickoffTestL()
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1866
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1867
	if (!GetIntFromConfig(iTestStepName, KRepeatCount, iRepeatCount)) 
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1868
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1869
		ERR_PRINTF2(KMsgErrorGetParameter, &KRepeatCount);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1870
		StopTest(KErrNotFound);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1871
		return;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1872
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1873
	if (!GetIntFromConfig(iTestStepName, KRepeatTrailingSilence, iRepeatTrailingSilence)) 
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1874
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1875
		ERR_PRINTF2(KMsgErrorGetParameter, &KRepeatTrailingSilence);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1876
		StopTest(KErrNotFound);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1877
		return;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1878
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1879
	if (!GetIntFromConfig(iTestStepName, KDuration, iDuration)) 
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1880
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1881
		ERR_PRINTF2(KMsgErrorGetParameter, &KDuration);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1882
		StopTest(KErrNotFound);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1883
		return;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1884
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1885
	if (!GetIntFromConfig(iTestStepName, KFrequencyTone1, iFrequencyTone1)) 
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1886
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1887
		ERR_PRINTF2(KMsgErrorGetParameter, &KFrequencyTone1);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1888
		StopTest(KErrNotFound);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1889
		return;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1890
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1891
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1892
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1893
void RA3FDevSoundToneSetToneRepetitionsNotPlayingTonesModeTest::Fsm(TMmfDevSoundEvent aDevSoundEvent, TInt aError)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1894
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1895
	switch (iDevSoundState)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1896
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1897
		case EStateCreated:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1898
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1899
			__ASSERT_ALWAYS((aError == KErrNone), Panic(_L("RA3FDevSoundToneSetToneRepetitionsNotPlayingTonesModeConfigurationTest"), EFsmIncorrectErrorPassed));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1900
			if(aDevSoundEvent == EEventInitialize)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1901
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1902
				INFO_PRINTF1(_L("Calling CMMFDevSound::InitializeL"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1903
				TRAPD(err, iMMFDevSound->InitializeL(*this, EMMFStatePlaying));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1904
				if (err != KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1905
					{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1906
					ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"), err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1907
					StopTest(err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1908
					break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1909
					}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1910
				INFO_PRINTF1(_L("DevSound State: EStateInitializing"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1911
				iDevSoundState = EStateInitializing;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1912
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1913
			else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1914
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1915
				ERR_PRINTF2(_L("DevSound EEventInitialize not received as expected. Received event: %d"), aDevSoundEvent);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1916
				StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1917
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1918
			break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1919
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1920
		case EStateInitializing:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1921
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1922
			if (aDevSoundEvent == EEventInitComplete && aError == KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1923
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1924
				if(!iInitializedToPlayTones)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1925
					{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1926
					INFO_PRINTF3(_L("Calling CMMFDevSound::SetToneRepeats using RepeatCount = %d and RepeatTrailingSilence = %d microsecs"), iRepeatCount, iRepeatTrailingSilence);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1927
					iMMFDevSound->SetToneRepeats(iRepeatCount, iRepeatTrailingSilence);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1928
					INFO_PRINTF1(_L("Calling CMMFDevSound::InitializeL for playing tones"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1929
					TRAPD(err, iMMFDevSound->InitializeL(*this, EMMFStateTonePlaying));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1930
					if (err != KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1931
						{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1932
						ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"), err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1933
						StopTest(err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1934
						break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1935
						}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1936
					iInitializedToPlayTones = ETrue;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1937
					}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1938
				else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1939
					{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1940
					iMMFDevSound->SetVolume(iMMFDevSound->MaxVolume());
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1941
					iStartTime.HomeTime();
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1942
					INFO_PRINTF3(_L("Calling CMMFDevSound::PlayToneL %d Hz during %d secs "), iFrequencyTone1, iDuration);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1943
					TRAPD(err, iMMFDevSound->PlayToneL(iFrequencyTone1, iDuration*KMicroSecsInOneSec));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1944
					if (err != KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1945
						{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1946
						ERR_PRINTF2(_L("CMMFDevSound::PlayToneL left with error : %d!"), err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1947
						StopTest(err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1948
						break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1949
						}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1950
					INFO_PRINTF1(_L("DevSound State: EStatePlaying"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1951
					iDevSoundState = EStatePlaying;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1952
					}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1953
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1954
			else if (aDevSoundEvent == EEventInitComplete && aError != KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1955
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1956
				ERR_PRINTF2(_L("DevSound called CMMFDevSound::InitializeComplete with error = %d"), aError);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1957
				StopTest(aError);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1958
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1959
			else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1960
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1961
				ERR_PRINTF2(_L("DevSound EEventInitComplete not received as expected. Received event: %d"), aDevSoundEvent);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1962
				StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1963
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1964
			break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1965
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1966
		default:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1967
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1968
			ERR_PRINTF2(_L("Invalid DevSound state received: %d"), iDevSoundState);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1969
			StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1970
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1971
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1972
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1973
	
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1974
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1975
void RA3FDevSoundToneSetToneRepetitionsNotPlayingTonesModeTest::ToneFinished(TInt aError)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1976
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1977
	INFO_PRINTF1(_L("========== DevSound ToneFinished() callback =========="));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1978
	if (aError == KErrUnderflow)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1979
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1980
		iEndTime.HomeTime();
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1981
		iPlayToneTime = iEndTime.MicroSecondsFrom(iStartTime);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1982
		TInt repeatTrailingSilenceToSecs = iRepeatTrailingSilence/KMicroSecsInOneSec;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1983
		TInt totalExpectedReproductionTime = (iDuration + iRepeatCount * iDuration+ (repeatTrailingSilenceToSecs*iRepeatCount)) * KMicroSecsInOneSec;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1984
		if(iPlayToneTime < (totalExpectedReproductionTime + KPlayVarianceTime) && iPlayToneTime > (totalExpectedReproductionTime - KPlayVarianceTime))
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1985
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1986
			INFO_PRINTF1(_L("Play tone repeats succeded."));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1987
			INFO_PRINTF2(_L("Play time is %Ld microseconds"), iPlayToneTime.Int64());
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1988
			StopTest();
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1989
			}		
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1990
		else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1991
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1992
			ERR_PRINTF1(_L("Play tone repeats did not work as planned."));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1993
			ERR_PRINTF3(_L("Play time is %Ld microseconds and it should have been %d microseconds"), iPlayToneTime.Int64(), totalExpectedReproductionTime);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1994
			StopTest(KErrNone, EFail);	
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1995
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1996
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1997
	else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1998
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  1999
		ERR_PRINTF2(_L("DevSound called ToneFinished with error = %d"), aError);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2000
		ERR_PRINTF2(_L("Expected error = %d"), KErrUnderflow);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2001
		StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2002
		}	
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2003
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2004
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2005
/*
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2006
 *========================================================================================================
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2007
 * MM-A3F-DEVSOUND-CHRTZ-TONE-0015
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2008
 */
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2009
RA3FDevSoundToneSetDTMFLengthsNotPlayingTonesModeTest::RA3FDevSoundToneSetDTMFLengthsNotPlayingTonesModeTest(const TDesC& aTestName)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2010
	:	RA3FDevSoundTestBase(aTestName), iInitializedToPlayTones(EFalse),
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2011
		iDTMFString(KNullDesC), iToneOnLength(0),
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2012
		iToneOffLength(0), iPauseLength(0),
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2013
		iDTMFPauses(0), iDTMFTones(0)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2014
		
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2015
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2016
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2017
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2018
RA3FDevSoundToneSetDTMFLengthsNotPlayingTonesModeTest* RA3FDevSoundToneSetDTMFLengthsNotPlayingTonesModeTest::NewL(const TDesC& aTestName)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2019
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2020
	RA3FDevSoundToneSetDTMFLengthsNotPlayingTonesModeTest * self = new(ELeave)RA3FDevSoundToneSetDTMFLengthsNotPlayingTonesModeTest(aTestName);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2021
	return self;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2022
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2023
	
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2024
void RA3FDevSoundToneSetDTMFLengthsNotPlayingTonesModeTest::DoKickoffTestL()
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2025
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2026
	if (!GetIntFromConfig(iTestStepName, KToneOnLength, iToneOnLength)) 
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2027
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2028
		ERR_PRINTF2(KMsgErrorGetParameter, &KToneOnLength);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2029
		StopTest(KErrNotFound);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2030
		return;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2031
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2032
	if (!GetIntFromConfig(iTestStepName, KToneOffLength, iToneOffLength)) 
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2033
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2034
		ERR_PRINTF2(KMsgErrorGetParameter, &KToneOffLength);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2035
		StopTest(KErrNotFound);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2036
		return;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2037
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2038
	if (!GetIntFromConfig(iTestStepName, KPauseLength, iPauseLength))
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2039
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2040
		ERR_PRINTF2(KMsgErrorGetParameter, &KPauseLength);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2041
		StopTest(KErrNotFound);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2042
		return;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2043
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2044
	TPtrC DTMF;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2045
	if (!GetStringFromConfig(iTestStepName, KDTMFString, DTMF))
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2046
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2047
		ERR_PRINTF2(KMsgErrorGetParameter, &KDTMFString);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2048
		StopTest(KErrNotFound);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2049
		return;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2050
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2051
	iDTMFString.Copy(DTMF);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2052
	for(TInt i =0 ; i< iDTMFString.Length() ; i++)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2053
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2054
		if (iDTMFString[i] == ',')
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2055
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2056
			iDTMFPauses++;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2057
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2058
		else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2059
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2060
			iDTMFTones++;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2061
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2062
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2063
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2064
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2065
void RA3FDevSoundToneSetDTMFLengthsNotPlayingTonesModeTest::Fsm(TMmfDevSoundEvent aDevSoundEvent, TInt aError)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2066
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2067
	switch (iDevSoundState)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2068
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2069
		case EStateCreated:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2070
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2071
			__ASSERT_ALWAYS((aError == KErrNone), Panic(_L("RA3FDevSoundToneSetDTMFLengthsNotPlayingTonesModeConfigurationTest"), EFsmIncorrectErrorPassed));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2072
			if(aDevSoundEvent == EEventInitialize)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2073
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2074
				INFO_PRINTF1(_L("Calling CMMFDevSound::InitializeL"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2075
				TRAPD(err, iMMFDevSound->InitializeL(*this, EMMFStateRecording));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2076
				if (err != KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2077
					{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2078
					ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"), err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2079
					StopTest(err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2080
					break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2081
					}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2082
				INFO_PRINTF1(_L("DevSound State: EStateInitializing"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2083
				iDevSoundState = EStateInitializing;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2084
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2085
			else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2086
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2087
				ERR_PRINTF2(_L("DevSound EEventInitialize not received as expected. Received event: %d"),  aDevSoundEvent);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2088
				StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2089
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2090
			break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2091
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2092
		case EStateInitializing:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2093
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2094
			if (aDevSoundEvent == EEventInitComplete && aError == KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2095
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2096
				if(!iInitializedToPlayTones)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2097
					{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2098
					TTimeIntervalMicroSeconds32 ToneOnLength(iToneOnLength);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2099
					TTimeIntervalMicroSeconds32 ToneOffLength(iToneOffLength);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2100
					TTimeIntervalMicroSeconds32 PauseLength(iPauseLength);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2101
					INFO_PRINTF4(_L("Calling CMMFDevSound::SetDTMFLengths. ToneOnLength = %d, ToneOffLength = %d and PauseLength = %d"), ToneOnLength.Int(), ToneOffLength.Int(), PauseLength.Int());
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2102
					iMMFDevSound->SetDTMFLengths(ToneOnLength, ToneOffLength, PauseLength);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2103
					INFO_PRINTF1(_L("Calling CMMFDevSound::InitializeL"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2104
					TRAPD(err, iMMFDevSound->InitializeL(*this, EMMFStateTonePlaying));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2105
					if (err != KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2106
						{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2107
						ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"), err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2108
						StopTest(err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2109
						break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2110
						}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2111
					iInitializedToPlayTones = ETrue;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2112
					}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2113
				else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2114
					{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2115
					iMMFDevSound->SetVolume(iMMFDevSound->MaxVolume());
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2116
					iStartTime.HomeTime();
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2117
					INFO_PRINTF2(_L("Calling CMMFDevSound::PlayDTMFStringL %S"), &iDTMFString);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2118
					TRAPD(err, iMMFDevSound->PlayDTMFStringL(iDTMFString));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2119
					if (err != KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2120
						{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2121
						ERR_PRINTF2(_L("Play DTMF string failed with error : %d!"), err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2122
						StopTest(err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2123
						break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2124
						}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2125
					INFO_PRINTF1(_L("DevSound State: EStatePlaying"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2126
					iDevSoundState = EStatePlaying;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2127
					}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2128
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2129
			else if (aDevSoundEvent == EEventInitComplete && aError != KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2130
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2131
				ERR_PRINTF2(_L("DevSound called CMMFDevSound::InitializeComplete with error = %d"), aError);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2132
				StopTest(aError);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2133
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2134
			else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2135
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2136
				ERR_PRINTF2(_L("DevSound EEventInitComplete not received as expected. Received event: %d"), aDevSoundEvent);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2137
				StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2138
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2139
			break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2140
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2141
		default:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2142
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2143
			ERR_PRINTF2(_L("Invalid DevSound state received: %d"), iDevSoundState);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2144
			StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2145
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2146
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2147
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2148
	
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2149
void RA3FDevSoundToneSetDTMFLengthsNotPlayingTonesModeTest::ToneFinished(TInt aError)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2150
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2151
	INFO_PRINTF1(_L("========== DevSound ToneFinished() callback =========="));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2152
	if (aError == KErrUnderflow)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2153
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2154
		iEndTime.HomeTime();
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2155
		iPlayToneTime = iEndTime.MicroSecondsFrom(iStartTime);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2156
		TInt totalExpectedReproductionTime = iToneOnLength*iDTMFTones + iToneOffLength * iDTMFTones + iDTMFPauses * iPauseLength;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2157
		if (iPlayToneTime.Int64() < totalExpectedReproductionTime + KPlayVarianceTime && iPlayToneTime.Int64() > totalExpectedReproductionTime - KPlayVarianceTime)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2158
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2159
			INFO_PRINTF1(_L("CMMFDevSound::SetDTMFLengths settings were remembered after re-initialization."));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2160
			INFO_PRINTF2(_L("Play time is %Ld microseconds"), iPlayToneTime.Int64());
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2161
			StopTest();
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2162
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2163
		else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2164
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2165
			ERR_PRINTF1(_L("CMMFDevSound::SetDTMFLengths settings were not remembered after re-initialization."));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2166
			ERR_PRINTF2(_L("Expected time %d"), totalExpectedReproductionTime);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2167
			StopTest(KErrNone, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2168
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2169
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2170
	else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2171
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2172
		ERR_PRINTF2(_L("DevSound called ToneFinished with error = %d"), aError);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2173
		ERR_PRINTF2(_L("Expected error = %d"), KErrUnderflow);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2174
		StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2175
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2176
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2177
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2178
/*
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2179
 *========================================================================================================
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2180
 * MM-A3F-DEVSOUND-CHRTZ-TONE-0016
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2181
 */
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2182
RA3FDevSoundToneSetConfigWhilePlayingTest::RA3FDevSoundToneSetConfigWhilePlayingTest(const TDesC& aTestName)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2183
	:	RA3FDevSoundTestBase(aTestName), iDuration(0), 
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2184
		iVolume(0), iFrequencyTone1(0), 
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2185
		iSampleRate(0), iChannels(0)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2186
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2187
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2188
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2189
RA3FDevSoundToneSetConfigWhilePlayingTest* RA3FDevSoundToneSetConfigWhilePlayingTest::NewL(const TDesC& aTestName)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2190
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2191
	RA3FDevSoundToneSetConfigWhilePlayingTest * self = new(ELeave)RA3FDevSoundToneSetConfigWhilePlayingTest(aTestName);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2192
	return self;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2193
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2194
	
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2195
void RA3FDevSoundToneSetConfigWhilePlayingTest::DoKickoffTestL()
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2196
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2197
	if (!GetIntFromConfig(iTestStepName, KSampleRate, iSampleRate)) 
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2198
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2199
		ERR_PRINTF2(KMsgErrorGetParameter, &KSampleRate);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2200
		StopTest(KErrNotFound);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2201
		return;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2202
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2203
	if (!GetIntFromConfig(iTestStepName, KChannel, iChannels)) 
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2204
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2205
		ERR_PRINTF2(KMsgErrorGetParameter, &KChannel);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2206
		StopTest(KErrNotFound);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2207
		return;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2208
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2209
	if (!GetIntFromConfig(iTestStepName, KDuration, iDuration)) 
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2210
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2211
		ERR_PRINTF2(KMsgErrorGetParameter, &KDuration);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2212
		StopTest(KErrNotFound);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2213
		return;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2214
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2215
	if (!GetIntFromConfig(iTestStepName, KFrequencyTone1, iFrequencyTone1)) 
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2216
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2217
		ERR_PRINTF2(KMsgErrorGetParameter, &KFrequencyTone1);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2218
		StopTest(KErrNotFound);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2219
		return;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2220
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2221
	iTimer = CPeriodic::NewL(CActive::EPriorityHigh);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2222
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2223
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2224
void RA3FDevSoundToneSetConfigWhilePlayingTest::Fsm(TMmfDevSoundEvent aDevSoundEvent,  TInt aError)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2225
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2226
	switch (iDevSoundState)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2227
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2228
		case EStateCreated:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2229
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2230
			__ASSERT_ALWAYS((aError == KErrNone), Panic(_L("RA3FDevSoundToneSetConfigWhilePlayingTest"), EFsmIncorrectErrorPassed));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2231
			if (aDevSoundEvent == EEventInitialize)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2232
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2233
				INFO_PRINTF1(_L("Calling CMMFDevSound::InitializeL"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2234
				TRAPD(err, iMMFDevSound->InitializeL(*this, EMMFStateTonePlaying));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2235
				if (err != KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2236
					{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2237
					ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"), err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2238
					StopTest(err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2239
					break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2240
					}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2241
				StartTimer(KMicroSecsTwoSec);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2242
				INFO_PRINTF1(_L("DevSound State: EStateInitializing"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2243
				iDevSoundState = EStateInitializing;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2244
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2245
			else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2246
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2247
				ERR_PRINTF2(_L("DevSound EEventInitialize not received as expected. Received event: %d"), aDevSoundEvent);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2248
				StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2249
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2250
			break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2251
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2252
		case EStateInitializing:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2253
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2254
			if (aDevSoundEvent == EEventInitComplete && aError == KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2255
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2256
				INFO_PRINTF1(_L("CMMFDevSound::PlayToneL"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2257
				TRAPD(err, iMMFDevSound->PlayToneL(iFrequencyTone1,  iDuration*KMicroSecsInOneSec));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2258
				if (err != KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2259
					{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2260
					ERR_PRINTF2(_L("CMMFDevSound::PlayToneL left with error : %d"), err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2261
					StopTest(err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2262
					break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2263
					}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2264
				INFO_PRINTF1(_L("DevSound State: EStatePlaying"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2265
				iDevSoundState = EStatePlaying;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2266
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2267
			else if (aDevSoundEvent == EEventInitComplete && aError != KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2268
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2269
				ERR_PRINTF2(_L("DevSound called CMMFDevSound::InitializeComplete with error = %d"), aError);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2270
				StopTest(aError);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2271
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2272
			else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2273
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2274
				ERR_PRINTF2(_L("DevSound EEventInitComplete not received as expected. Received event: %d"), aDevSoundEvent);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2275
				StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2276
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2277
			break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2278
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2279
		default:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2280
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2281
			ERR_PRINTF2(_L("Invalid DevSound state received: %d"), iDevSoundState);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2282
			StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2283
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2284
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2285
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2286
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2287
void RA3FDevSoundToneSetConfigWhilePlayingTest::DoTimerCallback()
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2288
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2289
	iTimer->Cancel();
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2290
	INFO_PRINTF1(_L("DevSound Event: EEventTimerComplete"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2291
	TMMFCapabilities capabilitiesSet;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2292
	TBuf<KMaxSampleRateStringLength> stringSampleRateSet;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2293
	TBuf<KMaxChannelsStringLength> stringChannelsSet;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2294
	TMMFSampleRate eSampleRate;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2295
	SampleRateFromTIntToTMMFSampleRate (iSampleRate, eSampleRate);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2296
	capabilitiesSet.iRate = eSampleRate;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2297
	capabilitiesSet.iChannels = iChannels;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2298
	SampleRateFromTUintToString (capabilitiesSet.iRate,	stringSampleRateSet);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2299
	ChannelsFromTUintToString (capabilitiesSet.iChannels, stringChannelsSet);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2300
	INFO_PRINTF3(_L("Calling CMMFDevSound::SetConfigL using sample rate = %S and channel mode = %S"), &stringSampleRateSet, &stringChannelsSet);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2301
	TRAPD(err, iMMFDevSound->SetConfigL(capabilitiesSet));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2302
	if (err == KErrNotReady)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2303
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2304
		INFO_PRINTF2(_L("CMMFDevSound::SetConfigL succeeded with error = %d"), err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2305
		StopTest(err, EPass);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2306
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2307
	else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2308
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2309
		ERR_PRINTF2(_L("CMMFDevSound::SetConfigL failed with error = %d"), err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2310
		ERR_PRINTF2(_L("Expected  error = %d"), KErrNotReady);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2311
		StopTest(err, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2312
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2313
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2314
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2315
/*
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2316
 *========================================================================================================
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2317
 * MM-A3F-DEVSOUND-CHRTZ-TONE-0017
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2318
 */
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2319
RA3FDevSoundToneSetPriorityWhilePlayingTest::RA3FDevSoundToneSetPriorityWhilePlayingTest(const TDesC& aTestName)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2320
	:	RA3FDevSoundTestBase(aTestName),
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2321
		iDuration(0), iFrequencyTone1(0)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2322
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2323
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2324
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2325
RA3FDevSoundToneSetPriorityWhilePlayingTest* RA3FDevSoundToneSetPriorityWhilePlayingTest::NewL(const TDesC& aTestName)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2326
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2327
	RA3FDevSoundToneSetPriorityWhilePlayingTest * self = new(ELeave)RA3FDevSoundToneSetPriorityWhilePlayingTest(aTestName);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2328
	return self;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2329
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2330
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2331
void RA3FDevSoundToneSetPriorityWhilePlayingTest::DoKickoffTestL()
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2332
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2333
	if (!GetIntFromConfig(iTestStepName, KDuration, iDuration)) 
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2334
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2335
		ERR_PRINTF2(KMsgErrorGetParameter, &KDuration);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2336
		StopTest(KErrNotFound);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2337
		return;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2338
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2339
	if (!GetIntFromConfig(iTestStepName, KFrequencyTone1, iFrequencyTone1)) 
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2340
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2341
		ERR_PRINTF2(KMsgErrorGetParameter, &KFrequencyTone1);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2342
		StopTest(KErrNotFound);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2343
		return;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2344
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2345
	iTimer = CPeriodic::NewL(CActive::EPriorityHigh);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2346
	iDevsoundToneClient = CA3FDevSoundToneClient::NewL(*this);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2347
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2348
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2349
void RA3FDevSoundToneSetPriorityWhilePlayingTest::Fsm(TMmfDevSoundEvent aDevSoundEvent, TInt aError)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2350
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2351
	switch(iDevSoundState)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2352
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2353
		case EStateCreated:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2354
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2355
			__ASSERT_ALWAYS((aError == KErrNone), Panic(_L("RA3FDevSoundToneSetPriorityWhilePlayingConfigurationTest"), EFsmIncorrectErrorPassed));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2356
			if(aDevSoundEvent == EEventInitialize)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2357
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2358
				INFO_PRINTF1(_L("Calling CMMFDevSound::InitializeL"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2359
				TRAPD(err, iMMFDevSound->InitializeL(*this, EMMFStateTonePlaying));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2360
				if (err != KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2361
					{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2362
					ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"), err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2363
					StopTest(err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2364
					break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2365
					}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2366
				INFO_PRINTF1(_L("DevSound State: EStateInitializing"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2367
				iDevSoundState = EStateInitializing;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2368
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2369
			else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2370
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2371
				ERR_PRINTF2(_L("DevSound EEventInitialize not received as expected. Received event: %d"), aDevSoundEvent);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2372
				StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2373
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2374
			break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2375
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2376
		case EStateInitializing:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2377
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2378
			if (aDevSoundEvent == EEventInitComplete && aError == KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2379
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2380
				iMMFDevSound->SetVolume(iMMFDevSound->MaxVolume ());
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2381
				INFO_PRINTF1(_L("Calling CMMFDevSound::PlayToneL"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2382
				TRAPD(err, iMMFDevSound->PlayToneL(iFrequencyTone1, iDuration*KMicroSecsInOneSec));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2383
				if (err != KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2384
					{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2385
					ERR_PRINTF2(_L("CMMFDevSound::PlayToneL left with error : %d!"), err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2386
					StopTest(err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2387
					break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2388
					}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2389
				StartTimer(KMicroSecsTwoSec);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2390
				INFO_PRINTF1(_L("DevSound State: EStatePlaying"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2391
				iDevSoundState = EStatePlaying;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2392
				INFO_PRINTF2(_L("Calling CMMFDevSound::SetPrioritySettings using a priority(highest) value = %d"), KMaximumPriority);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2393
				TMMFPrioritySettings priority;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2394
				priority.iPriority = KMaximumPriority;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2395
				iMMFDevSound->SetPrioritySettings(priority);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2396
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2397
			else if (aDevSoundEvent == EEventInitComplete && aError != KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2398
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2399
				ERR_PRINTF2(_L("DevSound called CMMFDevSound::InitializeComplete with error = %d"), aError);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2400
				StopTest(aError);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2401
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2402
			else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2403
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2404
				ERR_PRINTF2(_L("DevSound EEventInitComplete not received as expected. Received event: %d"), aDevSoundEvent);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2405
				StopTest(aError,  EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2406
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2407
			break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2408
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2409
		default:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2410
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2411
			ERR_PRINTF2(_L("Invalid DevSound state received: %d"), iDevSoundState);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2412
			StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2413
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2414
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2415
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2416
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2417
void RA3FDevSoundToneSetPriorityWhilePlayingTest::ClientInitializeCompleteCallback(TInt aError)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2418
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2419
	INFO_PRINTF1(_L("==========Second DevSound client called InitializeComplete()=========="));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2420
	if (aError == KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2421
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2422
		TInt err = iDevsoundToneClient->PlayTone ();
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2423
		if (err != KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2424
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2425
			ERR_PRINTF2(_L("Second Devsound client called PlayTone and failed with error = %d"), err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2426
			StopTest(err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2427
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2428
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2429
	else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2430
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2431
		ERR_PRINTF2(_L("Second Devsound InitializeComplete received an error = %d"), aError);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2432
		StopTest(aError);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2433
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2434
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2435
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2436
void RA3FDevSoundToneSetPriorityWhilePlayingTest::ClientToneFinishedCallback(TInt aError)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2437
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2438
	INFO_PRINTF1(_L("========== Second  DevSound client called ToneFinished()=========="));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2439
	if (aError == KErrUnderflow)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2440
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2441
		INFO_PRINTF2(_L("Second DevSound client called ToneFinished and succeeded with error = %d"), aError);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2442
		StopTest(aError, EPass);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2443
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2444
	else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2445
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2446
		ERR_PRINTF2(_L("Second DevSound client called ToneFinished and failed with error = %d"), aError);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2447
		StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2448
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2449
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2450
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2451
void RA3FDevSoundToneSetPriorityWhilePlayingTest::DoTimerCallback()
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2452
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2453
	INFO_PRINTF1(_L("TimerEvent called"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2454
	iTimer->Cancel();
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2455
	INFO_PRINTF1(_L("Starting another devsound client using the highest priority"));	
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2456
	iDevsoundToneClient->SetPriority(KMaximumPriority);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2457
	TInt err = iDevsoundToneClient->InitTonePlay(iFrequencyTone1, iDuration*KMicroSecsInOneSec);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2458
	if(err != KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2459
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2460
		ERR_PRINTF1(_L("Initialization to play tone thru second devsound client failed"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2461
		StopTest(err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2462
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2463
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2464
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2465
void RA3FDevSoundToneSetPriorityWhilePlayingTest::ToneFinished(TInt aError)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2466
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2467
	INFO_PRINTF1(_L("========== DevSound ToneFinished() callback =========="));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2468
	if (aError == KErrInUse || aError == KErrDied || aError == KErrAccessDenied)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2469
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2470
		INFO_PRINTF1(_L("========== Preempting 1st DevSound Instance=========="));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2471
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2472
	else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2473
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2474
		ERR_PRINTF2(_L("DevSound called ToneFinished and failed with error = %d"), aError);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2475
		ERR_PRINTF4(_L("Expected errors posibilities %d %d %d"), KErrInUse, KErrDied, KErrAccessDenied);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2476
		StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2477
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2478
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2479
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2480
/*
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2481
 *========================================================================================================
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2482
 * MM-A3F-DEVSOUND-CHRTZ-TONE-0018
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2483
 */
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2484
RA3FDevSoundToneSetConfigTestToInvalidSampleRateValue::RA3FDevSoundToneSetConfigTestToInvalidSampleRateValue(const TDesC& aTestName)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2485
	:	RA3FDevSoundTestBase(aTestName), iSampleRate(0),
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2486
		iChannels(0)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2487
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2488
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2489
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2490
RA3FDevSoundToneSetConfigTestToInvalidSampleRateValue* RA3FDevSoundToneSetConfigTestToInvalidSampleRateValue::NewL(const TDesC& aTestName)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2491
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2492
	RA3FDevSoundToneSetConfigTestToInvalidSampleRateValue * self = new(ELeave)RA3FDevSoundToneSetConfigTestToInvalidSampleRateValue(aTestName);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2493
	return self; 
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2494
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2495
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2496
void RA3FDevSoundToneSetConfigTestToInvalidSampleRateValue::DoKickoffTestL()
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2497
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2498
	if (!GetIntFromConfig(iTestStepName, KSampleRate, iSampleRate))
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2499
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2500
		ERR_PRINTF2(KMsgErrorGetParameter, &KSampleRate);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2501
		StopTest(KErrNotFound);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2502
		return;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2503
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2504
	if (!GetIntFromConfig(iTestStepName, KChannel, iChannels))
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2505
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2506
		ERR_PRINTF2(KMsgErrorGetParameter, &KChannel);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2507
		StopTest(KErrNotFound);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2508
		return;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2509
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2510
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2511
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2512
void RA3FDevSoundToneSetConfigTestToInvalidSampleRateValue::Fsm(TMmfDevSoundEvent aDevSoundEvent, TInt aError)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2513
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2514
	switch(iDevSoundState)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2515
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2516
		case EStateCreated:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2517
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2518
			if(aDevSoundEvent == EEventInitialize)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2519
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2520
				__ASSERT_ALWAYS((aError == KErrNone), Panic(_L("RA3FDevSoundToneSetConfigTestToInvalidSampleRateValue"), EFsmIncorrectErrorPassed));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2521
				INFO_PRINTF1(_L("Calling CMMFDevSound::InitializeL"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2522
				TRAPD(err, iMMFDevSound->InitializeL(*this, EMMFStateTonePlaying));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2523
				if (err != KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2524
					{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2525
					ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"), err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2526
					StopTest(err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2527
					break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2528
					}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2529
				INFO_PRINTF1(_L("DevSound State: EStateInitializing"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2530
				iDevSoundState = EStateInitializing;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2531
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2532
			else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2533
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2534
				ERR_PRINTF2(_L("DevSound EEventInitialize not received as expected. Received event: %d"), aDevSoundEvent);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2535
				StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2536
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2537
			break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2538
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2539
		case EStateInitializing:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2540
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2541
			if (aDevSoundEvent == EEventInitComplete && aError == KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2542
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2543
				TMMFCapabilities capabilitiesSet;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2544
				TBuf<KMaxSampleRateStringLength> stringSampleRateSet;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2545
				TBuf<KMaxChannelsStringLength> stringChannelsSet;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2546
				TMMFSampleRate eSampleRate;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2547
				SampleRateFromTIntToTMMFSampleRate (iSampleRate, eSampleRate);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2548
				capabilitiesSet.iRate = eSampleRate;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2549
				capabilitiesSet.iChannels = iChannels;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2550
				SampleRateFromTUintToString (capabilitiesSet.iRate,	stringSampleRateSet);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2551
				ChannelsFromTUintToString (capabilitiesSet.iChannels, stringChannelsSet);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2552
				INFO_PRINTF3(_L("Calling CMMFDevSound::SetConfigL using an invalid sample rate = %S and channel mode = %S"), &stringSampleRateSet, &stringChannelsSet);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2553
				TRAPD(err, iMMFDevSound->SetConfigL(capabilitiesSet));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2554
				if (err == KErrNotSupported || err == KErrArgument)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2555
					{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2556
					INFO_PRINTF2(_L("CMMFDevSound::SetConfigL succeeded with error = %d"), err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2557
					StopTest(err, EPass);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2558
					}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2559
				else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2560
					{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2561
					ERR_PRINTF2(_L("CMMFDevSound::SetConfigL failed with error = %d"), err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2562
					ERR_PRINTF3(_L("Expected  error posibilities %d %d"), KErrArgument, KErrNotSupported);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2563
					StopTest(err, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2564
					}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2565
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2566
			else if (aDevSoundEvent == EEventInitComplete && aError != KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2567
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2568
				ERR_PRINTF2(_L("DevSound called CMMFDevSound::InitializeComplete with error = %d"), aError);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2569
				StopTest(aError);	
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2570
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2571
			else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2572
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2573
				ERR_PRINTF2(_L("DevSound EEventInitComplete not received as expected. Received event: %d"), aDevSoundEvent);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2574
				StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2575
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2576
			break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2577
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2578
		default:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2579
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2580
			ERR_PRINTF2(_L("Invalid DevSound state received: %d"), iDevSoundState);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2581
			StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2582
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2583
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2584
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2585
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2586
/*
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2587
 *========================================================================================================
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2588
 * MM-A3F-DEVSOUND-CHRTZ-TONE-0019
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2589
 */
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2590
RA3FDevSoundToneSetConfigTestToInvalidChannelValueTest::RA3FDevSoundToneSetConfigTestToInvalidChannelValueTest(const TDesC& aTestName)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2591
	:	RA3FDevSoundTestBase(aTestName), iSampleRate(0),
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2592
		iChannels(0)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2593
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2594
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2595
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2596
RA3FDevSoundToneSetConfigTestToInvalidChannelValueTest* RA3FDevSoundToneSetConfigTestToInvalidChannelValueTest::NewL(const TDesC& aTestName)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2597
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2598
	RA3FDevSoundToneSetConfigTestToInvalidChannelValueTest * self = new(ELeave)RA3FDevSoundToneSetConfigTestToInvalidChannelValueTest(aTestName);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2599
	return self; 
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2600
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2601
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2602
void RA3FDevSoundToneSetConfigTestToInvalidChannelValueTest::DoKickoffTestL()
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2603
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2604
	if (!GetIntFromConfig(iTestStepName, KSampleRate, iSampleRate))
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2605
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2606
		ERR_PRINTF2(KMsgErrorGetParameter, &KSampleRate);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2607
		StopTest(KErrNotFound);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2608
		return;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2609
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2610
	if (!GetIntFromConfig(iTestStepName, KChannel, iChannels))
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2611
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2612
		ERR_PRINTF2(KMsgErrorGetParameter, &KChannel);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2613
		StopTest(KErrNotFound);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2614
		return;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2615
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2616
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2617
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2618
void RA3FDevSoundToneSetConfigTestToInvalidChannelValueTest::Fsm(TMmfDevSoundEvent aDevSoundEvent, TInt aError)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2619
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2620
	switch(iDevSoundState)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2621
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2622
		case EStateCreated:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2623
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2624
			if(aDevSoundEvent == EEventInitialize)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2625
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2626
				__ASSERT_ALWAYS((aError == KErrNone), Panic(_L("RA3FDevSoundToneSetConfigTestToInvalidChannelValueTest"), EFsmIncorrectErrorPassed));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2627
				INFO_PRINTF1(_L("Calling CMMFDevSound::InitializeL"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2628
				TRAPD(err, iMMFDevSound->InitializeL(*this, EMMFStateTonePlaying));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2629
				if (err != KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2630
					{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2631
					ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"), err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2632
					StopTest(err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2633
					break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2634
					}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2635
				INFO_PRINTF1(_L("DevSound State: EStateInitializing"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2636
				iDevSoundState = EStateInitializing;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2637
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2638
			else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2639
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2640
				ERR_PRINTF2(_L("DevSound EEventInitialize not received as expected. Received event: %d"), aDevSoundEvent);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2641
				StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2642
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2643
			break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2644
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2645
		case EStateInitializing:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2646
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2647
			if (aDevSoundEvent == EEventInitComplete && aError == KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2648
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2649
				TMMFCapabilities capabilitiesSet;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2650
				TBuf<KMaxSampleRateStringLength> stringSampleRateSet;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2651
				TBuf<KMaxChannelsStringLength> stringChannelsSet;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2652
				TMMFSampleRate eSampleRate;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2653
				SampleRateFromTIntToTMMFSampleRate (iSampleRate, eSampleRate);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2654
				capabilitiesSet.iRate = eSampleRate;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2655
				capabilitiesSet.iChannels = iChannels;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2656
				SampleRateFromTUintToString (capabilitiesSet.iRate,	stringSampleRateSet);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2657
				INFO_PRINTF3(_L("Calling CMMFDevSound::SetConfigL using a sample rate = %S and an invalid channel mode = %d"), &stringSampleRateSet, iChannels);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2658
				TRAPD(err, iMMFDevSound->SetConfigL(capabilitiesSet));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2659
				if (err == KErrNotSupported || err == KErrArgument)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2660
					{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2661
					INFO_PRINTF2(_L("CMMFDevSound::SetConfigL succeeded with error = %d"), err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2662
					StopTest(err, EPass);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2663
					}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2664
				else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2665
					{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2666
					ERR_PRINTF2(_L("CMMFDevSound::SetConfigL failed with error = %d"), err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2667
					ERR_PRINTF3(_L("Expected  error posibilities %d %d"), KErrArgument, KErrNotSupported);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2668
					StopTest(err, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2669
					}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2670
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2671
			else if (aDevSoundEvent == EEventInitComplete && aError != KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2672
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2673
				ERR_PRINTF2(_L("DevSound called CMMFDevSound::InitializeComplete with error = %d"), aError);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2674
				StopTest(aError);	
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2675
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2676
			else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2677
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2678
				ERR_PRINTF2(_L("DevSound EEventInitComplete not received as expected. Received event: %d"), aDevSoundEvent);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2679
				StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2680
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2681
			break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2682
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2683
		default:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2684
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2685
			ERR_PRINTF2(_L("Invalid DevSound state received: %d"), iDevSoundState);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2686
			StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2687
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2688
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2689
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2690
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2691
/*
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2692
 *========================================================================================================
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2693
 * MM-A3F-DEVSOUND-CHRTZ-TONE-0020
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2694
 */
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2695
RA3FDevSoundToneSetDTMFLengthsToNegativeTest::RA3FDevSoundToneSetDTMFLengthsToNegativeTest(const TDesC& aTestName)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2696
	:	RA3FDevSoundTestBase(aTestName), iToneOnLength(0),
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2697
		iToneOffLength(0), iPauseLength(0),
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2698
		iDTMFString(KNullDesC)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2699
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2700
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2701
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2702
RA3FDevSoundToneSetDTMFLengthsToNegativeTest* RA3FDevSoundToneSetDTMFLengthsToNegativeTest::NewL(const TDesC& aTestName)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2703
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2704
	RA3FDevSoundToneSetDTMFLengthsToNegativeTest * self = new(ELeave)RA3FDevSoundToneSetDTMFLengthsToNegativeTest(aTestName);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2705
	return self;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2706
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2707
	
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2708
void RA3FDevSoundToneSetDTMFLengthsToNegativeTest::DoKickoffTestL()
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2709
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2710
	if ( !GetIntFromConfig(iTestStepName, KToneOnLength, iToneOnLength) ) 
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2711
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2712
		ERR_PRINTF2(KMsgErrorGetParameter, &KToneOnLength);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2713
		StopTest(KErrNotFound);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2714
		return;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2715
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2716
	if ( !GetIntFromConfig(iTestStepName, KToneOffLength, iToneOffLength) ) 
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2717
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2718
		ERR_PRINTF2(KMsgErrorGetParameter, &KToneOffLength);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2719
		StopTest(KErrNotFound);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2720
		return;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2721
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2722
	if ( !GetIntFromConfig(iTestStepName, KPauseLength, iPauseLength) ) 
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2723
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2724
		ERR_PRINTF2(KMsgErrorGetParameter, &KPauseLength);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2725
		StopTest(KErrNotFound);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2726
		return;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2727
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2728
	TPtrC DTMF;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2729
	if ( !GetStringFromConfig(iTestStepName,  KDTMFString,  DTMF) )
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2730
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2731
		ERR_PRINTF2(KMsgErrorGetParameter, &KDTMFString);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2732
		StopTest(KErrNotFound);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2733
		return;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2734
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2735
	iDTMFString.Copy(DTMF);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2736
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2737
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2738
void RA3FDevSoundToneSetDTMFLengthsToNegativeTest::Fsm(TMmfDevSoundEvent aDevSoundEvent, TInt aError)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2739
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2740
	switch (iDevSoundState)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2741
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2742
		case EStateCreated:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2743
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2744
			__ASSERT_ALWAYS((aError == KErrNone), Panic(_L("RA3FDevSoundToneSetDTMFLengthsToNegativeConfigurationTest"), EFsmIncorrectErrorPassed));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2745
			if (aDevSoundEvent == EEventInitialize)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2746
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2747
				INFO_PRINTF1(_L("Calling iMMFDevSound::InitializeL"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2748
				TRAPD(err, iMMFDevSound->InitializeL(*this, EMMFStateTonePlaying));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2749
				if (err != KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2750
					{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2751
					ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"), err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2752
					StopTest(err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2753
					break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2754
					}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2755
				INFO_PRINTF1(_L("DevSound State: EStateInitializing"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2756
				iDevSoundState = EStateInitializing;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2757
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2758
			else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2759
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2760
				ERR_PRINTF2(_L("DevSound EEventInitialize not received as expected. Received event: %d"), aDevSoundEvent);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2761
				StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2762
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2763
			break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2764
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2765
		case EStateInitializing:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2766
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2767
			if (aDevSoundEvent == EEventInitComplete && aError == KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2768
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2769
				iMMFDevSound->SetVolume(iMMFDevSound->MaxVolume());
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2770
				TTimeIntervalMicroSeconds32 ToneOnLength(iToneOnLength);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2771
				TTimeIntervalMicroSeconds32 ToneOffLength(iToneOffLength);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2772
				TTimeIntervalMicroSeconds32 PauseLength(iPauseLength);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2773
				INFO_PRINTF4(_L("Setting DTMF tone to negative lengths. ToneOnLength %d, ToneOffLength %d and PauseLength %d"), iToneOnLength, iToneOffLength, iPauseLength);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2774
				iMMFDevSound->SetDTMFLengths(ToneOnLength, ToneOffLength, PauseLength);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2775
				iStartTime.HomeTime();
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2776
				INFO_PRINTF2(_L("Calling CMMFDevSound::PlayDTMFStringL %S"), &iDTMFString);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2777
				TRAPD(err, iMMFDevSound->PlayDTMFStringL(iDTMFString));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2778
				if (err != KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2779
					{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2780
					ERR_PRINTF2(_L("CMMFDevSound::PlayDTMFStringL left with error : %d!"),  err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2781
					StopTest(err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2782
					break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2783
					}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2784
				INFO_PRINTF1(_L("DevSound State: EStatePlaying"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2785
				iDevSoundState = EStatePlaying;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2786
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2787
			else if (aDevSoundEvent == EEventInitComplete && aError != KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2788
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2789
				ERR_PRINTF2(_L("DevSound called CMMFDevSound::InitializeComplete with error = %d"), aError);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2790
				StopTest(aError);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2791
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2792
			else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2793
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2794
				ERR_PRINTF2(_L("DevSound EEventInitComplete not received as expected. Received event: %d"), aDevSoundEvent);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2795
				StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2796
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2797
			break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2798
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2799
		default:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2800
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2801
			ERR_PRINTF2(_L("Invalid DevSound state received: %d"), iDevSoundState);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2802
			StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2803
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2804
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2805
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2806
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2807
void RA3FDevSoundToneSetDTMFLengthsToNegativeTest::ToneFinished(TInt aError)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2808
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2809
	INFO_PRINTF1(_L("========== DevSound ToneFinished() callback =========="));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2810
	INFO_PRINTF3(KMsgErrorDevSoundCallback, &KToneFinishedText, aError);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2811
		
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2812
	if (aError == KErrUnderflow)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2813
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2814
		iEndTime.HomeTime();
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2815
		iPlayToneTime = iEndTime.MicroSecondsFrom(iStartTime);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2816
		if(iPlayToneTime <= KPlayVarianceTime)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2817
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2818
			INFO_PRINTF2(_L("Setting DTMF tone lengths to negative gives a reproduction time of %Ld microseconds which is the expected result"), iPlayToneTime.Int64());	
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2819
			StopTest(aError, EPass);	
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2820
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2821
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2822
	else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2823
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2824
		INFO_PRINTF2(_L("DevSound called ToneFinished with error = %d that was NOT expected"), aError);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2825
		StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2826
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2827
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2828
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2829
/*
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2830
 *========================================================================================================
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2831
 * MM-A3F-DEVSOUND-CHRTZ-TONE-0021
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2832
 */
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2833
RA3FDevSoundToneSetDTMFToneOnLengthToMinusOneTest::RA3FDevSoundToneSetDTMFToneOnLengthToMinusOneTest(const TDesC& aTestName)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2834
	:	RA3FDevSoundTestBase(aTestName), 
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2835
		iFirstToneFinishedCall(EFalse),
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2836
		iToneOnLength(0), iToneOffLength(0),
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2837
		iPauseLength(0), iDTMFString(KNullDesC)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2838
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2839
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2840
RA3FDevSoundToneSetDTMFToneOnLengthToMinusOneTest* RA3FDevSoundToneSetDTMFToneOnLengthToMinusOneTest::NewL(const TDesC& aTestName)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2841
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2842
	RA3FDevSoundToneSetDTMFToneOnLengthToMinusOneTest * self = new(ELeave)RA3FDevSoundToneSetDTMFToneOnLengthToMinusOneTest(aTestName);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2843
	return self;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2844
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2845
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2846
void RA3FDevSoundToneSetDTMFToneOnLengthToMinusOneTest::DoKickoffTestL()
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2847
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2848
	if (!GetIntFromConfig(iTestStepName, KToneOnLength, iToneOnLength)) 
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2849
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2850
		ERR_PRINTF2(KMsgErrorGetParameter, &KToneOnLength);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2851
		StopTest(KErrNotFound);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2852
		return;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2853
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2854
	if (!GetIntFromConfig(iTestStepName, KToneOffLength, iToneOffLength)) 
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2855
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2856
		ERR_PRINTF2(KMsgErrorGetParameter, &KToneOffLength);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2857
		StopTest(KErrNotFound);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2858
		return;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2859
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2860
	if (!GetIntFromConfig(iTestStepName, KPauseLength, iPauseLength)) 
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2861
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2862
		ERR_PRINTF2(KMsgErrorGetParameter, &KPauseLength);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2863
		StopTest(KErrNotFound);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2864
		return;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2865
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2866
	TPtrC DTMF;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2867
	if (!GetStringFromConfig(iTestStepName, KDTMFString, DTMF))
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2868
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2869
		ERR_PRINTF2(KMsgErrorGetParameter, &KDTMFString);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2870
		StopTest(KErrNotFound);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2871
		return;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2872
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2873
	iDTMFString.Copy(DTMF);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2874
	iTimer = CPeriodic::NewL(CActive::EPriorityHigh);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2875
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2876
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2877
void RA3FDevSoundToneSetDTMFToneOnLengthToMinusOneTest::Fsm(TMmfDevSoundEvent aDevSoundEvent, TInt aError)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2878
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2879
	switch (iDevSoundState)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2880
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2881
		case EStateCreated:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2882
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2883
			__ASSERT_ALWAYS((aError == KErrNone), Panic(_L("RA3FDevSoundToneSetDTMFToneOnLengthToMinusOneTest"), EFsmIncorrectErrorPassed));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2884
			if(aDevSoundEvent == EEventInitialize)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2885
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2886
				INFO_PRINTF1(_L("Calling CMMFDevSound::InitializeL"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2887
				TRAPD(err, iMMFDevSound->InitializeL(*this, EMMFStateTonePlaying));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2888
				if (err != KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2889
					{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2890
					ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"), err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2891
					StopTest(err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2892
					break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2893
					}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2894
				INFO_PRINTF1(_L("DevSound State: EStateInitializing"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2895
				iDevSoundState = EStateInitializing;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2896
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2897
			else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2898
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2899
				ERR_PRINTF2(_L("DevSound EEventInitialize not received as expected. Received event: %d"), aDevSoundEvent);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2900
				StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2901
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2902
			break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2903
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2904
		case EStateInitializing:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2905
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2906
			if (aDevSoundEvent == EEventInitComplete && aError == KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2907
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2908
				iMMFDevSound->SetVolume(iMMFDevSound->MaxVolume());
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2909
				iStartTime.HomeTime();
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2910
				TTimeIntervalMicroSeconds32 ToneOnLength(iToneOnLength);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2911
				TTimeIntervalMicroSeconds32 ToneOffLength(iToneOffLength);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2912
				TTimeIntervalMicroSeconds32 PauseLength(iPauseLength);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2913
				INFO_PRINTF4(_L("Calling CMMFDevSound::SetDTMFLengths. ToneOnLength = %Ld, ToneOffLength = %Ld and PauseLength = %Ld"), iToneOnLength, iToneOffLength, iPauseLength);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2914
				iMMFDevSound->SetDTMFLengths(ToneOnLength, ToneOffLength, PauseLength);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2915
				INFO_PRINTF2(_L("Calling CMMFDevSound::PlayDTMFStringL %S"), &iDTMFString);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2916
				TRAPD(err, iMMFDevSound->PlayDTMFStringL(iDTMFString));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2917
				if (err != KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2918
					{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2919
					ERR_PRINTF2(_L("CMMFDevSound::PlayDTMFStringL left with error : %d!"), err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2920
					StopTest(err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2921
					break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2922
					}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2923
				StartTimer(KMicrosecsInTenSec);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2924
				INFO_PRINTF1(_L("DevSound State: EStatePlaying"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2925
				iDevSoundState=EStatePlaying;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2926
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2927
			else if (aDevSoundEvent == EEventInitComplete && aError != KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2928
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2929
				ERR_PRINTF2(_L("DevSound called CMMFDevSound::InitializeComplete with error = %d"), aError);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2930
				StopTest(aError);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2931
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2932
			else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2933
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2934
				ERR_PRINTF2(_L("DevSound EEventInitComplete not received as expected. Received event: %d"), aDevSoundEvent);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2935
				StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2936
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2937
			break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2938
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2939
		default:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2940
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2941
			ERR_PRINTF2(_L("Invalid DevSound state received: %d"), iDevSoundState);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2942
			StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2943
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2944
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2945
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2946
	
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2947
void RA3FDevSoundToneSetDTMFToneOnLengthToMinusOneTest::DoTimerCallback()
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2948
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2949
	iTimer->Cancel();
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2950
	INFO_PRINTF1(_L("DevSound Event: EEventTimerComplete"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2951
	iEndTime.HomeTime();
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2952
	iPlayToneTime = iEndTime.MicroSecondsFrom(iStartTime);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2953
	INFO_PRINTF1(_L("SetDTMF lengths succeded."));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2954
	INFO_PRINTF2(_L("Play time is %Ld microseconds"), iPlayToneTime.Int64());
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2955
	StopTest();
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2956
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2957
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2958
void RA3FDevSoundToneSetDTMFToneOnLengthToMinusOneTest::ToneFinished(TInt aError)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2959
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2960
	INFO_PRINTF1(_L("========== DevSound ToneFinished() callback =========="));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2961
	if (aError == KErrUnderflow)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2962
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2963
		INFO_PRINTF1(_L("ToneFinished was called before the timer event."));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2964
		StopTest(aError);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2965
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2966
	else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2967
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2968
		ERR_PRINTF2(_L("DevSound called ToneFinished with error = %d"), aError);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2969
		ERR_PRINTF2(_L("Expected error = %d"), KErrUnderflow);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2970
		StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2971
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2972
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2973
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2974
/*
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2975
 *========================================================================================================
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2976
 * MM-A3F-DEVSOUND-CHRTZ-TONE-0022
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2977
 */
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2978
RA3FDevSoundToneSetToneRepetitionsRepeatTrailingSilenceToNegativeTest::RA3FDevSoundToneSetToneRepetitionsRepeatTrailingSilenceToNegativeTest(const TDesC& aTestName)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2979
	:	RA3FDevSoundTestBase(aTestName), iDuration(0),
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2980
		iFrequencyTone1(0),
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2981
		iRepeatTrailingSilence(0), iRepeatCount(0),
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2982
		iInitializedToPlayTones(EFalse)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2983
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2984
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2985
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2986
RA3FDevSoundToneSetToneRepetitionsRepeatTrailingSilenceToNegativeTest* RA3FDevSoundToneSetToneRepetitionsRepeatTrailingSilenceToNegativeTest::NewL(const TDesC& aTestName)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2987
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2988
	RA3FDevSoundToneSetToneRepetitionsRepeatTrailingSilenceToNegativeTest * self = new(ELeave)RA3FDevSoundToneSetToneRepetitionsRepeatTrailingSilenceToNegativeTest(aTestName);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2989
	return self;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2990
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2991
	
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2992
void RA3FDevSoundToneSetToneRepetitionsRepeatTrailingSilenceToNegativeTest::DoKickoffTestL()
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2993
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2994
	if (!GetIntFromConfig(iTestStepName, KRepeatCount, iRepeatCount)) 
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2995
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2996
		ERR_PRINTF2(KMsgErrorGetParameter, &KRepeatCount);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2997
		StopTest(KErrNotFound);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2998
		return;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  2999
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3000
	if (!GetIntFromConfig(iTestStepName, KRepeatTrailingSilence, iRepeatTrailingSilence)) 
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3001
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3002
		ERR_PRINTF2(KMsgErrorGetParameter, &KRepeatTrailingSilence);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3003
		StopTest(KErrNotFound);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3004
		return;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3005
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3006
	if (!GetIntFromConfig(iTestStepName, KDuration, iDuration)) 
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3007
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3008
		ERR_PRINTF2(KMsgErrorGetParameter, &KDuration);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3009
		StopTest(KErrNotFound);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3010
		return;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3011
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3012
	if (!GetIntFromConfig(iTestStepName, KFrequencyTone1, iFrequencyTone1)) 
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3013
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3014
		ERR_PRINTF2(KMsgErrorGetParameter, &KFrequencyTone1);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3015
		StopTest(KErrNotFound);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3016
		return;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3017
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3018
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3019
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3020
void RA3FDevSoundToneSetToneRepetitionsRepeatTrailingSilenceToNegativeTest::Fsm(TMmfDevSoundEvent aDevSoundEvent, TInt aError)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3021
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3022
	switch (iDevSoundState)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3023
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3024
		case EStateCreated:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3025
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3026
			__ASSERT_ALWAYS((aError == KErrNone), Panic(_L("RA3FDevSoundToneSetToneRepetitionsRepeatTrailingSilenceToNegativeTest"), EFsmIncorrectErrorPassed));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3027
			if(aDevSoundEvent == EEventInitialize)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3028
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3029
				INFO_PRINTF1(_L("Calling CMMFDevSound::InitializeL"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3030
				TRAPD(err, iMMFDevSound->InitializeL(*this, EMMFStateTonePlaying));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3031
				if (err != KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3032
					{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3033
					ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"), err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3034
					StopTest(err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3035
					break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3036
					}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3037
				INFO_PRINTF1(_L("DevSound State: EStateInitializing"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3038
				iDevSoundState = EStateInitializing;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3039
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3040
			else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3041
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3042
				ERR_PRINTF2(_L("DevSound EEventInitialize not received as expected. Received event: %d"), aDevSoundEvent);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3043
				StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3044
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3045
			break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3046
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3047
		case EStateInitializing:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3048
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3049
			if (aDevSoundEvent == EEventInitComplete && aError == KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3050
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3051
				iMMFDevSound->SetVolume(iMMFDevSound->MaxVolume());
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3052
				INFO_PRINTF3(_L("Calling CMMFDevSound::SetToneRepeats using RepeatCount = %d and RepeatTrailingSilence = %d microsecs"), iRepeatCount, iRepeatTrailingSilence);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3053
				iMMFDevSound->SetToneRepeats(iRepeatCount, iRepeatTrailingSilence);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3054
				iStartTime.HomeTime();
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3055
				INFO_PRINTF3(_L("Calling CMMFDevSound::PlayToneL %d Hz during %d secs "), iFrequencyTone1, iDuration);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3056
				TRAPD(err, iMMFDevSound->PlayToneL(iFrequencyTone1, iDuration*KMicroSecsInOneSec));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3057
				if (err != KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3058
					{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3059
					ERR_PRINTF2(_L("CMMFDevSound::PlayToneL left with error : %d!"), err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3060
					StopTest(err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3061
					break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3062
					}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3063
				INFO_PRINTF1(_L("DevSound State: EStatePlaying"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3064
				iDevSoundState = EStatePlaying;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3065
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3066
			else if (aDevSoundEvent == EEventInitComplete && aError != KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3067
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3068
				ERR_PRINTF2(_L("DevSound called CMMFDevSound::InitializeComplete with error = %d"), aError);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3069
				StopTest(aError);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3070
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3071
			else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3072
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3073
				ERR_PRINTF2(_L("DevSound EEventInitComplete not received as expected. Received event: %d"), aDevSoundEvent);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3074
				StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3075
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3076
			break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3077
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3078
		default:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3079
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3080
			ERR_PRINTF2(_L("Invalid DevSound state received: %d"), iDevSoundState);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3081
			StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3082
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3083
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3084
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3085
	
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3086
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3087
void RA3FDevSoundToneSetToneRepetitionsRepeatTrailingSilenceToNegativeTest::ToneFinished(TInt aError)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3088
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3089
	INFO_PRINTF1(_L("========== DevSound ToneFinished() callback =========="));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3090
	if (aError == KErrUnderflow)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3091
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3092
		iEndTime.HomeTime();
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3093
		iPlayToneTime = iEndTime.MicroSecondsFrom(iStartTime);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3094
		TInt repeatTrailingSilenceToSecs = iRepeatTrailingSilence/KMicroSecsInOneSec;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3095
		TInt totalExpectedReproductionTime = (iRepeatCount * iDuration + iDuration + (repeatTrailingSilenceToSecs*iRepeatCount))*KMicroSecsInOneSec;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3096
		if(iPlayToneTime < totalExpectedReproductionTime + KPlayVarianceTime && iPlayToneTime > totalExpectedReproductionTime - KPlayVarianceTime)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3097
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3098
			INFO_PRINTF1(_L("Play tone repeats succeded."));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3099
			INFO_PRINTF2(_L("Play time is %Ld microseconds"), iPlayToneTime.Int64());
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3100
			StopTest();
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3101
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3102
		else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3103
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3104
			ERR_PRINTF1(_L("Play tone repeats did not work as planned."));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3105
			ERR_PRINTF3(_L("Play time is %Ld microseconds and it should have been %d microseconds"), iPlayToneTime.Int64(), totalExpectedReproductionTime);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3106
			StopTest(KErrNone, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3107
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3108
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3109
	else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3110
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3111
		ERR_PRINTF2(_L("DevSound called ToneFinished with error = %d"), aError);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3112
		ERR_PRINTF2(_L("Expected error = %d"), KErrUnderflow);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3113
		StopTest(aError);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3114
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3115
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3116
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3117
/*
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3118
 *========================================================================================================
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3119
 * MM-A3F-DEVSOUND-CHRTZ-TONE-0023
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3120
 */
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3121
RA3FDevSoundToneSetToneRepetitionsRepeatCountToKMdaRepeatForeverTest::RA3FDevSoundToneSetToneRepetitionsRepeatCountToKMdaRepeatForeverTest(const TDesC& aTestName)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3122
	:	RA3FDevSoundTestBase(aTestName), iDuration(0),
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3123
		iFrequencyTone1(0),
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3124
		iRepeatTrailingSilence(0), iRepeatCount(0),
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3125
		iInitializedToPlayTones(EFalse)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3126
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3127
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3128
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3129
RA3FDevSoundToneSetToneRepetitionsRepeatCountToKMdaRepeatForeverTest* RA3FDevSoundToneSetToneRepetitionsRepeatCountToKMdaRepeatForeverTest::NewL(const TDesC& aTestName)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3130
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3131
	RA3FDevSoundToneSetToneRepetitionsRepeatCountToKMdaRepeatForeverTest * self = new(ELeave)RA3FDevSoundToneSetToneRepetitionsRepeatCountToKMdaRepeatForeverTest(aTestName);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3132
	return self;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3133
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3134
	
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3135
void RA3FDevSoundToneSetToneRepetitionsRepeatCountToKMdaRepeatForeverTest::DoKickoffTestL()
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3136
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3137
	if (!GetIntFromConfig(iTestStepName, KRepeatCount, iRepeatCount)) 
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3138
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3139
		ERR_PRINTF2(KMsgErrorGetParameter, &KRepeatCount);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3140
		StopTest(KErrNotFound);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3141
		return;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3142
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3143
	if (!GetIntFromConfig(iTestStepName, KRepeatTrailingSilence, iRepeatTrailingSilence)) 
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3144
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3145
		ERR_PRINTF2(KMsgErrorGetParameter, &KRepeatTrailingSilence);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3146
		StopTest(KErrNotFound);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3147
		return;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3148
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3149
	if (!GetIntFromConfig(iTestStepName, KDuration, iDuration)) 
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3150
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3151
		ERR_PRINTF2(KMsgErrorGetParameter, &KDuration);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3152
		StopTest(KErrNotFound);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3153
		return;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3154
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3155
	if (!GetIntFromConfig(iTestStepName, KFrequencyTone1, iFrequencyTone1)) 
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3156
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3157
		ERR_PRINTF2(KMsgErrorGetParameter, &KFrequencyTone1);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3158
		StopTest(KErrNotFound);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3159
		return;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3160
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3161
	iTimer = CPeriodic::NewL(CActive::EPriorityHigh);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3162
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3163
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3164
void RA3FDevSoundToneSetToneRepetitionsRepeatCountToKMdaRepeatForeverTest::Fsm(TMmfDevSoundEvent aDevSoundEvent, TInt aError)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3165
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3166
	switch (iDevSoundState)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3167
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3168
		case EStateCreated:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3169
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3170
			__ASSERT_ALWAYS((aError == KErrNone), Panic(_L("RA3FDevSoundToneSetToneRepetitionsRepeatCountToKMdaRepeatForeverTest"), EFsmIncorrectErrorPassed));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3171
			if(aDevSoundEvent == EEventInitialize)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3172
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3173
				INFO_PRINTF1(_L("Calling CMMFDevSound::InitializeL"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3174
				TRAPD(err, iMMFDevSound->InitializeL(*this, EMMFStateTonePlaying));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3175
				if (err != KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3176
					{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3177
					ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"), err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3178
					StopTest(err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3179
					break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3180
					}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3181
				StartTimer(KMicrosecsInTenSec);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3182
				INFO_PRINTF1(_L("DevSound State: EStateInitializing"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3183
				iDevSoundState = EStateInitializing;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3184
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3185
			else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3186
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3187
				ERR_PRINTF2(_L("DevSound EEventInitialize not received as expected. Received event: %d"), aDevSoundEvent);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3188
				StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3189
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3190
			break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3191
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3192
		case EStateInitializing:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3193
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3194
			if (aDevSoundEvent == EEventInitComplete && aError == KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3195
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3196
				iMMFDevSound->SetVolume(iMMFDevSound->MaxVolume());
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3197
				INFO_PRINTF3(_L("Calling CMMFDevSound::SetToneRepeats using RepeatCount = %d and RepeatTrailingSilence = %d microsecs"), iRepeatCount, iRepeatTrailingSilence);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3198
				iMMFDevSound->SetToneRepeats(iRepeatCount, iRepeatTrailingSilence);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3199
				iStartTime.HomeTime();
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3200
				INFO_PRINTF3(_L("Calling CMMFDevSound::PlayToneL %d Hz during %d secs "), iFrequencyTone1, iDuration);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3201
				TRAPD(err, iMMFDevSound->PlayToneL(iFrequencyTone1, iDuration*KMicroSecsInOneSec));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3202
				if (err != KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3203
					{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3204
					ERR_PRINTF2(_L("CMMFDevSound::PlayToneL left with error : %d!"), err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3205
					StopTest(err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3206
					break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3207
					}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3208
				INFO_PRINTF1(_L("DevSound State: EStatePlaying"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3209
				iDevSoundState = EStatePlaying;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3210
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3211
			else if (aDevSoundEvent == EEventInitComplete && aError != KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3212
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3213
				ERR_PRINTF2(_L("DevSound called CMMFDevSound::InitializeComplete with error = %d"), aError);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3214
				StopTest(aError);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3215
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3216
			else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3217
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3218
				ERR_PRINTF2(_L("DevSound EEventInitComplete not received as expected. Received event: %d"), aDevSoundEvent);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3219
				StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3220
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3221
			break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3222
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3223
		default:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3224
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3225
			ERR_PRINTF2(_L("Invalid DevSound state received: %d"), iDevSoundState);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3226
			StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3227
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3228
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3229
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3230
	
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3231
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3232
void RA3FDevSoundToneSetToneRepetitionsRepeatCountToKMdaRepeatForeverTest::DoTimerCallback()
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3233
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3234
	iTimer->Cancel();
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3235
	INFO_PRINTF1(_L("DevSound Event: EEventTimerComplete"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3236
	iEndTime.HomeTime();
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3237
	iPlayToneTime = iEndTime.MicroSecondsFrom(iStartTime);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3238
	INFO_PRINTF1(_L("Setting repeatCount value to KMdaRepeatForeverTest succeded."));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3239
	INFO_PRINTF2(_L("Play time is %Ld microseconds"), iPlayToneTime.Int64());
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3240
	iMMFDevSound->Stop();
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3241
	StopTest();
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3242
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3243
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3244
void RA3FDevSoundToneSetToneRepetitionsRepeatCountToKMdaRepeatForeverTest::ToneFinished(TInt aError)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3245
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3246
	INFO_PRINTF1(_L("========== DevSound ToneFinished() callback =========="));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3247
	if (aError == KErrUnderflow)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3248
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3249
		INFO_PRINTF1(_L("ToneFinished was called before the timer event."));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3250
		StopTest(aError);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3251
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3252
	else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3253
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3254
		ERR_PRINTF2(_L("DevSound called ToneFinished with error = %d"), aError);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3255
		ERR_PRINTF2(_L("Expected error = %d"), KErrUnderflow);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3256
		StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3257
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3258
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3259
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3260
/*
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3261
 *========================================================================================================
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3262
 * MM-A3F-DEVSOUND-CHRTZ-TONE-0024
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3263
 */
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3264
RA3FDevSoundToneCapsTest::RA3FDevSoundToneCapsTest(const TDesC& aTestName)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3265
	:	RA3FDevSoundTestBase(aTestName), iExCapRate(0), iExCapChannels(0)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3266
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3267
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3268
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3269
RA3FDevSoundToneCapsTest* RA3FDevSoundToneCapsTest::NewL(const TDesC& aTestName)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3270
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3271
	RA3FDevSoundToneCapsTest * self = new(ELeave)RA3FDevSoundToneCapsTest(aTestName);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3272
	return self;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3273
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3274
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3275
void RA3FDevSoundToneCapsTest::DoKickoffTestL()
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3276
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3277
	if (!GetIntFromConfig(iTestStepName, KExCapRate, iExCapRate))
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3278
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3279
		ERR_PRINTF2(KMsgErrorGetParameter, &KSampleRate);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3280
		StopTest(KErrNotFound);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3281
		return;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3282
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3283
	if (!GetIntFromConfig(iTestStepName, KExCapChannels, iExCapChannels))
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3284
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3285
		ERR_PRINTF2(KMsgErrorGetParameter, &KChannel);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3286
		StopTest(KErrNotFound);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3287
		return;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3288
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3289
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3290
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3291
void RA3FDevSoundToneCapsTest::Fsm(TMmfDevSoundEvent aDevSoundEvent, TInt aError)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3292
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3293
	switch(iDevSoundState)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3294
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3295
		case EStateCreated:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3296
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3297
			__ASSERT_ALWAYS((aError == KErrNone), Panic(_L("RA3FDevSoundToneCapsTest"), EFsmIncorrectErrorPassed));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3298
			if (aDevSoundEvent == EEventInitialize)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3299
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3300
				INFO_PRINTF1(_L("Calling CMMFDevSound::InitializeL"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3301
				TRAPD(err, iMMFDevSound->InitializeL(*this, EMMFStateTonePlaying));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3302
				if (err != KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3303
					{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3304
					ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"), err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3305
					StopTest(err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3306
					break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3307
					}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3308
				INFO_PRINTF1(_L("DevSound State: EStateInitializing"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3309
				iDevSoundState = EStateInitializing;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3310
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3311
			else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3312
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3313
				ERR_PRINTF2(_L("DevSound EEventInitialize not received as expected. Received event: %d"), aDevSoundEvent);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3314
				StopTest(aError,  EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3315
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3316
			break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3317
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3318
		case EStateInitializing:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3319
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3320
			if (aDevSoundEvent == EEventInitComplete && aError == KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3321
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3322
				TMMFCapabilities capabilities;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3323
				INFO_PRINTF1(_L("Calling CMMFDevSound::Capabilities"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3324
				capabilities = iMMFDevSound->Capabilities();
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3325
				PrintSupportedCapabilities(capabilities.iRate, capabilities.iChannels);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3326
				if(capabilities.iRate == iExCapRate)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3327
					{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3328
					INFO_PRINTF2(_L("The total of possible sample rate values is 0x%08x"), capabilities.iRate);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3329
					}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3330
				else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3331
					{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3332
					ERR_PRINTF2(_L("The total of possible sample rate values failed with 0x%08x"), capabilities.iRate);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3333
					ERR_PRINTF2(_L("Expected value = %d"), iExCapRate);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3334
					StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3335
					}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3336
				if(capabilities.iChannels == iExCapChannels)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3337
					{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3338
					INFO_PRINTF2(_L("The total of possible channel values is 0x%08x"),capabilities.iChannels );
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3339
					StopTest();
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3340
					}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3341
				else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3342
					{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3343
					ERR_PRINTF2(_L("The total of possible channel values failed with 0x%08x"), capabilities.iChannels );
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3344
					ERR_PRINTF2(_L("Expected value = %d"), iExCapChannels);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3345
					StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3346
					}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3347
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3348
			else if (aDevSoundEvent == EEventInitComplete && aError != KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3349
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3350
				ERR_PRINTF2(_L("DevSound called CMMFDevSound::InitializeComplete with error = %d"), aError);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3351
				StopTest(aError);	
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3352
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3353
			else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3354
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3355
				ERR_PRINTF2(_L("DevSound EEventInitComplete not received as expected. Received event: %d"), aDevSoundEvent);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3356
				StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3357
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3358
			break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3359
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3360
		default:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3361
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3362
			ERR_PRINTF2(_L("Invalid DevSound state received: %d"), iDevSoundState);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3363
			StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3364
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3365
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3366
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3367
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3368
/*
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3369
 *========================================================================================================
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3370
 * MM-A3F-DEVSOUND-CHRTZ-TONE-0025
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3371
 */
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3372
RA3FDevSoundToneConfigDefaultTest::RA3FDevSoundToneConfigDefaultTest(const TDesC& aTestName)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3373
	:	RA3FDevSoundTestBase(aTestName), iExCapRate(0),
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3374
		iExCapChannels(0)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3375
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3376
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3377
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3378
RA3FDevSoundToneConfigDefaultTest* RA3FDevSoundToneConfigDefaultTest::NewL(const TDesC& aTestName)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3379
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3380
	RA3FDevSoundToneConfigDefaultTest * self = new(ELeave)RA3FDevSoundToneConfigDefaultTest(aTestName);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3381
	return self;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3382
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3383
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3384
void RA3FDevSoundToneConfigDefaultTest::DoKickoffTestL()
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3385
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3386
	if (!GetIntFromConfig(iTestStepName, KExCapRate, iExCapRate))
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3387
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3388
			ERR_PRINTF2(KMsgErrorGetParameter, &KExCapRate);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3389
			StopTest(KErrNotFound);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3390
			return;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3391
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3392
	if (!GetIntFromConfig(iTestStepName, KExCapChannels, iExCapChannels))
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3393
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3394
		ERR_PRINTF2(KMsgErrorGetParameter, &KExCapChannels);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3395
		StopTest(KErrNotFound);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3396
		return;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3397
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3398
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3399
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3400
void RA3FDevSoundToneConfigDefaultTest::Fsm(TMmfDevSoundEvent aDevSoundEvent, TInt aError)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3401
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3402
		switch(iDevSoundState)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3403
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3404
		case EStateCreated:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3405
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3406
			__ASSERT_ALWAYS((aError == KErrNone), Panic(_L("RA3FDevSoundToneConfigDefaultTest"), EFsmIncorrectErrorPassed));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3407
			if (aDevSoundEvent == EEventInitialize)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3408
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3409
				INFO_PRINTF1(_L("Calling CMMFDevSound::InitializeL"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3410
				TRAPD(err, iMMFDevSound->InitializeL(*this, EMMFStateTonePlaying));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3411
				if (err != KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3412
					{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3413
					ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"), err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3414
					StopTest(err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3415
					}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3416
				INFO_PRINTF1(_L("DevSound State: EStateInitializing"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3417
				iDevSoundState=EStateInitializing;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3418
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3419
			else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3420
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3421
				ERR_PRINTF2(_L("DevSound EEventInitialize not received as expected. Received event: %d"), aDevSoundEvent);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3422
				StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3423
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3424
			break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3425
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3426
		case EStateInitializing:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3427
			{		
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3428
			if (aDevSoundEvent == EEventInitComplete && aError == KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3429
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3430
				TMMFCapabilities capabilitiesGet;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3431
				TBuf<KMaxSampleRateStringLength> stringSampleRateGet;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3432
				TBuf<KMaxChannelsStringLength> stringChannelsGet;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3433
				TBuf<KMaxSampleRateStringLength> stringSampleRateExpected;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3434
				TBuf<KMaxChannelsStringLength> stringChannelsExpected;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3435
				INFO_PRINTF1(_L("Calling CMMFDevSound::Config"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3436
				capabilitiesGet=iMMFDevSound->Config();
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3437
				SampleRateFromTUintToString (capabilitiesGet.iRate, stringSampleRateGet);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3438
				ChannelsFromTUintToString (capabilitiesGet.iChannels, stringChannelsGet);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3439
				SampleRateFromTIntToTMMFSampleRate (iExCapRate, iExSampleRate);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3440
				SampleRateFromTUintToString (iExSampleRate, stringSampleRateExpected);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3441
				ChannelsFromTUintToString (iExCapChannels, stringChannelsExpected);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3442
				if (stringSampleRateExpected.Compare(stringSampleRateGet) == 0)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3443
					{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3444
					INFO_PRINTF2(_L("Sample rate value match default as expected with %S"), &stringSampleRateGet);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3445
					if (stringChannelsExpected.Compare(stringChannelsGet) == 0)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3446
						{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3447
						INFO_PRINTF2(_L("Channel mode value match default as expected with %S"), &stringChannelsGet);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3448
						StopTest();
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3449
						}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3450
					else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3451
						{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3452
						INFO_PRINTF2(_L("Channel mode value failed with %S"), &stringChannelsGet);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3453
						ERR_PRINTF2(_L("Expected channel mode %S"), &stringChannelsExpected);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3454
						StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3455
						}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3456
					}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3457
				else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3458
					{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3459
					ERR_PRINTF2(_L("Sample rate value failed with %S"), &stringSampleRateGet);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3460
					ERR_PRINTF2(_L("Expected sample rate %S"), &stringSampleRateExpected);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3461
					StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3462
					}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3463
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3464
			else if (aDevSoundEvent == EEventInitComplete && aError != KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3465
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3466
				ERR_PRINTF2(_L("DevSound called CMMFDevSound::InitializeComplete with error = %d"), aError);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3467
				StopTest(aError);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3468
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3469
			else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3470
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3471
				ERR_PRINTF2(_L("DevSound EEventInitComplete not received as expected. Received event: %d"), aDevSoundEvent);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3472
				StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3473
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3474
			break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3475
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3476
		default:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3477
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3478
			ERR_PRINTF2(_L("Invalid DevSound state received: %d"), iDevSoundState);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3479
			StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3480
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3481
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3482
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3483
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3484
/*
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3485
 *========================================================================================================
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3486
 * MM-A3F-DEVSOUND-CHRTZ-TONE-0026
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3487
 */
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3488
RA3FDevSoundToneMaxVolumeTest::RA3FDevSoundToneMaxVolumeTest(const TDesC& aTestName)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3489
	:	RA3FDevSoundTestBase(aTestName), iExVolume(0)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3490
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3491
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3492
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3493
RA3FDevSoundToneMaxVolumeTest* RA3FDevSoundToneMaxVolumeTest::NewL(const TDesC& aTestName)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3494
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3495
	RA3FDevSoundToneMaxVolumeTest * self = new(ELeave)RA3FDevSoundToneMaxVolumeTest(aTestName);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3496
	return self;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3497
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3498
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3499
void RA3FDevSoundToneMaxVolumeTest::DoKickoffTestL()
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3500
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3501
	if (!GetIntFromConfig(iTestStepName, KExVolume, iExVolume)) 
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3502
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3503
		ERR_PRINTF2(KMsgErrorGetParameter, &KExVolume);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3504
		StopTest(KErrNotFound);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3505
		return;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3506
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3507
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3508
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3509
void RA3FDevSoundToneMaxVolumeTest::Fsm(TMmfDevSoundEvent aDevSoundEvent,  TInt aError)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3510
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3511
	switch(iDevSoundState)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3512
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3513
		case EStateCreated:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3514
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3515
			__ASSERT_ALWAYS((aError == KErrNone), Panic(_L("RA3FDevSoundToneMaxVolumeTest"), EFsmIncorrectErrorPassed));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3516
			if (aDevSoundEvent == EEventInitialize)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3517
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3518
				INFO_PRINTF1(_L("Calling CMMFDevSound::InitializeL"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3519
				TRAPD(err, iMMFDevSound->InitializeL(*this, EMMFStateTonePlaying));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3520
				if (err != KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3521
					{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3522
					ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"), err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3523
					StopTest(err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3524
					break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3525
					}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3526
				INFO_PRINTF1(_L("DevSound State: EStateInitializing"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3527
				iDevSoundState = EStateInitializing;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3528
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3529
			else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3530
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3531
				ERR_PRINTF2(_L("DevSound EEventInitialize not received as expected. Received event: %d"), aDevSoundEvent);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3532
				StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3533
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3534
			break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3535
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3536
		case EStateInitializing:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3537
			{		
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3538
			if (aDevSoundEvent == EEventInitComplete && aError == KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3539
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3540
				INFO_PRINTF1(_L("Calling CMMFDevSound::MaxVolume"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3541
				TInt maxVolumeGet = iMMFDevSound->MaxVolume();
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3542
				if (maxVolumeGet == iExVolume)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3543
					{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3544
					INFO_PRINTF2(_L("The max device supported volume is %d."), maxVolumeGet);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3545
					StopTest();
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3546
					}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3547
				else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3548
					{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3549
					INFO_PRINTF2(_L("The max device supported volume failed with %d."), maxVolumeGet);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3550
					ERR_PRINTF2(_L("Expected value = %d."), iExVolume);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3551
					StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3552
					}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3553
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3554
			else if (aDevSoundEvent == EEventInitComplete && aError != KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3555
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3556
				ERR_PRINTF2(_L("DevSound called CMMFDevSound::InitializeComplete with error = %d"), aError);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3557
				StopTest(aError);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3558
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3559
			else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3560
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3561
				ERR_PRINTF2(_L("DevSound EEventInitComplete not received as expected. Received event: %d"), aDevSoundEvent);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3562
				StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3563
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3564
			break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3565
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3566
		default:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3567
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3568
			ERR_PRINTF2(_L("Invalid DevSound state received: %d"), iDevSoundState);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3569
			StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3570
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3571
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3572
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3573
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3574
/*
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3575
 *========================================================================================================
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3576
 * MM-A3F-DEVSOUND-CHRTZ-TONE-0027
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3577
 */
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3578
RA3FDevSoundToneVolumeTest::RA3FDevSoundToneVolumeTest(const TDesC& aTestName)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3579
	:	RA3FDevSoundTestBase(aTestName), iExVolume(0)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3580
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3581
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3582
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3583
RA3FDevSoundToneVolumeTest* RA3FDevSoundToneVolumeTest::NewL(const TDesC& aTestName)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3584
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3585
	RA3FDevSoundToneVolumeTest * self = new(ELeave)RA3FDevSoundToneVolumeTest(aTestName);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3586
	return self;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3587
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3588
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3589
void RA3FDevSoundToneVolumeTest::DoKickoffTestL()
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3590
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3591
	if (!GetIntFromConfig(iTestStepName, KExVolume, iExVolume)) 
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3592
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3593
		ERR_PRINTF2(KMsgErrorGetParameter, &KExVolume);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3594
		StopTest(KErrNotFound);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3595
		return;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3596
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3597
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3598
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3599
void RA3FDevSoundToneVolumeTest::Fsm(TMmfDevSoundEvent aDevSoundEvent, TInt aError)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3600
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3601
	switch (iDevSoundState)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3602
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3603
		case EStateCreated:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3604
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3605
			__ASSERT_ALWAYS((aError == KErrNone), Panic(_L("RA3FDevSoundToneVolumeTest"), EFsmIncorrectErrorPassed));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3606
			if (aDevSoundEvent == EEventInitialize)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3607
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3608
				INFO_PRINTF1(_L("Calling CMMFDevSound::InitializeL"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3609
				TRAPD(err, iMMFDevSound->InitializeL(*this, EMMFStateTonePlaying));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3610
				if (err != KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3611
					{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3612
					ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"), err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3613
					StopTest(err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3614
					break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3615
					}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3616
				INFO_PRINTF1(_L("DevSound State: EStateInitializing"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3617
				iDevSoundState = EStateInitializing;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3618
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3619
			else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3620
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3621
				ERR_PRINTF2(_L("DevSound EEventInitialize not received as expected. Received event: %d"), aDevSoundEvent);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3622
				StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3623
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3624
			break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3625
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3626
		case EStateInitializing:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3627
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3628
			if (aDevSoundEvent == EEventInitComplete && aError == KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3629
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3630
				INFO_PRINTF1(_L("Calling CMMFDevSound::Volume"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3631
				TInt volumeGet = iMMFDevSound->Volume();
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3632
				if(volumeGet == iExVolume)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3633
					{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3634
					INFO_PRINTF2(_L("Default device volume succeeded with = %d"), volumeGet);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3635
					StopTest();
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3636
					}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3637
				else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3638
					{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3639
					ERR_PRINTF2(_L("Default device volume failed with = %d"), volumeGet);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3640
					ERR_PRINTF2(_L("Expected value % d"), iExVolume);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3641
					StopTest(aError , EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3642
					}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3643
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3644
			else if (aDevSoundEvent == EEventInitComplete && aError != KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3645
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3646
				ERR_PRINTF2(_L("DevSound called CMMFDevSound::InitializeComplete with error = %d"), aError);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3647
				StopTest(aError);	
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3648
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3649
			else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3650
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3651
				ERR_PRINTF2(_L("DevSound EEventInitComplete not received as expected. Received event: %d"), aDevSoundEvent);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3652
				StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3653
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3654
			break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3655
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3656
		default:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3657
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3658
			ERR_PRINTF2(_L("Invalid DevSound state received: %d"), iDevSoundState);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3659
			StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3660
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3661
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3662
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3663
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3664
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3665
/*
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3666
 *========================================================================================================
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3667
 * MM-A3F-DEVSOUND-CHRTZ-TONE-0028
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3668
 */
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3669
RA3FDevSoundToneQueryCapsWhilePlayingTest::RA3FDevSoundToneQueryCapsWhilePlayingTest(const TDesC& aTestName)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3670
	:	RA3FDevSoundTestBase(aTestName), iDuration(0),
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3671
		iFrequencyTone1(0), iExCapRate(0), iExCapChannels(0)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3672
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3673
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3674
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3675
RA3FDevSoundToneQueryCapsWhilePlayingTest* RA3FDevSoundToneQueryCapsWhilePlayingTest::NewL(const TDesC& aTestName)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3676
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3677
	RA3FDevSoundToneQueryCapsWhilePlayingTest * self = new(ELeave)RA3FDevSoundToneQueryCapsWhilePlayingTest(aTestName);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3678
	return self;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3679
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3680
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3681
void RA3FDevSoundToneQueryCapsWhilePlayingTest::DoKickoffTestL()
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3682
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3683
	if (!GetIntFromConfig(iTestStepName, KDuration, iDuration)) 
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3684
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3685
		ERR_PRINTF2(KMsgErrorGetParameter, &KDuration);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3686
		StopTest(KErrNotFound);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3687
		return;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3688
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3689
	if (!GetIntFromConfig(iTestStepName, KFrequencyTone1, iFrequencyTone1)) 
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3690
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3691
		ERR_PRINTF2(KMsgErrorGetParameter, &KFrequencyTone1);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3692
		StopTest(KErrNotFound);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3693
		return;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3694
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3695
	if (!GetIntFromConfig(iTestStepName, KExCapRate, iExCapRate))
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3696
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3697
		ERR_PRINTF2(KMsgErrorGetParameter, &KSampleRate);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3698
		StopTest(KErrNotFound);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3699
		return;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3700
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3701
	if (!GetIntFromConfig(iTestStepName, KExCapChannels, iExCapChannels))
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3702
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3703
		ERR_PRINTF2(KMsgErrorGetParameter, &KChannel);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3704
		StopTest(KErrNotFound);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3705
		return;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3706
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3707
	iTimer = CPeriodic::NewL(CActive::EPriorityHigh);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3708
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3709
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3710
void RA3FDevSoundToneQueryCapsWhilePlayingTest::Fsm(TMmfDevSoundEvent aDevSoundEvent, TInt aError)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3711
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3712
	switch (iDevSoundState)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3713
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3714
		case EStateCreated:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3715
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3716
			__ASSERT_ALWAYS((aError == KErrNone), Panic(_L("RA3FDevSoundToneQueryCapsWhilePlayingTest"), EFsmIncorrectErrorPassed));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3717
			if (aDevSoundEvent == EEventInitialize)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3718
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3719
				INFO_PRINTF1(_L("Calling CMMFDevSound::InitializeL"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3720
				TRAPD(err, iMMFDevSound->InitializeL(*this, EMMFStateTonePlaying));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3721
				if (err != KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3722
					{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3723
					ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"), err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3724
					StopTest(err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3725
					break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3726
					}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3727
				INFO_PRINTF1(_L("DevSound State: EStateInitializing"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3728
				iDevSoundState = EStateInitializing;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3729
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3730
			else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3731
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3732
				ERR_PRINTF2(_L("DevSound EEventInitialize not received as expected. Received event: %d"), aDevSoundEvent);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3733
				StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3734
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3735
			break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3736
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3737
		case EStateInitializing:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3738
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3739
			if (aDevSoundEvent == EEventInitComplete && aError == KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3740
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3741
				INFO_PRINTF3(_L("Calling CMMFDevSound::PlayToneL using %d Hz during %d secs "), iFrequencyTone1, iDuration);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3742
				TRAPD(err, iMMFDevSound->PlayToneL(iFrequencyTone1, iDuration*KMicroSecsInOneSec));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3743
				if (err != KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3744
					{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3745
					ERR_PRINTF2(_L("CMMFDevSound::PlayToneL left with error : %d!"), err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3746
					StopTest(err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3747
					break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3748
					}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3749
				StartTimer(KMicroSecsTwoSec);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3750
				INFO_PRINTF1(_L("DevSound State: EStatePlaying"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3751
				iDevSoundState = EStatePlaying;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3752
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3753
			else if (aDevSoundEvent == EEventInitComplete && aError != KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3754
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3755
				ERR_PRINTF2(_L("DevSound called CMMFDevSound::InitializeComplete with error = %d"), aError);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3756
				StopTest(aError);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3757
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3758
			else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3759
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3760
				ERR_PRINTF2(_L("DevSound EEventInitComplete not received as expected. Received event: %d"), aDevSoundEvent);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3761
				StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3762
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3763
			break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3764
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3765
		default:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3766
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3767
			ERR_PRINTF2(_L("Invalid DevSound state received: %d"), iDevSoundState);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3768
			StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3769
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3770
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3771
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3772
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3773
void RA3FDevSoundToneQueryCapsWhilePlayingTest::DoTimerCallback()
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3774
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3775
	iTimer->Cancel();
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3776
	INFO_PRINTF1(_L("DevSound Event: EEventTimerComplete"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3777
	TMMFCapabilities capabilities;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3778
	INFO_PRINTF1(_L("Calling CMMFDevSound::Capabilities"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3779
	capabilities = iMMFDevSound->Capabilities();
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3780
	PrintSupportedCapabilities(capabilities.iRate, capabilities.iChannels);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3781
	if(capabilities.iRate == iExCapRate)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3782
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3783
		INFO_PRINTF2(_L("The total of possible sample rate values is 0x%08x"), capabilities.iRate);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3784
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3785
	else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3786
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3787
		ERR_PRINTF2(_L("The total of possible sample rate values failed with 0x%08x"), capabilities.iRate);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3788
		ERR_PRINTF2(_L("Expected value = %d"), iExCapRate);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3789
		StopTest(KErrNone, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3790
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3791
	if(capabilities.iChannels == iExCapChannels)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3792
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3793
		INFO_PRINTF2(_L("The total of possible channel values is 0x%08x"),capabilities.iChannels );
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3794
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3795
	else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3796
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3797
		ERR_PRINTF2(_L("The total of possible channel values failed with 0x%08x"), capabilities.iChannels );
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3798
		ERR_PRINTF2(_L("Expected value = %d"), iExCapChannels);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3799
		StopTest(KErrNone, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3800
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3801
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3802
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3803
/*
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3804
 *========================================================================================================
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3805
 * MM-A3F-DEVSOUND-CHRTZ-TONE-0029
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3806
 */
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3807
RA3FDevSoundToneConfigWhilePlayingTest::RA3FDevSoundToneConfigWhilePlayingTest(const TDesC& aTestName)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3808
	:	RA3FDevSoundTestBase(aTestName), iDuration(0),
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3809
		iFrequencyTone1(0)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3810
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3811
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3812
RA3FDevSoundToneConfigWhilePlayingTest* RA3FDevSoundToneConfigWhilePlayingTest::NewL(const TDesC& aTestName)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3813
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3814
	RA3FDevSoundToneConfigWhilePlayingTest * self = new(ELeave)RA3FDevSoundToneConfigWhilePlayingTest(aTestName);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3815
	return self;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3816
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3817
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3818
void RA3FDevSoundToneConfigWhilePlayingTest::DoKickoffTestL()
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3819
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3820
	if (!GetIntFromConfig(iTestStepName, KDuration, iDuration)) 
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3821
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3822
		ERR_PRINTF2(KMsgErrorGetParameter, &KDuration);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3823
		StopTest(KErrNotFound);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3824
		return;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3825
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3826
	if (!GetIntFromConfig(iTestStepName, KFrequencyTone1, iFrequencyTone1)) 
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3827
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3828
		ERR_PRINTF2(KMsgErrorGetParameter, &KFrequencyTone1);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3829
		StopTest(KErrNotFound);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3830
		return;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3831
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3832
	if (!GetIntFromConfig(iTestStepName, KExCapRate, iExCapRate))
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3833
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3834
			ERR_PRINTF2(KMsgErrorGetParameter, &KExCapRate);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3835
			StopTest(KErrNotFound);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3836
			return;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3837
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3838
	if (!GetIntFromConfig(iTestStepName, KExCapChannels, iExCapChannels))
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3839
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3840
		ERR_PRINTF2(KMsgErrorGetParameter, &KExCapChannels);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3841
		StopTest(KErrNotFound);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3842
		return;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3843
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3844
	iTimer = CPeriodic::NewL(CActive::EPriorityHigh);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3845
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3846
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3847
void RA3FDevSoundToneConfigWhilePlayingTest::Fsm(TMmfDevSoundEvent aDevSoundEvent, TInt aError)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3848
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3849
	switch(iDevSoundState)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3850
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3851
		case EStateCreated:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3852
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3853
			__ASSERT_ALWAYS((aError == KErrNone), Panic(_L("RA3FDevSoundToneConfigWhilePlayingTest"), EFsmIncorrectErrorPassed));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3854
			if (aDevSoundEvent == EEventInitialize)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3855
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3856
				INFO_PRINTF1(_L("Calling CMMFDevSound::InitializeL"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3857
				TRAPD(err, iMMFDevSound->InitializeL(*this, EMMFStateTonePlaying));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3858
				if (err != KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3859
					{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3860
					ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"), err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3861
					StopTest(err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3862
					break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3863
					}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3864
				INFO_PRINTF1(_L("DevSound State: EStateInitializing"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3865
				iDevSoundState = EStateInitializing;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3866
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3867
			else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3868
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3869
				ERR_PRINTF2(_L("DevSound EEventInitialize not received as expected. Received event: %d"), aDevSoundEvent);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3870
				StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3871
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3872
			break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3873
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3874
		case EStateInitializing:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3875
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3876
			if (aDevSoundEvent == EEventInitComplete && aError == KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3877
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3878
				iStartTime.HomeTime();
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3879
				INFO_PRINTF3(_L("Calling CMMFDevSound::PlayToneL using %d Hz during %d secs "), iFrequencyTone1, iDuration);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3880
				TRAPD(err, iMMFDevSound->PlayToneL(iFrequencyTone1, iDuration*KMicroSecsInOneSec));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3881
				if (err != KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3882
					{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3883
					ERR_PRINTF2(_L("CMMFDevSound::PlayToneL left with error : %d!"),  err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3884
					StopTest(err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3885
					break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3886
					}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3887
				StartTimer(KMicroSecsTwoSec);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3888
				INFO_PRINTF1(_L("DevSound State: EStatePlaying"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3889
				iDevSoundState = EStatePlaying;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3890
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3891
			else if (aDevSoundEvent == EEventInitComplete && aError != KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3892
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3893
				ERR_PRINTF2(_L("DevSound called CMMFDevSound::InitializeComplete with error = %d"), aError);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3894
				StopTest(aError);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3895
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3896
			else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3897
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3898
				ERR_PRINTF2(_L("DevSound EEventInitComplete not received as expected. Received event: %d"), aDevSoundEvent);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3899
				StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3900
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3901
			break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3902
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3903
		default:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3904
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3905
			ERR_PRINTF2(_L("Invalid DevSound state received: %d"), iDevSoundState);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3906
			StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3907
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3908
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3909
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3910
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3911
void RA3FDevSoundToneConfigWhilePlayingTest::DoTimerCallback()
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3912
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3913
	iTimer->Cancel();
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3914
	INFO_PRINTF1(_L("DevSound Event: EEventTimerComplete"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3915
	TMMFCapabilities capabilitiesGet;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3916
	TBuf<KMaxSampleRateStringLength> stringSampleRateGet;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3917
	TBuf<KMaxChannelsStringLength> stringChannelsGet;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3918
	TBuf<KMaxSampleRateStringLength> stringSampleRateExpected;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3919
	TBuf<KMaxChannelsStringLength> stringChannelsExpected;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3920
	INFO_PRINTF1(_L("Calling CMMFDevSound::Config while playing"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3921
	capabilitiesGet=iMMFDevSound->Config();
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3922
	SampleRateFromTUintToString (capabilitiesGet.iRate, stringSampleRateGet);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3923
	ChannelsFromTUintToString (capabilitiesGet.iChannels, stringChannelsGet);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3924
	SampleRateFromTIntToTMMFSampleRate (iExCapRate, iExSampleRate);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3925
	SampleRateFromTUintToString (iExSampleRate, stringSampleRateExpected);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3926
	ChannelsFromTUintToString (iExCapChannels, stringChannelsExpected);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3927
	if (stringSampleRateExpected.Compare(stringSampleRateGet) == 0)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3928
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3929
		INFO_PRINTF2(_L("Sample rate value match default as expected with %S"), &stringSampleRateGet);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3930
		if (stringChannelsExpected.Compare(stringChannelsGet) == 0)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3931
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3932
			INFO_PRINTF2(_L("Channel mode value match default as expected with %S"), &stringChannelsGet);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3933
			StopTest();
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3934
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3935
		else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3936
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3937
			INFO_PRINTF2(_L("Channel mode value failed with %S"), &stringChannelsGet);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3938
			ERR_PRINTF2(_L("Expected channel mode %S"), &stringChannelsExpected);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3939
			StopTest(KErrNone, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3940
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3941
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3942
	else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3943
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3944
		ERR_PRINTF2(_L("Sample rate value failed with %S"), &stringSampleRateGet);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3945
		ERR_PRINTF2(_L("Expected sample rate %S"), &stringSampleRateExpected);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3946
		StopTest(KErrNone, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3947
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3948
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3949
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3950
void RA3FDevSoundToneConfigWhilePlayingTest::ToneFinished(TInt aError)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3951
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3952
	INFO_PRINTF1(_L("========== DevSound ToneFinished() callback =========="));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3953
	if (aError == KErrUnderflow)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3954
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3955
		iEndTime.HomeTime();
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3956
		iPlayToneTime = iEndTime.MicroSecondsFrom(iStartTime);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3957
		TInt totalExpectedReproductionTime = iDuration * KMicroSecsInOneSec;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3958
		if(iPlayToneTime < totalExpectedReproductionTime + KPlayVarianceTime && iPlayToneTime > totalExpectedReproductionTime - KPlayVarianceTime)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3959
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3960
			INFO_PRINTF2(_L("Play time is %Ld microseconds"), iPlayToneTime.Int64());
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3961
			StopTest();
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3962
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3963
		else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3964
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3965
			ERR_PRINTF3(_L("Play time is %Ld microseconds and it should have been %d microseconds"), iPlayToneTime.Int64(), totalExpectedReproductionTime);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3966
			StopTest(KErrNone, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3967
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3968
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3969
	else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3970
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3971
		ERR_PRINTF2(_L("DevSound called ToneFinished with error = %d"), aError);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3972
		ERR_PRINTF2(_L("Expected error = %d"), KErrUnderflow);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3973
		StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3974
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3975
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3976
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3977
/*
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3978
 *========================================================================================================
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3979
 * MM-A3F-DEVSOUND-CHRTZ-TONE-0030
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3980
 */
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3981
RA3FDevSoundToneMaxVolumeWhilePlayingTest::RA3FDevSoundToneMaxVolumeWhilePlayingTest(const TDesC& aTestName)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3982
	:	RA3FDevSoundTestBase(aTestName), iDuration(0),
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3983
		iFrequencyTone1(0), iExVolume(0)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3984
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3985
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3986
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3987
RA3FDevSoundToneMaxVolumeWhilePlayingTest* RA3FDevSoundToneMaxVolumeWhilePlayingTest::NewL(const TDesC& aTestName)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3988
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3989
	RA3FDevSoundToneMaxVolumeWhilePlayingTest * self = new(ELeave)RA3FDevSoundToneMaxVolumeWhilePlayingTest(aTestName);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3990
	return self;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3991
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3992
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3993
void RA3FDevSoundToneMaxVolumeWhilePlayingTest::DoKickoffTestL()
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3994
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3995
	if (!GetIntFromConfig(iTestStepName, KExVolume, iExVolume)) 
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3996
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3997
		ERR_PRINTF2(KMsgErrorGetParameter, &KExVolume);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3998
		StopTest(KErrNotFound);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  3999
		return;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4000
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4001
	if (!GetIntFromConfig(iTestStepName, KDuration, iDuration)) 
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4002
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4003
		ERR_PRINTF2(KMsgErrorGetParameter, &KDuration);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4004
		StopTest(KErrNotFound);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4005
		return;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4006
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4007
	if (!GetIntFromConfig(iTestStepName, KFrequencyTone1, iFrequencyTone1)) 
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4008
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4009
		ERR_PRINTF2(KMsgErrorGetParameter, &KFrequencyTone1);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4010
		StopTest(KErrNotFound);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4011
		return;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4012
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4013
	iTimer = CPeriodic::NewL(CActive::EPriorityHigh);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4014
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4015
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4016
void RA3FDevSoundToneMaxVolumeWhilePlayingTest::Fsm(TMmfDevSoundEvent aDevSoundEvent, TInt aError)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4017
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4018
	switch (iDevSoundState)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4019
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4020
		case EStateCreated:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4021
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4022
			__ASSERT_ALWAYS((aError == KErrNone), Panic(_L("RA3FDevSoundToneMaxVolumeWhilePlayingTest"), EFsmIncorrectErrorPassed));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4023
			if (aDevSoundEvent == EEventInitialize)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4024
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4025
				INFO_PRINTF1(_L("Calling CMMFDevSound::InitializeL"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4026
				TRAPD(err, iMMFDevSound->InitializeL(*this, EMMFStateTonePlaying));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4027
				if (err != KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4028
					{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4029
					ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"), err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4030
					StopTest(err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4031
					break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4032
					}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4033
				INFO_PRINTF1(_L("DevSound State: EStateInitializing"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4034
				iDevSoundState = EStateInitializing;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4035
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4036
			else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4037
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4038
				ERR_PRINTF2(_L("DevSound EEventInitialize not received as expected. Received event: %d"), aDevSoundEvent);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4039
				StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4040
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4041
			break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4042
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4043
		case EStateInitializing:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4044
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4045
			if (aDevSoundEvent == EEventInitComplete && aError == KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4046
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4047
				iMMFDevSound->SetVolume(iMMFDevSound->MaxVolume());
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4048
				iStartTime.HomeTime();
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4049
				INFO_PRINTF3(_L("Calling CMMFDevSound::PlayToneL using %d Hz during %d secs "), iFrequencyTone1, iDuration);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4050
				TRAPD(err, iMMFDevSound->PlayToneL(iFrequencyTone1, iDuration*KMicroSecsInOneSec));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4051
				if (err != KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4052
					{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4053
					ERR_PRINTF2(_L("CMMFDevSound::PlayToneL left with error : %d!"),  err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4054
					StopTest(err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4055
					break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4056
					}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4057
				StartTimer(KMicroSecsTwoSec);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4058
				INFO_PRINTF1(_L("DevSound State: EStatePlaying"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4059
				iDevSoundState = EStatePlaying;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4060
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4061
			else if (aDevSoundEvent == EEventInitComplete && aError != KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4062
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4063
				ERR_PRINTF2(_L("DevSound called CMMFDevSound::InitializeComplete with error = %d"), aError);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4064
				StopTest(aError);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4065
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4066
			else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4067
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4068
				ERR_PRINTF2(_L("DevSound EEventInitComplete not received as expected. Received event: %d"), aDevSoundEvent);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4069
				StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4070
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4071
			break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4072
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4073
		default:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4074
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4075
			ERR_PRINTF2(_L("Invalid DevSound state received: %d"), iDevSoundState);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4076
			StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4077
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4078
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4079
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4080
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4081
void RA3FDevSoundToneMaxVolumeWhilePlayingTest::DoTimerCallback()
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4082
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4083
	iTimer->Cancel();
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4084
	INFO_PRINTF1(_L("DevSound Event: EEventTimerComplete"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4085
	INFO_PRINTF1(_L("Calling CMMFDevSound::MaxVolume"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4086
	TInt maxVolumeGet = iMMFDevSound->MaxVolume();
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4087
	if (maxVolumeGet == iExVolume)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4088
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4089
		INFO_PRINTF2(_L("The max device supported volume is %d."), maxVolumeGet);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4090
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4091
	else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4092
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4093
		INFO_PRINTF2(_L("The max device supported volume failed with %d."), maxVolumeGet);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4094
		ERR_PRINTF2(_L("Expected value = %d."), iExVolume);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4095
		StopTest(KErrNone, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4096
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4097
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4098
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4099
void RA3FDevSoundToneMaxVolumeWhilePlayingTest::ToneFinished(TInt aError)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4100
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4101
	INFO_PRINTF1(_L("========== DevSound ToneFinished() callback =========="));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4102
	if (aError == KErrUnderflow)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4103
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4104
		iEndTime.HomeTime();
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4105
		iPlayToneTime = iEndTime.MicroSecondsFrom(iStartTime);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4106
		TInt totalExpectedReproductionTime = iDuration * KMicroSecsInOneSec;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4107
		if(iPlayToneTime < totalExpectedReproductionTime + KPlayVarianceTime && iPlayToneTime > totalExpectedReproductionTime - KPlayVarianceTime)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4108
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4109
			INFO_PRINTF2(_L("Play time is %Ld microseconds"), iPlayToneTime.Int64());
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4110
			StopTest();
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4111
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4112
		else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4113
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4114
			ERR_PRINTF3(_L("Play time is %Ld microseconds and it should have been %d microseconds"), iPlayToneTime.Int64(), totalExpectedReproductionTime);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4115
			StopTest(KErrNone, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4116
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4117
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4118
	else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4119
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4120
		ERR_PRINTF2(_L("DevSound called ToneFinished with error = %d"), aError);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4121
		ERR_PRINTF2(_L("Expected error = %d"), KErrUnderflow);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4122
		StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4123
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4124
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4125
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4126
/*
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4127
 *========================================================================================================
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4128
 * MM-A3F-DEVSOUND-CHRTZ-TONE-0031
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4129
 */
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4130
RA3FDevSoundToneVolumeWhilePlayingTest::RA3FDevSoundToneVolumeWhilePlayingTest(const TDesC& aTestName)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4131
	:	RA3FDevSoundTestBase(aTestName), iDuration(0),
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4132
		iFrequencyTone1(0), iExVolume(0)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4133
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4134
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4135
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4136
RA3FDevSoundToneVolumeWhilePlayingTest* RA3FDevSoundToneVolumeWhilePlayingTest::NewL(const TDesC& aTestName)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4137
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4138
	RA3FDevSoundToneVolumeWhilePlayingTest * self = new(ELeave)RA3FDevSoundToneVolumeWhilePlayingTest(aTestName);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4139
	return self;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4140
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4141
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4142
void RA3FDevSoundToneVolumeWhilePlayingTest::DoKickoffTestL()
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4143
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4144
	if (!GetIntFromConfig(iTestStepName, KExVolume, iExVolume)) 
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4145
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4146
		ERR_PRINTF2(KMsgErrorGetParameter, &KExVolume);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4147
		StopTest(KErrNotFound);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4148
		return;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4149
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4150
	if (!GetIntFromConfig(iTestStepName, KDuration, iDuration)) 
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4151
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4152
		ERR_PRINTF2(KMsgErrorGetParameter, &KDuration);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4153
		StopTest(KErrNotFound);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4154
		return;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4155
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4156
	if (!GetIntFromConfig(iTestStepName, KFrequencyTone1, iFrequencyTone1)) 
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4157
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4158
		ERR_PRINTF2(KMsgErrorGetParameter, &KFrequencyTone1);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4159
		StopTest(KErrNotFound);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4160
		return;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4161
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4162
	iTimer = CPeriodic::NewL(CActive::EPriorityHigh);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4163
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4164
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4165
void RA3FDevSoundToneVolumeWhilePlayingTest::Fsm(TMmfDevSoundEvent aDevSoundEvent, TInt aError)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4166
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4167
	switch (iDevSoundState)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4168
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4169
		case EStateCreated:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4170
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4171
			__ASSERT_ALWAYS((aError == KErrNone), Panic(_L("RA3FDevSoundToneVolumeWhilePlayingTest"), EFsmIncorrectErrorPassed));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4172
			if (aDevSoundEvent == EEventInitialize)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4173
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4174
				INFO_PRINTF1(_L("Calling CMMFDevSound::InitializeL"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4175
				TRAPD(err, iMMFDevSound->InitializeL(*this, EMMFStateTonePlaying));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4176
				if (err != KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4177
					{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4178
					ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"), err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4179
					StopTest(err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4180
					break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4181
					}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4182
				INFO_PRINTF1(_L("DevSound State: EStateInitializing"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4183
				iDevSoundState = EStateInitializing;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4184
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4185
			else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4186
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4187
				ERR_PRINTF2(_L("DevSound EEventInitialize not received as expected. Received event: %d"), aDevSoundEvent);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4188
				StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4189
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4190
			break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4191
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4192
		case EStateInitializing:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4193
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4194
			if (aDevSoundEvent == EEventInitComplete && aError == KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4195
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4196
				iStartTime.HomeTime();
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4197
				INFO_PRINTF3(_L("Calling CMMFDevSound::PlayToneL using %d Hz during %d secs "), iFrequencyTone1, iDuration);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4198
				TRAPD(err, iMMFDevSound->PlayToneL(iFrequencyTone1, iDuration*KMicroSecsInOneSec));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4199
				if (err != KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4200
					{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4201
					ERR_PRINTF2(_L("CMMFDevSound::PlayToneL left with error : %d!"), err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4202
					StopTest(err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4203
					break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4204
					}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4205
				StartTimer(KMicroSecsTwoSec);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4206
				INFO_PRINTF1(_L("DevSound State: EStatePlaying"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4207
				iDevSoundState = EStatePlaying;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4208
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4209
			else if (aDevSoundEvent == EEventInitComplete && aError != KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4210
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4211
				ERR_PRINTF2(_L("DevSound called CMMFDevSound::InitializeComplete with error = %d"), aError);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4212
				StopTest(aError);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4213
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4214
			else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4215
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4216
				ERR_PRINTF2(_L("DevSound EEventInitComplete not received as expected. Received event: %d"), aDevSoundEvent);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4217
				StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4218
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4219
			break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4220
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4221
		default:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4222
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4223
			ERR_PRINTF2(_L("Invalid DevSound state received: %d"), iDevSoundState);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4224
			StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4225
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4226
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4227
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4228
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4229
void RA3FDevSoundToneVolumeWhilePlayingTest::DoTimerCallback()
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4230
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4231
	iTimer->Cancel();
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4232
	INFO_PRINTF1(_L("DevSound Event: EEventTimerComplete"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4233
	INFO_PRINTF1(_L("Calling CMMFDevSound::Volume"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4234
	TInt maxVolumeGet = iMMFDevSound->Volume();
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4235
	if (maxVolumeGet == iExVolume)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4236
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4237
		INFO_PRINTF2(_L("The device default supported volume value is %d."), maxVolumeGet);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4238
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4239
	else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4240
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4241
		INFO_PRINTF2(_L("The device default supported volume value failed with %d."), maxVolumeGet);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4242
		ERR_PRINTF2(_L("Expected value = %d."), iExVolume);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4243
		StopTest(KErrNone, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4244
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4245
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4246
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4247
void RA3FDevSoundToneVolumeWhilePlayingTest::ToneFinished(TInt aError)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4248
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4249
	INFO_PRINTF1(_L("========== DevSound ToneFinished() callback =========="));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4250
	if (aError == KErrUnderflow)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4251
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4252
		iEndTime.HomeTime();
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4253
		iPlayToneTime = iEndTime.MicroSecondsFrom(iStartTime);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4254
		TInt totalExpectedReproductionTime = iDuration * KMicroSecsInOneSec;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4255
		if(iPlayToneTime < totalExpectedReproductionTime + KPlayVarianceTime && iPlayToneTime > totalExpectedReproductionTime - KPlayVarianceTime)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4256
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4257
			INFO_PRINTF2(_L("Play time is %Ld microseconds"), iPlayToneTime.Int64());
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4258
			StopTest();
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4259
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4260
		else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4261
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4262
			ERR_PRINTF3(_L("Play time is %Ld microseconds and it should have been %d microseconds"), iPlayToneTime.Int64(), totalExpectedReproductionTime);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4263
			StopTest(KErrNone, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4264
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4265
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4266
	else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4267
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4268
		ERR_PRINTF2(_L("DevSound called ToneFinished with error = %d"), aError);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4269
		ERR_PRINTF2(_L("Expected error = %d"), KErrUnderflow);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4270
		StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4271
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4272
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4273
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4274
/*
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4275
 *========================================================================================================
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4276
 * MM-A3F-DEVSOUND-CHRTZ-TONE-0032
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4277
 */
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4278
RA3FDevSoundToneQueryCapsWhilePausePlayingTest::RA3FDevSoundToneQueryCapsWhilePausePlayingTest(const TDesC& aTestName)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4279
	:	RA3FDevSoundTestBase(aTestName), iDuration(0),
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4280
		iFrequencyTone1(0), iExCapRate(0), iExCapChannels(0),
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4281
		iTimeToEnterPauseElapsed(EFalse)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4282
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4283
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4284
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4285
RA3FDevSoundToneQueryCapsWhilePausePlayingTest* RA3FDevSoundToneQueryCapsWhilePausePlayingTest::NewL(const TDesC& aTestName)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4286
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4287
	RA3FDevSoundToneQueryCapsWhilePausePlayingTest * self = new(ELeave)RA3FDevSoundToneQueryCapsWhilePausePlayingTest(aTestName);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4288
	return self;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4289
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4290
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4291
void RA3FDevSoundToneQueryCapsWhilePausePlayingTest::DoKickoffTestL()
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4292
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4293
	if (!GetIntFromConfig(iTestStepName, KDuration, iDuration)) 
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4294
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4295
		ERR_PRINTF2(KMsgErrorGetParameter, &KDuration);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4296
		StopTest(KErrNotFound);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4297
		return;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4298
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4299
	if (!GetIntFromConfig(iTestStepName, KFrequencyTone1, iFrequencyTone1)) 
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4300
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4301
		ERR_PRINTF2(KMsgErrorGetParameter, &KFrequencyTone1);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4302
		StopTest(KErrNotFound);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4303
		return;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4304
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4305
	if (!GetIntFromConfig(iTestStepName, KExCapRate, iExCapRate))
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4306
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4307
		ERR_PRINTF2(KMsgErrorGetParameter, &KSampleRate);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4308
		StopTest(KErrNotFound);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4309
		return;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4310
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4311
	if (!GetIntFromConfig(iTestStepName, KExCapChannels, iExCapChannels))
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4312
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4313
		ERR_PRINTF2(KMsgErrorGetParameter, &KChannel);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4314
		StopTest(KErrNotFound);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4315
		return;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4316
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4317
	iTimer = CPeriodic::NewL(CActive::EPriorityHigh);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4318
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4319
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4320
void RA3FDevSoundToneQueryCapsWhilePausePlayingTest::Fsm(TMmfDevSoundEvent aDevSoundEvent, TInt aError)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4321
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4322
	switch (iDevSoundState)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4323
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4324
		case EStateCreated:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4325
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4326
			__ASSERT_ALWAYS((aError == KErrNone), Panic(_L("RA3FDevSoundToneQueryCapsWhilePausePlayingTest"), EFsmIncorrectErrorPassed));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4327
			if (aDevSoundEvent == EEventInitialize)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4328
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4329
				INFO_PRINTF1(_L("Calling CMMFDevSound::InitializeL"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4330
				TRAPD(err, iMMFDevSound->InitializeL(*this, EMMFStateTonePlaying));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4331
				if (err != KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4332
					{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4333
					ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"), err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4334
					StopTest(err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4335
					break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4336
					}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4337
				INFO_PRINTF1(_L("DevSound State: EStateInitializing"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4338
				iDevSoundState = EStateInitializing;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4339
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4340
			else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4341
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4342
				ERR_PRINTF2(_L("DevSound EEventInitialize not received as expected. Received event: %d"), aDevSoundEvent);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4343
				StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4344
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4345
			break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4346
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4347
		case EStateInitializing:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4348
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4349
			if (aDevSoundEvent == EEventInitComplete && aError == KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4350
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4351
				iMMFDevSound->SetVolume(iMMFDevSound->MaxVolume());
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4352
				INFO_PRINTF3(_L("Calling CMMFDevSound::PlayToneL using %d Hz during %d secs "), iFrequencyTone1, iDuration);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4353
				TRAPD(err, iMMFDevSound->PlayToneL(iFrequencyTone1, iDuration*KMicroSecsInOneSec));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4354
				if (err != KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4355
					{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4356
					ERR_PRINTF2(_L("CMMFDevSound::PlayToneL left with error : %d!"), err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4357
					StopTest(err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4358
					break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4359
					}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4360
				StartTimer(KMicroSecsTwoSec);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4361
				INFO_PRINTF1(_L("DevSound State: EStatePlaying"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4362
				iDevSoundState = EStatePlaying;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4363
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4364
			else if (aDevSoundEvent == EEventInitComplete && aError != KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4365
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4366
				ERR_PRINTF2(_L("DevSound called CMMFDevSound::InitializeComplete with error = %d"), aError);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4367
				StopTest(aError);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4368
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4369
			else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4370
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4371
				ERR_PRINTF2(_L("DevSound EEventInitComplete not received as expected. Received event: %d"), aDevSoundEvent);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4372
				StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4373
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4374
			break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4375
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4376
		case EStatePlaying:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4377
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4378
			if(aDevSoundEvent == EEventTimerComplete)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4379
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4380
				INFO_PRINTF1(_L("Calling CMMFDevSound::Pause"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4381
				iMMFDevSound->Pause();
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4382
				INFO_PRINTF1(_L("DevSound State: EStatePause"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4383
				iDevSoundState = EStatePause;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4384
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4385
			else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4386
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4387
				ERR_PRINTF2(_L("DevSound EEventTimerComplete not received as expected. Received event: %d"), aDevSoundEvent);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4388
				StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4389
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4390
			break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4391
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4392
		case EStatePause:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4393
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4394
			if(aDevSoundEvent == EEventTimerComplete)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4395
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4396
				TMMFCapabilities capabilities;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4397
				INFO_PRINTF1(_L("Calling CMMFDevSound::Capabilities"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4398
				capabilities = iMMFDevSound->Capabilities();
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4399
				PrintSupportedCapabilities(capabilities.iRate, capabilities.iChannels);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4400
				if(capabilities.iRate == iExCapRate)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4401
					{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4402
					INFO_PRINTF2(_L("The total of possible sample rate values is 0x%08x"), capabilities.iRate);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4403
					if(capabilities.iChannels == iExCapChannels)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4404
						{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4405
						INFO_PRINTF2(_L("The total of possible channel values is 0x%08x"),capabilities.iChannels );
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4406
						StopTest();
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4407
						}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4408
					else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4409
						{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4410
						ERR_PRINTF2(_L("The total of possible channel values failed with 0x%08x"), capabilities.iChannels );
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4411
						ERR_PRINTF2(_L("Expected value = %d"), iExCapChannels);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4412
						StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4413
						}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4414
					}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4415
				else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4416
					{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4417
					ERR_PRINTF2(_L("The total of possible sample rate values failed with 0x%08x"), capabilities.iRate);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4418
					ERR_PRINTF2(_L("Expected value = %d"), iExCapRate);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4419
					StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4420
					}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4421
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4422
			else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4423
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4424
				ERR_PRINTF2(_L("DevSound EEventTimerComplete not received as expected. Received event: %d"), aDevSoundEvent);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4425
				StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4426
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4427
			break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4428
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4429
		default:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4430
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4431
			ERR_PRINTF2(_L("Invalid DevSound state received: %d"), iDevSoundState);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4432
			StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4433
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4434
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4435
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4436
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4437
void RA3FDevSoundToneQueryCapsWhilePausePlayingTest::DoTimerCallback()
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4438
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4439
	INFO_PRINTF1(_L("TimerEvent called"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4440
	if(!iTimeToEnterPauseElapsed)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4441
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4442
		iTimeToEnterPauseElapsed = ETrue;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4443
		INFO_PRINTF1(_L("DevSound Event: EEventTimerComplete"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4444
		Fsm(EEventTimerComplete, KErrNone);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4445
		iTimeToEnterPauseElapsed = ETrue;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4446
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4447
	else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4448
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4449
		iTimer->Cancel();
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4450
		INFO_PRINTF1(_L("DevSound Event: EEventTimerComplete"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4451
		Fsm(EEventTimerComplete, KErrNone);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4452
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4453
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4454
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4455
void RA3FDevSoundToneQueryCapsWhilePausePlayingTest::ToneFinished(TInt aError)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4456
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4457
	INFO_PRINTF1(_L("========== DevSound ToneFinished() callback =========="));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4458
	ERR_PRINTF1(_L("DevSound should not have called ToneFinished because it is supposed to be paused then stopped"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4459
	StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4460
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4461
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4462
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4463
/*
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4464
 *========================================================================================================
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4465
 * MM-A3F-DEVSOUND-CHRTZ-TONE-0033
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4466
 */
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4467
RA3FDevSoundToneConfigWhilePausePlayingTest::RA3FDevSoundToneConfigWhilePausePlayingTest(const TDesC& aTestName)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4468
	:	RA3FDevSoundTestBase(aTestName), iDuration(0),
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4469
		iFrequencyTone1(0), iTimeToEnterPauseElapsed(EFalse),
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4470
		iExCapRate(0), iExCapChannels(0)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4471
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4472
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4473
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4474
RA3FDevSoundToneConfigWhilePausePlayingTest* RA3FDevSoundToneConfigWhilePausePlayingTest::NewL(const TDesC& aTestName)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4475
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4476
	RA3FDevSoundToneConfigWhilePausePlayingTest * self = new(ELeave)RA3FDevSoundToneConfigWhilePausePlayingTest(aTestName);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4477
	return self;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4478
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4479
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4480
void RA3FDevSoundToneConfigWhilePausePlayingTest::DoKickoffTestL()
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4481
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4482
	if (!GetIntFromConfig(iTestStepName, KDuration, iDuration)) 
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4483
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4484
		ERR_PRINTF2(KMsgErrorGetParameter, &KDuration);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4485
		StopTest(KErrNotFound);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4486
		return;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4487
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4488
	if (!GetIntFromConfig(iTestStepName, KFrequencyTone1, iFrequencyTone1)) 
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4489
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4490
		ERR_PRINTF2(KMsgErrorGetParameter, &KFrequencyTone1);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4491
		StopTest(KErrNotFound);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4492
		return;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4493
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4494
	if (!GetIntFromConfig(iTestStepName, KExCapRate, iExCapRate))
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4495
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4496
			ERR_PRINTF2(KMsgErrorGetParameter, &KExCapRate);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4497
			StopTest(KErrNotFound);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4498
			return;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4499
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4500
	if (!GetIntFromConfig(iTestStepName, KExCapChannels, iExCapChannels))
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4501
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4502
		ERR_PRINTF2(KMsgErrorGetParameter, &KExCapChannels);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4503
		StopTest(KErrNotFound);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4504
		return;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4505
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4506
	iTimer = CPeriodic::NewL(CActive::EPriorityHigh);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4507
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4508
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4509
void RA3FDevSoundToneConfigWhilePausePlayingTest::Fsm(TMmfDevSoundEvent aDevSoundEvent, TInt aError)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4510
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4511
	switch (iDevSoundState)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4512
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4513
		case EStateCreated:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4514
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4515
			__ASSERT_ALWAYS((aError == KErrNone), Panic(_L("RA3FDevSoundToneConfigWhilePausePlayingTest"), EFsmIncorrectErrorPassed));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4516
			if (aDevSoundEvent == EEventInitialize)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4517
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4518
				INFO_PRINTF1(_L("Calling CMMFDevSound::InitializeL"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4519
				TRAPD(err, iMMFDevSound->InitializeL(*this, EMMFStateTonePlaying));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4520
				if (err != KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4521
					{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4522
					ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"), err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4523
					StopTest(err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4524
					break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4525
					}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4526
				INFO_PRINTF1(_L("DevSound State: EStateInitializing"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4527
				iDevSoundState = EStateInitializing;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4528
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4529
			else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4530
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4531
				ERR_PRINTF2(_L("DevSound EEventInitialize not received as expected. Received event: %d"), aDevSoundEvent);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4532
				StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4533
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4534
			break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4535
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4536
		case EStateInitializing:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4537
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4538
			if (aDevSoundEvent == EEventInitComplete && aError == KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4539
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4540
				iMMFDevSound->SetVolume(iMMFDevSound->MaxVolume());
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4541
				INFO_PRINTF3(_L("Calling CMMFDevSound::PlayToneL using %d Hz during %d secs "), iFrequencyTone1, iDuration);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4542
				TRAPD(err, iMMFDevSound->PlayToneL(iFrequencyTone1, iDuration*KMicroSecsInOneSec));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4543
				if (err != KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4544
					{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4545
					ERR_PRINTF2(_L("CMMFDevSound::PlayToneL left with error : %d!"), err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4546
					StopTest(err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4547
					break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4548
					}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4549
				StartTimer(KMicroSecsTwoSec);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4550
				INFO_PRINTF1(_L("DevSound State: EStatePlaying"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4551
				iDevSoundState = EStatePlaying;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4552
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4553
			else if (aDevSoundEvent == EEventInitComplete && aError != KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4554
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4555
				ERR_PRINTF2(_L("DevSound called CMMFDevSound::InitializeComplete with error = %d"), aError);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4556
				StopTest(aError);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4557
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4558
			else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4559
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4560
				ERR_PRINTF2(_L("DevSound EEventInitComplete not received as expected. Received event: %d"), aDevSoundEvent);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4561
				StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4562
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4563
			break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4564
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4565
		case EStatePlaying:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4566
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4567
			if(aDevSoundEvent == EEventTimerComplete)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4568
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4569
				INFO_PRINTF1(_L("Calling CMMFDevSound::Pause"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4570
				iMMFDevSound->Pause();
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4571
				INFO_PRINTF1(_L("DevSound State: EStatePause"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4572
				iDevSoundState = EStatePause;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4573
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4574
			else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4575
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4576
				ERR_PRINTF2(_L("DevSound EEventTimerComplete not received as expected. Received event: %d"), aDevSoundEvent);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4577
				StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4578
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4579
			break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4580
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4581
		case EStatePause:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4582
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4583
			if(aDevSoundEvent == EEventTimerComplete)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4584
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4585
				TMMFCapabilities capabilitiesGet;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4586
				TBuf<KMaxSampleRateStringLength> stringSampleRateGet;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4587
				TBuf<KMaxChannelsStringLength> stringChannelsGet;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4588
				TBuf<KMaxSampleRateStringLength> stringSampleRateExpected;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4589
				TBuf<KMaxChannelsStringLength> stringChannelsExpected;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4590
				INFO_PRINTF1(_L("Calling CMMFDevSound::Config while playing"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4591
				capabilitiesGet=iMMFDevSound->Config();
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4592
				SampleRateFromTUintToString (capabilitiesGet.iRate, stringSampleRateGet);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4593
				ChannelsFromTUintToString (capabilitiesGet.iChannels, stringChannelsGet);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4594
				SampleRateFromTIntToTMMFSampleRate (iExCapRate, iExSampleRate);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4595
				SampleRateFromTUintToString (iExSampleRate, stringSampleRateExpected);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4596
				ChannelsFromTUintToString (iExCapChannels, stringChannelsExpected);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4597
				if (stringSampleRateExpected.Compare(stringSampleRateGet) == 0)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4598
					{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4599
					INFO_PRINTF2(_L("Sample rate value match default as expected with %S"), &stringSampleRateGet);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4600
					if (stringChannelsExpected.Compare(stringChannelsGet) == 0)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4601
						{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4602
						INFO_PRINTF2(_L("Channel mode value match default as expected with %S"), &stringChannelsGet);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4603
						StopTest();
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4604
						}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4605
					else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4606
						{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4607
						INFO_PRINTF2(_L("Channel mode value failed with %S"), &stringChannelsGet);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4608
						ERR_PRINTF2(_L("Expected channel mode %S"), &stringChannelsExpected);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4609
						StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4610
						}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4611
					}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4612
				else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4613
					{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4614
					ERR_PRINTF2(_L("Sample rate value failed with %S"), &stringSampleRateGet);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4615
					ERR_PRINTF2(_L("Expected sample rate %S"), &stringSampleRateExpected);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4616
					StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4617
					}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4618
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4619
			else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4620
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4621
				ERR_PRINTF2(_L("DevSound EEventTimerComplete not received as expected. Received event: %d"), aDevSoundEvent);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4622
				StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4623
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4624
			break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4625
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4626
		default:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4627
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4628
			ERR_PRINTF2(_L("Invalid DevSound state received: %d"), iDevSoundState);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4629
			StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4630
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4631
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4632
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4633
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4634
void RA3FDevSoundToneConfigWhilePausePlayingTest::DoTimerCallback()
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4635
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4636
	INFO_PRINTF1(_L("TimerEvent called"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4637
	if(!iTimeToEnterPauseElapsed)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4638
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4639
		iTimeToEnterPauseElapsed = ETrue;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4640
		INFO_PRINTF1(_L("DevSound Event: EEventTimerComplete"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4641
		Fsm(EEventTimerComplete, KErrNone);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4642
		iTimeToEnterPauseElapsed = ETrue;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4643
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4644
	else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4645
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4646
		iTimer->Cancel();
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4647
		INFO_PRINTF1(_L("DevSound Event: EEventTimerComplete"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4648
		Fsm(EEventTimerComplete, KErrNone);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4649
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4650
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4651
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4652
void RA3FDevSoundToneConfigWhilePausePlayingTest::ToneFinished(TInt aError)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4653
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4654
	INFO_PRINTF1(_L("========== DevSound ToneFinished() callback =========="));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4655
	ERR_PRINTF1(_L("DevSound should not have called ToneFinished because it is supposed to be paused then stopped"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4656
	StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4657
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4658
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4659
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4660
/*
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4661
 *========================================================================================================
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4662
 * MM-A3F-DEVSOUND-CHRTZ-TONE-0034
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4663
 */
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4664
RA3FDevSoundToneMaxVolumeWhilePausePlayingTest::RA3FDevSoundToneMaxVolumeWhilePausePlayingTest(const TDesC& aTestName)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4665
	:	RA3FDevSoundTestBase(aTestName), iDuration(0),
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4666
		iFrequencyTone1(0), iExVolume(0),
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4667
		iTimeToEnterPauseElapsed(EFalse)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4668
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4669
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4670
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4671
RA3FDevSoundToneMaxVolumeWhilePausePlayingTest* RA3FDevSoundToneMaxVolumeWhilePausePlayingTest::NewL(const TDesC& aTestName)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4672
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4673
	RA3FDevSoundToneMaxVolumeWhilePausePlayingTest * self = new(ELeave)RA3FDevSoundToneMaxVolumeWhilePausePlayingTest(aTestName);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4674
	return self;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4675
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4676
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4677
void RA3FDevSoundToneMaxVolumeWhilePausePlayingTest::DoKickoffTestL()
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4678
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4679
	if (!GetIntFromConfig(iTestStepName, KDuration, iDuration)) 
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4680
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4681
		ERR_PRINTF2(KMsgErrorGetParameter, &KDuration);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4682
		StopTest(KErrNotFound);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4683
		return;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4684
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4685
	if (!GetIntFromConfig(iTestStepName, KFrequencyTone1, iFrequencyTone1)) 
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4686
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4687
		ERR_PRINTF2(KMsgErrorGetParameter, &KFrequencyTone1);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4688
		StopTest(KErrNotFound);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4689
		return;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4690
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4691
	if (!GetIntFromConfig(iTestStepName, KExVolume, iExVolume)) 
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4692
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4693
		ERR_PRINTF2(KMsgErrorGetParameter, &KExVolume);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4694
		StopTest(KErrNotFound);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4695
		return;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4696
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4697
	iTimer = CPeriodic::NewL(CActive::EPriorityHigh);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4698
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4699
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4700
void RA3FDevSoundToneMaxVolumeWhilePausePlayingTest::Fsm(TMmfDevSoundEvent aDevSoundEvent, TInt aError)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4701
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4702
	switch (iDevSoundState)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4703
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4704
		case EStateCreated:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4705
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4706
			__ASSERT_ALWAYS((aError == KErrNone), Panic(_L("RA3FDevSoundToneMaxVolumeWhilePausePlayingTest"), EFsmIncorrectErrorPassed));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4707
			if (aDevSoundEvent == EEventInitialize)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4708
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4709
				INFO_PRINTF1(_L("Calling CMMFDevSound::InitializeL"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4710
				TRAPD(err, iMMFDevSound->InitializeL(*this, EMMFStateTonePlaying));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4711
				if (err != KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4712
					{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4713
					ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"), err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4714
					StopTest(err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4715
					break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4716
					}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4717
				INFO_PRINTF1(_L("DevSound State: EStateInitializing"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4718
				iDevSoundState = EStateInitializing;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4719
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4720
			else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4721
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4722
				ERR_PRINTF2(_L("DevSound EEventInitialize not received as expected. Received event: %d"), aDevSoundEvent);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4723
				StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4724
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4725
			break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4726
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4727
		case EStateInitializing:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4728
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4729
			if (aDevSoundEvent == EEventInitComplete && aError == KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4730
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4731
				iMMFDevSound->SetVolume(iMMFDevSound->MaxVolume());
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4732
				INFO_PRINTF3(_L("Calling CMMFDevSound::PlayToneL using %d Hz during %d secs "), iFrequencyTone1, iDuration);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4733
				TRAPD(err, iMMFDevSound->PlayToneL(iFrequencyTone1, iDuration*KMicroSecsInOneSec));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4734
				if (err != KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4735
					{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4736
					ERR_PRINTF2(_L("CMMFDevSound::PlayToneL left with error : %d!"), err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4737
					StopTest(err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4738
					break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4739
					}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4740
				StartTimer(KMicroSecsTwoSec);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4741
				INFO_PRINTF1(_L("DevSound State: EStatePlaying"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4742
				iDevSoundState = EStatePlaying;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4743
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4744
			else if (aDevSoundEvent == EEventInitComplete && aError != KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4745
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4746
				ERR_PRINTF2(_L("DevSound called CMMFDevSound::InitializeComplete with error = %d"), aError);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4747
				StopTest(aError);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4748
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4749
			else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4750
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4751
				ERR_PRINTF2(_L("DevSound EEventInitComplete not received as expected. Received event: %d"), aDevSoundEvent);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4752
				StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4753
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4754
			break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4755
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4756
		case EStatePlaying:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4757
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4758
			if(aDevSoundEvent == EEventTimerComplete)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4759
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4760
				INFO_PRINTF1(_L("Calling CMMFDevSound::Pause"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4761
				iMMFDevSound->Pause();
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4762
				INFO_PRINTF1(_L("DevSound State: EStatePause"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4763
				iDevSoundState = EStatePause;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4764
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4765
			else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4766
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4767
				ERR_PRINTF2(_L("DevSound EEventTimerComplete not received as expected. Received event: %d"), aDevSoundEvent);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4768
				StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4769
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4770
			break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4771
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4772
		case EStatePause:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4773
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4774
			if(aDevSoundEvent == EEventTimerComplete)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4775
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4776
				INFO_PRINTF1(_L("Calling CMMFDevSound::MaxVolume"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4777
				TInt maxVolumeGet = iMMFDevSound->MaxVolume();
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4778
				if (maxVolumeGet == iExVolume)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4779
					{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4780
					INFO_PRINTF2(_L("The max device supported volume is %d."), maxVolumeGet);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4781
					StopTest();
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4782
					}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4783
				else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4784
					{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4785
					INFO_PRINTF2(_L("The max device supported volume failed with %d."), maxVolumeGet);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4786
					ERR_PRINTF2(_L("Expected value = %d."), iExVolume);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4787
					StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4788
					}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4789
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4790
			else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4791
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4792
				ERR_PRINTF2(_L("DevSound EEventTimerComplete not received as expected. Received event: %d"), aDevSoundEvent);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4793
				StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4794
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4795
			break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4796
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4797
		default:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4798
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4799
			ERR_PRINTF2(_L("Invalid DevSound state received: %d"), iDevSoundState);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4800
			StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4801
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4802
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4803
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4804
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4805
void RA3FDevSoundToneMaxVolumeWhilePausePlayingTest::DoTimerCallback()
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4806
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4807
	INFO_PRINTF1(_L("TimerEvent called"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4808
	if(!iTimeToEnterPauseElapsed)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4809
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4810
		iTimeToEnterPauseElapsed = ETrue;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4811
		INFO_PRINTF1(_L("DevSound Event: EEventTimerComplete"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4812
		Fsm(EEventTimerComplete, KErrNone);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4813
		iTimeToEnterPauseElapsed = ETrue;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4814
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4815
	else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4816
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4817
		iTimer->Cancel();
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4818
		INFO_PRINTF1(_L("DevSound Event: EEventTimerComplete"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4819
		Fsm(EEventTimerComplete, KErrNone);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4820
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4821
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4822
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4823
void RA3FDevSoundToneMaxVolumeWhilePausePlayingTest::ToneFinished(TInt aError)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4824
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4825
	INFO_PRINTF1(_L("========== DevSound ToneFinished() callback =========="));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4826
	ERR_PRINTF1(_L("DevSound should not have called ToneFinished because it is supposed to be paused then stopped"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4827
	StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4828
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4829
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4830
/*
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4831
 *========================================================================================================
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4832
 * MM-A3F-DEVSOUND-CHRTZ-TONE-0035
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4833
 */
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4834
RA3FDevSoundToneVolumeWhilePausePlayingTest::RA3FDevSoundToneVolumeWhilePausePlayingTest(const TDesC& aTestName)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4835
	:	RA3FDevSoundTestBase(aTestName), iDuration(0),
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4836
		iFrequencyTone1(0), iExVolume(0),
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4837
		iTimeToEnterPauseElapsed(EFalse)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4838
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4839
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4840
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4841
RA3FDevSoundToneVolumeWhilePausePlayingTest* RA3FDevSoundToneVolumeWhilePausePlayingTest::NewL(const TDesC& aTestName)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4842
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4843
	RA3FDevSoundToneVolumeWhilePausePlayingTest * self = new(ELeave)RA3FDevSoundToneVolumeWhilePausePlayingTest(aTestName);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4844
	return self;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4845
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4846
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4847
void RA3FDevSoundToneVolumeWhilePausePlayingTest::DoKickoffTestL()
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4848
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4849
	if (!GetIntFromConfig(iTestStepName, KDuration, iDuration)) 
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4850
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4851
		ERR_PRINTF2(KMsgErrorGetParameter, &KDuration);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4852
		StopTest(KErrNotFound);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4853
		return;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4854
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4855
	if (!GetIntFromConfig(iTestStepName, KFrequencyTone1, iFrequencyTone1)) 
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4856
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4857
		ERR_PRINTF2(KMsgErrorGetParameter, &KFrequencyTone1);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4858
		StopTest(KErrNotFound);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4859
		return;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4860
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4861
	if (!GetIntFromConfig(iTestStepName, KExVolume, iExVolume)) 
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4862
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4863
		ERR_PRINTF2(KMsgErrorGetParameter, &KExVolume);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4864
		StopTest(KErrNotFound);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4865
		return;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4866
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4867
	iTimer = CPeriodic::NewL(CActive::EPriorityHigh);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4868
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4869
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4870
void RA3FDevSoundToneVolumeWhilePausePlayingTest::Fsm(TMmfDevSoundEvent aDevSoundEvent, TInt aError)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4871
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4872
	switch (iDevSoundState)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4873
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4874
		case EStateCreated:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4875
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4876
			__ASSERT_ALWAYS((aError == KErrNone), Panic(_L("RA3FDevSoundToneVolumeWhilePausePlayingTest"), EFsmIncorrectErrorPassed));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4877
			if (aDevSoundEvent == EEventInitialize)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4878
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4879
				INFO_PRINTF1(_L("Calling CMMFDevSound::InitializeL"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4880
				TRAPD(err, iMMFDevSound->InitializeL(*this, EMMFStateTonePlaying));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4881
				if (err != KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4882
					{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4883
					ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"), err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4884
					StopTest(err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4885
					break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4886
					}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4887
				INFO_PRINTF1(_L("DevSound State: EStateInitializing"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4888
				iDevSoundState = EStateInitializing;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4889
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4890
			else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4891
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4892
				ERR_PRINTF2(_L("DevSound EEventInitialize not received as expected. Received event: %d"), aDevSoundEvent);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4893
				StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4894
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4895
			break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4896
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4897
		case EStateInitializing:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4898
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4899
			if (aDevSoundEvent == EEventInitComplete && aError == KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4900
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4901
				INFO_PRINTF3(_L("Calling CMMFDevSound::PlayToneL using %d Hz during %d secs "), iFrequencyTone1, iDuration);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4902
				TRAPD(err, iMMFDevSound->PlayToneL(iFrequencyTone1, iDuration*KMicroSecsInOneSec));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4903
				if (err != KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4904
					{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4905
					ERR_PRINTF2(_L("CMMFDevSound::PlayToneL left with error : %d!"), err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4906
					StopTest(err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4907
					break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4908
					}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4909
				StartTimer(KMicroSecsTwoSec);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4910
				INFO_PRINTF1(_L("DevSound State: EStatePlaying"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4911
				iDevSoundState = EStatePlaying;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4912
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4913
			else if (aDevSoundEvent == EEventInitComplete && aError != KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4914
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4915
				ERR_PRINTF2(_L("DevSound called CMMFDevSound::InitializeComplete with error = %d"), aError);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4916
				StopTest(aError);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4917
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4918
			else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4919
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4920
				ERR_PRINTF2(_L("DevSound EEventInitComplete not received as expected. Received event: %d"), aDevSoundEvent);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4921
				StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4922
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4923
			break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4924
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4925
		case EStatePlaying:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4926
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4927
			if(aDevSoundEvent == EEventTimerComplete)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4928
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4929
				INFO_PRINTF1(_L("Calling CMMFDevSound::Pause"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4930
				iMMFDevSound->Pause();
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4931
				INFO_PRINTF1(_L("DevSound State: EStatePause"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4932
				iDevSoundState = EStatePause;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4933
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4934
			else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4935
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4936
				ERR_PRINTF2(_L("DevSound EEventTimerComplete not received as expected. Received event: %d"), aDevSoundEvent);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4937
				StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4938
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4939
			break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4940
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4941
		case EStatePause:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4942
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4943
			if(aDevSoundEvent == EEventTimerComplete)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4944
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4945
				INFO_PRINTF1(_L("Calling CMMFDevSound::Volume"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4946
				TInt maxVolumeGet = iMMFDevSound->Volume();
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4947
				if (maxVolumeGet == iExVolume)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4948
					{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4949
					INFO_PRINTF2(_L("The device default supported volume value is %d."), maxVolumeGet);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4950
					StopTest();
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4951
					}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4952
				else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4953
					{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4954
					INFO_PRINTF2(_L("The device default supported volume value failed with %d."), maxVolumeGet);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4955
					ERR_PRINTF2(_L("Expected value = %d."), iExVolume);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4956
					StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4957
					}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4958
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4959
			else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4960
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4961
				ERR_PRINTF2(_L("DevSound EEventTimerComplete not received as expected. Received event: %d"), aDevSoundEvent);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4962
				StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4963
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4964
			break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4965
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4966
		default:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4967
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4968
			ERR_PRINTF2(_L("Invalid DevSound state received: %d"), iDevSoundState);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4969
			StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4970
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4971
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4972
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4973
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4974
void RA3FDevSoundToneVolumeWhilePausePlayingTest::DoTimerCallback()
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4975
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4976
	INFO_PRINTF1(_L("TimerEvent called"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4977
	if(!iTimeToEnterPauseElapsed)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4978
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4979
		iTimeToEnterPauseElapsed = ETrue;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4980
		INFO_PRINTF1(_L("DevSound Event: EEventTimerComplete"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4981
		Fsm(EEventTimerComplete, KErrNone);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4982
		iTimeToEnterPauseElapsed = ETrue;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4983
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4984
	else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4985
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4986
		iTimer->Cancel();
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4987
		INFO_PRINTF1(_L("DevSound Event: EEventTimerComplete"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4988
		Fsm(EEventTimerComplete, KErrNone);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4989
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4990
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4991
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4992
void RA3FDevSoundToneVolumeWhilePausePlayingTest::ToneFinished(TInt aError)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4993
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4994
	INFO_PRINTF1(_L("========== DevSound ToneFinished() callback =========="));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4995
	ERR_PRINTF1(_L("DevSound should not have called ToneFinished because it is supposed to be paused then stopped"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4996
	StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4997
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4998
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  4999
/*
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5000
 *========================================================================================================
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5001
 * MM-A3F-DEVSOUND-CHRTZ-TONE-0036
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5002
 */
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5003
RA3FDevSoundTonePlayToneOnceTest::RA3FDevSoundTonePlayToneOnceTest(const TDesC& aTestName)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5004
	:	RA3FDevSoundTestBase(aTestName), 
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5005
		iDuration(0), iFrequencyTone1(0)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5006
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5007
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5008
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5009
RA3FDevSoundTonePlayToneOnceTest* RA3FDevSoundTonePlayToneOnceTest::NewL(const TDesC& aTestName)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5010
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5011
	RA3FDevSoundTonePlayToneOnceTest * self = new(ELeave)RA3FDevSoundTonePlayToneOnceTest(aTestName);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5012
	return self;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5013
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5014
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5015
void RA3FDevSoundTonePlayToneOnceTest::DoKickoffTestL()
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5016
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5017
	if (!GetIntFromConfig(iTestStepName, KDuration, iDuration)) 
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5018
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5019
		ERR_PRINTF2(KMsgErrorGetParameter, &KDuration);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5020
		StopTest(KErrNotFound);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5021
		return;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5022
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5023
	if (!GetIntFromConfig(iTestStepName, KFrequencyTone1, iFrequencyTone1)) 
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5024
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5025
		ERR_PRINTF2(KMsgErrorGetParameter, &KFrequencyTone1);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5026
		StopTest(KErrNotFound);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5027
		return;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5028
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5029
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5030
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5031
void RA3FDevSoundTonePlayToneOnceTest::Fsm(TMmfDevSoundEvent aDevSoundEvent, TInt aError)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5032
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5033
	switch (iDevSoundState)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5034
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5035
		case EStateCreated:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5036
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5037
			__ASSERT_ALWAYS((aError == KErrNone), Panic(_L("RA3FDevSoundTonePlayToneOnceTest"), EFsmIncorrectErrorPassed));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5038
			if (aDevSoundEvent == EEventInitialize)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5039
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5040
				INFO_PRINTF1(_L("Calling CMMFDevSound::InitializeL"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5041
				TRAPD(err, iMMFDevSound->InitializeL(*this, EMMFStateTonePlaying));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5042
				if (err != KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5043
					{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5044
					ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"), err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5045
					StopTest(err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5046
					break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5047
					}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5048
				INFO_PRINTF1(_L("DevSound State: EStateInitializing"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5049
				iDevSoundState = EStateInitializing;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5050
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5051
			else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5052
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5053
				ERR_PRINTF2(_L("DevSound EEventInitialize not received as expected. Received event: %d"), aDevSoundEvent);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5054
				StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5055
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5056
			break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5057
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5058
		case EStateInitializing:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5059
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5060
			if (aDevSoundEvent == EEventInitComplete && aError == KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5061
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5062
				iMMFDevSound->SetVolume(iMMFDevSound->MaxVolume());
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5063
				INFO_PRINTF3(_L("Calling CMMFDevSound::PlayToneL using %d Hz  during %d secs "), iFrequencyTone1, iDuration);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5064
				iStartTime.HomeTime();
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5065
				TRAPD(err, iMMFDevSound->PlayToneL(iFrequencyTone1, iDuration*KMicroSecsInOneSec));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5066
				if (err != KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5067
					{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5068
					ERR_PRINTF2(_L("CMMFDevSound::PlayToneL failed with error : %d!"), err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5069
					StopTest(err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5070
					}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5071
				INFO_PRINTF1(_L("DevSound State: EStatePlaying"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5072
				iDevSoundState = EStatePlaying;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5073
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5074
			else if (aDevSoundEvent == EEventInitComplete && aError != KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5075
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5076
				ERR_PRINTF2(_L("DevSound called CMMFDevSound::InitializeComplete with error = %d"), aError);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5077
				StopTest(aError);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5078
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5079
			else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5080
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5081
				ERR_PRINTF2(_L("DevSound EEventInitComplete not received as expected. Received event: %d"), aDevSoundEvent);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5082
				StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5083
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5084
			break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5085
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5086
		default:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5087
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5088
			ERR_PRINTF2(_L("Invalid DevSound state received: %d"), iDevSoundState);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5089
			StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5090
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5091
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5092
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5093
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5094
void RA3FDevSoundTonePlayToneOnceTest::ToneFinished(TInt aError)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5095
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5096
	INFO_PRINTF1(_L("========== DevSound ToneFinished() callback =========="));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5097
	if (aError == KErrUnderflow)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5098
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5099
		iEndTime.HomeTime();
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5100
		iPlayToneTime = iEndTime.MicroSecondsFrom(iStartTime);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5101
		TInt totalExpectedReproductionTime = iDuration * KMicroSecsInOneSec;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5102
		if(iPlayToneTime < totalExpectedReproductionTime + KPlayVarianceTime && iPlayToneTime > totalExpectedReproductionTime - KPlayVarianceTime)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5103
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5104
			INFO_PRINTF2(_L("Play time is %Ld microseconds"), iPlayToneTime.Int64());
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5105
			StopTest();
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5106
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5107
		else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5108
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5109
			ERR_PRINTF3(_L("Play time is %Ld microseconds and it should have been %d microseconds"), iPlayToneTime.Int64(), totalExpectedReproductionTime);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5110
			StopTest(KErrNone, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5111
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5112
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5113
	else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5114
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5115
		ERR_PRINTF2(_L("DevSound called ToneFinished with error = %d"), aError);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5116
		ERR_PRINTF2(_L("Expected error = %d"), KErrUnderflow);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5117
		StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5118
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5119
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5120
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5121
/*
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5122
 *========================================================================================================
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5123
 * MM-A3F-DEVSOUND-CHRTZ-TONE-0037
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5124
 */
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5125
RA3FDevSoundTonePlayDualToneTest::RA3FDevSoundTonePlayDualToneTest(const TDesC& aTestName)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5126
	:	RA3FDevSoundTestBase(aTestName), 
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5127
		iDuration(0), iFrequencyTone1(0),
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5128
		iFrequencyTone2(0)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5129
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5130
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5131
RA3FDevSoundTonePlayDualToneTest* RA3FDevSoundTonePlayDualToneTest::NewL(const TDesC& aTestName)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5132
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5133
	RA3FDevSoundTonePlayDualToneTest * self = new(ELeave)RA3FDevSoundTonePlayDualToneTest(aTestName);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5134
	return self;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5135
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5136
void RA3FDevSoundTonePlayDualToneTest::DoKickoffTestL()
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5137
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5138
	if (!GetIntFromConfig(iTestStepName, KDuration, iDuration)) 
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5139
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5140
		ERR_PRINTF2(KMsgErrorGetParameter, &KDuration);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5141
		StopTest(KErrNotFound);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5142
		return;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5143
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5144
	if (!GetIntFromConfig(iTestStepName, KFrequencyTone1, iFrequencyTone1)) 
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5145
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5146
		ERR_PRINTF2(KMsgErrorGetParameter, &KFrequencyTone1);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5147
		StopTest(KErrNotFound);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5148
		return;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5149
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5150
	if (!GetIntFromConfig(iTestStepName, KFrequencyTone2, iFrequencyTone2)) 
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5151
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5152
		ERR_PRINTF2(KMsgErrorGetParameter, &KFrequencyTone2);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5153
		StopTest(KErrNotFound);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5154
		return;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5155
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5156
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5157
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5158
void RA3FDevSoundTonePlayDualToneTest::Fsm(TMmfDevSoundEvent aDevSoundEvent, TInt aError)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5159
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5160
	switch (iDevSoundState)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5161
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5162
		case EStateCreated:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5163
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5164
			__ASSERT_ALWAYS((aError == KErrNone), Panic(_L("RA3FDevSoundTonePlayDualToneTest"), EFsmIncorrectErrorPassed));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5165
			if (aDevSoundEvent == EEventInitialize)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5166
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5167
				INFO_PRINTF1(_L("Calling CMMFDevSound::InitializeL"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5168
				TRAPD(err, iMMFDevSound->InitializeL(*this, EMMFStateTonePlaying));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5169
				if (err != KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5170
					{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5171
					ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"), err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5172
					StopTest(err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5173
					break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5174
					}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5175
				INFO_PRINTF1(_L("DevSound State: EStateInitializing"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5176
				iDevSoundState = EStateInitializing;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5177
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5178
			else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5179
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5180
				ERR_PRINTF2(_L("DevSound EEventInitialize not received as expected. Received event: %d"), aDevSoundEvent);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5181
				StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5182
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5183
			break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5184
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5185
		case EStateInitializing:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5186
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5187
			if (aDevSoundEvent == EEventInitComplete && aError == KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5188
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5189
				iMMFDevSound->SetVolume(iMMFDevSound->MaxVolume());
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5190
				iStartTime.HomeTime();
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5191
				INFO_PRINTF4(_L("Calling CMMFDevSound::PlayDualToneL using %d Hz %d Hz during %d secs "), iFrequencyTone1, iFrequencyTone2, iDuration);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5192
				TRAPD(err, iMMFDevSound->PlayDualToneL(iFrequencyTone1, iFrequencyTone2, iDuration*KMicroSecsInOneSec));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5193
				if (err != KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5194
					{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5195
					ERR_PRINTF2(_L("CMMFDevSound::PlayDualToneL left with error : %d!"),  err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5196
					StopTest(err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5197
					break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5198
					}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5199
				INFO_PRINTF1(_L("DevSound State: EStatePlaying"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5200
				iDevSoundState = EStatePlaying;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5201
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5202
			else if (aDevSoundEvent == EEventInitComplete && aError != KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5203
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5204
				ERR_PRINTF2(_L("DevSound called CMMFDevSound::InitializeComplete with error = %d"), aError);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5205
				StopTest(aError);	
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5206
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5207
			else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5208
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5209
				ERR_PRINTF2(_L("DevSound EEventInitComplete not received as expected. Received event: %d"), aDevSoundEvent);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5210
				StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5211
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5212
			break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5213
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5214
		default:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5215
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5216
			ERR_PRINTF2(_L("Invalid DevSound state received: %d"), iDevSoundState);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5217
			StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5218
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5219
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5220
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5221
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5222
void RA3FDevSoundTonePlayDualToneTest::ToneFinished(TInt aError)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5223
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5224
	INFO_PRINTF1(_L("========== DevSound ToneFinished() callback =========="));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5225
	if (aError == KErrUnderflow)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5226
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5227
		iEndTime.HomeTime();
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5228
		iPlayToneTime = iEndTime.MicroSecondsFrom(iStartTime);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5229
		TInt totalExpectedReproductionTime = iDuration * KMicroSecsInOneSec;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5230
		if(iPlayToneTime < totalExpectedReproductionTime + KPlayVarianceTime && iPlayToneTime > totalExpectedReproductionTime - KPlayVarianceTime)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5231
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5232
			INFO_PRINTF2(_L("Play time is %Ld microseconds"), iPlayToneTime.Int64());
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5233
			StopTest();
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5234
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5235
		else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5236
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5237
			ERR_PRINTF3(_L("Play time is %Ld microseconds and it should have been %d microseconds"), iPlayToneTime.Int64(), totalExpectedReproductionTime);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5238
			StopTest(KErrNone, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5239
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5240
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5241
	else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5242
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5243
		ERR_PRINTF2(_L("DevSound called ToneFinished with error = %d"), aError);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5244
		ERR_PRINTF2(_L("Expected error = %d"), KErrUnderflow);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5245
		StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5246
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5247
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5248
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5249
/*
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5250
 *========================================================================================================
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5251
 * MM-A3F-DEVSOUND-CHRTZ-TONE-0038
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5252
 */
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5253
RA3FDevSoundTonePlayDTMFToneTest::RA3FDevSoundTonePlayDTMFToneTest(const TDesC& aTestName)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5254
	:	RA3FDevSoundTestBase(aTestName),iDTMFString(KNullDesC),
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5255
		iDTMFPauses(0), iDTMFTones(0)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5256
		
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5257
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5258
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5259
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5260
RA3FDevSoundTonePlayDTMFToneTest* RA3FDevSoundTonePlayDTMFToneTest::NewL(const TDesC& aTestName)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5261
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5262
	RA3FDevSoundTonePlayDTMFToneTest * self = new(ELeave)RA3FDevSoundTonePlayDTMFToneTest(aTestName);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5263
	return self;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5264
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5265
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5266
void RA3FDevSoundTonePlayDTMFToneTest::DoKickoffTestL()
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5267
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5268
	TPtrC DTMF;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5269
	if (!GetStringFromConfig(iTestStepName, KDTMFString, DTMF))
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5270
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5271
		ERR_PRINTF2(KMsgErrorGetParameter, &KDTMFString);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5272
		StopTest(KErrNotFound);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5273
		return;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5274
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5275
	iDTMFString.Copy(DTMF);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5276
	for(TInt i =0 ; i< iDTMFString.Length() ; i++)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5277
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5278
		if (iDTMFString[i] == ',')
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5279
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5280
			iDTMFPauses++;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5281
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5282
		else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5283
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5284
			iDTMFTones++;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5285
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5286
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5287
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5288
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5289
void RA3FDevSoundTonePlayDTMFToneTest::Fsm(TMmfDevSoundEvent aDevSoundEvent, TInt aError)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5290
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5291
	switch (iDevSoundState)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5292
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5293
		case EStateCreated:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5294
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5295
			__ASSERT_ALWAYS((aError == KErrNone), Panic(_L("RA3FDevSoundTonePlayDTMFToneTest"), EFsmIncorrectErrorPassed));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5296
			if (aDevSoundEvent == EEventInitialize)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5297
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5298
				INFO_PRINTF1(_L("Calling CMMFDevSound::InitializeL"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5299
				TRAPD(err, iMMFDevSound->InitializeL(*this, EMMFStateTonePlaying));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5300
				if (err != KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5301
					{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5302
					ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"),  err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5303
					StopTest(err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5304
					break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5305
					}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5306
				INFO_PRINTF1(_L("DevSound State: EStateInitializing"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5307
				iDevSoundState = EStateInitializing;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5308
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5309
			else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5310
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5311
				ERR_PRINTF2(_L("DevSound EEventInitialize not received as expected. Received event: %d"), aDevSoundEvent);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5312
				StopTest(aError,  EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5313
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5314
			break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5315
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5316
		case EStateInitializing:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5317
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5318
			if (aDevSoundEvent == EEventInitComplete && aError == KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5319
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5320
				iMMFDevSound->SetVolume(iMMFDevSound->MaxVolume());
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5321
				iStartTime.HomeTime();
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5322
				INFO_PRINTF2(_L("Calling CMMFDevSound::PlayDTMFStringL %S"), &iDTMFString);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5323
				TRAPD(err, iMMFDevSound->PlayDTMFStringL(iDTMFString));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5324
				if (err != KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5325
					{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5326
					ERR_PRINTF2(_L("CMMFDevSound::PlayDTMFStringL left with error : %d!"), err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5327
					StopTest(err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5328
					break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5329
					}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5330
				INFO_PRINTF1(_L("DevSound State: EStatePlaying"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5331
				iDevSoundState = EStatePlaying;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5332
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5333
			else if (aDevSoundEvent == EEventInitComplete && aError != KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5334
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5335
				ERR_PRINTF2(_L("DevSound called CMMFDevSound::InitializeComplete with error = %d"), aError);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5336
				StopTest(aError);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5337
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5338
			else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5339
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5340
				ERR_PRINTF2(_L("DevSound EEventInitComplete not received as expected. Received event: %d"), aDevSoundEvent);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5341
				StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5342
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5343
			break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5344
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5345
		default:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5346
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5347
			ERR_PRINTF2(_L("Invalid DevSound state received: %d"), iDevSoundState);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5348
			StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5349
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5350
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5351
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5352
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5353
void RA3FDevSoundTonePlayDTMFToneTest::ToneFinished(TInt aError)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5354
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5355
	INFO_PRINTF1(_L("========== DevSound ToneFinished() callback =========="));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5356
	if (aError == KErrUnderflow)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5357
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5358
		iEndTime.HomeTime();
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5359
		iPlayToneTime = iEndTime.MicroSecondsFrom(iStartTime);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5360
		TInt defaultToneOn = 250000;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5361
		TInt defaultToneOff = 50000;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5362
		TInt defaultPauseLength = 250000;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5363
		TInt totalExpectedReproductionTime = defaultToneOn*iDTMFTones + defaultToneOff * iDTMFTones + iDTMFPauses * defaultPauseLength;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5364
		if (iPlayToneTime < totalExpectedReproductionTime + KPlayVarianceTime && iPlayToneTime > totalExpectedReproductionTime - KPlayVarianceTime)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5365
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5366
			INFO_PRINTF2(_L("Play time is %Ld microseconds"), iPlayToneTime.Int64());
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5367
			StopTest();
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5368
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5369
		else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5370
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5371
			ERR_PRINTF2(_L("Calling CMMFDevSound::PlayDTMFStringL failed with %Ld"), iPlayToneTime.Int64());
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5372
			ERR_PRINTF2(_L("Expected time %d"), totalExpectedReproductionTime);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5373
			StopTest(KErrNone, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5374
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5375
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5376
	else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5377
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5378
		ERR_PRINTF2(_L("DevSound called ToneFinished with error = %d"), aError);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5379
		ERR_PRINTF2(_L("Expected error = %d"), KErrUnderflow);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5380
		StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5381
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5382
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5383
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5384
/*
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5385
 *========================================================================================================
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5386
 * MM-A3F-DEVSOUND-CHRTZ-TONE-0039
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5387
 */
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5388
RA3FDevSoundTonePlayToneSequenceTest::RA3FDevSoundTonePlayToneSequenceTest(const TDesC& aTestName)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5389
	:	RA3FDevSoundTestBase(aTestName)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5390
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5391
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5392
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5393
RA3FDevSoundTonePlayToneSequenceTest* RA3FDevSoundTonePlayToneSequenceTest::NewL(const TDesC& aTestName)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5394
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5395
	RA3FDevSoundTonePlayToneSequenceTest * self = new(ELeave)RA3FDevSoundTonePlayToneSequenceTest(aTestName);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5396
	return self;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5397
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5398
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5399
void RA3FDevSoundTonePlayToneSequenceTest::DoKickoffTestL()
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5400
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5401
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5402
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5403
void RA3FDevSoundTonePlayToneSequenceTest::Fsm(TMmfDevSoundEvent aDevSoundEvent, TInt aError)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5404
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5405
	switch(iDevSoundState)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5406
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5407
		case EStateCreated:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5408
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5409
			__ASSERT_ALWAYS((aError == KErrNone), Panic(_L("RA3FDevSoundTonePlayToneSequenceTest"), EFsmIncorrectErrorPassed));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5410
			if (aDevSoundEvent == EEventInitialize)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5411
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5412
				INFO_PRINTF1(_L("Calling MMFDevSound::InitializeL"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5413
				TRAPD(err, iMMFDevSound->InitializeL(*this,  EMMFStateTonePlaying));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5414
				if (err != KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5415
					{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5416
					ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"), err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5417
					StopTest(err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5418
					break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5419
					}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5420
				INFO_PRINTF1(_L("DevSound State: EStateInitializing"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5421
				iDevSoundState = EStateInitializing;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5422
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5423
			else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5424
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5425
				ERR_PRINTF2(_L("DevSound EEventInitialize not received as expected. Received event: %d"), aDevSoundEvent);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5426
				StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5427
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5428
			break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5429
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5430
		case EStateInitializing:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5431
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5432
			if (aDevSoundEvent == EEventInitComplete && aError == KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5433
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5434
				iMMFDevSound->SetVolume(iMMFDevSound->MaxVolume());
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5435
				TUint8* tablePointer = const_cast<TUint8*>(&(KFixedSequenceTestSequenceDataX[0])); 
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5436
				TPtrC8 KFixedSequenceData(tablePointer, sizeof(KFixedSequenceTestSequenceDataX));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5437
				INFO_PRINTF1(_L("Calling CMMFDevSound::PlayToneSequenceL"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5438
				TRAPD(err, iMMFDevSound->PlayToneSequenceL(KFixedSequenceData));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5439
				if (err != KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5440
					{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5441
					ERR_PRINTF2(_L("Play tone sequence failed with error = %d!"), err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5442
					StopTest(err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5443
					break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5444
					}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5445
				INFO_PRINTF1(_L("DevSound State: EStatePlaying"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5446
				iDevSoundState = EStatePlaying;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5447
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5448
			else if (aDevSoundEvent == EEventInitComplete && aError != KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5449
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5450
				ERR_PRINTF2(_L("DevSound called CMMFDevSound::InitializeComplete with error = %d"), aError);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5451
				StopTest(aError);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5452
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5453
			else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5454
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5455
				ERR_PRINTF2(_L("DevSound EEventInitComplete not received as expected. Received event: %d"), aDevSoundEvent);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5456
				StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5457
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5458
			break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5459
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5460
		default:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5461
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5462
			ERR_PRINTF2(_L("Invalid DevSound state received: %d"), iDevSoundState);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5463
			StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5464
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5465
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5466
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5467
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5468
/*
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5469
 *========================================================================================================
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5470
 * MM-A3F-DEVSOUND-CHRTZ-TONE-0040
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5471
 */
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5472
RA3FDevSoundToneNewToneRequestWhilePlayingTest::RA3FDevSoundToneNewToneRequestWhilePlayingTest(const TDesC& aTestName)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5473
	:	RA3FDevSoundTestBase(aTestName), 
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5474
		iDuration(0), iFrequencyTone1(0)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5475
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5476
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5477
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5478
RA3FDevSoundToneNewToneRequestWhilePlayingTest* RA3FDevSoundToneNewToneRequestWhilePlayingTest::NewL(const TDesC& aTestName)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5479
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5480
	RA3FDevSoundToneNewToneRequestWhilePlayingTest * self = new(ELeave)RA3FDevSoundToneNewToneRequestWhilePlayingTest(aTestName);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5481
	return self;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5482
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5483
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5484
void RA3FDevSoundToneNewToneRequestWhilePlayingTest::DoKickoffTestL()
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5485
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5486
	if (!GetIntFromConfig(iTestStepName, KDuration, iDuration)) 
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5487
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5488
		ERR_PRINTF2(KMsgErrorGetParameter, &KDuration);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5489
		StopTest(KErrNotFound);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5490
		return;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5491
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5492
	if (!GetIntFromConfig(iTestStepName, KFrequencyTone1, iFrequencyTone1)) 
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5493
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5494
		ERR_PRINTF2(KMsgErrorGetParameter, &KFrequencyTone1);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5495
		StopTest(KErrNotFound);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5496
		return;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5497
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5498
	iTimer = CPeriodic::NewL(CActive::EPriorityHigh);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5499
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5500
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5501
void RA3FDevSoundToneNewToneRequestWhilePlayingTest::Fsm(TMmfDevSoundEvent aDevSoundEvent, TInt aError)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5502
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5503
	switch (iDevSoundState)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5504
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5505
		case EStateCreated:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5506
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5507
			if (aDevSoundEvent == EEventInitialize)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5508
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5509
				__ASSERT_ALWAYS((aError == KErrNone), Panic(_L("RA3FDevSoundToneNewToneRequestWhilePlayingTest"), EFsmIncorrectErrorPassed));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5510
				INFO_PRINTF1(_L("Calling CMMFDevSound::InitializeL"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5511
				TRAPD(err, iMMFDevSound->InitializeL(*this, EMMFStateTonePlaying));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5512
				if (err != KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5513
					{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5514
					ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"), err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5515
					StopTest(err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5516
					break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5517
					}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5518
				INFO_PRINTF1(_L("DevSound State: EStateInitializing"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5519
				iDevSoundState = EStateInitializing;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5520
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5521
			else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5522
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5523
				ERR_PRINTF2(_L("DevSound EEventInitialize not received as expected. Received event: %d"), aDevSoundEvent);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5524
				StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5525
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5526
			break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5527
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5528
		case EStateInitializing:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5529
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5530
			if (aDevSoundEvent == EEventInitComplete && aError == KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5531
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5532
				iMMFDevSound->SetVolume(iMMFDevSound->MaxVolume());
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5533
				iStartTime.HomeTime();
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5534
				INFO_PRINTF3(_L("Calling CMMFDevSound::PlayToneL using %d Hz during %d secs "), iFrequencyTone1, iDuration);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5535
				TRAPD(err, iMMFDevSound->PlayToneL(iFrequencyTone1, iDuration*KMicroSecsInOneSec));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5536
				if (err != KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5537
					{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5538
					ERR_PRINTF2(_L("CMMFDevSound::PlayToneL left with error : %d!"), err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5539
					StopTest(err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5540
					break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5541
					}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5542
				StartTimer(KMicroSecsTwoSec);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5543
				INFO_PRINTF1(_L("DevSound State: EStatePlaying"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5544
				iDevSoundState = EStatePlaying;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5545
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5546
			else if (aDevSoundEvent == EEventInitComplete && aError != KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5547
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5548
				ERR_PRINTF2(_L("DevSound called CMMFDevSound::InitializeComplete with error = %d"), aError);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5549
				StopTest(aError);	
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5550
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5551
			else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5552
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5553
				ERR_PRINTF2(_L("DevSound EEventInitComplete not received as expected. Received event: %d"), aDevSoundEvent);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5554
				StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5555
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5556
			break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5557
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5558
		case EStatePlaying:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5559
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5560
			if(aDevSoundEvent == EEventTimerComplete)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5561
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5562
				INFO_PRINTF3(_L("Calling CMMFDevSound::PlayToneL using %d Hz during %d secs "), iFrequencyTone1, iDuration);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5563
				TRAPD(err, iMMFDevSound->PlayToneL(iFrequencyTone1, iDuration*KMicroSecsInOneSec));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5564
				if (err == KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5565
					{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5566
					INFO_PRINTF2(_L("CMMFDevSound::PlayToneL left with the expected error = %d"), err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5567
					}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5568
				else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5569
					{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5570
					ERR_PRINTF2(_L("CMMFDevSound::PlayToneL left with error = %d"), err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5571
					ERR_PRINTF2(_L("Expected error value = %d!"), KErrNotReady);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5572
					StopTest(err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5573
					break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5574
					}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5575
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5576
			break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5577
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5578
		default:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5579
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5580
			ERR_PRINTF2(_L("Invalid DevSound state received: %d"), iDevSoundState);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5581
			StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5582
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5583
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5584
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5585
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5586
void RA3FDevSoundToneNewToneRequestWhilePlayingTest::DoTimerCallback()
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5587
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5588
	INFO_PRINTF1(_L("TimerEvent called"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5589
	iTimer->Cancel();
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5590
	INFO_PRINTF1(_L("DevSound Event: EEventTimerComplete"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5591
	Fsm(EEventTimerComplete, KErrNone);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5592
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5593
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5594
void RA3FDevSoundToneNewToneRequestWhilePlayingTest::ToneFinished(TInt aError)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5595
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5596
	INFO_PRINTF1(_L("========== DevSound ToneFinished() callback =========="));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5597
	if (aError == KErrUnderflow)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5598
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5599
		iEndTime.HomeTime();
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5600
		iPlayToneTime = iEndTime.MicroSecondsFrom(iStartTime);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5601
		TInt totalExpectedReproductionTime = iDuration * KMicroSecsInOneSec;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5602
		if(iPlayToneTime < totalExpectedReproductionTime + KPlayVarianceTime && iPlayToneTime > totalExpectedReproductionTime - KPlayVarianceTime)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5603
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5604
			INFO_PRINTF2(_L("Play time is %Ld microseconds"), iPlayToneTime.Int64());
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5605
			StopTest();
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5606
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5607
		else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5608
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5609
			ERR_PRINTF3(_L("Play time is %Ld microseconds and it should have been %d microseconds"), iPlayToneTime.Int64(), totalExpectedReproductionTime);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5610
			StopTest(KErrNone, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5611
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5612
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5613
	else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5614
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5615
		ERR_PRINTF2(_L("DevSound called ToneFinished with error = %d"), aError);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5616
		ERR_PRINTF2(_L("Expected error = %d"), KErrUnderflow);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5617
		StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5618
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5619
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5620
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5621
/*
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5622
 *========================================================================================================
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5623
 * MM-A3F-DEVSOUND-CHRTZ-TONE-0041
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5624
 */
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5625
RA3FDevSoundTonePreemptionTest::RA3FDevSoundTonePreemptionTest(const TDesC& aTestName)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5626
	:	RA3FDevSoundTestBase(aTestName), 
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5627
		iDuration(0), iFrequencyTone1(0)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5628
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5629
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5630
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5631
RA3FDevSoundTonePreemptionTest* RA3FDevSoundTonePreemptionTest::NewL(const TDesC& aTestName)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5632
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5633
	RA3FDevSoundTonePreemptionTest * self = new(ELeave)RA3FDevSoundTonePreemptionTest(aTestName);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5634
	return self;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5635
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5636
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5637
void RA3FDevSoundTonePreemptionTest::DoKickoffTestL()
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5638
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5639
	if (!GetIntFromConfig(iTestStepName, KDuration, iDuration)) 
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5640
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5641
		ERR_PRINTF2(KMsgErrorGetParameter, &KDuration);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5642
		StopTest(KErrNotFound);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5643
		return;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5644
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5645
	if (!GetIntFromConfig(iTestStepName, KFrequencyTone1, iFrequencyTone1)) 
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5646
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5647
		ERR_PRINTF2(KMsgErrorGetParameter, &KFrequencyTone1);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5648
		StopTest(KErrNotFound);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5649
		return;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5650
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5651
	iTimer = CPeriodic::NewL(CActive::EPriorityHigh);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5652
	iDevsoundToneClient = CA3FDevSoundToneClient::NewL(*this);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5653
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5654
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5655
void RA3FDevSoundTonePreemptionTest::Fsm(TMmfDevSoundEvent aDevSoundEvent, TInt aError)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5656
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5657
	switch (iDevSoundState)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5658
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5659
		case EStateCreated:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5660
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5661
			if (aDevSoundEvent == EEventInitialize)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5662
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5663
				__ASSERT_ALWAYS((aError == KErrNone), Panic(_L("RA3FDevSoundTonePreemptionTest"), EFsmIncorrectErrorPassed));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5664
				INFO_PRINTF1(_L("Calling CMMFDevSound::InitializeL"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5665
				TRAPD(err, iMMFDevSound->InitializeL(*this, EMMFStateTonePlaying));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5666
				if (err != KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5667
					{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5668
					ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"), err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5669
					StopTest(err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5670
					break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5671
					}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5672
				INFO_PRINTF1(_L("DevSound State: EStateInitializing"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5673
				iDevSoundState = EStateInitializing;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5674
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5675
			else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5676
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5677
				ERR_PRINTF2(_L("DevSound EEventInitialize not received as expected. Received event: %d"), aDevSoundEvent);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5678
				StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5679
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5680
			break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5681
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5682
		case EStateInitializing:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5683
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5684
			if (aDevSoundEvent == EEventInitComplete && aError == KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5685
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5686
				iMMFDevSound->SetVolume(iMMFDevSound->MaxVolume());
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5687
				TMMFPrioritySettings prioritySettings;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5688
				prioritySettings.iPriority = KMinimumPriority;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5689
				prioritySettings.iPref = EMdaPriorityPreferenceTime;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5690
				prioritySettings.iState = EMMFStateIdle;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5691
				iMMFDevSound->SetPrioritySettings(prioritySettings);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5692
				INFO_PRINTF3(_L("Calling CMMFDevSound::PlayToneL using %d Hz during %d secs "), iFrequencyTone1, iDuration);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5693
				TRAPD(err, iMMFDevSound->PlayToneL(iFrequencyTone1, iDuration*KMicroSecsInOneSec));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5694
				if (err != KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5695
					{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5696
					ERR_PRINTF2(_L("CMMFDevSound::PlayToneL left with error : %d!"), err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5697
					StopTest(err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5698
					break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5699
					}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5700
				StartTimer(KMicroSecsTwoSec);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5701
				INFO_PRINTF1(_L("DevSound State: EStatePlaying"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5702
				iDevSoundState = EStatePlaying;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5703
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5704
			else if (aDevSoundEvent == EEventInitComplete && aError != KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5705
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5706
				ERR_PRINTF2(_L("DevSound called CMMFDevSound::InitializeComplete with error = %d"), aError);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5707
				StopTest(aError);	
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5708
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5709
			else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5710
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5711
				ERR_PRINTF2(_L("DevSound EEventInitComplete not received as expected. Received event: %d"), aDevSoundEvent);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5712
				StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5713
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5714
			break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5715
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5716
		case EStatePlaying:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5717
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5718
			if(aDevSoundEvent == EEventTimerComplete)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5719
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5720
				INFO_PRINTF1(_L("Starting lower priority devsound client"));	
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5721
				iDevsoundToneClient->SetPriority(KMaximumPriority);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5722
				TInt err = iDevsoundToneClient->InitTonePlay(iFrequencyTone1, iDuration*KMicroSecsInOneSec);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5723
				if(err != KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5724
					{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5725
					ERR_PRINTF1(_L("Initialization to play tone thru second devsound client failed"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5726
					StopTest(err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5727
					}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5728
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5729
			break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5730
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5731
		default:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5732
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5733
			ERR_PRINTF2(_L("Invalid DevSound state received: %d"), iDevSoundState);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5734
			StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5735
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5736
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5737
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5738
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5739
void RA3FDevSoundTonePreemptionTest::DoTimerCallback()
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5740
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5741
	INFO_PRINTF1(_L("TimerEvent called"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5742
	iTimer->Cancel();
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5743
	INFO_PRINTF1(_L("DevSound Event: EEventTimerComplete"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5744
	Fsm(EEventTimerComplete, KErrNone);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5745
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5746
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5747
void RA3FDevSoundTonePreemptionTest::ToneFinished(TInt aError)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5748
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5749
	INFO_PRINTF1(_L("========== DevSound ToneFinished() callback =========="));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5750
	if (aError == KErrInUse || aError == KErrDied || aError == KErrAccessDenied)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5751
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5752
		INFO_PRINTF1(_L("========== Preempting 1st DevSound Instance=========="));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5753
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5754
	else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5755
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5756
		ERR_PRINTF2(_L("First DevSound client called ToneFinished() and failed with error = %d "), aError);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5757
		ERR_PRINTF4(_L("Expected posibilities %d %d %d "), KErrInUse, KErrDied, KErrAccessDenied);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5758
		StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5759
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5760
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5761
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5762
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5763
void RA3FDevSoundTonePreemptionTest::ClientInitializeCompleteCallback(TInt aError)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5764
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5765
	INFO_PRINTF1(_L("========== Second Client DevSound InitializeComplete() callback =========="));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5766
	if (aError != KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5767
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5768
		ERR_PRINTF2(_L("Second Devsound InitializeComplete received an error = %d"), aError);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5769
		StopTest(aError);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5770
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5771
	else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5772
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5773
		INFO_PRINTF1(_L("Starting to play audio thru second devsound client"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5774
		TInt err = iDevsoundToneClient->PlayTone();
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5775
		if (err != KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5776
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5777
			ERR_PRINTF2(_L("Starting to play tones thru second devsound client left with error = %d"), err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5778
			StopTest(err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5779
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5780
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5781
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5782
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5783
void RA3FDevSoundTonePreemptionTest::ClientToneFinishedCallback(TInt aError)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5784
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5785
	INFO_PRINTF1(_L("========== DevSound ToneFinished() callback =========="));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5786
		if (aError == KErrUnderflow)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5787
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5788
			INFO_PRINTF2(_L("Second DevSound instance called ToneFinished with error = %d"), aError);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5789
			StopTest(aError,EPass);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5790
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5791
		else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5792
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5793
			ERR_PRINTF2(_L("Second DevSound instance called ToneFinished with error = %d that was NOT expected"), aError);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5794
			ERR_PRINTF2(_L("Expected error = %d"), aError);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5795
			StopTest(aError);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5796
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5797
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5798
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5799
/*
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5800
 *========================================================================================================
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5801
 * MM-A3F-DEVSOUND-CHRTZ-TONE-0042
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5802
 */
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5803
RA3FDevSoundToneRejectionTest::RA3FDevSoundToneRejectionTest(const TDesC& aTestName)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5804
	:	RA3FDevSoundTestBase(aTestName), 
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5805
		iDuration(0), iFrequencyTone1(0)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5806
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5807
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5808
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5809
RA3FDevSoundToneRejectionTest* RA3FDevSoundToneRejectionTest::NewL(const TDesC& aTestName)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5810
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5811
	RA3FDevSoundToneRejectionTest * self = new(ELeave)RA3FDevSoundToneRejectionTest(aTestName);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5812
	return self;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5813
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5814
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5815
void RA3FDevSoundToneRejectionTest::DoKickoffTestL()
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5816
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5817
	if (!GetIntFromConfig(iTestStepName, KDuration, iDuration)) 
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5818
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5819
		ERR_PRINTF2(KMsgErrorGetParameter, &KDuration);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5820
		StopTest(KErrNotFound);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5821
		return;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5822
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5823
	if (!GetIntFromConfig(iTestStepName, KFrequencyTone1, iFrequencyTone1)) 
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5824
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5825
		ERR_PRINTF2(KMsgErrorGetParameter, &KFrequencyTone1);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5826
		StopTest(KErrNotFound);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5827
		return;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5828
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5829
	iTimer = CPeriodic::NewL(CActive::EPriorityHigh);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5830
	iDevsoundToneClient = CA3FDevSoundToneClient::NewL(*this);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5831
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5832
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5833
void RA3FDevSoundToneRejectionTest::Fsm(TMmfDevSoundEvent aDevSoundEvent, TInt aError)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5834
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5835
	switch (iDevSoundState)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5836
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5837
		case EStateCreated:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5838
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5839
			if (aDevSoundEvent == EEventInitialize)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5840
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5841
				__ASSERT_ALWAYS((aError == KErrNone), Panic(_L("RA3FDevSoundToneRejectionTest"), EFsmIncorrectErrorPassed));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5842
				INFO_PRINTF1(_L("Calling CMMFDevSound::InitializeL"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5843
				TRAPD(err, iMMFDevSound->InitializeL(*this, EMMFStateTonePlaying));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5844
				if (err != KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5845
					{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5846
					ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"), err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5847
					StopTest(err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5848
					break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5849
					}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5850
				INFO_PRINTF1(_L("DevSound State: EStateInitializing"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5851
				iDevSoundState = EStateInitializing;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5852
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5853
			else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5854
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5855
				ERR_PRINTF2(_L("DevSound EEventInitialize not received as expected. Received event: %d"), aDevSoundEvent);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5856
				StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5857
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5858
			break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5859
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5860
		case EStateInitializing:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5861
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5862
			if (aDevSoundEvent == EEventInitComplete && aError == KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5863
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5864
				iMMFDevSound->SetVolume(iMMFDevSound->MaxVolume());
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5865
				TMMFPrioritySettings prioritySettings;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5866
				prioritySettings.iPriority = KMinimumPriority;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5867
				prioritySettings.iPref = EMdaPriorityPreferenceTime;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5868
				prioritySettings.iState = EMMFStateIdle;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5869
				iMMFDevSound->SetPrioritySettings(prioritySettings);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5870
				INFO_PRINTF3(_L("Calling CMMFDevSound::PlayToneL using %d Hz during %d secs "), iFrequencyTone1, iDuration);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5871
				TRAPD(err, iMMFDevSound->PlayToneL(iFrequencyTone1, iDuration*KMicroSecsInOneSec));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5872
				if (err != KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5873
					{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5874
					ERR_PRINTF2(_L("CMMFDevSound::PlayToneL left with error : %d!"), err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5875
					StopTest(err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5876
					break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5877
					}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5878
				StartTimer(KMicroSecsTwoSec);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5879
				INFO_PRINTF1(_L("DevSound State: EStatePlaying"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5880
				iDevSoundState = EStatePlaying;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5881
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5882
			else if (aDevSoundEvent == EEventInitComplete && aError != KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5883
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5884
				ERR_PRINTF2(_L("DevSound called CMMFDevSound::InitializeComplete with error = %d"), aError);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5885
				StopTest(aError);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5886
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5887
			else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5888
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5889
				ERR_PRINTF2(_L("DevSound EEventInitComplete not received as expected. Received event: %d"), aDevSoundEvent);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5890
				StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5891
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5892
			break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5893
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5894
		case EStatePlaying:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5895
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5896
			if(aDevSoundEvent == EEventTimerComplete)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5897
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5898
				INFO_PRINTF1(_L("Starting lower priority devsound client"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5899
				iDevsoundToneClient->SetPriority(KMinimumPriority);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5900
				TInt err = iDevsoundToneClient->InitTonePlay(iFrequencyTone1, iDuration*KMicroSecsInOneSec);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5901
				if(err != KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5902
					{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5903
					ERR_PRINTF1(_L("Initialization to play tone thru second devsound client failed"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5904
					StopTest(err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5905
					}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5906
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5907
			break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5908
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5909
		default:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5910
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5911
			ERR_PRINTF2(_L("Invalid DevSound state received: %d"), iDevSoundState);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5912
			StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5913
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5914
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5915
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5916
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5917
void RA3FDevSoundToneRejectionTest::DoTimerCallback()
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5918
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5919
	INFO_PRINTF1(_L("TimerEvent called"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5920
	iTimer->Cancel();
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5921
	INFO_PRINTF1(_L("DevSound Event: EEventTimerComplete"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5922
	Fsm(EEventTimerComplete, KErrNone);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5923
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5924
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5925
void RA3FDevSoundToneRejectionTest::ToneFinished(TInt aError)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5926
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5927
	INFO_PRINTF1(_L("========== DevSound ToneFinished() callback =========="));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5928
	if (aError == KErrUnderflow)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5929
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5930
		INFO_PRINTF2(_L("First DevSound instance called ToneFinished with error = %d"), aError);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5931
		StopTest(aError,EPass);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5932
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5933
	else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5934
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5935
		ERR_PRINTF2(_L("First DevSound instance called ToneFinished with error = %d that was NOT expected"), aError);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5936
		ERR_PRINTF2(_L("Expected error = %d"), aError);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5937
		StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5938
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5939
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5940
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5941
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5942
void RA3FDevSoundToneRejectionTest::ClientInitializeCompleteCallback(TInt aError)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5943
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5944
	INFO_PRINTF1(_L("========== Second Client DevSound InitializeComplete() callback =========="));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5945
	if (aError != KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5946
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5947
		ERR_PRINTF2(_L("Second Devsound InitializeComplete received an error = %d"), aError);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5948
		StopTest(aError);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5949
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5950
	else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5951
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5952
		INFO_PRINTF1(_L("Starting to play audio thru second devsound client"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5953
		TInt err = iDevsoundToneClient->PlayTone();
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5954
		if (err != KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5955
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5956
			ERR_PRINTF2(_L("Starting to play tones thru second devsound client left with error = %d"), err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5957
			StopTest(err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5958
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5959
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5960
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5961
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5962
void RA3FDevSoundToneRejectionTest::ClientToneFinishedCallback(TInt aError)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5963
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5964
	INFO_PRINTF1(_L("========== DevSound ToneFinished() callback =========="));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5965
	if (aError == KErrInUse || aError == KErrDied || aError == KErrAccessDenied)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5966
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5967
		INFO_PRINTF1(_L("========== Rejection 2nd DevSound Instance=========="));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5968
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5969
	else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5970
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5971
		ERR_PRINTF2(_L("Second DevSound client called ToneFinished() and failed with error = %d "), aError);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5972
		ERR_PRINTF4(_L("Expected posibilities %d %d %d "), KErrInUse, KErrDied, KErrAccessDenied);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5973
		StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5974
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5975
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5976
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5977
/*
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5978
 *========================================================================================================
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5979
 * MM-A3F-DEVSOUND-CHRTZ-TONE-0043
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5980
 */
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5981
RA3FDevSoundTonePlayToneOnceAndStopTest::RA3FDevSoundTonePlayToneOnceAndStopTest(const TDesC& aTestName)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5982
	:	RA3FDevSoundTestBase(aTestName), 
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5983
		iDuration(0), iFrequencyTone1(0),
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5984
		iToneStopped(EFalse)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5985
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5986
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5987
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5988
RA3FDevSoundTonePlayToneOnceAndStopTest* RA3FDevSoundTonePlayToneOnceAndStopTest::NewL(const TDesC& aTestName)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5989
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5990
	RA3FDevSoundTonePlayToneOnceAndStopTest * self = new(ELeave)RA3FDevSoundTonePlayToneOnceAndStopTest(aTestName);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5991
	return self;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5992
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5993
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5994
void RA3FDevSoundTonePlayToneOnceAndStopTest::DoKickoffTestL()
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5995
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5996
	if (!GetIntFromConfig(iTestStepName, KDuration, iDuration)) 
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5997
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5998
		ERR_PRINTF2(KMsgErrorGetParameter, &KDuration);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  5999
		StopTest(KErrNotFound);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6000
		return;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6001
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6002
	if (!GetIntFromConfig(iTestStepName, KFrequencyTone1, iFrequencyTone1)) 
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6003
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6004
		ERR_PRINTF2(KMsgErrorGetParameter, &KFrequencyTone1);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6005
		StopTest(KErrNotFound);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6006
		return;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6007
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6008
	iTimer = CPeriodic::NewL(CActive::EPriorityHigh);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6009
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6010
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6011
void RA3FDevSoundTonePlayToneOnceAndStopTest::Fsm(TMmfDevSoundEvent aDevSoundEvent, TInt aError)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6012
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6013
	switch (iDevSoundState)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6014
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6015
		case EStateCreated:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6016
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6017
			__ASSERT_ALWAYS((aError == KErrNone), Panic(_L("RA3FDevSoundTonePlayToneOnceAndStopTest"), EFsmIncorrectErrorPassed));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6018
			if (aDevSoundEvent == EEventInitialize)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6019
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6020
				INFO_PRINTF1(_L("Calling CMMFDevSound::InitializeL"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6021
				TRAPD(err, iMMFDevSound->InitializeL(*this,  EMMFStateTonePlaying));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6022
				if (err != KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6023
					{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6024
					ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"),  err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6025
					StopTest(err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6026
					break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6027
					}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6028
				INFO_PRINTF1(_L("DevSound State: EStateInitializing"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6029
				iDevSoundState = EStateInitializing;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6030
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6031
			else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6032
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6033
				ERR_PRINTF2(_L("DevSound EEventInitialize not received as expected. Received event: %d"), aDevSoundEvent);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6034
				StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6035
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6036
			break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6037
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6038
		case EStateInitializing:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6039
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6040
			if (aDevSoundEvent == EEventInitComplete && aError == KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6041
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6042
				if (!iToneStopped)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6043
					{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6044
					iMMFDevSound->SetVolume(iMMFDevSound->MaxVolume());
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6045
					INFO_PRINTF3(_L("Calling CMMFDevSound::PlayToneL using %d Hz during %d secs "), iFrequencyTone1, iDuration);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6046
					TRAPD(err, iMMFDevSound->PlayToneL(iFrequencyTone1, iDuration*KMicroSecsInOneSec));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6047
					if (err != KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6048
						{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6049
						ERR_PRINTF2(_L("CMMFDevSound::PlayToneL left with error : %d!"), err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6050
						StopTest(err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6051
						break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6052
						}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6053
					StartTimer(KMicroSecsTwoSec);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6054
					INFO_PRINTF1(_L("DevSound State: EStatePlaying"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6055
					iDevSoundState = EStatePlaying;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6056
					}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6057
				else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6058
					{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6059
					INFO_PRINTF1(_L("Calling CMMFDevSound::Stop succeeded"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6060
					StopTest(aError);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6061
					}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6062
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6063
			else if (aDevSoundEvent == EEventInitComplete && aError != KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6064
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6065
				ERR_PRINTF2(_L("DevSound called CMMFDevSound::InitializeComplete with error = %d"), aError);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6066
				StopTest(aError);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6067
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6068
			else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6069
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6070
				ERR_PRINTF2(_L("DevSound EEventInitComplete not received as expected. Received event: %d"), aDevSoundEvent);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6071
				StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6072
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6073
			break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6074
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6075
		case EStatePlaying:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6076
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6077
			if(aDevSoundEvent == EEventTimerComplete)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6078
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6079
				INFO_PRINTF1(_L("Calling CMMFDevSound::Stop"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6080
				iMMFDevSound->Stop();
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6081
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6082
			else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6083
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6084
				ERR_PRINTF2(_L("DevSound EEventTimerComplete not received as expected. Received event: %d"), aDevSoundEvent);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6085
				StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6086
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6087
			break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6088
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6089
		default:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6090
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6091
			ERR_PRINTF2(_L("Invalid DevSound state received: %d"), iDevSoundState);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6092
			StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6093
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6094
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6095
	
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6096
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6097
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6098
void RA3FDevSoundTonePlayToneOnceAndStopTest::DoTimerCallback()
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6099
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6100
	INFO_PRINTF1(_L("TimerEvent called"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6101
	INFO_PRINTF1(_L("DevSound Event: EEventTimerComplete"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6102
	if(!iToneStopped)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6103
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6104
		Fsm(EEventTimerComplete, KErrNone); 
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6105
		iToneStopped = ETrue;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6106
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6107
	else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6108
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6109
		iTimer->Cancel();
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6110
		INFO_PRINTF1(_L("Calling CMMFDevSound::InitializeL"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6111
		TRAPD(err, iMMFDevSound->InitializeL(*this, EMMFStateTonePlaying));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6112
		if (err != KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6113
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6114
			ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"),  err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6115
			ERR_PRINTF2(_L("Expected error = %d"), KErrNone);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6116
			StopTest(err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6117
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6118
		INFO_PRINTF1(_L("DevSound State: EStateInitializing"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6119
		iDevSoundState = EStateInitializing;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6120
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6121
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6122
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6123
void RA3FDevSoundTonePlayToneOnceAndStopTest::ToneFinished(TInt aError)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6124
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6125
	INFO_PRINTF1(_L("========== DevSound ToneFinished() callback =========="));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6126
	ERR_PRINTF1(_L("DevSound should not have called ToneFinished because it is supposed to have been stopped"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6127
	StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6128
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6129
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6130
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6131
/*
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6132
 *========================================================================================================
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6133
 * MM-A3F-DEVSOUND-CHRTZ-TONE-0044
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6134
 */
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6135
RA3FDevSoundTonePlayDualToneOnceAndStopTest::RA3FDevSoundTonePlayDualToneOnceAndStopTest(const TDesC& aTestName)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6136
	:	RA3FDevSoundTestBase(aTestName), 
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6137
		iDuration(0), iFrequencyTone1(0),
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6138
		iFrequencyTone2(0), iToneStopped(EFalse)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6139
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6140
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6141
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6142
RA3FDevSoundTonePlayDualToneOnceAndStopTest* RA3FDevSoundTonePlayDualToneOnceAndStopTest::NewL(const TDesC& aTestName)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6143
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6144
	RA3FDevSoundTonePlayDualToneOnceAndStopTest * self = new(ELeave)RA3FDevSoundTonePlayDualToneOnceAndStopTest(aTestName);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6145
	return self;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6146
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6147
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6148
void RA3FDevSoundTonePlayDualToneOnceAndStopTest::DoKickoffTestL()
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6149
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6150
	if (!GetIntFromConfig(iTestStepName, KDuration, iDuration)) 
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6151
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6152
		ERR_PRINTF2(KMsgErrorGetParameter, &KDuration);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6153
		StopTest(KErrNotFound);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6154
		return;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6155
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6156
	if (!GetIntFromConfig(iTestStepName, KFrequencyTone1, iFrequencyTone1)) 
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6157
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6158
		ERR_PRINTF2(KMsgErrorGetParameter, &KFrequencyTone1);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6159
		StopTest(KErrNotFound);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6160
		return;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6161
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6162
	if (!GetIntFromConfig(iTestStepName, KFrequencyTone2, iFrequencyTone2)) 
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6163
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6164
		ERR_PRINTF2(KMsgErrorGetParameter, &KFrequencyTone2);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6165
		StopTest(KErrNotFound);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6166
		return;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6167
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6168
	iTimer = CPeriodic::NewL(CActive::EPriorityHigh);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6169
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6170
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6171
void RA3FDevSoundTonePlayDualToneOnceAndStopTest::Fsm(TMmfDevSoundEvent aDevSoundEvent, TInt aError)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6172
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6173
	switch (iDevSoundState)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6174
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6175
		case EStateCreated:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6176
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6177
			__ASSERT_ALWAYS((aError == KErrNone), Panic(_L("RA3FDevSoundTonePlayDualToneOnceAndStopTest"), EFsmIncorrectErrorPassed));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6178
			if (aDevSoundEvent == EEventInitialize)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6179
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6180
				INFO_PRINTF1(_L("Calling CMMFDevSound::InitializeL"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6181
				TRAPD(err, iMMFDevSound->InitializeL(*this, EMMFStateTonePlaying));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6182
				if (err != KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6183
					{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6184
					ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"),  err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6185
					StopTest(err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6186
					break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6187
					}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6188
				INFO_PRINTF1(_L("DevSound State: EStateInitializing"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6189
				iDevSoundState = EStateInitializing;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6190
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6191
			else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6192
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6193
				ERR_PRINTF2(_L("DevSound EEventInitialize not received as expected. Received event: %d"), aDevSoundEvent);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6194
				StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6195
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6196
			break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6197
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6198
		case EStateInitializing:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6199
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6200
			if (aDevSoundEvent == EEventInitComplete && aError == KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6201
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6202
				if (!iToneStopped)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6203
					{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6204
					iMMFDevSound->SetVolume(iMMFDevSound->MaxVolume());
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6205
					INFO_PRINTF4(_L("Calling CMMFDevSound::PlayDualToneL using %d Hz %d Hz during %d secs "), iFrequencyTone1, iFrequencyTone2, iDuration);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6206
					TRAPD(err, iMMFDevSound->PlayDualToneL(iFrequencyTone1, iFrequencyTone2, iDuration*KMicroSecsInOneSec));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6207
					if (err != KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6208
						{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6209
						ERR_PRINTF2(_L("CMMFDevSound::PlayDualToneL left with error = %d!"),  err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6210
						StopTest(err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6211
						break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6212
						}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6213
					StartTimer(KMicroSecsTwoSec);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6214
					INFO_PRINTF1(_L("DevSound State: EStatePlaying"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6215
					iDevSoundState = EStatePlaying;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6216
					}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6217
				else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6218
					{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6219
					INFO_PRINTF1(_L("Calling CMMFDevSound::Stop succeeded"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6220
					StopTest(aError);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6221
					}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6222
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6223
			else if (aDevSoundEvent == EEventInitComplete && aError != KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6224
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6225
				ERR_PRINTF2(_L("DevSound called CMMFDevSound::InitializeComplete with error = %d"), aError);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6226
				StopTest(aError);	
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6227
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6228
			else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6229
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6230
				ERR_PRINTF2(_L("DevSound EEventInitComplete not received as expected. Received event: %d"), aDevSoundEvent);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6231
				StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6232
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6233
			break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6234
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6235
		case EStatePlaying:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6236
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6237
			if(aDevSoundEvent == EEventTimerComplete)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6238
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6239
				INFO_PRINTF1(_L("Calling CMMFDevSound::Stop"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6240
				iMMFDevSound->Stop();
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6241
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6242
			else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6243
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6244
				ERR_PRINTF2(_L("DevSound EEventTimerComplete not received as expected. Received event: %d"), aDevSoundEvent);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6245
				StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6246
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6247
			break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6248
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6249
		default:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6250
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6251
			ERR_PRINTF2(_L("Invalid DevSound state received: %d"), iDevSoundState);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6252
			StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6253
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6254
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6255
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6256
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6257
void RA3FDevSoundTonePlayDualToneOnceAndStopTest::DoTimerCallback()
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6258
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6259
	INFO_PRINTF1(_L("TimerEvent called"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6260
	INFO_PRINTF1(_L("DevSound Event: EEventTimerComplete"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6261
	if(!iToneStopped)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6262
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6263
		Fsm(EEventTimerComplete, KErrNone); 
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6264
		iToneStopped = ETrue;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6265
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6266
	else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6267
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6268
		iTimer->Cancel();
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6269
		INFO_PRINTF1(_L("Calling CMMFDevSound::InitializeL"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6270
		TRAPD(err, iMMFDevSound->InitializeL(*this, EMMFStateTonePlaying));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6271
		if (err != KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6272
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6273
			ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"),  err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6274
			ERR_PRINTF2(_L("Expected error = %d"), KErrNone);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6275
			StopTest(err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6276
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6277
		INFO_PRINTF1(_L("DevSound State: EStateInitializing"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6278
		iDevSoundState = EStateInitializing;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6279
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6280
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6281
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6282
void RA3FDevSoundTonePlayDualToneOnceAndStopTest::ToneFinished(TInt aError)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6283
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6284
	INFO_PRINTF1(_L("========== DevSound ToneFinished() callback =========="));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6285
	ERR_PRINTF1(_L("DevSound should not have called ToneFinished because it is supposed to have been stopped"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6286
	StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6287
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6288
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6289
/*
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6290
 *========================================================================================================
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6291
 * MM-A3F-DEVSOUND-CHRTZ-TONE-0045
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6292
 */
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6293
RA3FDevSoundTonePlayDTMFStringOnceAndStopTest::RA3FDevSoundTonePlayDTMFStringOnceAndStopTest(const TDesC& aTestName)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6294
	:	RA3FDevSoundTestBase(aTestName),iDTMFString(KNullDesC),
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6295
		iToneStopped(EFalse)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6296
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6297
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6298
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6299
RA3FDevSoundTonePlayDTMFStringOnceAndStopTest* RA3FDevSoundTonePlayDTMFStringOnceAndStopTest::NewL(const TDesC& aTestName)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6300
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6301
	RA3FDevSoundTonePlayDTMFStringOnceAndStopTest * self = new(ELeave)RA3FDevSoundTonePlayDTMFStringOnceAndStopTest(aTestName);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6302
	return self;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6303
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6304
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6305
void RA3FDevSoundTonePlayDTMFStringOnceAndStopTest::DoKickoffTestL()
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6306
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6307
	TPtrC DTMF;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6308
	if ( !GetStringFromConfig(iTestStepName, KDTMFString, DTMF) )
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6309
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6310
		ERR_PRINTF2(KMsgErrorGetParameter, &KDTMFString);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6311
		StopTest(KErrNotFound);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6312
		return;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6313
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6314
	iDTMFString.Copy(DTMF);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6315
	iTimer = CPeriodic::NewL(CActive::EPriorityHigh);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6316
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6317
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6318
void RA3FDevSoundTonePlayDTMFStringOnceAndStopTest::Fsm(TMmfDevSoundEvent aDevSoundEvent, TInt aError)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6319
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6320
	switch(iDevSoundState)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6321
		{		
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6322
		case EStateCreated:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6323
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6324
			__ASSERT_ALWAYS((aError == KErrNone), Panic(_L("RA3FDevSoundTonePlayDTMFStringOnceAndStopTest"), EFsmIncorrectErrorPassed));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6325
			if (aDevSoundEvent == EEventInitialize)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6326
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6327
				INFO_PRINTF1(_L("Calling CMMFDevSound::InitializeL"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6328
				TRAPD(err, iMMFDevSound->InitializeL(*this, EMMFStateTonePlaying));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6329
				if (err != KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6330
					{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6331
					ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"), err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6332
					StopTest(err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6333
					break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6334
					}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6335
				INFO_PRINTF1(_L("DevSound State: EStateInitializing"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6336
				iDevSoundState = EStateInitializing;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6337
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6338
			else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6339
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6340
				ERR_PRINTF2(_L("DevSound EEventInitialize not received as expected. Received event: %d"), aDevSoundEvent);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6341
				StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6342
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6343
			break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6344
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6345
		case EStateInitializing:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6346
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6347
			if (aDevSoundEvent == EEventInitComplete && aError == KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6348
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6349
				if (!iToneStopped)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6350
					{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6351
					iMMFDevSound->SetVolume(iMMFDevSound->MaxVolume());
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6352
					INFO_PRINTF2(_L("Calling CMMFDevSound::PlayDTMFStringL %S"), &iDTMFString);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6353
					TRAPD(err, iMMFDevSound->PlayDTMFStringL(iDTMFString));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6354
					if (err != KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6355
						{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6356
						ERR_PRINTF2(_L("CMMFDevSound::PlayDTMFStringL left with error = %d"), err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6357
						StopTest(err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6358
						break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6359
						}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6360
					StartTimer(KMicroSecsTwoSec);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6361
					INFO_PRINTF1(_L("DevSound State: EStatePlaying"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6362
					iDevSoundState = EStatePlaying;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6363
					}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6364
				else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6365
					{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6366
					INFO_PRINTF1(_L("Calling CMMFDevSound::Stop succeeded"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6367
					StopTest(aError);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6368
					}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6369
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6370
			else if (aDevSoundEvent == EEventInitComplete && aError != KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6371
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6372
				ERR_PRINTF2(_L("DevSound called CMMFDevSound::InitializeComplete with error = %d"), aError);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6373
				StopTest(aError);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6374
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6375
			else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6376
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6377
				ERR_PRINTF2(_L("DevSound EEventInitComplete not received as expected. Received event: %d"), aDevSoundEvent);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6378
				StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6379
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6380
			break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6381
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6382
		case EStatePlaying:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6383
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6384
			if(aDevSoundEvent == EEventTimerComplete)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6385
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6386
				INFO_PRINTF1(_L("Calling CMMFDevSound::Stop"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6387
				iMMFDevSound->Stop();
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6388
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6389
			else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6390
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6391
				ERR_PRINTF2(_L("DevSound EEventTimerComplete not received as expected. Received event: %d"), aDevSoundEvent);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6392
				StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6393
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6394
			break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6395
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6396
		default:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6397
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6398
			ERR_PRINTF2(_L("Invalid DevSound state received: %d"), iDevSoundState);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6399
			StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6400
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6401
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6402
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6403
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6404
void RA3FDevSoundTonePlayDTMFStringOnceAndStopTest::DoTimerCallback()
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6405
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6406
	INFO_PRINTF1(_L("TimerEvent called"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6407
	INFO_PRINTF1(_L("DevSound Event: EEventTimerComplete"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6408
	if(!iToneStopped)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6409
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6410
		Fsm(EEventTimerComplete, KErrNone); 
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6411
		iToneStopped = ETrue;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6412
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6413
	else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6414
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6415
		iTimer->Cancel();
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6416
		INFO_PRINTF1(_L("Calling CMMFDevSound::InitializeL"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6417
		TRAPD(err, iMMFDevSound->InitializeL(*this, EMMFStateTonePlaying));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6418
		if (err != KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6419
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6420
			ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"),  err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6421
			ERR_PRINTF2(_L("Expected error = %d"), KErrNone);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6422
			StopTest(err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6423
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6424
		INFO_PRINTF1(_L("DevSound State: EStateInitializing"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6425
		iDevSoundState = EStateInitializing;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6426
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6427
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6428
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6429
void RA3FDevSoundTonePlayDTMFStringOnceAndStopTest::ToneFinished(TInt aError)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6430
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6431
	INFO_PRINTF1(_L("========== DevSound ToneFinished() callback =========="));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6432
	ERR_PRINTF1(_L("DevSound should not have called ToneFinished because it is supposed to have been stopped"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6433
	StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6434
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6435
/*
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6436
 *========================================================================================================
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6437
 * MM-A3F-DEVSOUND-CHRTZ-TONE-0046
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6438
 */
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6439
RA3FDevSoundTonePlayToneSequenceOnceAndStopTest::RA3FDevSoundTonePlayToneSequenceOnceAndStopTest(const TDesC& aTestName)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6440
	:	RA3FDevSoundTestBase(aTestName), iToneStopped(EFalse)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6441
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6442
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6443
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6444
RA3FDevSoundTonePlayToneSequenceOnceAndStopTest* RA3FDevSoundTonePlayToneSequenceOnceAndStopTest::NewL(const TDesC& aTestName)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6445
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6446
	RA3FDevSoundTonePlayToneSequenceOnceAndStopTest * self = new(ELeave)RA3FDevSoundTonePlayToneSequenceOnceAndStopTest(aTestName);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6447
	return self;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6448
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6449
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6450
void RA3FDevSoundTonePlayToneSequenceOnceAndStopTest::DoKickoffTestL()
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6451
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6452
	iTimer = CPeriodic::NewL(CActive::EPriorityHigh);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6453
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6454
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6455
void RA3FDevSoundTonePlayToneSequenceOnceAndStopTest::Fsm(TMmfDevSoundEvent aDevSoundEvent, TInt aError)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6456
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6457
	switch (iDevSoundState)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6458
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6459
		case EStateCreated:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6460
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6461
			__ASSERT_ALWAYS((aError == KErrNone), Panic(_L("RA3FDevSoundTonePlayToneSequenceOnceAndStopTest"), EFsmIncorrectErrorPassed));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6462
			if (aDevSoundEvent == EEventInitialize)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6463
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6464
				INFO_PRINTF1(_L("Calling CMMFDevSound::InitializeL"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6465
				TRAPD(err, iMMFDevSound->InitializeL(*this, EMMFStateTonePlaying));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6466
				if (err != KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6467
					{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6468
					ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"),  err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6469
					StopTest(err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6470
					break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6471
					}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6472
				INFO_PRINTF1(_L("DevSound State: EStateInitializing"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6473
				iDevSoundState = EStateInitializing;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6474
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6475
			else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6476
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6477
				ERR_PRINTF2(_L("DevSound EEventInitialize not received as expected. Received event: %d"), aDevSoundEvent);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6478
				StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6479
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6480
			break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6481
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6482
		case EStateInitializing:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6483
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6484
			if (aDevSoundEvent == EEventInitComplete && aError == KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6485
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6486
				if (!iToneStopped)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6487
					{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6488
					iMMFDevSound->SetVolume(iMMFDevSound->MaxVolume());
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6489
					TUint8* tablePointer = const_cast<TUint8*>( &(KFixedSequenceTestSequenceDataX[0])); 
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6490
					TPtrC8 KFixedSequenceData(tablePointer,  sizeof(KFixedSequenceTestSequenceDataX));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6491
					INFO_PRINTF1(_L("Calling CMMFDevSound::PlayToneSequenceL"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6492
					TRAPD(err, iMMFDevSound->PlayToneSequenceL(KFixedSequenceData));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6493
					if (err != KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6494
						{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6495
						ERR_PRINTF2(_L("CMMFDevSound::PlayToneSequenceL left with error = %d!"), err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6496
						StopTest(err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6497
						break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6498
						}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6499
					StartTimer(KMicroSecsTwoSec);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6500
					INFO_PRINTF1(_L("DevSound State: EStatePlaying"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6501
					iDevSoundState = EStatePlaying;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6502
					}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6503
				else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6504
					{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6505
					INFO_PRINTF1(_L("Calling CMMFDevSound::Stop succeeded"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6506
					StopTest(aError);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6507
					}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6508
				
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6509
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6510
			else if (aDevSoundEvent == EEventInitComplete && aError != KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6511
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6512
				ERR_PRINTF2(_L("DevSound called CMMFDevSound::InitializeComplete with error = %d"), aError);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6513
				StopTest(aError);	
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6514
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6515
			else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6516
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6517
				ERR_PRINTF2(_L("DevSound EEventInitComplete not received as expected. Received event: %d"), aDevSoundEvent);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6518
				StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6519
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6520
			break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6521
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6522
		case EStatePlaying:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6523
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6524
			if(aDevSoundEvent == EEventTimerComplete)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6525
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6526
				INFO_PRINTF1(_L("Calling CMMFDevSound::Stop"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6527
				iMMFDevSound->Stop();
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6528
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6529
			else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6530
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6531
				ERR_PRINTF2(_L("DevSound EEventTimerComplete not received as expected. Received event: %d"), aDevSoundEvent);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6532
				StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6533
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6534
			break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6535
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6536
		default:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6537
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6538
			ERR_PRINTF2(_L("Invalid DevSound state received: %d"),  iDevSoundState);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6539
			StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6540
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6541
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6542
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6543
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6544
void RA3FDevSoundTonePlayToneSequenceOnceAndStopTest::DoTimerCallback()
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6545
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6546
	INFO_PRINTF1(_L("TimerEvent called"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6547
	INFO_PRINTF1(_L("DevSound Event: EEventTimerComplete"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6548
	if(!iToneStopped)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6549
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6550
		Fsm(EEventTimerComplete, KErrNone); 
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6551
		iToneStopped = ETrue;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6552
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6553
	else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6554
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6555
		iTimer->Cancel();
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6556
		INFO_PRINTF1(_L("Calling CMMFDevSound::InitializeL"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6557
		TRAPD(err, iMMFDevSound->InitializeL(*this, EMMFStateTonePlaying));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6558
		if (err != KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6559
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6560
			ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"),  err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6561
			ERR_PRINTF2(_L("Expected error = %d"), KErrNone);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6562
			StopTest(err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6563
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6564
		INFO_PRINTF1(_L("DevSound State: EStateInitializing"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6565
		iDevSoundState = EStateInitializing;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6566
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6567
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6568
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6569
void RA3FDevSoundTonePlayToneSequenceOnceAndStopTest::ToneFinished(TInt aError)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6570
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6571
	INFO_PRINTF1(_L("========== DevSound ToneFinished() callback =========="));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6572
	ERR_PRINTF1(_L("DevSound should not have called ToneFinished because it is supposed to have been stopped"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6573
	StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6574
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6575
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6576
/*
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6577
 *========================================================================================================
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6578
 * MM-A3F-DEVSOUND-CHRTZ-TONE-0047
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6579
 */
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6580
RA3FDevSoundTonePlayToneOncePauseTest::RA3FDevSoundTonePlayToneOncePauseTest(const TDesC& aTestName)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6581
	:	RA3FDevSoundTestBase(aTestName),iDuration(0),
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6582
		iFrequencyTone1(0), iPaused(EFalse),
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6583
		iSamplesPlayedPaused(0)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6584
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6585
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6586
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6587
RA3FDevSoundTonePlayToneOncePauseTest* RA3FDevSoundTonePlayToneOncePauseTest::NewL(const TDesC& aTestName)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6588
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6589
	RA3FDevSoundTonePlayToneOncePauseTest * self = new(ELeave)RA3FDevSoundTonePlayToneOncePauseTest(aTestName);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6590
	return self;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6591
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6592
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6593
void RA3FDevSoundTonePlayToneOncePauseTest::DoKickoffTestL()
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6594
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6595
	if (!GetIntFromConfig(iTestStepName, KDuration, iDuration)) 
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6596
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6597
		ERR_PRINTF2(KMsgErrorGetParameter, &KDuration);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6598
		StopTest(KErrNotFound);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6599
		return;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6600
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6601
	if (!GetIntFromConfig(iTestStepName, KFrequencyTone1, iFrequencyTone1)) 
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6602
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6603
		ERR_PRINTF2(KMsgErrorGetParameter, &KFrequencyTone1);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6604
		StopTest(KErrNotFound);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6605
		return;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6606
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6607
	iTimer = CPeriodic::NewL(CActive::EPriorityHigh);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6608
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6609
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6610
void RA3FDevSoundTonePlayToneOncePauseTest::Fsm(TMmfDevSoundEvent aDevSoundEvent,  TInt aError)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6611
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6612
	switch (iDevSoundState)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6613
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6614
		case EStateCreated:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6615
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6616
			__ASSERT_ALWAYS((aError == KErrNone), Panic(_L("RA3FDevSoundTonePlayToneOncePauseTest"), EFsmIncorrectErrorPassed));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6617
			if (aDevSoundEvent == EEventInitialize)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6618
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6619
				INFO_PRINTF1(_L("Calling CMMFDevSound::InitializeL"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6620
				TRAPD(err, iMMFDevSound->InitializeL(*this, EMMFStateTonePlaying));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6621
				if (err != KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6622
					{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6623
					ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"),  err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6624
					StopTest(err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6625
					break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6626
					}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6627
				INFO_PRINTF1(_L("DevSound State: EStateInitializing"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6628
				iDevSoundState = EStateInitializing;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6629
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6630
			else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6631
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6632
				ERR_PRINTF2(_L("DevSound EEventInitialize not received as expected. Received event: %d"), aDevSoundEvent);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6633
				StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6634
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6635
			break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6636
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6637
		case EStateInitializing:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6638
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6639
			if (aDevSoundEvent == EEventInitComplete && aError == KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6640
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6641
				iMMFDevSound->SetVolume(iMMFDevSound->MaxVolume());
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6642
				INFO_PRINTF3(_L("Calling CMMFDevSound::PlayToneL using %d Hz during %d secs "), iFrequencyTone1, iDuration);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6643
				TRAPD(err, iMMFDevSound->PlayToneL(iFrequencyTone1, iDuration*KMicroSecsInOneSec));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6644
				if (err != KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6645
					{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6646
					ERR_PRINTF2(_L("CMMFDevSound::PlayToneL left with error = %d!"),  err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6647
					StopTest(err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6648
					break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6649
					}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6650
				StartTimer(KMicroSecsTwoSec);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6651
				INFO_PRINTF1(_L("DevSound State: EStatePlaying"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6652
				iDevSoundState = EStatePlaying;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6653
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6654
			else if (aDevSoundEvent == EEventInitComplete && aError != KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6655
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6656
				ERR_PRINTF2(_L("DevSound called CMMFDevSound::InitializeComplete with error = %d"), aError);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6657
				StopTest(aError);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6658
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6659
			else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6660
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6661
				ERR_PRINTF2(_L("DevSound EEventInitComplete not received as expected. Received event: %d"),  aDevSoundEvent);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6662
				StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6663
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6664
			break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6665
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6666
		case EStatePlaying:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6667
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6668
			if(aDevSoundEvent == EEventTimerComplete)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6669
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6670
				INFO_PRINTF1(_L("Calling CMMFDevSound::Pause"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6671
				iMMFDevSound->Pause();
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6672
				INFO_PRINTF1(_L("DevSound State: EStatePause"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6673
				iDevSoundState = EStatePause;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6674
				INFO_PRINTF1(_L("Calling CMMFDevSound::SamplesPlayed"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6675
				iSamplesPlayedPaused = iMMFDevSound->SamplesPlayed();
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6676
				INFO_PRINTF2(_L("The number of samples played is %d"), iSamplesPlayedPaused);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6677
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6678
			else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6679
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6680
				ERR_PRINTF2(_L("DevSound EEventTimerComplete not received as expected. Received event: %d"), aDevSoundEvent);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6681
				StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6682
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6683
			break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6684
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6685
		case EStatePause:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6686
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6687
			if (aDevSoundEvent == EEventTimerComplete)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6688
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6689
				TInt samplesPlayed = iMMFDevSound->SamplesPlayed();
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6690
				if(iSamplesPlayedPaused == samplesPlayed)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6691
					{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6692
					INFO_PRINTF2(_L("After waiting a couple of seconds, the samples played are still being the same %d"), iSamplesPlayedPaused);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6693
					StopTest();
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6694
					}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6695
				else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6696
					{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6697
					ERR_PRINTF2(_L("After waiting a couple of seconds, the samples played are not the same %d"), samplesPlayed);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6698
					ERR_PRINTF2(_L("Expected samples played = %d"), iSamplesPlayedPaused);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6699
					StopTest(aError,EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6700
					}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6701
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6702
			else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6703
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6704
				ERR_PRINTF2(_L("EEventTimerComplete not received as expected. Received event: %d"), aDevSoundEvent);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6705
				StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6706
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6707
			break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6708
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6709
		default:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6710
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6711
			ERR_PRINTF2(_L("Invalid DevSound state received: %d"), iDevSoundState);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6712
			StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6713
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6714
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6715
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6716
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6717
void RA3FDevSoundTonePlayToneOncePauseTest::DoTimerCallback()
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6718
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6719
	INFO_PRINTF1(_L("TimerEvent called"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6720
	if (!iPaused)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6721
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6722
		INFO_PRINTF1(_L("DevSound Event: EEventTimerComplete"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6723
		Fsm(EEventTimerComplete, KErrNone);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6724
		iPaused = ETrue;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6725
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6726
	else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6727
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6728
		iTimer->Cancel();
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6729
		INFO_PRINTF1(_L("DevSound Event: EEventTimerComplete"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6730
		Fsm(EEventTimerComplete, KErrNone);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6731
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6732
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6733
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6734
void RA3FDevSoundTonePlayToneOncePauseTest::ToneFinished(TInt aError)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6735
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6736
	INFO_PRINTF1(_L("========== DevSound ToneFinished() callback =========="));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6737
	ERR_PRINTF1(_L("DevSound should not have called ToneFinished because it is supposed to be paused"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6738
	StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6739
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6740
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6741
/*
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6742
 *========================================================================================================
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6743
 * MM-A3F-DEVSOUND-CHRTZ-TONE-0048
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6744
 */
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6745
RA3FDevSoundTonePlayDualToneOncePauseTest::RA3FDevSoundTonePlayDualToneOncePauseTest(const TDesC& aTestName)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6746
	:	RA3FDevSoundTestBase(aTestName), 
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6747
		iDuration(0),iFrequencyTone1(0),
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6748
		iFrequencyTone2(0), iPaused(EFalse),
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6749
		iSamplesPlayedPaused(0)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6750
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6751
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6752
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6753
RA3FDevSoundTonePlayDualToneOncePauseTest* RA3FDevSoundTonePlayDualToneOncePauseTest::NewL(const TDesC& aTestName)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6754
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6755
	RA3FDevSoundTonePlayDualToneOncePauseTest * self = new(ELeave)RA3FDevSoundTonePlayDualToneOncePauseTest(aTestName);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6756
	return self;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6757
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6758
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6759
void RA3FDevSoundTonePlayDualToneOncePauseTest::DoKickoffTestL()
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6760
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6761
	if (!GetIntFromConfig(iTestStepName, KDuration, iDuration)) 
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6762
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6763
		ERR_PRINTF2(KMsgErrorGetParameter, &KDuration);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6764
		StopTest(KErrNotFound);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6765
		return;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6766
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6767
	if (!GetIntFromConfig(iTestStepName, KFrequencyTone1, iFrequencyTone1)) 
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6768
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6769
		ERR_PRINTF2(KMsgErrorGetParameter, &KFrequencyTone1);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6770
		StopTest(KErrNotFound);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6771
		return;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6772
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6773
	if (!GetIntFromConfig(iTestStepName, KFrequencyTone2, iFrequencyTone2)) 
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6774
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6775
		ERR_PRINTF2(KMsgErrorGetParameter, &KFrequencyTone2);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6776
		StopTest(KErrNotFound);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6777
		return;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6778
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6779
	iTimer = CPeriodic::NewL(CActive::EPriorityHigh);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6780
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6781
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6782
void RA3FDevSoundTonePlayDualToneOncePauseTest::Fsm(TMmfDevSoundEvent aDevSoundEvent, TInt aError)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6783
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6784
	switch (iDevSoundState)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6785
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6786
		case EStateCreated:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6787
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6788
			__ASSERT_ALWAYS((aError == KErrNone), Panic(_L("RA3FDevSoundTonePlayDualToneOncePauseTest"), EFsmIncorrectErrorPassed));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6789
			if (aDevSoundEvent == EEventInitialize)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6790
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6791
				INFO_PRINTF1(_L("Calling CMMFDevSound::InitializeL"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6792
				TRAPD(err, iMMFDevSound->InitializeL(*this,  EMMFStateTonePlaying));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6793
				if (err != KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6794
					{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6795
					ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"), err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6796
					StopTest(err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6797
					break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6798
					}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6799
				INFO_PRINTF1(_L("DevSound State: EStateInitializing"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6800
				iDevSoundState = EStateInitializing;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6801
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6802
			else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6803
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6804
				ERR_PRINTF2(_L("DevSound EEventInitialize not received as expected. Received event: %d"), aDevSoundEvent);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6805
				StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6806
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6807
			break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6808
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6809
		case EStateInitializing:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6810
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6811
			if (aDevSoundEvent == EEventInitComplete && aError == KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6812
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6813
				iMMFDevSound->SetVolume(iMMFDevSound->MaxVolume());
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6814
				INFO_PRINTF4(_L("Calling CMMFDevSound::PlayDualToneL using %d Hz %d Hz during %d secs "), iFrequencyTone1, iFrequencyTone2, iDuration);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6815
				TRAPD(err, iMMFDevSound->PlayDualToneL(iFrequencyTone1, iFrequencyTone2, iDuration*KMicroSecsInOneSec));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6816
				if (err != KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6817
					{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6818
					ERR_PRINTF2(_L("CMMFDevSound::PlayDualToneL left with error : %d!"),  err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6819
					StopTest(err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6820
					break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6821
					}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6822
				StartTimer(KMicroSecsTwoSec);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6823
				INFO_PRINTF1(_L("DevSound State: EStatePlaying"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6824
				iDevSoundState = EStatePlaying;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6825
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6826
			else if (aDevSoundEvent == EEventInitComplete && aError != KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6827
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6828
				ERR_PRINTF2(_L("DevSound called CMMFDevSound::InitializeComplete with error = %d"), aError);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6829
				StopTest(aError);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6830
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6831
			else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6832
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6833
				ERR_PRINTF2(_L("DevSound EEventInitComplete not received as expected. Received event: %d"), aDevSoundEvent);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6834
				StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6835
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6836
			break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6837
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6838
		case EStatePlaying:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6839
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6840
			if(aDevSoundEvent == EEventTimerComplete)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6841
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6842
				INFO_PRINTF1(_L("Calling CMMFDevSound::Pause"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6843
				iMMFDevSound->Pause();
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6844
				INFO_PRINTF1(_L("DevSound State: EStatePause"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6845
				iDevSoundState = EStatePause;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6846
				INFO_PRINTF1(_L("Calling CMMFDevSound::SamplesPlayed"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6847
				iSamplesPlayedPaused = iMMFDevSound->SamplesPlayed();
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6848
				INFO_PRINTF2(_L("The number of samples played is %d"), iSamplesPlayedPaused);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6849
				StopTest();
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6850
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6851
			else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6852
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6853
				ERR_PRINTF2(_L("DevSound EEventTimerComplete not received as expected. Received event: %d"), aDevSoundEvent);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6854
				StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6855
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6856
			break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6857
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6858
		case EStatePause:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6859
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6860
			if (aDevSoundEvent == EEventTimerComplete)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6861
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6862
				TInt samplesPlayed = iMMFDevSound->SamplesPlayed();
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6863
				if(iSamplesPlayedPaused == samplesPlayed)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6864
					{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6865
					INFO_PRINTF2(_L("After waiting a couple of seconds, the samples played are still being the same %d"), iSamplesPlayedPaused);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6866
					StopTest();
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6867
					}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6868
				else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6869
					{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6870
					ERR_PRINTF2(_L("After waiting a couple of seconds, the samples played are not the same %d"), samplesPlayed);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6871
					ERR_PRINTF2(_L("Expected samples played = %d"), iSamplesPlayedPaused);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6872
					StopTest(aError,EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6873
					}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6874
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6875
			else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6876
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6877
				ERR_PRINTF2(_L("EEventTimerComplete not received as expected. Received event: %d"), aDevSoundEvent);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6878
				StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6879
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6880
			break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6881
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6882
		default:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6883
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6884
			ERR_PRINTF2(_L("Invalid DevSound state received: %d"), iDevSoundState);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6885
			StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6886
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6887
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6888
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6889
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6890
void RA3FDevSoundTonePlayDualToneOncePauseTest::DoTimerCallback()
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6891
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6892
	INFO_PRINTF1(_L("TimerEvent called"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6893
	if (!iPaused)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6894
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6895
		INFO_PRINTF1(_L("DevSound Event: EEventTimerComplete"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6896
		Fsm(EEventTimerComplete, KErrNone);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6897
		iPaused = ETrue;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6898
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6899
	else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6900
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6901
		iTimer->Cancel();
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6902
		INFO_PRINTF1(_L("DevSound Event: EEventTimerComplete"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6903
		Fsm(EEventTimerComplete, KErrNone);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6904
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6905
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6906
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6907
void RA3FDevSoundTonePlayDualToneOncePauseTest::ToneFinished(TInt aError)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6908
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6909
	INFO_PRINTF1(_L("========== DevSound ToneFinished() callback =========="));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6910
	ERR_PRINTF1(_L("DevSound should not have called ToneFinished because it is supposed to be paused"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6911
	StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6912
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6913
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6914
/*
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6915
 *========================================================================================================
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6916
 * MM-A3F-DEVSOUND-CHRTZ-TONE-0049
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6917
 */
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6918
RA3FDevSoundTonePlayDTMFStringOncePauseTest::RA3FDevSoundTonePlayDTMFStringOncePauseTest(const TDesC& aTestName)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6919
	:	RA3FDevSoundTestBase(aTestName), 
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6920
		iDTMFString(KNullDesC),iPaused(EFalse),
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6921
		iSamplesPlayedPaused(0),iDTMFPauses(0),
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6922
		iDTMFTones(0)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6923
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6924
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6925
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6926
RA3FDevSoundTonePlayDTMFStringOncePauseTest* RA3FDevSoundTonePlayDTMFStringOncePauseTest::NewL(const TDesC& aTestName)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6927
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6928
	RA3FDevSoundTonePlayDTMFStringOncePauseTest * self = new(ELeave)RA3FDevSoundTonePlayDTMFStringOncePauseTest(aTestName);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6929
	return self;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6930
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6931
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6932
void RA3FDevSoundTonePlayDTMFStringOncePauseTest::DoKickoffTestL()
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6933
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6934
	TPtrC DTMF;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6935
	if ( !GetStringFromConfig(iTestStepName, KDTMFString, DTMF) )
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6936
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6937
		ERR_PRINTF2(KMsgErrorGetParameter, &KDTMFString);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6938
		StopTest(KErrNotFound);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6939
		return;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6940
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6941
	iDTMFString.Copy(DTMF);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6942
	for(TInt i =0 ; i< iDTMFString.Length() ; i++)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6943
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6944
		if (iDTMFString[i] == ',')
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6945
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6946
			iDTMFPauses++;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6947
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6948
		else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6949
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6950
			iDTMFTones++;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6951
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6952
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6953
	iTimer = CPeriodic::NewL(CActive::EPriorityHigh);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6954
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6955
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6956
void RA3FDevSoundTonePlayDTMFStringOncePauseTest::Fsm(TMmfDevSoundEvent aDevSoundEvent, TInt aError)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6957
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6958
	switch (iDevSoundState)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6959
		{		
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6960
		case EStateCreated:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6961
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6962
			__ASSERT_ALWAYS((aError == KErrNone), Panic(_L("RA3FDevSoundTonePlayDTMFStringOncePauseTest"), EFsmIncorrectErrorPassed));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6963
			if (aDevSoundEvent == EEventInitialize)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6964
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6965
				INFO_PRINTF1(_L("Calling CMMFDevSound::InitializeL"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6966
				TRAPD(err, iMMFDevSound->InitializeL(*this, EMMFStateTonePlaying));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6967
				if (err != KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6968
					{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6969
					ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"), err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6970
					StopTest(err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6971
					break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6972
					}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6973
				INFO_PRINTF1(_L("DevSound State: EStateInitializing"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6974
				iDevSoundState = EStateInitializing;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6975
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6976
			else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6977
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6978
				ERR_PRINTF2(_L("DevSound EEventInitialize not received as expected. Received event: %d"), aDevSoundEvent);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6979
				StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6980
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6981
			break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6982
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6983
		case EStateInitializing:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6984
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6985
			if (aDevSoundEvent == EEventInitComplete && aError == KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6986
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6987
				iMMFDevSound->SetVolume(iMMFDevSound->MaxVolume());
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6988
				INFO_PRINTF2(_L("Calling CMMFDevSound::PlayDTMFStringL %S"),  &iDTMFString);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6989
				TRAPD(err, iMMFDevSound->PlayDTMFStringL(iDTMFString));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6990
				if (err != KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6991
					{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6992
					ERR_PRINTF2(_L("CMMFDevSound::PlayDTMFStringL left with error : %d!"),  err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6993
					StopTest(err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6994
					}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6995
				StartTimer(KMicroSecsTwoSec);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6996
				INFO_PRINTF1(_L("DevSound State: EStatePlaying"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6997
				iDevSoundState = EStatePlaying;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6998
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  6999
			else if (aDevSoundEvent == EEventInitComplete && aError != KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7000
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7001
				ERR_PRINTF2(_L("DevSound called CMMFDevSound::InitializeComplete with error = %d"), aError);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7002
				StopTest(aError);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7003
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7004
			else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7005
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7006
				ERR_PRINTF2(_L("DevSound EEventInitComplete not received as expected. Received event: %d"), aDevSoundEvent);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7007
				StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7008
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7009
			break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7010
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7011
		case EStatePlaying:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7012
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7013
			if(aDevSoundEvent == EEventTimerComplete)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7014
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7015
				INFO_PRINTF1(_L("Calling CMMFDevSound::Pause"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7016
				iMMFDevSound->Pause();
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7017
				INFO_PRINTF1(_L("DevSound State: EStatePause"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7018
				iDevSoundState = EStatePause;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7019
				INFO_PRINTF1(_L("Calling CMMFDevSound::SamplesPlayed"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7020
				iSamplesPlayedPaused = iMMFDevSound->SamplesPlayed();
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7021
				INFO_PRINTF2(_L("The number of samples played is %d"), iSamplesPlayedPaused);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7022
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7023
			else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7024
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7025
				ERR_PRINTF2(_L("DevSound EEventTimerComplete not received as expected. Received event: %d"), aDevSoundEvent);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7026
				StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7027
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7028
			break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7029
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7030
		case EStatePause:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7031
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7032
			if (aDevSoundEvent == EEventTimerComplete)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7033
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7034
				TInt samplesPlayed = iMMFDevSound->SamplesPlayed();
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7035
				if(iSamplesPlayedPaused == samplesPlayed)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7036
					{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7037
					INFO_PRINTF2(_L("After waiting a couple of seconds, the samples played are still being the same %d"), iSamplesPlayedPaused);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7038
					StopTest();
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7039
					}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7040
				else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7041
					{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7042
					ERR_PRINTF2(_L("After waiting a couple of seconds, the samples played are not the same %d"), samplesPlayed);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7043
					ERR_PRINTF2(_L("Expected samples played = %d"), iSamplesPlayedPaused);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7044
					StopTest(aError,EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7045
					}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7046
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7047
			else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7048
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7049
				ERR_PRINTF2(_L("EEventTimerComplete not received as expected. Received event: %d"), aDevSoundEvent);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7050
				StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7051
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7052
			break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7053
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7054
		default:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7055
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7056
			ERR_PRINTF2(_L("Invalid DevSound state received: %d"), iDevSoundState);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7057
			StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7058
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7059
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7060
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7061
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7062
void RA3FDevSoundTonePlayDTMFStringOncePauseTest::DoTimerCallback()
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7063
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7064
	INFO_PRINTF1(_L("TimerEvent called"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7065
	if (!iPaused)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7066
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7067
		INFO_PRINTF1(_L("DevSound Event: EEventTimerComplete"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7068
		Fsm(EEventTimerComplete, KErrNone);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7069
		iPaused = ETrue;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7070
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7071
	else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7072
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7073
		iTimer->Cancel();
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7074
		INFO_PRINTF1(_L("DevSound Event: EEventTimerComplete"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7075
		Fsm(EEventTimerComplete, KErrNone);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7076
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7077
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7078
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7079
void RA3FDevSoundTonePlayDTMFStringOncePauseTest::ToneFinished(TInt aError)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7080
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7081
	INFO_PRINTF1(_L("========== DevSound ToneFinished() callback =========="));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7082
	ERR_PRINTF1(_L("DevSound should not have called ToneFinished because it is supposed to be paused"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7083
	StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7084
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7085
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7086
/*
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7087
 *========================================================================================================
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7088
 * MM-A3F-DEVSOUND-CHRTZ-TONE-0050
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7089
 */
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7090
RA3FDevSoundTonePlayToneSequenceOncePauseTest::RA3FDevSoundTonePlayToneSequenceOncePauseTest(const TDesC& aTestName)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7091
	:	RA3FDevSoundTestBase(aTestName), iPaused(EFalse),
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7092
		iSamplesPlayedPaused(0)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7093
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7094
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7095
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7096
RA3FDevSoundTonePlayToneSequenceOncePauseTest* RA3FDevSoundTonePlayToneSequenceOncePauseTest::NewL(const TDesC& aTestName)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7097
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7098
	RA3FDevSoundTonePlayToneSequenceOncePauseTest * self = new(ELeave)RA3FDevSoundTonePlayToneSequenceOncePauseTest(aTestName);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7099
	return self;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7100
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7101
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7102
void RA3FDevSoundTonePlayToneSequenceOncePauseTest::DoKickoffTestL()
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7103
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7104
	iTimer = CPeriodic::NewL(CActive::EPriorityHigh);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7105
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7106
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7107
void RA3FDevSoundTonePlayToneSequenceOncePauseTest::Fsm(TMmfDevSoundEvent aDevSoundEvent, TInt aError)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7108
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7109
	switch(iDevSoundState)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7110
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7111
		case EStateCreated:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7112
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7113
			__ASSERT_ALWAYS((aError == KErrNone), Panic(_L("RA3FDevSoundTonePlayToneSequenceOncePauseTest"), EFsmIncorrectErrorPassed));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7114
			if (aDevSoundEvent == EEventInitialize)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7115
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7116
				INFO_PRINTF1(_L("Calling CMMFDevSound::InitializeL"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7117
				TRAPD(err, iMMFDevSound->InitializeL(*this, EMMFStateTonePlaying));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7118
				if (err != KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7119
					{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7120
					ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"), err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7121
					StopTest(err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7122
					break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7123
					}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7124
				INFO_PRINTF1(_L("DevSound State: EStateInitializing"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7125
				iDevSoundState = EStateInitializing;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7126
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7127
			else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7128
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7129
				ERR_PRINTF2(_L("DevSound EEventInitialize not received as expected. Received event: %d"), aDevSoundEvent);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7130
				StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7131
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7132
			break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7133
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7134
		case EStateInitializing:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7135
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7136
			if (aDevSoundEvent == EEventInitComplete && aError == KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7137
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7138
				TUint8* tablePointer = const_cast<TUint8*>( &(KFixedSequenceTestSequenceDataX[0] ) ); 
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7139
				TPtrC8 KFixedSequenceData(tablePointer, sizeof(KFixedSequenceTestSequenceDataX));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7140
				INFO_PRINTF1(_L("Calling CMMFDevSound::PlayToneSequenceL"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7141
				TRAPD(err, iMMFDevSound->PlayToneSequenceL(KFixedSequenceData));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7142
				if (err != KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7143
					{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7144
					ERR_PRINTF2(_L("CMMFDevSound::PlayToneSequenceL left  with error : %d!"),  err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7145
					StopTest(err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7146
					break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7147
					}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7148
				StartTimer(KMicroSecsTwoSec);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7149
				INFO_PRINTF1(_L("DevSound State: EStatePlaying"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7150
				iDevSoundState = EStatePlaying;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7151
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7152
			else if (aDevSoundEvent == EEventInitComplete && aError != KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7153
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7154
				ERR_PRINTF2(_L("DevSound called CMMFDevSound::InitializeComplete with error = %d"), aError);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7155
				StopTest(aError);	
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7156
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7157
			else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7158
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7159
				ERR_PRINTF2(_L("DevSound EEventInitComplete not received as expected. Received event: %d"), aDevSoundEvent);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7160
				StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7161
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7162
			break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7163
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7164
		case EStatePlaying:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7165
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7166
			if(aDevSoundEvent == EEventTimerComplete)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7167
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7168
				INFO_PRINTF1(_L("Calling CMMFDevSound::Pause"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7169
				iMMFDevSound->Pause();
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7170
				INFO_PRINTF1(_L("DevSound State: EStatePause"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7171
				iDevSoundState = EStatePause;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7172
				INFO_PRINTF1(_L("Calling CMMFDevSound::SamplesPlayed"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7173
				iSamplesPlayedPaused = iMMFDevSound->SamplesPlayed();
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7174
				INFO_PRINTF2(_L("The number of samples played is %d"), iSamplesPlayedPaused);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7175
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7176
			else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7177
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7178
				ERR_PRINTF2(_L("DevSound EEventTimerComplete not received as expected. Received event: %d"), aDevSoundEvent);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7179
				StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7180
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7181
			break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7182
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7183
		case EStatePause:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7184
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7185
			if (aDevSoundEvent == EEventTimerComplete)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7186
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7187
				TInt samplesPlayed = iMMFDevSound->SamplesPlayed();
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7188
				if(iSamplesPlayedPaused == samplesPlayed)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7189
					{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7190
					INFO_PRINTF2(_L("After waiting a couple of seconds, the samples played are still being the same %d"), iSamplesPlayedPaused);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7191
					StopTest();
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7192
					}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7193
				else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7194
					{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7195
					ERR_PRINTF2(_L("After waiting a couple of seconds, the samples played are not the same %d"), samplesPlayed);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7196
					ERR_PRINTF2(_L("Expected samples played = %d"), iSamplesPlayedPaused);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7197
					StopTest(aError,EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7198
					}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7199
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7200
			else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7201
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7202
				ERR_PRINTF2(_L("EEventTimerComplete not received as expected. Received event: %d"), aDevSoundEvent);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7203
				StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7204
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7205
			break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7206
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7207
		default:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7208
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7209
			ERR_PRINTF2(_L("Invalid DevSound state received: %d"), iDevSoundState);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7210
			StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7211
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7212
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7213
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7214
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7215
void RA3FDevSoundTonePlayToneSequenceOncePauseTest::DoTimerCallback()
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7216
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7217
	INFO_PRINTF1(_L("TimerEvent called"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7218
	if (!iPaused)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7219
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7220
		INFO_PRINTF1(_L("DevSound Event: EEventTimerComplete"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7221
		Fsm(EEventTimerComplete, KErrNone);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7222
		iPaused = ETrue;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7223
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7224
	else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7225
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7226
		iTimer->Cancel();
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7227
		INFO_PRINTF1(_L("DevSound Event: EEventTimerComplete"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7228
		Fsm(EEventTimerComplete, KErrNone);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7229
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7230
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7231
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7232
void RA3FDevSoundTonePlayToneSequenceOncePauseTest::ToneFinished(TInt aError)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7233
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7234
	INFO_PRINTF1(_L("========== DevSound ToneFinished() callback =========="));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7235
	ERR_PRINTF1(_L("DevSound should not have called ToneFinished because it is supposed to be paused"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7236
	StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7237
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7238
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7239
/*
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7240
 *========================================================================================================
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7241
 * MM-A3F-DEVSOUND-CHRTZ-TONE-0051
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7242
 */
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7243
RA3FDevSoundTonePlayToneOnceInitializedToPlayAudioTest::RA3FDevSoundTonePlayToneOnceInitializedToPlayAudioTest(const TDesC& aTestName)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7244
	:	RA3FDevSoundTestBase(aTestName), iDuration(0),
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7245
		iFrequencyTone1(0)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7246
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7247
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7248
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7249
RA3FDevSoundTonePlayToneOnceInitializedToPlayAudioTest* RA3FDevSoundTonePlayToneOnceInitializedToPlayAudioTest::NewL(const TDesC& aTestName)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7250
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7251
	RA3FDevSoundTonePlayToneOnceInitializedToPlayAudioTest * self = new(ELeave)RA3FDevSoundTonePlayToneOnceInitializedToPlayAudioTest(aTestName);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7252
	return self;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7253
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7254
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7255
void RA3FDevSoundTonePlayToneOnceInitializedToPlayAudioTest::DoKickoffTestL()
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7256
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7257
	if (!GetIntFromConfig(iTestStepName, KDuration, iDuration)) 
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7258
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7259
		ERR_PRINTF2(KMsgErrorGetParameter, &KDuration);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7260
		StopTest(KErrNotFound);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7261
		return;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7262
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7263
	if (!GetIntFromConfig(iTestStepName, KFrequencyTone1, iFrequencyTone1)) 
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7264
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7265
		ERR_PRINTF2(KMsgErrorGetParameter, &KFrequencyTone1);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7266
		StopTest(KErrNotFound);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7267
		return;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7268
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7269
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7270
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7271
void RA3FDevSoundTonePlayToneOnceInitializedToPlayAudioTest::Fsm(TMmfDevSoundEvent aDevSoundEvent, TInt aError)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7272
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7273
	switch (iDevSoundState)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7274
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7275
		case EStateCreated:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7276
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7277
			__ASSERT_ALWAYS((aError == KErrNone), Panic(_L("RA3FDevSoundTonePlayToneOnceInitializedToPlayAudioTest"), EFsmIncorrectErrorPassed));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7278
			if (aDevSoundEvent == EEventInitialize)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7279
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7280
				INFO_PRINTF1(_L("Calling CMMFDevSound::InitializeL for playing audio files"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7281
				TRAPD(err, iMMFDevSound->InitializeL(*this, EMMFStatePlaying));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7282
				if (err != KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7283
					{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7284
					ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"), err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7285
					StopTest(err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7286
					break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7287
					}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7288
				INFO_PRINTF1(_L("DevSound State: EStateInitializing"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7289
				iDevSoundState = EStateInitializing;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7290
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7291
			else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7292
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7293
				ERR_PRINTF2(_L("DevSound EEventInitialize not received as expected. Received event: %d"), aDevSoundEvent);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7294
				StopTest(aError,  EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7295
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7296
			break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7297
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7298
		case EStateInitializing:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7299
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7300
			if (aDevSoundEvent == EEventInitComplete && aError == KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7301
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7302
				INFO_PRINTF3(_L("Calling CMMFDevSound::PlayToneL using %d Hz during %d secs"), iFrequencyTone1, iDuration);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7303
				TRAPD(err, iMMFDevSound->PlayToneL(iFrequencyTone1, iDuration*KMicroSecsInOneSec));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7304
				if (err	== KErrNotSupported)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7305
					{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7306
					ERR_PRINTF2(_L("CMMFDevSound::PlayToneL left with KErrNotSupported %d which is the expected error"), err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7307
					StopTest();
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7308
					}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7309
				else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7310
					{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7311
					ERR_PRINTF2(_L("CMMFDevSound::PlayToneL left with error = %d"), err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7312
					ERR_PRINTF2(_L("Expected error = %d"), KErrNotSupported);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7313
					StopTest(err, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7314
					}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7315
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7316
			else if (aDevSoundEvent == EEventInitComplete && aError != KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7317
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7318
				ERR_PRINTF2(_L("DevSound called CMMFDevSound::InitializeComplete with error = %d"), aError);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7319
				StopTest(aError);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7320
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7321
			else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7322
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7323
				ERR_PRINTF2(_L("DevSound EEventInitComplete not received as expected. Received event: %d"), aDevSoundEvent);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7324
				StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7325
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7326
			break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7327
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7328
		default:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7329
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7330
			ERR_PRINTF2(_L("Invalid DevSound state received: %d"), iDevSoundState);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7331
			StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7332
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7333
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7334
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7335
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7336
/*
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7337
 *========================================================================================================
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7338
 * MM-A3F-DEVSOUND-CHRTZ-TONE-0052
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7339
 */
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7340
RA3FDevSoundTonePlayDualToneOnceInitializedToPlayAudioTest::RA3FDevSoundTonePlayDualToneOnceInitializedToPlayAudioTest(const TDesC& aTestName)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7341
	:	RA3FDevSoundTestBase(aTestName), iDuration(0),
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7342
		iFrequencyTone1(0), iFrequencyTone2(0)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7343
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7344
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7345
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7346
RA3FDevSoundTonePlayDualToneOnceInitializedToPlayAudioTest* RA3FDevSoundTonePlayDualToneOnceInitializedToPlayAudioTest::NewL(const TDesC& aTestName)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7347
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7348
	RA3FDevSoundTonePlayDualToneOnceInitializedToPlayAudioTest * self = new(ELeave)RA3FDevSoundTonePlayDualToneOnceInitializedToPlayAudioTest(aTestName);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7349
	return self;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7350
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7351
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7352
void RA3FDevSoundTonePlayDualToneOnceInitializedToPlayAudioTest::DoKickoffTestL()
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7353
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7354
	if (!GetIntFromConfig(iTestStepName, KDuration, iDuration)) 
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7355
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7356
		ERR_PRINTF2(KMsgErrorGetParameter, &KDuration);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7357
		StopTest(KErrNotFound);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7358
		return;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7359
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7360
	if (!GetIntFromConfig(iTestStepName, KFrequencyTone1, iFrequencyTone1)) 
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7361
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7362
		ERR_PRINTF2(KMsgErrorGetParameter, &KFrequencyTone1);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7363
		StopTest(KErrNotFound);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7364
		return;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7365
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7366
	if (!GetIntFromConfig(iTestStepName, KFrequencyTone2, iFrequencyTone2)) 
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7367
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7368
		ERR_PRINTF2(KMsgErrorGetParameter, &KFrequencyTone2);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7369
		StopTest(KErrNotFound);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7370
		return;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7371
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7372
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7373
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7374
void RA3FDevSoundTonePlayDualToneOnceInitializedToPlayAudioTest::Fsm(TMmfDevSoundEvent aDevSoundEvent, TInt aError)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7375
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7376
	switch(iDevSoundState)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7377
		{		
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7378
		case EStateCreated:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7379
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7380
			__ASSERT_ALWAYS((aError == KErrNone), Panic(_L("RA3FDevSoundTonePlayDualToneOnceInitializedToPlayAudioTest"), EFsmIncorrectErrorPassed));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7381
			if (aDevSoundEvent == EEventInitialize)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7382
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7383
				INFO_PRINTF1(_L("Calling CMMFDevSound::InitializeL for playing audio files"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7384
				TRAPD(err, iMMFDevSound->InitializeL(*this, EMMFStatePlaying));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7385
				if (err != KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7386
					{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7387
					ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"), err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7388
					StopTest(err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7389
					break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7390
					}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7391
				INFO_PRINTF1(_L("DevSound State: EStateInitializing"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7392
				iDevSoundState = EStateInitializing;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7393
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7394
			else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7395
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7396
				ERR_PRINTF2(_L("DevSound EEventInitialize not received as expected. Received event: %d"), aDevSoundEvent);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7397
				StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7398
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7399
			break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7400
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7401
		case EStateInitializing:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7402
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7403
			if (aDevSoundEvent == EEventInitComplete && aError == KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7404
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7405
				INFO_PRINTF4(_L("Calling CMMFDevSound::PlayDualToneL using %d Hz %d Hz during %d secs "), iFrequencyTone1, iFrequencyTone2, iDuration);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7406
				TRAPD(err, iMMFDevSound->PlayDualToneL(iFrequencyTone1, iFrequencyTone2, iDuration*KMicroSecsInOneSec));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7407
				if (err	== KErrNotSupported)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7408
					{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7409
					ERR_PRINTF2(_L("CMMFDevSound::PlayDualToneL left with KErrNotSupported %d which is the expected error"), err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7410
					StopTest(err, EPass);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7411
					}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7412
				else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7413
					{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7414
					ERR_PRINTF2(_L("CMMFDevSound::PlayDualToneL left with error = %d"), err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7415
					ERR_PRINTF2(_L("Expected error = %d"), KErrNotSupported);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7416
					StopTest(err, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7417
					}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7418
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7419
			else if (aDevSoundEvent == EEventInitComplete && aError != KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7420
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7421
				ERR_PRINTF2(_L("DevSound called CMMFDevSound::InitializeComplete with error = %d"), aError);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7422
				StopTest(aError);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7423
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7424
			else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7425
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7426
				ERR_PRINTF2(_L("DevSound EEventInitComplete not received as expected. Received event: %d"), aDevSoundEvent);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7427
				StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7428
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7429
			break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7430
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7431
		default:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7432
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7433
			ERR_PRINTF2(_L("Invalid DevSound state received: %d"), iDevSoundState);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7434
			StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7435
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7436
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7437
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7438
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7439
/*
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7440
 *========================================================================================================
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7441
 * MM-A3F-DEVSOUND-CHRTZ-TONE-0053
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7442
 */
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7443
RA3FDevSoundTonePlayDTMFStringOnceInitializedToPlayAudioTest::RA3FDevSoundTonePlayDTMFStringOnceInitializedToPlayAudioTest(const TDesC& aTestName)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7444
	:	RA3FDevSoundTestBase(aTestName), iDTMFString(KNullDesC)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7445
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7446
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7447
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7448
RA3FDevSoundTonePlayDTMFStringOnceInitializedToPlayAudioTest* RA3FDevSoundTonePlayDTMFStringOnceInitializedToPlayAudioTest::NewL(const TDesC& aTestName)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7449
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7450
	RA3FDevSoundTonePlayDTMFStringOnceInitializedToPlayAudioTest * self = new(ELeave)RA3FDevSoundTonePlayDTMFStringOnceInitializedToPlayAudioTest(aTestName);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7451
	return self;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7452
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7453
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7454
void RA3FDevSoundTonePlayDTMFStringOnceInitializedToPlayAudioTest::DoKickoffTestL()
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7455
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7456
	TPtrC DTMF;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7457
	if (!GetStringFromConfig(iTestStepName, KDTMFString, DTMF))
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7458
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7459
		ERR_PRINTF2(KMsgErrorGetParameter, &KDTMFString);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7460
		StopTest(KErrNotFound);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7461
		return;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7462
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7463
	iDTMFString.Copy(DTMF);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7464
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7465
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7466
void RA3FDevSoundTonePlayDTMFStringOnceInitializedToPlayAudioTest::Fsm(TMmfDevSoundEvent aDevSoundEvent, TInt aError)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7467
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7468
	switch(iDevSoundState)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7469
	{		
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7470
		case EStateCreated:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7471
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7472
			__ASSERT_ALWAYS((aError == KErrNone), Panic(_L("RA3FDevSoundTonePlayDTMFStringOnceInitializedToPlayAudioTest"), EFsmIncorrectErrorPassed));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7473
			if (aDevSoundEvent == EEventInitialize)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7474
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7475
				INFO_PRINTF1(_L("Calling iMMFDevSound::InitializeL for playing audio files"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7476
				TRAPD(err, iMMFDevSound->InitializeL(*this, EMMFStatePlaying));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7477
				if (err != KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7478
					{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7479
					ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"), err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7480
					StopTest(err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7481
					break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7482
					}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7483
				INFO_PRINTF1(_L("DevSound State: EStateInitializing"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7484
				iDevSoundState = EStateInitializing;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7485
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7486
			else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7487
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7488
				ERR_PRINTF2(_L("DevSound EEventInitialize not received as expected. Received event: %d"), aDevSoundEvent);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7489
				StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7490
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7491
			break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7492
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7493
		case EStateInitializing:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7494
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7495
			if (aDevSoundEvent == EEventInitComplete && aError == KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7496
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7497
				INFO_PRINTF2(_L("Calling CMMFDevSound::PlayDTMFStringL %S "), &iDTMFString);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7498
				TRAPD(err, iMMFDevSound->PlayDTMFStringL(iDTMFString));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7499
				if (err	== KErrNotSupported)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7500
					{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7501
					ERR_PRINTF2(_L("CMMFDevSound::PlayDTMFStringL left with KErrNotSupported %d which is the expected error"), err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7502
					StopTest();
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7503
					}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7504
				else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7505
					{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7506
					ERR_PRINTF2(_L("CMMFDevSound::PlayDTMFStringL left with error = %d"), err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7507
					ERR_PRINTF2(_L("Expected error = %d"), KErrNotSupported);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7508
					StopTest(err, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7509
					}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7510
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7511
			else if (aDevSoundEvent == EEventInitComplete && aError != KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7512
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7513
				ERR_PRINTF2(_L("DevSound called CMMFDevSound::InitializeComplete with error = %d"), aError);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7514
				StopTest(aError);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7515
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7516
			else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7517
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7518
				ERR_PRINTF2(_L("DevSound EEventInitComplete not received as expected. Received event: %d"), aDevSoundEvent);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7519
				StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7520
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7521
			break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7522
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7523
		default:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7524
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7525
			ERR_PRINTF2(_L("Invalid DevSound state received: %d"), iDevSoundState);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7526
			StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7527
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7528
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7529
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7530
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7531
/*
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7532
 *========================================================================================================
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7533
 * MM-A3F-DEVSOUND-CHRTZ-TONE-0054
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7534
 */
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7535
RA3FDevSoundTonePlayToneSequenceOnceInitializedToPlayAudioTest::RA3FDevSoundTonePlayToneSequenceOnceInitializedToPlayAudioTest(const TDesC& aTestName)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7536
	:	RA3FDevSoundTestBase(aTestName)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7537
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7538
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7539
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7540
RA3FDevSoundTonePlayToneSequenceOnceInitializedToPlayAudioTest* RA3FDevSoundTonePlayToneSequenceOnceInitializedToPlayAudioTest::NewL(const TDesC& aTestName)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7541
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7542
	RA3FDevSoundTonePlayToneSequenceOnceInitializedToPlayAudioTest * self = new(ELeave)RA3FDevSoundTonePlayToneSequenceOnceInitializedToPlayAudioTest(aTestName);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7543
	return self;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7544
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7545
void RA3FDevSoundTonePlayToneSequenceOnceInitializedToPlayAudioTest::DoKickoffTestL()
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7546
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7547
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7548
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7549
void RA3FDevSoundTonePlayToneSequenceOnceInitializedToPlayAudioTest::Fsm(TMmfDevSoundEvent aDevSoundEvent,  TInt aError)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7550
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7551
	switch(iDevSoundState)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7552
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7553
		case EStateCreated:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7554
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7555
			__ASSERT_ALWAYS((aError == KErrNone), Panic(_L("RA3FDevSoundTonePlayToneSequenceOnceInitializedToPlayAudioTest"), EFsmIncorrectErrorPassed));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7556
			if (aDevSoundEvent == EEventInitialize)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7557
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7558
				INFO_PRINTF1(_L("Calling iMMFDevSound::InitializeL for playing audio files"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7559
				TRAPD(err, iMMFDevSound->InitializeL(*this,  EMMFStatePlaying));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7560
				if (err != KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7561
					{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7562
					ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"), err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7563
					StopTest(err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7564
					break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7565
					}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7566
				INFO_PRINTF1(_L("DevSound State: EStateInitializing"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7567
				iDevSoundState = EStateInitializing;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7568
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7569
			else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7570
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7571
				ERR_PRINTF2(_L("DevSound EEventInitialize not received as expected. Received event: %d"), aDevSoundEvent);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7572
				StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7573
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7574
			break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7575
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7576
		case EStateInitializing:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7577
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7578
			if (aDevSoundEvent == EEventInitComplete && aError == KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7579
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7580
				TUint8* tablePointer = const_cast<TUint8*>( &(KFixedSequenceTestSequenceDataX[0] ) ); 
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7581
				TPtrC8 KFixedSequenceData(tablePointer,  sizeof(KFixedSequenceTestSequenceDataX));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7582
				INFO_PRINTF1(_L("Calling CMMFDevSound::PlayToneSequenceL"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7583
				TRAPD(err,  iMMFDevSound->PlayToneSequenceL(KFixedSequenceData));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7584
				if (err == KErrNotSupported)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7585
					{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7586
					ERR_PRINTF2(_L("CMMFDevSound::PlayToneSequenceL left with KErrNotSupported %d which is the expected error"), err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7587
					StopTest(err, EPass);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7588
					}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7589
				else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7590
					{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7591
					ERR_PRINTF2(_L("Play  dual tone failed with error = %d"),  err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7592
					ERR_PRINTF2(_L("Expected error = %d"), KErrNotSupported);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7593
					StopTest(err, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7594
					}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7595
				}	
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7596
			else if (aDevSoundEvent == EEventInitComplete && aError != KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7597
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7598
				ERR_PRINTF2(_L("DevSound called CMMFDevSound::InitializeComplete with error = %d"), aError);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7599
				StopTest(aError);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7600
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7601
			else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7602
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7603
				ERR_PRINTF2(_L("DevSound EEventInitComplete not received as expected. Received event: %d"), aDevSoundEvent);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7604
				StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7605
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7606
			break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7607
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7608
		default:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7609
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7610
			ERR_PRINTF2(_L("Invalid DevSound state received: %d"), iDevSoundState);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7611
			StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7612
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7613
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7614
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7615
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7616
/*
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7617
 *========================================================================================================
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7618
 * MM-A3F-DEVSOUND-CHRTZ-TONE-0055
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7619
 */
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7620
RA3FDevSoundTonePlayToneOnceInitializedToRecordAudioTest::RA3FDevSoundTonePlayToneOnceInitializedToRecordAudioTest(const TDesC& aTestName)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7621
	:	RA3FDevSoundTestBase(aTestName), iDuration(0),
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7622
		iFrequencyTone1(0)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7623
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7624
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7625
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7626
RA3FDevSoundTonePlayToneOnceInitializedToRecordAudioTest* RA3FDevSoundTonePlayToneOnceInitializedToRecordAudioTest::NewL(const TDesC& aTestName)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7627
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7628
	RA3FDevSoundTonePlayToneOnceInitializedToRecordAudioTest * self = new(ELeave)RA3FDevSoundTonePlayToneOnceInitializedToRecordAudioTest(aTestName);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7629
	return self;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7630
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7631
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7632
void RA3FDevSoundTonePlayToneOnceInitializedToRecordAudioTest::DoKickoffTestL()
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7633
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7634
	if (!GetIntFromConfig(iTestStepName, KDuration, iDuration)) 
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7635
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7636
		ERR_PRINTF2(KMsgErrorGetParameter, &KDuration);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7637
		StopTest(KErrNotFound);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7638
		return;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7639
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7640
	if (!GetIntFromConfig(iTestStepName, KFrequencyTone1, iFrequencyTone1)) 
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7641
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7642
		ERR_PRINTF2(KMsgErrorGetParameter, &KFrequencyTone1);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7643
		StopTest(KErrNotFound);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7644
		return;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7645
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7646
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7647
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7648
void RA3FDevSoundTonePlayToneOnceInitializedToRecordAudioTest::Fsm(TMmfDevSoundEvent aDevSoundEvent, TInt aError)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7649
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7650
	switch (iDevSoundState)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7651
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7652
		case EStateCreated:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7653
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7654
			__ASSERT_ALWAYS((aError == KErrNone), Panic(_L("RA3FDevSoundTonePlayToneOnceInitializedToRecordAudioTest"), EFsmIncorrectErrorPassed));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7655
			if (aDevSoundEvent == EEventInitialize)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7656
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7657
				INFO_PRINTF1(_L("Calling CMMFDevSound::InitializeL for recording audio files"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7658
				TRAPD(err, iMMFDevSound->InitializeL(*this, EMMFStateRecording));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7659
				if (err != KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7660
					{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7661
					ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"), err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7662
					StopTest(err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7663
					break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7664
					}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7665
				INFO_PRINTF1(_L("DevSound State: EStateInitializing"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7666
				iDevSoundState = EStateInitializing;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7667
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7668
			else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7669
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7670
				ERR_PRINTF2(_L("DevSound EEventInitialize not received as expected. Received event: %d"), aDevSoundEvent);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7671
				StopTest(aError,  EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7672
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7673
			break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7674
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7675
		case EStateInitializing:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7676
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7677
			if (aDevSoundEvent == EEventInitComplete && aError == KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7678
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7679
				INFO_PRINTF3(_L("Calling CMMFDevSound::PlayToneL using %d Hz during %d secs"), iFrequencyTone1, iDuration);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7680
				TRAPD(err, iMMFDevSound->PlayToneL(iFrequencyTone1, iDuration*KMicroSecsInOneSec));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7681
				if (err	== KErrNotSupported)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7682
					{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7683
					ERR_PRINTF2(_L("CMMFDevSound::PlayToneL left with KErrNotSupported %d which is the expected error"), err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7684
					StopTest();
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7685
					}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7686
				else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7687
					{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7688
					ERR_PRINTF2(_L("CMMFDevSound::PlayToneL left with error = %d"), err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7689
					ERR_PRINTF2(_L("Expected error = %d"), KErrNotSupported);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7690
					StopTest(err, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7691
					}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7692
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7693
			else if (aDevSoundEvent == EEventInitComplete && aError != KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7694
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7695
				ERR_PRINTF2(_L("DevSound called CMMFDevSound::InitializeComplete with error = %d"), aError);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7696
				StopTest(aError);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7697
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7698
			else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7699
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7700
				ERR_PRINTF2(_L("DevSound EEventInitComplete not received as expected. Received event: %d"), aDevSoundEvent);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7701
				StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7702
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7703
			break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7704
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7705
		default:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7706
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7707
			ERR_PRINTF2(_L("Invalid DevSound state received: %d"), iDevSoundState);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7708
			StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7709
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7710
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7711
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7712
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7713
/*
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7714
 *========================================================================================================
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7715
 * MM-A3F-DEVSOUND-CHRTZ-TONE-0056
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7716
 */
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7717
RA3FDevSoundTonePlayDualToneOnceInitializedToRecordAudioTest::RA3FDevSoundTonePlayDualToneOnceInitializedToRecordAudioTest(const TDesC& aTestName)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7718
	:	RA3FDevSoundTestBase(aTestName), iDuration(0),
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7719
		iFrequencyTone1(0), iFrequencyTone2(0)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7720
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7721
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7722
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7723
RA3FDevSoundTonePlayDualToneOnceInitializedToRecordAudioTest* RA3FDevSoundTonePlayDualToneOnceInitializedToRecordAudioTest::NewL(const TDesC& aTestName)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7724
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7725
	RA3FDevSoundTonePlayDualToneOnceInitializedToRecordAudioTest * self = new(ELeave)RA3FDevSoundTonePlayDualToneOnceInitializedToRecordAudioTest(aTestName);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7726
	return self;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7727
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7728
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7729
void RA3FDevSoundTonePlayDualToneOnceInitializedToRecordAudioTest::DoKickoffTestL()
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7730
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7731
	if (!GetIntFromConfig(iTestStepName, KDuration, iDuration)) 
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7732
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7733
		ERR_PRINTF2(KMsgErrorGetParameter, &KDuration);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7734
		StopTest(KErrNotFound);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7735
		return;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7736
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7737
	if (!GetIntFromConfig(iTestStepName, KFrequencyTone1, iFrequencyTone1)) 
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7738
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7739
		ERR_PRINTF2(KMsgErrorGetParameter, &KFrequencyTone1);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7740
		StopTest(KErrNotFound);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7741
		return;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7742
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7743
	if (!GetIntFromConfig(iTestStepName, KFrequencyTone2, iFrequencyTone2)) 
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7744
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7745
		ERR_PRINTF2(KMsgErrorGetParameter, &KFrequencyTone2);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7746
		StopTest(KErrNotFound);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7747
		return;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7748
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7749
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7750
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7751
void RA3FDevSoundTonePlayDualToneOnceInitializedToRecordAudioTest::Fsm(TMmfDevSoundEvent aDevSoundEvent, TInt aError)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7752
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7753
	switch(iDevSoundState)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7754
		{		
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7755
		case EStateCreated:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7756
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7757
			__ASSERT_ALWAYS((aError == KErrNone), Panic(_L("RA3FDevSoundTonePlayDualToneOnceInitializedToRecordAudioTest"), EFsmIncorrectErrorPassed));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7758
			if (aDevSoundEvent == EEventInitialize)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7759
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7760
				INFO_PRINTF1(_L("Calling CMMFDevSound::InitializeL for recording audio files"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7761
				TRAPD(err, iMMFDevSound->InitializeL(*this, EMMFStateRecording));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7762
				if (err != KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7763
					{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7764
					ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"), err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7765
					StopTest(err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7766
					break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7767
					}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7768
				INFO_PRINTF1(_L("DevSound State: EStateInitializing"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7769
				iDevSoundState = EStateInitializing;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7770
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7771
			else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7772
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7773
				ERR_PRINTF2(_L("DevSound EEventInitialize not received as expected. Received event: %d"), aDevSoundEvent);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7774
				StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7775
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7776
			break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7777
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7778
		case EStateInitializing:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7779
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7780
			if (aDevSoundEvent == EEventInitComplete && aError == KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7781
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7782
				INFO_PRINTF4(_L("Calling CMMFDevSound::PlayDualToneL using %d Hz %d Hz during %d secs "), iFrequencyTone1, iFrequencyTone2, iDuration);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7783
				TRAPD(err, iMMFDevSound->PlayDualToneL(iFrequencyTone1, iFrequencyTone2, iDuration*KMicroSecsInOneSec));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7784
				if (err	== KErrNotSupported)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7785
					{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7786
					ERR_PRINTF2(_L("CMMFDevSound::PlayDualToneL left with KErrNotSupported %d which is the expected error"), err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7787
					StopTest(err, EPass);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7788
					}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7789
				else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7790
					{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7791
					ERR_PRINTF2(_L("CMMFDevSound::PlayDualToneL left with error = %d"), err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7792
					ERR_PRINTF2(_L("Expected error = %d"), KErrNotSupported);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7793
					StopTest(err, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7794
					}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7795
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7796
			else if (aDevSoundEvent == EEventInitComplete && aError != KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7797
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7798
				ERR_PRINTF2(_L("DevSound called CMMFDevSound::InitializeComplete with error = %d"), aError);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7799
				StopTest(aError);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7800
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7801
			else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7802
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7803
				ERR_PRINTF2(_L("DevSound EEventInitComplete not received as expected. Received event: %d"), aDevSoundEvent);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7804
				StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7805
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7806
			break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7807
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7808
		default:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7809
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7810
			ERR_PRINTF2(_L("Invalid DevSound state received: %d"), iDevSoundState);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7811
			StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7812
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7813
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7814
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7815
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7816
/*
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7817
 *========================================================================================================
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7818
 * MM-A3F-DEVSOUND-CHRTZ-TONE-0057
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7819
 */
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7820
RA3FDevSoundTonePlayDTMFStringOnceInitializedToRecordAudioTest::RA3FDevSoundTonePlayDTMFStringOnceInitializedToRecordAudioTest(const TDesC& aTestName)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7821
	:	RA3FDevSoundTestBase(aTestName), iDTMFString(KNullDesC)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7822
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7823
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7824
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7825
RA3FDevSoundTonePlayDTMFStringOnceInitializedToRecordAudioTest* RA3FDevSoundTonePlayDTMFStringOnceInitializedToRecordAudioTest::NewL(const TDesC& aTestName)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7826
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7827
	RA3FDevSoundTonePlayDTMFStringOnceInitializedToRecordAudioTest * self = new(ELeave)RA3FDevSoundTonePlayDTMFStringOnceInitializedToRecordAudioTest(aTestName);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7828
	return self;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7829
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7830
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7831
void RA3FDevSoundTonePlayDTMFStringOnceInitializedToRecordAudioTest::DoKickoffTestL()
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7832
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7833
	TPtrC DTMF;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7834
	if (!GetStringFromConfig(iTestStepName, KDTMFString, DTMF))
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7835
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7836
		ERR_PRINTF2(KMsgErrorGetParameter, &KDTMFString);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7837
		StopTest(KErrNotFound);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7838
		return;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7839
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7840
	iDTMFString.Copy(DTMF);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7841
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7842
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7843
void RA3FDevSoundTonePlayDTMFStringOnceInitializedToRecordAudioTest::Fsm(TMmfDevSoundEvent aDevSoundEvent, TInt aError)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7844
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7845
	switch(iDevSoundState)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7846
	{		
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7847
		case EStateCreated:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7848
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7849
			__ASSERT_ALWAYS((aError == KErrNone), Panic(_L("RA3FDevSoundTonePlayDTMFStringOnceInitializedToRecordAudioTest"), EFsmIncorrectErrorPassed));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7850
			if (aDevSoundEvent == EEventInitialize)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7851
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7852
				INFO_PRINTF1(_L("Calling iMMFDevSound::InitializeL for recording audio files"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7853
				TRAPD(err, iMMFDevSound->InitializeL(*this, EMMFStateRecording));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7854
				if (err != KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7855
					{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7856
					ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"), err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7857
					StopTest(err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7858
					break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7859
					}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7860
				INFO_PRINTF1(_L("DevSound State: EStateInitializing"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7861
				iDevSoundState = EStateInitializing;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7862
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7863
			else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7864
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7865
				ERR_PRINTF2(_L("DevSound EEventInitialize not received as expected. Received event: %d"), aDevSoundEvent);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7866
				StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7867
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7868
			break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7869
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7870
		case EStateInitializing:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7871
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7872
			if (aDevSoundEvent == EEventInitComplete && aError == KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7873
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7874
				INFO_PRINTF2(_L("Calling CMMFDevSound::PlayDTMFStringL %S "), &iDTMFString);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7875
				TRAPD(err, iMMFDevSound->PlayDTMFStringL(iDTMFString));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7876
				if (err	== KErrNotSupported)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7877
					{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7878
					ERR_PRINTF2(_L("CMMFDevSound::PlayDTMFStringL left with KErrNotSupported %d which is the expected error"), err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7879
					StopTest();
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7880
					}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7881
				else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7882
					{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7883
					ERR_PRINTF2(_L("CMMFDevSound::PlayDTMFStringL left with error = %d"), err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7884
					ERR_PRINTF2(_L("Expected error = %d"), KErrNotSupported);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7885
					StopTest(err, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7886
					}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7887
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7888
			else if (aDevSoundEvent == EEventInitComplete && aError != KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7889
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7890
				ERR_PRINTF2(_L("DevSound called CMMFDevSound::InitializeComplete with error = %d"), aError);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7891
				StopTest(aError);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7892
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7893
			else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7894
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7895
				ERR_PRINTF2(_L("DevSound EEventInitComplete not received as expected. Received event: %d"), aDevSoundEvent);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7896
				StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7897
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7898
			break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7899
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7900
		default:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7901
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7902
			ERR_PRINTF2(_L("Invalid DevSound state received: %d"), iDevSoundState);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7903
			StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7904
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7905
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7906
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7907
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7908
/*
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7909
 *========================================================================================================
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7910
 * MM-A3F-DEVSOUND-CHRTZ-TONE-0058
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7911
 */
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7912
RA3FDevSoundTonePlayToneSequenceOnceInitializedToRecordAudioTest::RA3FDevSoundTonePlayToneSequenceOnceInitializedToRecordAudioTest(const TDesC& aTestName)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7913
	:	RA3FDevSoundTestBase(aTestName)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7914
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7915
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7916
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7917
RA3FDevSoundTonePlayToneSequenceOnceInitializedToRecordAudioTest* RA3FDevSoundTonePlayToneSequenceOnceInitializedToRecordAudioTest::NewL(const TDesC& aTestName)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7918
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7919
	RA3FDevSoundTonePlayToneSequenceOnceInitializedToRecordAudioTest * self = new(ELeave)RA3FDevSoundTonePlayToneSequenceOnceInitializedToRecordAudioTest(aTestName);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7920
	return self;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7921
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7922
void RA3FDevSoundTonePlayToneSequenceOnceInitializedToRecordAudioTest::DoKickoffTestL()
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7923
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7924
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7925
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7926
void RA3FDevSoundTonePlayToneSequenceOnceInitializedToRecordAudioTest::Fsm(TMmfDevSoundEvent aDevSoundEvent,  TInt aError)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7927
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7928
	switch(iDevSoundState)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7929
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7930
		case EStateCreated:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7931
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7932
			__ASSERT_ALWAYS((aError == KErrNone), Panic(_L("RA3FDevSoundTonePlayToneSequenceOnceInitializedToRecordAudioTest"), EFsmIncorrectErrorPassed));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7933
			if (aDevSoundEvent == EEventInitialize)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7934
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7935
				INFO_PRINTF1(_L("Calling iMMFDevSound::InitializeL for playing audio files"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7936
				TRAPD(err, iMMFDevSound->InitializeL(*this,  EMMFStateRecording));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7937
				if (err != KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7938
					{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7939
					ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"), err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7940
					StopTest(err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7941
					break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7942
					}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7943
				INFO_PRINTF1(_L("DevSound State: EStateInitializing"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7944
				iDevSoundState = EStateInitializing;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7945
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7946
			else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7947
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7948
				ERR_PRINTF2(_L("DevSound EEventInitialize not received as expected. Received event: %d"), aDevSoundEvent);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7949
				StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7950
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7951
			break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7952
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7953
		case EStateInitializing:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7954
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7955
			if (aDevSoundEvent == EEventInitComplete && aError == KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7956
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7957
				TUint8* tablePointer = const_cast<TUint8*>( &(KFixedSequenceTestSequenceDataX[0] ) ); 
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7958
				TPtrC8 KFixedSequenceData(tablePointer,  sizeof(KFixedSequenceTestSequenceDataX));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7959
				INFO_PRINTF1(_L("Calling CMMFDevSound::PlayToneSequenceL"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7960
				TRAPD(err,  iMMFDevSound->PlayToneSequenceL(KFixedSequenceData));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7961
				if (err == KErrNotSupported)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7962
					{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7963
					ERR_PRINTF2(_L("CMMFDevSound::PlayToneSequenceL left with KErrNotSupported %d which is the expected error"), err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7964
					StopTest(err, EPass);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7965
					}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7966
				else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7967
					{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7968
					ERR_PRINTF2(_L("Play  dual tone failed with error = %d"),  err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7969
					ERR_PRINTF2(_L("Expected error = %d"), KErrNotSupported);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7970
					StopTest(err, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7971
					}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7972
				}	
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7973
			else if (aDevSoundEvent == EEventInitComplete && aError != KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7974
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7975
				ERR_PRINTF2(_L("DevSound called CMMFDevSound::InitializeComplete with error = %d"), aError);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7976
				StopTest(aError);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7977
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7978
			else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7979
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7980
				ERR_PRINTF2(_L("DevSound EEventInitComplete not received as expected. Received event: %d"), aDevSoundEvent);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7981
				StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7982
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7983
			break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7984
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7985
		default:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7986
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7987
			ERR_PRINTF2(_L("Invalid DevSound state received: %d"), iDevSoundState);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7988
			StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7989
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7990
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7991
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7992
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7993
/*
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7994
 *========================================================================================================
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7995
 * MM-A3F-DEVSOUND-CHRTZ-TONE-0059
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7996
 */
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7997
RA3FDevSoundTonePlayToneWithoutCallingInitializeTest::RA3FDevSoundTonePlayToneWithoutCallingInitializeTest(const TDesC& aTestName)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7998
	:	RA3FDevSoundTestBase(aTestName), iDuration(0),
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  7999
		iFrequencyTone1(0)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8000
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8001
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8002
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8003
RA3FDevSoundTonePlayToneWithoutCallingInitializeTest* RA3FDevSoundTonePlayToneWithoutCallingInitializeTest::NewL(const TDesC& aTestName)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8004
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8005
	RA3FDevSoundTonePlayToneWithoutCallingInitializeTest * self = new(ELeave)RA3FDevSoundTonePlayToneWithoutCallingInitializeTest(aTestName);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8006
	return self;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8007
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8008
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8009
void RA3FDevSoundTonePlayToneWithoutCallingInitializeTest::DoKickoffTestL()
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8010
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8011
	if (!GetIntFromConfig(iTestStepName, KDuration, iDuration)) 
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8012
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8013
		ERR_PRINTF2(KMsgErrorGetParameter, &KDuration);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8014
		StopTest(KErrNotFound);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8015
		return;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8016
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8017
	if (!GetIntFromConfig(iTestStepName, KFrequencyTone1, iFrequencyTone1)) 
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8018
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8019
		ERR_PRINTF2(KMsgErrorGetParameter, &KFrequencyTone1);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8020
		StopTest(KErrNotFound);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8021
		return;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8022
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8023
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8024
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8025
void RA3FDevSoundTonePlayToneWithoutCallingInitializeTest::Fsm(TMmfDevSoundEvent aDevSoundEvent,  TInt aError)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8026
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8027
	switch (iDevSoundState)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8028
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8029
		case EStateCreated:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8030
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8031
			__ASSERT_ALWAYS((aError == KErrNone), Panic(_L("RA3FDevSoundTonePlayToneWithoutCallingInitializeTest"), EFsmIncorrectErrorPassed));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8032
			if (aDevSoundEvent == EEventInitialize)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8033
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8034
				INFO_PRINTF3(_L("Calling CMMFDevSound::PlayToneL using %d Hz during %d secs"), iFrequencyTone1, iDuration);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8035
				TRAPD(err, iMMFDevSound->PlayToneL(iFrequencyTone1, iDuration*KMicroSecsInOneSec));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8036
				if (err	== KErrNotReady)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8037
					{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8038
					ERR_PRINTF2(_L("CMMFDevSound::PlayToneL left with KErrNotReady %d which is the expected error"), err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8039
					StopTest();
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8040
					}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8041
				else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8042
					{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8043
					ERR_PRINTF2(_L("CMMFDevSound::PlayToneL left with error = %d"), err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8044
					ERR_PRINTF2(_L("Expected error = %d"), KErrNotReady);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8045
					StopTest(err, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8046
					}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8047
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8048
			else if (aDevSoundEvent == EEventInitComplete && aError != KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8049
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8050
				ERR_PRINTF2(_L("DevSound called CMMFDevSound::InitializeComplete with error = %d"), aError);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8051
				StopTest(aError);	
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8052
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8053
			else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8054
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8055
				ERR_PRINTF2(_L("DevSound EEventInitComplete not received as expected. Received event: %d"), aDevSoundEvent);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8056
				StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8057
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8058
			break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8059
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8060
		default:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8061
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8062
			ERR_PRINTF2(_L("Invalid DevSound state received: %d"),  iDevSoundState);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8063
			StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8064
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8065
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8066
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8067
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8068
/*
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8069
 *========================================================================================================
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8070
 * MM-A3F-DEVSOUND-CHRTZ-TONE-0060
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8071
 */
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8072
RA3FDevSoundTonePlayDualToneWithoutCallingInitializeTest::RA3FDevSoundTonePlayDualToneWithoutCallingInitializeTest(const TDesC& aTestName)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8073
	:	RA3FDevSoundTestBase(aTestName), iDuration(0),
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8074
		iFrequencyTone1(0), iFrequencyTone2(0)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8075
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8076
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8077
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8078
RA3FDevSoundTonePlayDualToneWithoutCallingInitializeTest* RA3FDevSoundTonePlayDualToneWithoutCallingInitializeTest::NewL(const TDesC& aTestName)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8079
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8080
	RA3FDevSoundTonePlayDualToneWithoutCallingInitializeTest * self = new(ELeave)RA3FDevSoundTonePlayDualToneWithoutCallingInitializeTest(aTestName);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8081
	return self;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8082
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8083
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8084
void RA3FDevSoundTonePlayDualToneWithoutCallingInitializeTest::DoKickoffTestL()
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8085
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8086
	if (!GetIntFromConfig(iTestStepName, KDuration, iDuration)) 
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8087
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8088
		ERR_PRINTF2(KMsgErrorGetParameter, &KDuration);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8089
		StopTest(KErrNotFound);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8090
		return;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8091
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8092
	if (!GetIntFromConfig(iTestStepName, KFrequencyTone1, iFrequencyTone1)) 
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8093
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8094
		ERR_PRINTF2(KMsgErrorGetParameter, &KFrequencyTone1);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8095
		StopTest(KErrNotFound);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8096
		return;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8097
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8098
	if (!GetIntFromConfig(iTestStepName, KFrequencyTone2, iFrequencyTone2)) 
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8099
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8100
		ERR_PRINTF2(KMsgErrorGetParameter, &KFrequencyTone2);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8101
		StopTest(KErrNotFound);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8102
		return;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8103
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8104
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8105
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8106
void RA3FDevSoundTonePlayDualToneWithoutCallingInitializeTest::Fsm(TMmfDevSoundEvent aDevSoundEvent, TInt aError)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8107
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8108
	switch (iDevSoundState)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8109
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8110
		case EStateCreated:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8111
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8112
			__ASSERT_ALWAYS((aError == KErrNone), Panic(_L("RA3FDevSoundTonePlayDualToneWithoutCallingInitializeTest"), EFsmIncorrectErrorPassed));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8113
			if (aDevSoundEvent == EEventInitialize)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8114
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8115
				INFO_PRINTF4(_L("Calling CMMFDevSound::PlayDualToneL using %d Hz %d Hz during %d secs "), iFrequencyTone1, iFrequencyTone2, iDuration);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8116
				TRAPD(err, iMMFDevSound->PlayDualToneL(iFrequencyTone1, iFrequencyTone2, iDuration*KMicroSecsInOneSec));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8117
				if (err == KErrNotReady)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8118
					{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8119
					ERR_PRINTF2(_L("CMMFDevSound::PlayDualToneL left with KErrNotReady %d which is the expected error"), err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8120
					StopTest();
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8121
					}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8122
				else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8123
					{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8124
					ERR_PRINTF2(_L("CMMFDevSound::PlayDualToneL left with error = %d"), err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8125
					ERR_PRINTF2(_L("Expected error = %d"), KErrNotReady);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8126
					StopTest(err, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8127
					}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8128
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8129
			else if (aDevSoundEvent == EEventInitComplete && aError != KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8130
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8131
				ERR_PRINTF2(_L("DevSound called CMMFDevSound::InitializeComplete with error = %d"), aError);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8132
				StopTest(aError);	
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8133
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8134
			else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8135
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8136
				ERR_PRINTF2(_L("DevSound EEventInitComplete not received as expected. Received event: %d"), aDevSoundEvent);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8137
				StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8138
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8139
			break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8140
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8141
		default:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8142
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8143
			ERR_PRINTF2(_L("Invalid DevSound state received: %d"), iDevSoundState);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8144
			StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8145
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8146
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8147
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8148
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8149
/*
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8150
 *========================================================================================================
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8151
 * MM-A3F-DEVSOUND-CHRTZ-TONE-0061
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8152
 */
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8153
RA3FDevSoundTonePlayDTMFStringWithoutCallingInitializeTest::RA3FDevSoundTonePlayDTMFStringWithoutCallingInitializeTest(const TDesC& aTestName)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8154
	:	RA3FDevSoundTestBase(aTestName), iDTMFString(KNullDesC)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8155
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8156
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8157
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8158
RA3FDevSoundTonePlayDTMFStringWithoutCallingInitializeTest* RA3FDevSoundTonePlayDTMFStringWithoutCallingInitializeTest::NewL(const TDesC& aTestName)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8159
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8160
	RA3FDevSoundTonePlayDTMFStringWithoutCallingInitializeTest * self = new(ELeave)RA3FDevSoundTonePlayDTMFStringWithoutCallingInitializeTest(aTestName);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8161
	return self;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8162
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8163
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8164
void RA3FDevSoundTonePlayDTMFStringWithoutCallingInitializeTest::DoKickoffTestL()
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8165
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8166
	TPtrC DTMF;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8167
	if (!GetStringFromConfig(iTestStepName, KDTMFString, DTMF))
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8168
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8169
		ERR_PRINTF2(KMsgErrorGetParameter, &KDTMFString);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8170
		StopTest(KErrNotFound);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8171
		return;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8172
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8173
	iDTMFString.Copy(DTMF);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8174
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8175
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8176
void RA3FDevSoundTonePlayDTMFStringWithoutCallingInitializeTest::Fsm(TMmfDevSoundEvent aDevSoundEvent,  TInt aError)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8177
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8178
	switch (iDevSoundState)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8179
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8180
		case EStateCreated:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8181
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8182
			__ASSERT_ALWAYS((aError == KErrNone), Panic(_L("RA3FDevSoundTonePlayDTMFStringWithoutCallingInitializeTest"), EFsmIncorrectErrorPassed));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8183
			if (aDevSoundEvent == EEventInitialize)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8184
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8185
				INFO_PRINTF2(_L("Calling CMMFDevSound::PlayDTMFStringL %S"), &iDTMFString);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8186
				TRAPD(err, iMMFDevSound->PlayDTMFStringL(iDTMFString));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8187
				if (err == KErrNotReady)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8188
					{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8189
					ERR_PRINTF2(_L("CMMFDevSound::PlayDTMFStringL left with KErrNotReady %d which is the expected error"), err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8190
					StopTest();
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8191
					}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8192
				else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8193
					{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8194
					ERR_PRINTF2(_L("CMMFDevSound::PlayDTMFStringL left with error = %d"), err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8195
					ERR_PRINTF2(_L("Expected error = %d"), KErrNotReady);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8196
					StopTest(err, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8197
					}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8198
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8199
			else if (aDevSoundEvent == EEventInitComplete && aError != KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8200
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8201
				ERR_PRINTF2(_L("DevSound called CMMFDevSound::InitializeComplete with error = %d"), aError);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8202
				StopTest(aError);	
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8203
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8204
			else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8205
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8206
				ERR_PRINTF2(_L("DevSound EEventInitComplete not received as expected. Received event: %d"), aDevSoundEvent);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8207
				StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8208
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8209
			break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8210
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8211
		default:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8212
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8213
			ERR_PRINTF2(_L("Invalid DevSound state received: %d"), iDevSoundState);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8214
			StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8215
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8216
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8217
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8218
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8219
/*
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8220
 *========================================================================================================
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8221
 * MM-A3F-DEVSOUND-CHRTZ-TONE-0062
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8222
 */
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8223
RA3FDevSoundTonePlayToneSequenceWithoutCallingInitializeTest::RA3FDevSoundTonePlayToneSequenceWithoutCallingInitializeTest(const TDesC& aTestName)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8224
	:	RA3FDevSoundTestBase(aTestName)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8225
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8226
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8227
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8228
RA3FDevSoundTonePlayToneSequenceWithoutCallingInitializeTest* RA3FDevSoundTonePlayToneSequenceWithoutCallingInitializeTest::NewL(const TDesC& aTestName)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8229
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8230
	RA3FDevSoundTonePlayToneSequenceWithoutCallingInitializeTest * self = new(ELeave)RA3FDevSoundTonePlayToneSequenceWithoutCallingInitializeTest(aTestName);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8231
	return self;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8232
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8233
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8234
void RA3FDevSoundTonePlayToneSequenceWithoutCallingInitializeTest::DoKickoffTestL()
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8235
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8236
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8237
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8238
void RA3FDevSoundTonePlayToneSequenceWithoutCallingInitializeTest::Fsm(TMmfDevSoundEvent aDevSoundEvent, TInt aError)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8239
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8240
	switch (iDevSoundState)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8241
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8242
		case EStateCreated:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8243
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8244
			__ASSERT_ALWAYS((aError == KErrNone), Panic(_L("RA3FDevSoundTonePlayToneSequenceWithoutCallingInitializeTest"), EFsmIncorrectErrorPassed));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8245
			if (aDevSoundEvent == EEventInitialize)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8246
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8247
				TUint8* tablePointer = const_cast<TUint8*>( &(KFixedSequenceTestSequenceDataX[0] ) ); 
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8248
				TPtrC8 KFixedSequenceData(tablePointer,  sizeof(KFixedSequenceTestSequenceDataX));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8249
				INFO_PRINTF1(_L("Calling CMMFDevSound::PlayToneSequenceL"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8250
				TRAPD(err, iMMFDevSound->PlayToneSequenceL(KFixedSequenceData));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8251
				if (err == KErrNotReady)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8252
					{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8253
					ERR_PRINTF2(_L("CMMFDevSound::PlayToneSequenceL left with KErrNotReady %d which is the expected error"), err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8254
					StopTest();
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8255
					}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8256
				else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8257
					{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8258
					ERR_PRINTF2(_L("CMMFDevSound::PlayToneSequenceL left with error = %d"), err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8259
					ERR_PRINTF2(_L("Expected error = %d"), KErrNotReady);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8260
					StopTest(err, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8261
					}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8262
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8263
			else if (aDevSoundEvent == EEventInitComplete && aError != KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8264
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8265
				ERR_PRINTF2(_L("DevSound called CMMFDevSound::InitializeComplete with error = %d"), aError);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8266
				StopTest(aError);	
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8267
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8268
			else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8269
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8270
				ERR_PRINTF2(_L("DevSound EEventInitComplete not received as expected. Received event: %d"), aDevSoundEvent);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8271
				StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8272
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8273
			break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8274
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8275
		default:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8276
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8277
			ERR_PRINTF2(_L("Invalid DevSound state received: %d"), iDevSoundState);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8278
			StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8279
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8280
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8281
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8282
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8283
/*
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8284
 *========================================================================================================
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8285
 * MM-A3F-DEVSOUND-CHRTZ-TONE-0063
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8286
 */
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8287
RA3FDevSoundTonePlayToneSequenceUsingInvalidDescriptorTest::RA3FDevSoundTonePlayToneSequenceUsingInvalidDescriptorTest(const TDesC& aTestName)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8288
	:	RA3FDevSoundTestBase(aTestName), iInvalidToneSequence(KNullDesC8)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8289
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8290
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8291
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8292
RA3FDevSoundTonePlayToneSequenceUsingInvalidDescriptorTest* RA3FDevSoundTonePlayToneSequenceUsingInvalidDescriptorTest::NewL(const TDesC& aTestName)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8293
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8294
	RA3FDevSoundTonePlayToneSequenceUsingInvalidDescriptorTest * self = new(ELeave)RA3FDevSoundTonePlayToneSequenceUsingInvalidDescriptorTest(aTestName);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8295
	return self;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8296
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8297
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8298
void RA3FDevSoundTonePlayToneSequenceUsingInvalidDescriptorTest::DoKickoffTestL()
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8299
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8300
	TPtrC TS;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8301
	if ( !GetStringFromConfig(iTestStepName, KInvalidToneSequence,  TS) )
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8302
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8303
		ERR_PRINTF2(KMsgErrorGetParameter, &KInvalidToneSequence);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8304
		StopTest(KErrNotFound);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8305
		return;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8306
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8307
	iInvalidToneSequence.Copy(TS);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8308
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8309
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8310
void RA3FDevSoundTonePlayToneSequenceUsingInvalidDescriptorTest::Fsm(TMmfDevSoundEvent aDevSoundEvent,  TInt aError)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8311
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8312
	switch (iDevSoundState)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8313
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8314
		case EStateCreated:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8315
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8316
			__ASSERT_ALWAYS((aError == KErrNone), Panic(_L("RA3FDevSoundTonePlayToneSequenceUsingInvalidDescriptorTest"), EFsmIncorrectErrorPassed));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8317
			if (aDevSoundEvent == EEventInitialize)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8318
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8319
				INFO_PRINTF1(_L("Calling iMMFDevSound::InitializeL"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8320
				TRAPD(err, iMMFDevSound->InitializeL(*this, EMMFStateTonePlaying));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8321
				if (err != KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8322
					{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8323
					ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"),  err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8324
					StopTest(err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8325
					break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8326
					}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8327
				INFO_PRINTF1(_L("DevSound State: EStateInitializing"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8328
				iDevSoundState = EStateInitializing;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8329
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8330
			else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8331
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8332
				ERR_PRINTF2(_L("DevSound EEventInitialize not received as expected. Received event: %d"), aDevSoundEvent);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8333
				StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8334
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8335
			break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8336
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8337
		case EStateInitializing:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8338
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8339
			if (aDevSoundEvent == EEventInitComplete && aError == KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8340
				{				
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8341
				INFO_PRINTF1(_L("Calling iMMFDevSound->PlayToneSequenceL with an invalid descriptor as argument"));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8342
				TRAPD(err, iMMFDevSound->PlayToneSequenceL(iInvalidToneSequence));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8343
				if (err != KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8344
					{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8345
					ERR_PRINTF2(_L("CMMFDevSound::PlayToneSequenceL left with error = %d and it should not leave"), err);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8346
					StopTest(err, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8347
					}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8348
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8349
			else if (aDevSoundEvent == EEventInitComplete && aError != KErrNone)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8350
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8351
				ERR_PRINTF2(_L("DevSound called CMMFDevSound::InitializeComplete with error = %d"), aError);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8352
				StopTest(aError);	
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8353
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8354
			else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8355
				{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8356
				ERR_PRINTF2(_L("DevSound EEventInitComplete not received as expected. Received event: %d"), aDevSoundEvent);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8357
				StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8358
				}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8359
			break;
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8360
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8361
		default:
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8362
			{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8363
			ERR_PRINTF2(_L("Invalid DevSound state received: %d"), iDevSoundState);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8364
			StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8365
			}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8366
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8367
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8368
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8369
void RA3FDevSoundTonePlayToneSequenceUsingInvalidDescriptorTest::ToneFinished(TInt aError)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8370
	{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8371
	INFO_PRINTF1(_L("========== DevSound ToneFinished() callback =========="));
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8372
	if (aError == KErrCorrupt)
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8373
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8374
		INFO_PRINTF2(_L("ToneFinished called with KErrCorrupt %d which is the expected error"), aError);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8375
		StopTest();
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8376
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8377
	else
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8378
		{
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8379
		ERR_PRINTF3(_L("ToneFinished called with error = %d, when the expected error is = %d"), aError, KErrCorrupt);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8380
		StopTest(aError, EFail);
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8381
		}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8382
	}
c36d67f77f75 2010wk21_04
hgs
parents:
diff changeset
  8383