devsound/a3fcharacterisationtest/src/char_a3f_devsound_tonetest.cpp
author hgs
Wed, 13 Oct 2010 12:45:32 +0100
changeset 2 5c1df44f2eed
parent 0 b8ed18f6c07b
permissions -rw-r--r--
2010wk42_01
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
0
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
     1
// Copyright (c) 2008-2009 Nokia Corporation and/or its subsidiary(-ies).
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
     2
// All rights reserved.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
     3
// This component and the accompanying materials are made available
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
     4
// under the terms of "Eclipse Public License v1.0"
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
     5
// which accompanies this distribution, and is available
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
     6
// at the URL "http://www.eclipse.org/legal/epl-v10.html".
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
     7
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
     8
// Initial Contributors:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
     9
// Nokia Corporation - initial contribution.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    10
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    11
// Contributors:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    12
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    13
// Description:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    14
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    15
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    16
#include "char_a3f_devsound_tonetest.h"
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    17
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    18
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    19
/*
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    20
 *========================================================================================================
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    21
 * MM-A3F-DEVSOUND-CHRTZ-TONE-0001
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    22
 */
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    23
RA3FDevSoundToneSetConfigTest::RA3FDevSoundToneSetConfigTest(const TDesC& aTestName)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    24
	:	RA3FDevSoundTestBase(aTestName), iSampleRate(0),
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    25
		iChannels(0)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    26
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    27
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    28
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    29
RA3FDevSoundToneSetConfigTest* RA3FDevSoundToneSetConfigTest::NewL(const TDesC& aTestName)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    30
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    31
	RA3FDevSoundToneSetConfigTest * self = new(ELeave)RA3FDevSoundToneSetConfigTest(aTestName);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    32
	return self;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    33
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    34
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    35
void RA3FDevSoundToneSetConfigTest::DoKickoffTestL()
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    36
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    37
	if (!GetIntFromConfig(iTestStepName, KSampleRate, iSampleRate))
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    38
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    39
		ERR_PRINTF2(KMsgErrorGetParameter, &KSampleRate);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    40
		StopTest(KErrNotFound);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    41
		return;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    42
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    43
	if (!GetIntFromConfig(iTestStepName, KChannel, iChannels))
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    44
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    45
		ERR_PRINTF2(KMsgErrorGetParameter, &KChannel);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    46
		StopTest(KErrNotFound);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    47
		return;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    48
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    49
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    50
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    51
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    52
void RA3FDevSoundToneSetConfigTest::Fsm(TMmfDevSoundEvent aDevSoundEvent, TInt aError)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    53
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    54
	switch(iDevSoundState)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    55
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    56
		case EStateCreated:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    57
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    58
			if(aDevSoundEvent == EEventInitialize)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    59
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    60
				__ASSERT_ALWAYS((aError == KErrNone), Panic(_L("RA3FDevSoundToneSetConfigTest"), EFsmIncorrectErrorPassed));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    61
				INFO_PRINTF1(_L("Calling CMMFDevSound::InitializeL"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    62
				TRAPD(err, iMMFDevSound->InitializeL(*this, EMMFStateTonePlaying));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    63
				if (err != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    64
					{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    65
					ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"), err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    66
					StopTest(err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    67
					break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    68
					}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    69
				INFO_PRINTF1(_L("DevSound State: EStateInitializing"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    70
				iDevSoundState = EStateInitializing;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    71
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    72
			else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    73
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    74
				ERR_PRINTF2(_L("DevSound EEventInitialize not received as expected. Received event: %d"), aDevSoundEvent);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    75
				StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    76
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    77
			break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    78
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    79
		case EStateInitializing:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    80
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    81
			if (aDevSoundEvent == EEventInitComplete && aError == KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    82
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    83
				TMMFCapabilities capabilitiesSet;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    84
				TBuf<KMaxSampleRateStringLength> stringSampleRateSet;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    85
				TBuf<KMaxChannelsStringLength> stringChannelsSet;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    86
				TMMFSampleRate eSampleRate;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    87
				SampleRateFromTIntToTMMFSampleRate (iSampleRate, eSampleRate);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    88
				capabilitiesSet.iRate = eSampleRate;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    89
				capabilitiesSet.iChannels = iChannels;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    90
				SampleRateFromTUintToString (capabilitiesSet.iRate,	stringSampleRateSet);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    91
				ChannelsFromTUintToString (capabilitiesSet.iChannels, stringChannelsSet);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    92
				INFO_PRINTF3(_L("Calling CMMFDevSound::SetConfigL using sample rate = %S and channel mode =%S"), &stringSampleRateSet, &stringChannelsSet);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    93
				TRAPD(err, iMMFDevSound->SetConfigL(capabilitiesSet));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    94
				if (err != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    95
					{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    96
					ERR_PRINTF2(_L("CMMFDevSound::SetConfigL left with error = %d"), err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    97
					StopTest(err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    98
					break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    99
					}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   100
				TMMFCapabilities capabilitiesGet;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   101
				TBuf<KMaxSampleRateStringLength> stringSampleRateGet;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   102
				TBuf<KMaxChannelsStringLength> stringChannelsGet;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   103
				capabilitiesGet=iMMFDevSound->Config();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   104
				SampleRateFromTUintToString (capabilitiesGet.iRate, stringSampleRateGet);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   105
				ChannelsFromTUintToString (capabilitiesGet.iChannels, stringChannelsGet);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   106
				if (capabilitiesGet.iRate != capabilitiesSet.iRate && capabilitiesGet.iChannels != capabilitiesSet.iChannels)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   107
					{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   108
					ERR_PRINTF3(_L("Retrieved sample rate and channel %S %S"), &stringSampleRateGet, &stringChannelsGet);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   109
					ERR_PRINTF3(_L("Expected %S %S"), &stringSampleRateSet, &stringChannelsSet);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   110
					StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   111
					break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   112
					}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   113
				INFO_PRINTF1(_L("========== Test Case Successfully Completed =========="));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   114
				StopTest();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   115
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   116
			else if (aDevSoundEvent == EEventInitComplete && aError != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   117
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   118
				ERR_PRINTF2(_L("DevSound called CMMFDevSound::InitializeComplete with error = %d"), aError);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   119
				StopTest(aError);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   120
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   121
			else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   122
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   123
				ERR_PRINTF2(_L("DevSound EEventInitComplete not received as expected. Received event: %d"), aDevSoundEvent);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   124
				StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   125
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   126
			break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   127
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   128
		default:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   129
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   130
			ERR_PRINTF2(_L("Invalid DevSound state received: %d"), iDevSoundState);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   131
			StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   132
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   133
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   134
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   135
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   136
/*
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   137
 *========================================================================================================
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   138
 * MM-A3F-DEVSOUND-CHRTZ-TONE-0002
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   139
 */
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   140
RA3FDevSoundToneSetPrioritySettingsTest::RA3FDevSoundToneSetPrioritySettingsTest(const TDesC& aTestName)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   141
	:	RA3FDevSoundTestBase(aTestName), iPriority(0)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   142
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   143
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   144
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   145
RA3FDevSoundToneSetPrioritySettingsTest* RA3FDevSoundToneSetPrioritySettingsTest::NewL(const TDesC& aTestName)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   146
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   147
	RA3FDevSoundToneSetPrioritySettingsTest * self = new(ELeave)RA3FDevSoundToneSetPrioritySettingsTest(aTestName);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   148
	return self;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   149
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   150
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   151
void RA3FDevSoundToneSetPrioritySettingsTest::DoKickoffTestL()
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   152
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   153
	if (!GetIntFromConfig(iTestStepName, KPriority, iPriority))
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   154
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   155
		ERR_PRINTF2(KMsgErrorGetParameter, &KPriority);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   156
		StopTest(KErrUnknown);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   157
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   158
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   159
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   160
void RA3FDevSoundToneSetPrioritySettingsTest::Fsm(TMmfDevSoundEvent aDevSoundEvent, TInt aError)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   161
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   162
	switch (iDevSoundState)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   163
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   164
		case EStateCreated:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   165
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   166
			if (aDevSoundEvent == EEventInitialize)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   167
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   168
				__ASSERT_ALWAYS((aError == KErrNone), Panic(_L("RA3FDevSoundToneSetPrioritySettingsTest"), EFsmIncorrectErrorPassed));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   169
				INFO_PRINTF1(_L("Calling CMMFDevSound::InitializeL"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   170
				TRAPD(err, iMMFDevSound->InitializeL(*this, EMMFStateTonePlaying));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   171
				if (err != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   172
					{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   173
					ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"), err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   174
					StopTest(err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   175
					break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   176
					}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   177
				INFO_PRINTF1(_L("DevSound State: EStateInitializing"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   178
				iDevSoundState = EStateInitializing;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   179
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   180
			else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   181
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   182
				ERR_PRINTF2(_L("DevSound EEventInitialize not received as expected. Received event: %d"), aDevSoundEvent);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   183
				StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   184
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   185
			break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   186
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   187
		case EStateInitializing:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   188
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   189
			if (aDevSoundEvent == EEventInitComplete && aError == KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   190
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   191
				TMMFPrioritySettings priority;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   192
				priority.iPriority = iPriority;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   193
				INFO_PRINTF2(_L("Calling CMMFDevSound::SetPrioritySettings using a priority value = %d"), iPriority);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   194
				iMMFDevSound->SetPrioritySettings (priority);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   195
				INFO_PRINTF1(_L("========== Test Case Successfully Completed =========="));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   196
				StopTest();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   197
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   198
			else if (aDevSoundEvent == EEventInitComplete && aError != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   199
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   200
				ERR_PRINTF2(_L("DevSound called CMMFDevSound::InitializeComplete with error = %d"), aError);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   201
				StopTest(aError);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   202
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   203
			else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   204
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   205
				ERR_PRINTF2(_L("DevSound EEventInitComplete not received as expected. Received event: %d"), aDevSoundEvent);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   206
				StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   207
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   208
			break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   209
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   210
		default:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   211
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   212
			ERR_PRINTF2(_L("Invalid DevSound state received: %d"), iDevSoundState);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   213
			StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   214
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   215
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   216
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   217
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   218
/*
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   219
 *========================================================================================================
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   220
 * MM-A3F-DEVSOUND-CHRTZ-TONE-0003
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   221
 */
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   222
RA3FDevSoundToneSetVolumeTest::RA3FDevSoundToneSetVolumeTest(const TDesC& aTestName)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   223
	:	RA3FDevSoundTestBase(aTestName), iVolume(0)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   224
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   225
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   226
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   227
RA3FDevSoundToneSetVolumeTest* RA3FDevSoundToneSetVolumeTest::NewL(const TDesC& aTestName)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   228
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   229
	RA3FDevSoundToneSetVolumeTest * self = new(ELeave)RA3FDevSoundToneSetVolumeTest(aTestName);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   230
	return self;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   231
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   232
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   233
void RA3FDevSoundToneSetVolumeTest::DoKickoffTestL()
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   234
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   235
	if (!GetIntFromConfig(iTestStepName, KVolume, iVolume))
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   236
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   237
		ERR_PRINTF2(KMsgErrorGetParameter, &KVolume);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   238
		StopTest(KErrUnknown);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   239
		return;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   240
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   241
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   242
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   243
void RA3FDevSoundToneSetVolumeTest::Fsm(TMmfDevSoundEvent aDevSoundEvent, TInt aError)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   244
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   245
	switch (iDevSoundState)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   246
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   247
		case EStateCreated:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   248
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   249
			if (aDevSoundEvent == EEventInitialize)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   250
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   251
				__ASSERT_ALWAYS((aError == KErrNone), Panic(_L("RA3FDevSoundToneSetVolumeTest"), EFsmIncorrectErrorPassed));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   252
				INFO_PRINTF1(_L("Calling CMMFDevSound::InitializeL"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   253
				TRAPD(err, iMMFDevSound->InitializeL(*this, EMMFStateTonePlaying));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   254
				if (err != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   255
					{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   256
					ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"), err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   257
					StopTest(err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   258
					break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   259
					}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   260
				INFO_PRINTF1(_L("DevSound State: EStateInitializing"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   261
				iDevSoundState = EStateInitializing;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   262
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   263
			else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   264
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   265
				ERR_PRINTF2(_L("DevSound EEventInitialize not received as expected. Received event: %d"), aDevSoundEvent);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   266
				StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   267
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   268
			break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   269
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   270
		case EStateInitializing:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   271
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   272
			if (aDevSoundEvent == EEventInitComplete && aError == KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   273
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   274
				INFO_PRINTF2(_L("Calling CMMFDevSound::SetVolume with volume value = %d"), iVolume);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   275
				iMMFDevSound->SetVolume(iVolume);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   276
				TInt volumeGet;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   277
				volumeGet=iMMFDevSound->Volume();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   278
				if (volumeGet == iVolume)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   279
					{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   280
					INFO_PRINTF2(_L("CMMFDevSound::SetVolume succeeded with value = %d"), volumeGet);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   281
					StopTest();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   282
					}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   283
				else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   284
					{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   285
					ERR_PRINTF2(_L("CMMFDevSound::SetVolume failed with value = %d"), volumeGet);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   286
					ERR_PRINTF2(_L("Expected value = %d"), iVolume);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   287
					StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   288
					}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   289
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   290
			else if (aDevSoundEvent == EEventInitComplete && aError != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   291
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   292
				ERR_PRINTF2(_L("DevSound called CMMFDevSound::InitializeComplete with error = %d"), aError);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   293
				StopTest(aError);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   294
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   295
			else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   296
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   297
				ERR_PRINTF2(_L("DevSound EEventInitComplete not received as expected. Received event: %d"), aDevSoundEvent);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   298
				StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   299
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   300
			break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   301
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   302
		default:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   303
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   304
			ERR_PRINTF2(_L("Invalid DevSound state received: %d"), iDevSoundState);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   305
			StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   306
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   307
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   308
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   309
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   310
/*
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   311
 *========================================================================================================
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   312
 * MM-A3F-DEVSOUND-CHRTZ-TONE-0004
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   313
 */
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   314
RA3FDevSoundToneVolumeRampTest::RA3FDevSoundToneVolumeRampTest(const TDesC& aTestName)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   315
	:	RA3FDevSoundTestBase(aTestName), iVolumeRamp(0),
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   316
		iDuration(0), iFrequencyTone1(0)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   317
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   318
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   319
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   320
RA3FDevSoundToneVolumeRampTest* RA3FDevSoundToneVolumeRampTest::NewL(const TDesC& aTestName)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   321
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   322
	RA3FDevSoundToneVolumeRampTest * self = new(ELeave)RA3FDevSoundToneVolumeRampTest(aTestName);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   323
	return self;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   324
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   325
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   326
void RA3FDevSoundToneVolumeRampTest::DoKickoffTestL()
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   327
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   328
	if (!GetIntFromConfig(iTestStepName, KVolumeRamp, iVolumeRamp))
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   329
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   330
		ERR_PRINTF2(KMsgErrorGetParameter, &KVolumeRamp);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   331
		StopTest(KErrNotFound);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   332
		return;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   333
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   334
	if (!GetIntFromConfig(iTestStepName, KDuration, iDuration))
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   335
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   336
			ERR_PRINTF2(KMsgErrorGetParameter, &KDuration);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   337
			StopTest(KErrNotFound);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   338
			return;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   339
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   340
	if (!GetIntFromConfig(iTestStepName, KFrequencyTone1, iFrequencyTone1))
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   341
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   342
		ERR_PRINTF2(KMsgErrorGetParameter, &KFrequencyTone1);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   343
		StopTest(KErrNotFound);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   344
		return;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   345
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   346
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   347
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   348
void RA3FDevSoundToneVolumeRampTest::Fsm(TMmfDevSoundEvent aDevSoundEvent, TInt aError)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   349
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   350
	switch (iDevSoundState)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   351
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   352
		case EStateCreated:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   353
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   354
			if (aDevSoundEvent == EEventInitialize)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   355
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   356
				__ASSERT_ALWAYS((aError == KErrNone), Panic(_L("RA3FDevSoundToneVolumeRampTest"), EFsmIncorrectErrorPassed));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   357
				INFO_PRINTF1(_L("Calling CMMFDevSound::InitializeL"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   358
				TRAPD(err, iMMFDevSound->InitializeL(*this, EMMFStateTonePlaying));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   359
				if (err != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   360
					{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   361
					ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"), err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   362
					StopTest(err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   363
					break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   364
					}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   365
				INFO_PRINTF1(_L("DevSound State: EStateInitializing"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   366
				iDevSoundState = EStateInitializing;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   367
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   368
			else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   369
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   370
				ERR_PRINTF2(_L("DevSound EEventInitialize not received as expected. Received event: %d"), aDevSoundEvent);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   371
				StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   372
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   373
			break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   374
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   375
		case EStateInitializing:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   376
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   377
			if (aDevSoundEvent == EEventInitComplete && aError == KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   378
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   379
				INFO_PRINTF2(_L("Calling CMMFDevSound::SetVolumeRamp using volume ramp time = %d"), iVolumeRamp);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   380
				iMMFDevSound->SetVolumeRamp(iVolumeRamp);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   381
				iStartTime.HomeTime();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   382
				INFO_PRINTF3(_L("Calling CMMFDevSound::PlayToneL %d Hz during %d secs "), iFrequencyTone1, iDuration);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   383
				TRAPD(err, iMMFDevSound->PlayToneL(iFrequencyTone1, iDuration*KMicroSecsInOneSec));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   384
				if (err != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   385
					{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   386
					ERR_PRINTF2(_L("CMMFDevSound::PlayToneL left with error : %d!"), err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   387
					StopTest(err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   388
					break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   389
					}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   390
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   391
			else if (aDevSoundEvent == EEventInitComplete && aError != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   392
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   393
				ERR_PRINTF2(_L("DevSound called CMMFDevSound::InitializeComplete with error = %d"), aError);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   394
				StopTest(aError);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   395
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   396
			else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   397
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   398
				ERR_PRINTF2(_L("DevSound EEventInitComplete not received as expected. Received event: %d"), aDevSoundEvent);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   399
				StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   400
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   401
			break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   402
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   403
		default:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   404
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   405
			ERR_PRINTF2(_L("Invalid DevSound state received: %d"), iDevSoundState);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   406
			StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   407
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   408
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   409
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   410
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   411
void RA3FDevSoundToneVolumeRampTest::ToneFinished(TInt aError)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   412
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   413
	INFO_PRINTF1(_L("========== DevSound ToneFinished() callback =========="));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   414
	if (aError == KErrUnderflow)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   415
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   416
		iEndTime.HomeTime();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   417
		iPlayToneTime = iEndTime.MicroSecondsFrom(iStartTime);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   418
		TInt totalExpectedReproductionTime = iDuration * KMicroSecsInOneSec;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   419
		if(iPlayToneTime < totalExpectedReproductionTime + KPlayVarianceTime && iPlayToneTime > totalExpectedReproductionTime - KPlayVarianceTime)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   420
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   421
			INFO_PRINTF2(_L("Play time is %Ld microseconds"), iPlayToneTime.Int64());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   422
			StopTest();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   423
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   424
		else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   425
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   426
			ERR_PRINTF3(_L("Play time is %Ld microseconds and it should have been %d microseconds"), iPlayToneTime.Int64(), totalExpectedReproductionTime);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   427
			StopTest(KErrNone, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   428
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   429
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   430
	else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   431
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   432
		ERR_PRINTF2(_L("DevSound called ToneFinished with error = %d"), aError);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   433
		ERR_PRINTF2(_L("Expected error = %d"), KErrUnderflow);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   434
		StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   435
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   436
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   437
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   438
/*
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   439
 *========================================================================================================
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   440
 * MM-A3F-DEVSOUND-CHRTZ-TONE-0005
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   441
 */
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   442
RA3FDevSoundToneSetToneRepeatsTest::RA3FDevSoundToneSetToneRepeatsTest(const TDesC& aTestName)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   443
	:	RA3FDevSoundTestBase(aTestName),
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   444
		iDuration(0),
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   445
		iFrequencyTone1(0),
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   446
		iRepeatTrailingSilence(0),
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   447
		iRepeatCount(0)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   448
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   449
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   450
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   451
RA3FDevSoundToneSetToneRepeatsTest* RA3FDevSoundToneSetToneRepeatsTest::NewL(const TDesC& aTestName)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   452
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   453
	RA3FDevSoundToneSetToneRepeatsTest * self = new(ELeave)RA3FDevSoundToneSetToneRepeatsTest(aTestName);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   454
	return self;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   455
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   456
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   457
void RA3FDevSoundToneSetToneRepeatsTest::DoKickoffTestL()
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   458
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   459
	if (!GetIntFromConfig(iTestStepName, KRepeatCount, iRepeatCount))
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   460
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   461
		ERR_PRINTF2(KMsgErrorGetParameter, &KRepeatCount);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   462
		StopTest(KErrNotFound);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   463
		return;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   464
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   465
	if (!GetIntFromConfig(iTestStepName, KRepeatTrailingSilence, iRepeatTrailingSilence))
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   466
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   467
		ERR_PRINTF2(KMsgErrorGetParameter, &KRepeatTrailingSilence);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   468
		StopTest(KErrNotFound);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   469
		return;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   470
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   471
	if (!GetIntFromConfig(iTestStepName, KDuration, iDuration))
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   472
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   473
		ERR_PRINTF2(KMsgErrorGetParameter, &KDuration);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   474
		StopTest(KErrNotFound);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   475
		return;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   476
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   477
	if (!GetIntFromConfig(iTestStepName, KFrequencyTone1, iFrequencyTone1))
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   478
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   479
		ERR_PRINTF2(KMsgErrorGetParameter, &KFrequencyTone1);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   480
		StopTest(KErrNotFound);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   481
		return;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   482
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   483
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   484
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   485
void RA3FDevSoundToneSetToneRepeatsTest::Fsm(TMmfDevSoundEvent aDevSoundEvent, TInt aError)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   486
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   487
	switch (iDevSoundState)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   488
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   489
		case EStateCreated:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   490
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   491
			if (aDevSoundEvent == EEventInitialize)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   492
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   493
				__ASSERT_ALWAYS((aError == KErrNone), Panic(_L("RA3FDevSoundToneSetToneRepeatsTest"), EFsmIncorrectErrorPassed));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   494
				INFO_PRINTF1(_L("Calling CMMFDevSound::InitializeL"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   495
				TRAPD(err, iMMFDevSound->InitializeL(*this, EMMFStateTonePlaying));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   496
				if (err != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   497
					{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   498
					ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"), err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   499
					StopTest(err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   500
					break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   501
					}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   502
				INFO_PRINTF1(_L("DevSound State: EStateInitializing"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   503
				iDevSoundState = EStateInitializing;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   504
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   505
			else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   506
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   507
				ERR_PRINTF2(_L("DevSound EEventInitialize not received as expected. Received event: %d"), aDevSoundEvent);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   508
				StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   509
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   510
			break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   511
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   512
		case EStateInitializing:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   513
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   514
			if (aDevSoundEvent == EEventInitComplete && aError == KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   515
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   516
				iMMFDevSound->SetVolume(iMMFDevSound->MaxVolume());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   517
				iStartTime.HomeTime();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   518
				INFO_PRINTF3(_L("Calling CMMFDevSound::SetToneRepeats using repeatCount = %d and trailingSilence = %d"), iRepeatCount, iRepeatTrailingSilence);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   519
				iMMFDevSound->SetToneRepeats(iRepeatCount, iRepeatTrailingSilence);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   520
				INFO_PRINTF3(_L("Calling CMMFDevSound::PlayToneL %d Hz during %d secs "), iFrequencyTone1, iDuration);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   521
				TRAPD(err, iMMFDevSound->PlayToneL(iFrequencyTone1, iDuration*KMicroSecsInOneSec));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   522
				if (err != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   523
					{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   524
					ERR_PRINTF2(_L("CMMFDevSound::PlayToneL left with error : %d!"), err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   525
					StopTest(err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   526
					break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   527
					}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   528
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   529
			else if (aDevSoundEvent == EEventInitComplete && aError != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   530
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   531
				ERR_PRINTF2(_L("DevSound called CMMFDevSound::InitializeComplete with error = %d"), aError);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   532
				StopTest(aError);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   533
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   534
			else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   535
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   536
				ERR_PRINTF2(_L("DevSound EEventInitComplete not received as expected. Received event: %d"), aDevSoundEvent);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   537
				StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   538
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   539
			break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   540
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   541
		default:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   542
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   543
			ERR_PRINTF2(_L("Invalid DevSound state received: %d"), iDevSoundState);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   544
			StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   545
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   546
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   547
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   548
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   549
void RA3FDevSoundToneSetToneRepeatsTest::ToneFinished(TInt aError)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   550
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   551
	INFO_PRINTF1(_L("========== DevSound ToneFinished() callback =========="));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   552
	if (aError == KErrUnderflow)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   553
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   554
		iEndTime.HomeTime();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   555
		iPlayToneTime = iEndTime.MicroSecondsFrom(iStartTime);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   556
		TInt repeatTrailingSilenceToSecs = iRepeatTrailingSilence/KMicroSecsInOneSec;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   557
		TInt totalExpectedReproductionTime = (iRepeatCount * iDuration + iDuration + (repeatTrailingSilenceToSecs*iRepeatCount))*KMicroSecsInOneSec;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   558
		if(iPlayToneTime < totalExpectedReproductionTime + KPlayVarianceTime && iPlayToneTime > totalExpectedReproductionTime - KPlayVarianceTime)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   559
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   560
			INFO_PRINTF1(_L("Play tone repeats succeded."));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   561
			INFO_PRINTF2(_L("Play time is %Ld microseconds"), iPlayToneTime.Int64());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   562
			StopTest();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   563
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   564
		else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   565
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   566
			ERR_PRINTF1(_L("Play tone repeats did not work as planned."));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   567
			ERR_PRINTF3(_L("Play time is %Ld microseconds and it should have been %d microseconds"), iPlayToneTime.Int64(), totalExpectedReproductionTime);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   568
			StopTest(KErrNone, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   569
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   570
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   571
	else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   572
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   573
		ERR_PRINTF2(_L("DevSound called ToneFinished with error = %d"), aError);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   574
		ERR_PRINTF2(_L("Expected error = %d"), KErrUnderflow);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   575
		StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   576
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   577
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   578
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   579
/*
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   580
 *========================================================================================================
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   581
 * MM-A3F-DEVSOUND-CHRTZ-TONE-0006
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   582
 */
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   583
RA3FDevSoundToneSetDTMFLengthsTest::RA3FDevSoundToneSetDTMFLengthsTest(const TDesC& aTestName)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   584
	:	RA3FDevSoundTestBase(aTestName), iToneOnLength(0),
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   585
		iToneOffLength(0), iPauseLength(0), iDTMFPauses(0),
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   586
		iDTMFTones(0)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   587
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   588
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   589
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   590
RA3FDevSoundToneSetDTMFLengthsTest* RA3FDevSoundToneSetDTMFLengthsTest::NewL(const TDesC& aTestName)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   591
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   592
	RA3FDevSoundToneSetDTMFLengthsTest * self = new(ELeave)RA3FDevSoundToneSetDTMFLengthsTest(aTestName);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   593
	return self;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   594
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   595
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   596
void RA3FDevSoundToneSetDTMFLengthsTest::DoKickoffTestL()
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   597
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   598
	if (!GetIntFromConfig(iTestStepName, KToneOnLength, iToneOnLength))
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   599
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   600
		ERR_PRINTF2(KMsgErrorGetParameter, &KToneOnLength);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   601
		StopTest(KErrNotFound);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   602
		return;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   603
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   604
	if (!GetIntFromConfig(iTestStepName, KToneOffLength, iToneOffLength))
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   605
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   606
		ERR_PRINTF2(KMsgErrorGetParameter, &KToneOffLength);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   607
		StopTest(KErrNotFound);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   608
		return;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   609
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   610
	if (!GetIntFromConfig(iTestStepName, KPauseLength, iPauseLength))
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   611
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   612
		ERR_PRINTF2(KMsgErrorGetParameter, &KPauseLength);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   613
		StopTest(KErrNotFound);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   614
		return;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   615
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   616
	TPtrC DTMF;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   617
	if (!GetStringFromConfig(iTestStepName, KDTMFString, DTMF))
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   618
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   619
		ERR_PRINTF2(KMsgErrorGetParameter, &KDTMFString);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   620
		StopTest(KErrNotFound);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   621
		return;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   622
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   623
	iDTMFString.Copy(DTMF);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   624
	for(TInt i =0 ; i< iDTMFString.Length() ; i++)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   625
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   626
		if (iDTMFString[i] == ',')
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   627
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   628
			iDTMFPauses++;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   629
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   630
		else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   631
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   632
			iDTMFTones++;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   633
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   634
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   635
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   636
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   637
void RA3FDevSoundToneSetDTMFLengthsTest::Fsm(TMmfDevSoundEvent aDevSoundEvent, TInt aError)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   638
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   639
	switch (iDevSoundState)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   640
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   641
		case EStateCreated:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   642
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   643
			if (aDevSoundEvent == EEventInitialize)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   644
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   645
				__ASSERT_ALWAYS((aError == KErrNone), Panic(_L("RA3FDevSoundToneSetDTMFLengthsTest"), EFsmIncorrectErrorPassed));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   646
				INFO_PRINTF1(_L("Calling CMMFDevSound::InitializeL"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   647
				TRAPD(err, iMMFDevSound->InitializeL(*this, EMMFStateTonePlaying));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   648
				if (err != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   649
					{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   650
					ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"), err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   651
					StopTest(err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   652
					break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   653
					}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   654
				INFO_PRINTF1(_L("DevSound State: EStateInitializing"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   655
				iDevSoundState = EStateInitializing;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   656
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   657
			else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   658
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   659
				ERR_PRINTF2(_L("DevSound EEventInitialize not received as expected. Received event: %d"), aDevSoundEvent);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   660
				StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   661
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   662
			break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   663
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   664
		case EStateInitializing:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   665
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   666
			if (aDevSoundEvent == EEventInitComplete && aError == KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   667
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   668
				iMMFDevSound->SetVolume(iMMFDevSound->MaxVolume());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   669
				TTimeIntervalMicroSeconds32 ToneOnLength(iToneOnLength);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   670
				TTimeIntervalMicroSeconds32 ToneOffLength(iToneOffLength);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   671
				TTimeIntervalMicroSeconds32 PauseLength(iPauseLength);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   672
				INFO_PRINTF4(_L("Calling CMMFDevSound::SetDTMFLengths. ToneOnLength = %d, ToneOffLength = %d and PauseLength = %d"), ToneOnLength.Int(), ToneOffLength.Int(), PauseLength.Int());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   673
				iMMFDevSound->SetDTMFLengths(ToneOnLength, ToneOffLength, PauseLength);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   674
				iStartTime.HomeTime();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   675
				INFO_PRINTF2(_L("Calling CMMFDevSound::PlayDTMFStringL %S"), &iDTMFString);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   676
				TRAPD(err, iMMFDevSound->PlayDTMFStringL(iDTMFString));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   677
				if (err != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   678
					{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   679
					ERR_PRINTF2(_L("CMMFDevSound::PlayDTMFStringL left with error : %d!"), err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   680
					StopTest(err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   681
					break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   682
					}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   683
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   684
			else if (aDevSoundEvent == EEventInitComplete && aError != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   685
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   686
				ERR_PRINTF2(_L("DevSound called CMMFDevSound::InitializeComplete with error = %d"), aError);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   687
				StopTest(aError);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   688
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   689
			else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   690
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   691
				ERR_PRINTF2(_L("DevSound EEventInitComplete not received as expected. Received event: %d"), aDevSoundEvent);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   692
				StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   693
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   694
			break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   695
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   696
		default:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   697
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   698
			ERR_PRINTF2(_L("Invalid DevSound state received: %d"), iDevSoundState);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   699
			StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   700
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   701
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   702
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   703
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   704
void RA3FDevSoundToneSetDTMFLengthsTest::ToneFinished(TInt aError)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   705
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   706
	INFO_PRINTF1(_L("========== DevSound ToneFinished() callback =========="));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   707
	if (aError == KErrUnderflow)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   708
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   709
		iEndTime.HomeTime();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   710
		iPlayToneTime = iEndTime.MicroSecondsFrom(iStartTime);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   711
		TInt totalExpectedReproductionTime = iToneOnLength*iDTMFTones + iToneOffLength * iDTMFTones + iDTMFPauses * iPauseLength;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   712
		if (iPlayToneTime.Int64() < totalExpectedReproductionTime + KPlayVarianceTime && iPlayToneTime.Int64() > totalExpectedReproductionTime - KPlayVarianceTime)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   713
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   714
			INFO_PRINTF1(_L("Calling CMMFDevSound::SetDTMFLengths succeded."));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   715
			INFO_PRINTF2(_L("Play time is %Ld microseconds"), iPlayToneTime.Int64());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   716
			StopTest();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   717
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   718
		else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   719
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   720
			ERR_PRINTF2(_L("Calling CMMFDevSound::SetDTMFLengths failed with %Ld"), iPlayToneTime.Int64());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   721
			ERR_PRINTF2(_L("Expected time %d"), totalExpectedReproductionTime);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   722
			StopTest(KErrNone, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   723
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   724
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   725
	else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   726
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   727
		ERR_PRINTF2(_L("DevSound called ToneFinished with error = %d"), aError);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   728
		ERR_PRINTF2(_L("Expected error = %d"), KErrUnderflow);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   729
		StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   730
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   731
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   732
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   733
/*
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   734
 *========================================================================================================
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   735
 * MM-A3F-DEVSOUND-CHRTZ-TONE-0007
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   736
 */
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   737
RA3FDevSoundToneSetVolumeWhilePlayingTest::RA3FDevSoundToneSetVolumeWhilePlayingTest(const TDesC& aTestName)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   738
	:	RA3FDevSoundTestBase(aTestName), iDuration(0),
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   739
		iVolume(0), iFrequencyTone1(0)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   740
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   741
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   742
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   743
RA3FDevSoundToneSetVolumeWhilePlayingTest* RA3FDevSoundToneSetVolumeWhilePlayingTest::NewL(const TDesC& aTestName)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   744
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   745
	RA3FDevSoundToneSetVolumeWhilePlayingTest * self = new(ELeave)RA3FDevSoundToneSetVolumeWhilePlayingTest(aTestName);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   746
	return self;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   747
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   748
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   749
void RA3FDevSoundToneSetVolumeWhilePlayingTest::DoKickoffTestL()
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   750
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   751
	if (!GetIntFromConfig(iTestStepName, KVolume, iVolume))
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   752
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   753
		ERR_PRINTF2(KMsgErrorGetParameter, &KVolume);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   754
		StopTest(KErrNotFound);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   755
		return;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   756
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   757
	if (!GetIntFromConfig(iTestStepName, KDuration, iDuration))
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   758
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   759
		ERR_PRINTF2(KMsgErrorGetParameter, &KDuration);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   760
		StopTest(KErrNotFound);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   761
		return;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   762
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   763
	if (!GetIntFromConfig(iTestStepName, KFrequencyTone1, iFrequencyTone1))
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   764
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   765
		ERR_PRINTF2(KMsgErrorGetParameter, &KFrequencyTone1);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   766
		StopTest(KErrNotFound);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   767
		return;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   768
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   769
	iTimer = CPeriodic::NewL(CActive::EPriorityHigh);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   770
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   771
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   772
void RA3FDevSoundToneSetVolumeWhilePlayingTest::Fsm(TMmfDevSoundEvent aDevSoundEvent, TInt aError)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   773
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   774
	switch (iDevSoundState)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   775
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   776
		case EStateCreated:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   777
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   778
			if (aDevSoundEvent == EEventInitialize)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   779
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   780
				__ASSERT_ALWAYS((aError == KErrNone), Panic(_L("RA3FDevSoundToneSetVolumeWhilePlayingTest"), EFsmIncorrectErrorPassed));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   781
				INFO_PRINTF1(_L("Calling CMMFDevSound::InitializeL"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   782
				TRAPD(err, iMMFDevSound->InitializeL(*this, EMMFStateTonePlaying));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   783
				if (err != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   784
					{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   785
					ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"), err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   786
					StopTest(err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   787
					break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   788
					}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   789
				INFO_PRINTF1(_L("DevSound State: EStateInitializing"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   790
				iDevSoundState = EStateInitializing;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   791
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   792
			else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   793
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   794
				ERR_PRINTF2(_L("DevSound EEventInitialize not received as expected. Received event: %d"), aDevSoundEvent);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   795
				StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   796
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   797
			break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   798
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   799
		case EStateInitializing:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   800
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   801
			if (aDevSoundEvent == EEventInitComplete && aError == KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   802
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   803
				iStartTime.HomeTime();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   804
				INFO_PRINTF3(_L("Calling CMMFDevSound::PlayToneL using frequency = %d Hz and duration = %d secs "), iFrequencyTone1, iDuration);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   805
				TRAPD(err, iMMFDevSound->PlayToneL(iFrequencyTone1, iDuration*KMicroSecsInOneSec));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   806
				if (err != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   807
					{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   808
					ERR_PRINTF2(_L("CMMFDevSound::PlayToneL left with error : %d!"), err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   809
					StopTest(err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   810
					break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   811
					}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   812
				StartTimer(KMicroSecsTwoSec);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   813
				INFO_PRINTF1(_L("DevSound State: EStatePlaying"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   814
				iDevSoundState = EStatePlaying;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   815
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   816
			else if (aDevSoundEvent == EEventInitComplete && aError != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   817
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   818
				ERR_PRINTF2(_L("DevSound called CMMFDevSound::InitializeComplete with error = %d"), aError);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   819
				StopTest(aError);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   820
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   821
			else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   822
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   823
				ERR_PRINTF2(_L("DevSound EEventInitComplete not received as expected. Received event: %d"), aDevSoundEvent);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   824
				StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   825
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   826
			break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   827
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   828
		default:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   829
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   830
			ERR_PRINTF2(_L("Invalid DevSound state received: %d"), iDevSoundState);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   831
			StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   832
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   833
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   834
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   835
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   836
void RA3FDevSoundToneSetVolumeWhilePlayingTest::DoTimerCallback()
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   837
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   838
	iTimer->Cancel();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   839
	INFO_PRINTF1(_L("DevSound Event: EEventTimerComplete"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   840
	INFO_PRINTF2(_L("Calling CMMFDevSound::SetVolume with volume value = %d"), iVolume);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   841
	iMMFDevSound->SetVolume(iVolume);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   842
	TInt volumeGet;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   843
	volumeGet=iMMFDevSound->Volume();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   844
	if (volumeGet == iVolume)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   845
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   846
		INFO_PRINTF2(_L("CMMFDevSound::SetVolume succeeded with value = %d"), volumeGet);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   847
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   848
	else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   849
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   850
		ERR_PRINTF2(_L("CMMFDevSound::SetVolume failed with value = %d"), volumeGet);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   851
		ERR_PRINTF2(_L("Expected value = %d"), iVolume);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   852
		StopTest(KErrNone, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   853
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   854
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   855
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   856
void RA3FDevSoundToneSetVolumeWhilePlayingTest::ToneFinished(TInt aError)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   857
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   858
	INFO_PRINTF1(_L("========== DevSound ToneFinished() callback =========="));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   859
	if (aError == KErrUnderflow)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   860
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   861
		iEndTime.HomeTime();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   862
		iPlayToneTime = iEndTime.MicroSecondsFrom(iStartTime);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   863
		TInt totalExpectedReproductionTime = iDuration * KMicroSecsInOneSec;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   864
		if(iPlayToneTime < totalExpectedReproductionTime + KPlayVarianceTime && iPlayToneTime > totalExpectedReproductionTime - KPlayVarianceTime)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   865
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   866
			INFO_PRINTF2(_L("Play time is %Ld microseconds"), iPlayToneTime.Int64());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   867
			StopTest();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   868
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   869
		else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   870
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   871
			ERR_PRINTF3(_L("Play time is %Ld microseconds and it should have been %d microseconds"), iPlayToneTime.Int64(), totalExpectedReproductionTime);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   872
			StopTest(KErrNone, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   873
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   874
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   875
	else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   876
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   877
		ERR_PRINTF2(_L("DevSound called ToneFinished with error = %d"), aError);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   878
		ERR_PRINTF2(_L("Expected error = %d"), KErrUnderflow);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   879
		StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   880
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   881
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   882
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   883
/*
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   884
 *========================================================================================================
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   885
 * MM-A3F-DEVSOUND-CHRTZ-TONE-0008
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   886
 */
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   887
RA3FDevSoundToneSetPlayBalanceWhilePlayingTest::RA3FDevSoundToneSetPlayBalanceWhilePlayingTest(const TDesC& aTestName)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   888
	:	RA3FDevSoundTestBase(aTestName), iDuration(0),
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   889
		iVolume(0), iFrequencyTone1(0), iLSpeakerBalance(0),
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   890
		iRSpeakerBalance(0)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   891
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   892
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   893
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   894
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   895
RA3FDevSoundToneSetPlayBalanceWhilePlayingTest* RA3FDevSoundToneSetPlayBalanceWhilePlayingTest::NewL(const TDesC& aTestName)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   896
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   897
	RA3FDevSoundToneSetPlayBalanceWhilePlayingTest * self = new(ELeave)RA3FDevSoundToneSetPlayBalanceWhilePlayingTest(aTestName);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   898
	return self;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   899
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   900
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   901
void RA3FDevSoundToneSetPlayBalanceWhilePlayingTest::DoKickoffTestL()
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   902
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   903
	if (!GetIntFromConfig(iTestStepName, KVolume, iVolume))
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   904
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   905
		ERR_PRINTF2(KMsgErrorGetParameter, &KVolume);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   906
		StopTest(KErrNotFound);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   907
		return;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   908
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   909
	if (!GetIntFromConfig(iTestStepName, KDuration, iDuration))
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   910
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   911
		ERR_PRINTF2(KMsgErrorGetParameter, &KDuration);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   912
		StopTest(KErrNotFound);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   913
		return;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   914
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   915
	if (!GetIntFromConfig(iTestStepName, KFrequencyTone1, iFrequencyTone1))
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   916
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   917
		ERR_PRINTF2(KMsgErrorGetParameter, &KFrequencyTone1);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   918
		StopTest(KErrNotFound);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   919
		return;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   920
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   921
	if (!GetIntFromConfig(iTestStepName, KLSpeakerBalance, iLSpeakerBalance))
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   922
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   923
		ERR_PRINTF2(KMsgErrorGetParameter, &KLSpeakerBalance);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   924
		StopTest(KErrNotFound);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   925
		return;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   926
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   927
	if (!GetIntFromConfig(iTestStepName, KRSpeakerBalance, iRSpeakerBalance))
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   928
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   929
		ERR_PRINTF2(KMsgErrorGetParameter, &KRSpeakerBalance);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   930
		StopTest(KErrNotFound);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   931
		return;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   932
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   933
	iTimer = CPeriodic::NewL(CActive::EPriorityHigh);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   934
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   935
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   936
void RA3FDevSoundToneSetPlayBalanceWhilePlayingTest::Fsm(TMmfDevSoundEvent aDevSoundEvent, TInt aError)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   937
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   938
	switch (iDevSoundState)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   939
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   940
		case EStateCreated:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   941
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   942
			if (aDevSoundEvent == EEventInitialize)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   943
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   944
				__ASSERT_ALWAYS((aError == KErrNone), Panic(_L("RA3FDevSoundToneSetPlayBalanceWhilePlayingTest"), EFsmIncorrectErrorPassed));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   945
				INFO_PRINTF1(_L("Calling CMMFDevSound::InitializeL"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   946
				TRAPD(err, iMMFDevSound->InitializeL(*this, EMMFStateTonePlaying));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   947
				if (err != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   948
					{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   949
					ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"), err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   950
					StopTest(err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   951
					break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   952
					}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   953
				INFO_PRINTF1(_L("DevSound State: EStateInitializing"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   954
				iDevSoundState = EStateInitializing;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   955
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   956
			else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   957
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   958
				ERR_PRINTF2(_L("DevSound EEventInitialize not received as expected. Received event: %d"), aDevSoundEvent);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   959
				StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   960
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   961
			break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   962
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   963
		case EStateInitializing:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   964
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   965
			if (aDevSoundEvent == EEventInitComplete && aError == KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   966
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   967
				iStartTime.HomeTime();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   968
				INFO_PRINTF3(_L("Calling CMMFDevSound::PlayToneL using frequency = %d Hz and duration = %d secs "), iFrequencyTone1, iDuration);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   969
				TRAPD(err, iMMFDevSound->PlayToneL(iFrequencyTone1, iDuration*KMicroSecsInOneSec));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   970
				if (err != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   971
					{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   972
					ERR_PRINTF2(_L("CMMFDevSound::PlayToneL left with error : %d!"), err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   973
					StopTest(err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   974
					break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   975
					}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   976
				StartTimer(KMicroSecsTwoSec);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   977
				INFO_PRINTF1(_L("DevSound State: EStatePlaying"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   978
				iDevSoundState = EStatePlaying;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   979
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   980
			else if (aDevSoundEvent == EEventInitComplete && aError != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   981
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   982
				ERR_PRINTF2(_L("DevSound called CMMFDevSound::InitializeComplete with error = %d"), aError);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   983
				StopTest(aError);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   984
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   985
			else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   986
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   987
				ERR_PRINTF2(_L("DevSound EEventInitComplete not received as expected. Received event: %d"), aDevSoundEvent);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   988
				StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   989
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   990
			break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   991
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   992
		default:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   993
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   994
			ERR_PRINTF2(_L("Invalid DevSound state received: %d"), iDevSoundState);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   995
			StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   996
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   997
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   998
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   999
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1000
void RA3FDevSoundToneSetPlayBalanceWhilePlayingTest::DoTimerCallback()
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1001
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1002
	iTimer->Cancel();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1003
	INFO_PRINTF1(_L("DevSound Event: EEventTimerComplete"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1004
	INFO_PRINTF3(_L("Calling CMMFDevSound::SetPlayBalanceL using left = %d right = %d"), iLSpeakerBalance, iRSpeakerBalance);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1005
	TRAPD(err, iMMFDevSound->SetPlayBalanceL(iLSpeakerBalance, iRSpeakerBalance));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1006
	if (err == KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1007
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1008
		TInt getBalanceL, getBalanceR;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1009
		TRAPD(err, iMMFDevSound->GetPlayBalanceL(getBalanceL, getBalanceR));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1010
		if (err == KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1011
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1012
			if(iLSpeakerBalance == getBalanceL && iRSpeakerBalance == getBalanceR)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1013
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1014
				INFO_PRINTF3(_L("Calling CMMFDevSound::SetPlayBalanceL to set balance values succeeded, left = %d right = %d"), getBalanceL, getBalanceR);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1015
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1016
			else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1017
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1018
				ERR_PRINTF3(_L("Calling CMMFDevSound::SetPlayBalanceL to set balance values failed, left = %d right = %d"), getBalanceL, getBalanceR);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1019
				ERR_PRINTF3(_L("Expected balances values for right and left respectively %d, %d"),iLSpeakerBalance, iRSpeakerBalance);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1020
				StopTest(err,EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1021
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1022
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1023
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1024
	else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1025
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1026
		ERR_PRINTF1(_L("Error in setting left and right play balance."));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1027
		StopTest (err, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1028
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1029
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1030
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1031
void RA3FDevSoundToneSetPlayBalanceWhilePlayingTest::ToneFinished(TInt aError)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1032
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1033
	INFO_PRINTF1(_L("========== DevSound ToneFinished() callback =========="));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1034
	if (aError == KErrUnderflow)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1035
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1036
		iEndTime.HomeTime();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1037
		iPlayToneTime = iEndTime.MicroSecondsFrom(iStartTime);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1038
		TInt totalExpectedReproductionTime = iDuration * KMicroSecsInOneSec;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1039
		if(iPlayToneTime < totalExpectedReproductionTime + KPlayVarianceTime && iPlayToneTime > totalExpectedReproductionTime - KPlayVarianceTime)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1040
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1041
			INFO_PRINTF2(_L("Play time is %Ld microseconds"), iPlayToneTime.Int64());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1042
			StopTest();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1043
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1044
		else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1045
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1046
			ERR_PRINTF3(_L("Play time is %Ld microseconds and it should have been %d microseconds"), iPlayToneTime.Int64(), totalExpectedReproductionTime);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1047
			StopTest(KErrNone, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1048
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1049
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1050
	else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1051
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1052
		ERR_PRINTF2(_L("DevSound called ToneFinished with error = %d"), aError);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1053
		ERR_PRINTF2(_L("Expected error = %d"), KErrUnderflow);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1054
		StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1055
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1056
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1057
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1058
/*
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1059
 *  **========================================================================================================
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1060
 * MM-A3F-DEVSOUND-CHRTZ-TONE-0009
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1061
 */
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1062
RA3FDevSoundToneSetVolumeWhilePausePlayingTest::RA3FDevSoundToneSetVolumeWhilePausePlayingTest(const TDesC& aTestName)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1063
	:	RA3FDevSoundTestBase(aTestName),
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1064
		iDuration(0), iVolume(0),
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1065
		iFrequencyTone1(0),
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1066
		iTimeToEnterPauseElapsed(EFalse)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1067
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1068
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1069
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1070
RA3FDevSoundToneSetVolumeWhilePausePlayingTest* RA3FDevSoundToneSetVolumeWhilePausePlayingTest::NewL(const TDesC& aTestName)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1071
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1072
	RA3FDevSoundToneSetVolumeWhilePausePlayingTest * self = new(ELeave)RA3FDevSoundToneSetVolumeWhilePausePlayingTest(aTestName);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1073
	return self;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1074
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1075
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1076
void RA3FDevSoundToneSetVolumeWhilePausePlayingTest::DoKickoffTestL()
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1077
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1078
	if (!GetIntFromConfig(iTestStepName, KVolume, iVolume))
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1079
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1080
		ERR_PRINTF2(KMsgErrorGetParameter, &KVolume);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1081
		StopTest(KErrNotFound);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1082
		return;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1083
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1084
	if (!GetIntFromConfig(iTestStepName, KDuration, iDuration))
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1085
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1086
		ERR_PRINTF2(KMsgErrorGetParameter, &KDuration);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1087
		StopTest(KErrNotFound);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1088
		return;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1089
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1090
	if (!GetIntFromConfig(iTestStepName, KFrequencyTone1, iFrequencyTone1))
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1091
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1092
		ERR_PRINTF2(KMsgErrorGetParameter, &KFrequencyTone1);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1093
		StopTest(KErrNotFound);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1094
		return;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1095
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1096
	iTimer = CPeriodic::NewL(CActive::EPriorityHigh);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1097
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1098
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1099
void RA3FDevSoundToneSetVolumeWhilePausePlayingTest::Fsm(TMmfDevSoundEvent aDevSoundEvent,  TInt aError)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1100
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1101
	switch (iDevSoundState)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1102
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1103
		case EStateCreated:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1104
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1105
			__ASSERT_ALWAYS((aError == KErrNone), Panic(_L("RA3FDevSoundToneSetVolumeWhilePausePlayingTest"), EFsmIncorrectErrorPassed));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1106
			if (aDevSoundEvent == EEventInitialize)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1107
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1108
				INFO_PRINTF1(_L("Calling CMMFDevSound::InitializeL"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1109
				TRAPD(err, iMMFDevSound->InitializeL(*this, EMMFStateTonePlaying));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1110
				if (err != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1111
					{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1112
					ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"), err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1113
					StopTest(err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1114
					break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1115
					}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1116
				INFO_PRINTF1(_L("DevSound State: EStateInitializing"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1117
				iDevSoundState = EStateInitializing;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1118
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1119
			else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1120
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1121
				ERR_PRINTF2(_L("DevSound EEventInitialize not received as expected. Received event: %d"), aDevSoundEvent);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1122
				StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1123
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1124
			break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1125
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1126
		case EStateInitializing:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1127
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1128
			if (aDevSoundEvent == EEventInitComplete && aError == KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1129
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1130
				INFO_PRINTF3(_L("CMMFDevSound::PlayToneL %d Hz during %d secs "), iFrequencyTone1, iDuration);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1131
				TRAPD(err, iMMFDevSound->PlayToneL(iFrequencyTone1, iDuration*KMicroSecsInOneSec));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1132
				if (err != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1133
					{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1134
					ERR_PRINTF2(_L("CMMFDevSound::PlayToneL left with error : %d!"), err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1135
					StopTest(err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1136
					break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1137
					}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1138
				StartTimer(KMicroSecsTwoSec);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1139
				INFO_PRINTF1(_L("DevSound State: EStatePlaying"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1140
				iDevSoundState = EStatePlaying;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1141
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1142
			else if (aDevSoundEvent == EEventInitComplete && aError != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1143
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1144
				ERR_PRINTF2(_L("DevSound called CMMFDevSound::InitializeComplete with error = %d"), aError);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1145
				StopTest(aError);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1146
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1147
			else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1148
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1149
				ERR_PRINTF2(_L("DevSound EEventInitComplete not received as expected. Received event: %d"),  aDevSoundEvent);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1150
				StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1151
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1152
			break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1153
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1154
		case EStatePlaying:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1155
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1156
			if(aDevSoundEvent == EEventTimerComplete)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1157
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1158
				INFO_PRINTF1(_L("Calling CMMFDevSound::Pause"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1159
				iMMFDevSound->Pause();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1160
				INFO_PRINTF1(_L("DevSound State: EStatePause"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1161
				iDevSoundState = EStatePause;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1162
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1163
			else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1164
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1165
				ERR_PRINTF2(_L("DevSound EEventTimerComplete not received as expected. Received event: %d"), aDevSoundEvent);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1166
				StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1167
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1168
			break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1169
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1170
		case EStatePause:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1171
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1172
			if(aDevSoundEvent == EEventTimerComplete)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1173
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1174
				INFO_PRINTF2(_L("Calling CMMFDevSound::SetVolume with volume value = %d"), iVolume);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1175
				iMMFDevSound->SetVolume(iVolume);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1176
				TInt volumeGet;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1177
				volumeGet=iMMFDevSound->Volume();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1178
				if (volumeGet == iVolume)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1179
					{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1180
					INFO_PRINTF2(_L("CMMFDevSound::SetVolume succeeded with value = %d"), volumeGet);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1181
					StopTest();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1182
					}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1183
				else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1184
					{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1185
					ERR_PRINTF2(_L("CMMFDevSound::SetVolume failed with value = %d"), volumeGet);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1186
					ERR_PRINTF2(_L("Expected value = %d"), iVolume);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1187
					StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1188
					}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1189
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1190
			else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1191
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1192
				ERR_PRINTF2(_L("DevSound EEventTimerComplete not received as expected. Received event: %d"), aDevSoundEvent);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1193
				StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1194
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1195
			break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1196
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1197
		default:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1198
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1199
			ERR_PRINTF2(_L("Invalid DevSound state received: %d"), iDevSoundState);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1200
			StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1201
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1202
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1203
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1204
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1205
void RA3FDevSoundToneSetVolumeWhilePausePlayingTest::DoTimerCallback()
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1206
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1207
	INFO_PRINTF1(_L("TimerEvent called"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1208
	if(!iTimeToEnterPauseElapsed)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1209
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1210
		iTimeToEnterPauseElapsed = ETrue;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1211
		INFO_PRINTF1(_L("DevSound Event: EEventTimerComplete"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1212
		Fsm(EEventTimerComplete, KErrNone);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1213
		iTimeToEnterPauseElapsed = ETrue;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1214
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1215
	else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1216
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1217
		iTimer->Cancel();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1218
		INFO_PRINTF1(_L("DevSound Event: EEventTimerComplete"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1219
		Fsm(EEventTimerComplete, KErrNone);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1220
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1221
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1222
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1223
void RA3FDevSoundToneSetVolumeWhilePausePlayingTest::ToneFinished(TInt aError)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1224
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1225
	INFO_PRINTF1(_L("========== DevSound ToneFinished() callback =========="));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1226
	ERR_PRINTF1(_L("DevSound should not have called ToneFinished because it is supposed to be paused"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1227
	StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1228
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1229
/*
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1230
 *========================================================================================================
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1231
 * MM-A3F-DEVSOUND-CHRTZ-TONE-0010
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1232
 */
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1233
RA3FDevSoundToneSetVolumeThenInitializeToPlayAudioTest::RA3FDevSoundToneSetVolumeThenInitializeToPlayAudioTest(const TDesC& aTestName)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1234
	:	RA3FDevSoundTestBase(aTestName), iVolume(0),
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1235
		iReinitialized(EFalse)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1236
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1237
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1238
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1239
RA3FDevSoundToneSetVolumeThenInitializeToPlayAudioTest* RA3FDevSoundToneSetVolumeThenInitializeToPlayAudioTest::NewL(const TDesC& aTestName)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1240
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1241
	RA3FDevSoundToneSetVolumeThenInitializeToPlayAudioTest * self = new(ELeave)RA3FDevSoundToneSetVolumeThenInitializeToPlayAudioTest(aTestName);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1242
	return self;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1243
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1244
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1245
void RA3FDevSoundToneSetVolumeThenInitializeToPlayAudioTest::DoKickoffTestL()
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1246
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1247
	if (!GetIntFromConfig(iTestStepName, KVolume, iVolume))
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1248
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1249
		ERR_PRINTF2(KMsgErrorGetParameter, &KVolume);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1250
		StopTest(KErrNotFound);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1251
		return;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1252
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1253
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1254
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1255
void RA3FDevSoundToneSetVolumeThenInitializeToPlayAudioTest::Fsm(TMmfDevSoundEvent aDevSoundEvent,  TInt aError)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1256
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1257
	switch (iDevSoundState)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1258
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1259
		case EStateCreated:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1260
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1261
			__ASSERT_ALWAYS((aError == KErrNone), Panic(_L("RA3FDevSoundToneSetVolumeThenInitializeToPlayAudioTest"), EFsmIncorrectErrorPassed));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1262
			if (aDevSoundEvent == EEventInitialize)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1263
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1264
				INFO_PRINTF1(_L("Calling CMMFDevSound::InitializeL"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1265
				TRAPD(err, iMMFDevSound->InitializeL(*this, EMMFStateTonePlaying));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1266
				if (err != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1267
					{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1268
					ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"), err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1269
					StopTest(err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1270
					break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1271
					}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1272
				INFO_PRINTF1(_L("DevSound State: EStateInitializing"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1273
				iDevSoundState = EStateInitializing;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1274
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1275
			else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1276
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1277
				ERR_PRINTF2(_L("DevSound EEventInitialize not received as expected. Received event: %d"), aDevSoundEvent);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1278
				StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1279
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1280
			break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1281
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1282
		case EStateInitializing:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1283
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1284
			if (aDevSoundEvent == EEventInitComplete && aError == KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1285
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1286
				if(!iReinitialized)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1287
					{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1288
					INFO_PRINTF1(_L("Calling CMMFDevSound::InitializeL"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1289
					TRAPD(err, iMMFDevSound->InitializeL(*this, EMMFStateTonePlaying));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1290
					if (err != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1291
						{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1292
						ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"), err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1293
						StopTest(err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1294
						break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1295
						}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1296
					INFO_PRINTF1(_L("DevSound State: EStateInitializing"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1297
					iDevSoundState = EStateInitializing;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1298
					iReinitialized = ETrue;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1299
					INFO_PRINTF2(_L("Calling CMMFDevSound::SetVolume with volume value = %d"), iVolume);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1300
					iMMFDevSound->SetVolume(iVolume);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1301
					INFO_PRINTF1(_L("DevSound State: EStateInitializing"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1302
					iDevSoundState = EStateInitializing;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1303
					}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1304
				else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1305
					{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1306
					TInt volumeGet;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1307
					volumeGet=iMMFDevSound->Volume();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1308
					if (volumeGet == iVolume)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1309
						{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1310
						INFO_PRINTF1(_L("After calling CMMFDevSound::InitializeL for playing audio, "));
b8ed18f6c07b 2010wk40
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);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1312
						StopTest();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1313
						}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1314
					else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1315
						{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1316
						INFO_PRINTF1(_L("After calling CMMFDevSound::InitializeL for playing audio, "));
b8ed18f6c07b 2010wk40
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);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1318
						ERR_PRINTF2(_L("Expected value = %d"), iVolume);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1319
						StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1320
						}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1321
					}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1322
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1323
			else if (aDevSoundEvent == EEventInitComplete && aError != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1324
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1325
				ERR_PRINTF2(_L("DevSound called CMMFDevSound::InitializeComplete with error = %d"), aError);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1326
				StopTest(aError);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1327
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1328
			else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1329
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1330
				ERR_PRINTF2(_L("DevSound EEventInitComplete not received as expected. Received event: %d"),  aDevSoundEvent);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1331
				StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1332
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1333
			break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1334
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1335
		default:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1336
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1337
			ERR_PRINTF2(_L("Invalid DevSound state received: %d"), iDevSoundState);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1338
			StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1339
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1340
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1341
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1342
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1343
/*
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1344
 *========================================================================================================
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1345
 * MM-A3F-DEVSOUND-CHRTZ-TONE-0011
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1346
 */
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1347
RA3FDevSoundToneSetVolumeRampWhilePlayingTest::RA3FDevSoundToneSetVolumeRampWhilePlayingTest(const TDesC& aTestName)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1348
	:	RA3FDevSoundTestBase(aTestName), iDuration(0),
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1349
		iVolume(0), iFrequencyTone1(0),iTonePlayedTwice(EFalse),
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1350
		iTimesToneFinishedCalled(0)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1351
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1352
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1353
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1354
RA3FDevSoundToneSetVolumeRampWhilePlayingTest* RA3FDevSoundToneSetVolumeRampWhilePlayingTest::NewL(const TDesC& aTestName)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1355
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1356
	RA3FDevSoundToneSetVolumeRampWhilePlayingTest * self = new(ELeave)RA3FDevSoundToneSetVolumeRampWhilePlayingTest(aTestName);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1357
	return self;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1358
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1359
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1360
void RA3FDevSoundToneSetVolumeRampWhilePlayingTest::DoKickoffTestL()
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1361
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1362
	if (!GetIntFromConfig(iTestStepName, KVolume, iVolume))
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1363
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1364
		ERR_PRINTF2(KMsgErrorGetParameter, &KVolume);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1365
		StopTest(KErrNotFound);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1366
		return;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1367
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1368
	if (!GetIntFromConfig(iTestStepName, KDuration, iDuration))
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1369
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1370
		ERR_PRINTF2(KMsgErrorGetParameter, &KDuration);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1371
		StopTest(KErrNotFound);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1372
		return;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1373
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1374
	if (!GetIntFromConfig(iTestStepName, KFrequencyTone1, iFrequencyTone1))
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1375
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1376
		ERR_PRINTF2(KMsgErrorGetParameter, &KFrequencyTone1);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1377
		StopTest(KErrNotFound);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1378
		return;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1379
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1380
	if (!GetIntFromConfig(iTestStepName, KVolumeRamp, iVolumeRamp))
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1381
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1382
			ERR_PRINTF2(KMsgErrorGetParameter, &KVolumeRamp);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1383
			StopTest(KErrNotFound);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1384
			return;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1385
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1386
	iTimer = CPeriodic::NewL(CActive::EPriorityHigh);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1387
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1388
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1389
void RA3FDevSoundToneSetVolumeRampWhilePlayingTest::Fsm(TMmfDevSoundEvent aDevSoundEvent,  TInt aError)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1390
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1391
	switch (iDevSoundState)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1392
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1393
		case EStateCreated:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1394
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1395
			if (aDevSoundEvent == EEventInitialize)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1396
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1397
				__ASSERT_ALWAYS((aError == KErrNone), Panic(_L("RA3FDevSoundToneSetVolumeRampWhilePlayingTest"), EFsmIncorrectErrorPassed));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1398
				INFO_PRINTF1(_L("Calling CMMFDevSound::InitializeL"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1399
				TRAPD(err, iMMFDevSound->InitializeL(*this, EMMFStateTonePlaying));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1400
				if (err != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1401
					{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1402
					ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"),  err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1403
					StopTest(err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1404
					break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1405
					}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1406
				INFO_PRINTF1(_L("DevSound State: EStateInitializing"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1407
				iDevSoundState = EStateInitializing;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1408
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1409
			else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1410
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1411
				ERR_PRINTF2(_L("DevSound EEventInitialize not received as expected. Received event: %d"), aDevSoundEvent);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1412
				StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1413
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1414
			break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1415
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1416
		case EStateInitializing:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1417
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1418
			if (aDevSoundEvent == EEventInitComplete && aError == KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1419
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1420
				iMMFDevSound->SetVolume(iMMFDevSound->MaxVolume());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1421
				iStartTime.HomeTime();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1422
				INFO_PRINTF3(_L("Calling CMMFDevSound::PlayToneL using frequency = %d Hz and duration = %d secs "), iFrequencyTone1, iDuration);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1423
				TRAPD(err, iMMFDevSound->PlayToneL(iFrequencyTone1, iDuration*KMicroSecsInOneSec));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1424
				if (err != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1425
					{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1426
					ERR_PRINTF2(_L("Play tone left with error : %d!"), err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1427
					StopTest(err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1428
					break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1429
					}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1430
				StartTimer(KMicroSecsTwoSec);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1431
				INFO_PRINTF1(_L("DevSound State: EStatePlaying"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1432
				iDevSoundState = EStatePlaying;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1433
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1434
			else if (aDevSoundEvent == EEventInitComplete && aError != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1435
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1436
				ERR_PRINTF2(_L("DevSound called CMMFDevSound::InitializeComplete with error = %d"), aError);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1437
				StopTest(aError);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1438
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1439
			else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1440
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1441
				ERR_PRINTF2(_L("DevSound EEventInitComplete not received as expected. Received event: %d"), aDevSoundEvent);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1442
				StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1443
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1444
			break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1445
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1446
		default:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1447
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1448
			ERR_PRINTF2(_L("Invalid DevSound state received: %d"), iDevSoundState);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1449
			StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1450
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1451
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1452
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1453
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1454
void RA3FDevSoundToneSetVolumeRampWhilePlayingTest::DoTimerCallback()
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1455
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1456
	iTimer->Cancel();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1457
	INFO_PRINTF1(_L("DevSound Event: EEventTimerComplete"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1458
	INFO_PRINTF2(_L("Calling CMMFDevSound::SetVolumeRamp using volume ramp time = %d"), iVolumeRamp);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1459
	iMMFDevSound->SetVolumeRamp(iVolumeRamp);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1460
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1461
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1462
void RA3FDevSoundToneSetVolumeRampWhilePlayingTest::ToneFinished(TInt aError)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1463
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1464
	INFO_PRINTF1(_L("========== DevSound ToneFinished() callback =========="));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1465
	if (aError == KErrUnderflow)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1466
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1467
		TInt totalExpectedReproductionTime;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1468
		iTimesToneFinishedCalled++;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1469
		totalExpectedReproductionTime = iDuration * iTimesToneFinishedCalled * KMicroSecsInOneSec;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1470
		iEndTime.HomeTime();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1471
		iPlayToneTime = iEndTime.MicroSecondsFrom(iStartTime);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1472
		if(!iTonePlayedTwice)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1473
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1474
			INFO_PRINTF2(_L("DevSound called ToneFinished with error = %d"), aError);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1475
			INFO_PRINTF3(_L("Calling CMMFDevSound::PlayToneL using frequency = %d Hz and duration = %d secs "), iFrequencyTone1, iDuration);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1476
			TRAPD(err, iMMFDevSound->PlayToneL(iFrequencyTone1, iDuration*KMicroSecsInOneSec));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1477
			if (err != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1478
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1479
				ERR_PRINTF2(_L("CMMFDevSound::PlayToneL with error : %d!"), err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1480
				StopTest(err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1481
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1482
			iTonePlayedTwice = ETrue;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1483
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1484
		else if (iPlayToneTime < totalExpectedReproductionTime + (2*KPlayVarianceTime) && iPlayToneTime > totalExpectedReproductionTime - (2*KPlayVarianceTime))
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1485
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1486
			INFO_PRINTF2(_L("DevSound called ToneFinished twice with error = %d"), aError);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1487
			INFO_PRINTF2(_L("Play time is %Ld microseconds"), iPlayToneTime.Int64());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1488
			StopTest();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1489
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1490
		else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1491
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1492
			ERR_PRINTF3(_L("Play time is %Ld microseconds and it should have been %d microseconds"), iPlayToneTime.Int64(), totalExpectedReproductionTime);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1493
			StopTest(KErrNone, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1494
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1495
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1496
	else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1497
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1498
		ERR_PRINTF2(_L("DevSound called ToneFinished with error = %d"), aError);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1499
		ERR_PRINTF2(_L("Expected error = %d"), KErrUnderflow);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1500
		StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1501
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1502
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1503
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1504
/*
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1505
 *========================================================================================================
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1506
 * MM-A3F-DEVSOUND-CHRTZ-TONE-0012
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1507
 */
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1508
RA3FDevSoundToneSetToneRepetitionsWhilePlayingTest::RA3FDevSoundToneSetToneRepetitionsWhilePlayingTest(const TDesC& aTestName)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1509
	:	RA3FDevSoundTestBase(aTestName),
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1510
		iDuration(0),
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1511
		iFrequencyTone1(0),
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1512
		iRepeatTrailingSilence(0),
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1513
		iRepeatCount(0)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1514
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1515
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1516
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1517
RA3FDevSoundToneSetToneRepetitionsWhilePlayingTest* RA3FDevSoundToneSetToneRepetitionsWhilePlayingTest::NewL(const TDesC& aTestName)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1518
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1519
	RA3FDevSoundToneSetToneRepetitionsWhilePlayingTest * self = new(ELeave)RA3FDevSoundToneSetToneRepetitionsWhilePlayingTest(aTestName);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1520
	return self;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1521
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1522
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1523
void RA3FDevSoundToneSetToneRepetitionsWhilePlayingTest::DoKickoffTestL()
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1524
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1525
	if (!GetIntFromConfig(iTestStepName, KRepeatCount, iRepeatCount))
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1526
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1527
		ERR_PRINTF2(KMsgErrorGetParameter, &KRepeatCount);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1528
		StopTest(KErrNotFound);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1529
		return;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1530
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1531
	if (!GetIntFromConfig(iTestStepName, KRepeatTrailingSilence, iRepeatTrailingSilence))
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1532
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1533
		ERR_PRINTF2(KMsgErrorGetParameter, &KRepeatTrailingSilence);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1534
		StopTest(KErrNotFound);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1535
		return;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1536
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1537
	if (!GetIntFromConfig(iTestStepName, KDuration, iDuration))
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1538
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1539
		ERR_PRINTF2(KMsgErrorGetParameter, &KDuration);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1540
		StopTest(KErrNotFound);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1541
		return;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1542
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1543
	if (!GetIntFromConfig(iTestStepName, KFrequencyTone1, iFrequencyTone1))
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1544
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1545
		ERR_PRINTF2(KMsgErrorGetParameter, &KFrequencyTone1);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1546
		StopTest(KErrNotFound);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1547
		return;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1548
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1549
	iTimer = CPeriodic::NewL(CActive::EPriorityHigh);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1550
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1551
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1552
void RA3FDevSoundToneSetToneRepetitionsWhilePlayingTest::Fsm(TMmfDevSoundEvent aDevSoundEvent, TInt aError)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1553
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1554
	switch (iDevSoundState)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1555
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1556
		case EStateCreated:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1557
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1558
			__ASSERT_ALWAYS((aError == KErrNone), Panic(_L("RA3FDevSoundToneSetToneRepetitionsWhilePlayingConfigurationTest"), EFsmIncorrectErrorPassed));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1559
			if(aDevSoundEvent == EEventInitialize)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1560
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1561
				INFO_PRINTF1(_L("Calling CMMFDevSound::InitializeL"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1562
				TRAPD(err, iMMFDevSound->InitializeL(*this, EMMFStateTonePlaying));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1563
				if (err != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1564
					{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1565
					ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"), err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1566
					StopTest(err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1567
					break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1568
					}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1569
				INFO_PRINTF1(_L("DevSound State: EStateInitializing"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1570
				iDevSoundState = EStateInitializing;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1571
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1572
			else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1573
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1574
				ERR_PRINTF2(_L("DevSound EEventInitialize not received as expected. Received event: %d"), aDevSoundEvent);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1575
				StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1576
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1577
			break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1578
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1579
		case EStateInitializing:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1580
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1581
			if (aDevSoundEvent == EEventInitComplete && aError == KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1582
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1583
				iMMFDevSound->SetVolume(iMMFDevSound->MaxVolume());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1584
				iStartTime.HomeTime();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1585
				INFO_PRINTF3(_L("Calling CMMFDevSound::PlayToneL %d Hz during %d secs "), iFrequencyTone1, iDuration);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1586
				TRAPD(err, iMMFDevSound->PlayToneL(iFrequencyTone1, iDuration*KMicroSecsInOneSec));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1587
				if (err != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1588
					{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1589
					ERR_PRINTF2(_L("CMMFDevSound::PlayToneL left with error : %d!"), err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1590
					StopTest(err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1591
					break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1592
					}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1593
				StartTimer(KMicroSecsTwoSec);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1594
				INFO_PRINTF1(_L("DevSound State: EStatePlaying"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1595
				iDevSoundState = EStatePlaying;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1596
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1597
			else if (aDevSoundEvent == EEventInitComplete && aError != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1598
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1599
				ERR_PRINTF2(_L("DevSound called CMMFDevSound::InitializeComplete with error = %d"), aError);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1600
				StopTest(aError);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1601
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1602
			else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1603
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1604
				ERR_PRINTF2(_L("DevSound EEventInitComplete not received as expected. Received event: %d"), aDevSoundEvent);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1605
				StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1606
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1607
			break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1608
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1609
		default:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1610
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1611
			ERR_PRINTF2(_L("Invalid DevSound state received: %d"), iDevSoundState);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1612
			StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1613
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1614
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1615
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1616
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1617
void RA3FDevSoundToneSetToneRepetitionsWhilePlayingTest::DoTimerCallback()
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1618
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1619
	iTimer->Cancel();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1620
	INFO_PRINTF1(_L("DevSound Event: EEventTimerComplete"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1621
	INFO_PRINTF3(_L("Calling CMMFDevSound::SetToneRepeats using RepeatCount = %d and RepeatTrailingSilence = %d microsecs"), iRepeatCount, iRepeatTrailingSilence);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1622
	iMMFDevSound->SetToneRepeats(iRepeatCount, iRepeatTrailingSilence);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1623
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1624
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1625
void RA3FDevSoundToneSetToneRepetitionsWhilePlayingTest::ToneFinished(TInt aError)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1626
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1627
	INFO_PRINTF1(_L("========== DevSound ToneFinished() callback =========="));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1628
	const TInt KtimesPlayToneIsCalled = 2;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1629
	if (aError == KErrUnderflow)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1630
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1631
		iEndTime.HomeTime();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1632
		iPlayToneTime = iEndTime.MicroSecondsFrom(iStartTime);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1633
		TInt repeatTrailingSilenceToSecs = iRepeatTrailingSilence/KMicroSecsInOneSec;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1634
		TInt totalExpectedReproductionTime = (KtimesPlayToneIsCalled*iDuration+iRepeatCount*iDuration + (repeatTrailingSilenceToSecs*iRepeatCount))*KMicroSecsInOneSec;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1635
		if(iPlayToneTime < ((iDuration*KMicroSecsInOneSec) + KPlayVarianceTime)&& iPlayToneTime > (iDuration*KMicroSecsInOneSec) - KPlayVarianceTime)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1636
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1637
			INFO_PRINTF1(_L("First play tone succeded."));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1638
			INFO_PRINTF2(_L("Play time is %Ld microseconds"), iPlayToneTime.Int64());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1639
			TRAPD(err, iMMFDevSound->PlayToneL(iFrequencyTone1, iDuration*KMicroSecsInOneSec));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1640
			if (err != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1641
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1642
				ERR_PRINTF2(_L("CMMFDevSound::PlayToneL failed with error : %d!"), err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1643
				StopTest(err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1644
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1645
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1646
		else if(iPlayToneTime < totalExpectedReproductionTime + KPlayVarianceTime && iPlayToneTime > totalExpectedReproductionTime - KPlayVarianceTime)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1647
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1648
			INFO_PRINTF1(_L("Play tone repeats succeded."));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1649
			INFO_PRINTF2(_L("Play time is %Ld microseconds"), iPlayToneTime.Int64());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1650
			StopTest();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1651
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1652
		else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1653
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1654
			ERR_PRINTF1(_L("Play tone repeats did not work as planned."));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1655
			ERR_PRINTF3(_L("Play time is %Ld microseconds and it should have been %d microseconds"), iPlayToneTime.Int64(), totalExpectedReproductionTime);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1656
			StopTest(KErrNone, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1657
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1658
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1659
	else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1660
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1661
		ERR_PRINTF2(_L("DevSound called ToneFinished with error = %d"), aError);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1662
		ERR_PRINTF2(_L("Expected error = %d"), KErrUnderflow);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1663
		StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1664
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1665
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1666
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1667
/*
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1668
 *========================================================================================================
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1669
 * MM-A3F-DEVSOUND-CHRTZ-TONE-0013
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1670
 */
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1671
RA3FDevSoundToneSetDTMFLengthsWhilePlayingTest::RA3FDevSoundToneSetDTMFLengthsWhilePlayingTest(const TDesC& aTestName)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1672
	:	RA3FDevSoundTestBase(aTestName),
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1673
		iFirstToneFinishedCall(EFalse),
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1674
		iToneOnLength(0), iToneOffLength(0),
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1675
		iPauseLength(0), iDTMFString(KNullDesC),
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1676
		iDTMFPauses(0), iDTMFTones(0),
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1677
		iTotalExpectedPlayToneTime(0)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1678
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1679
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1680
RA3FDevSoundToneSetDTMFLengthsWhilePlayingTest* RA3FDevSoundToneSetDTMFLengthsWhilePlayingTest::NewL(const TDesC& aTestName)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1681
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1682
	RA3FDevSoundToneSetDTMFLengthsWhilePlayingTest * self = new(ELeave)RA3FDevSoundToneSetDTMFLengthsWhilePlayingTest(aTestName);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1683
	return self;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1684
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1685
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1686
void RA3FDevSoundToneSetDTMFLengthsWhilePlayingTest::DoKickoffTestL()
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1687
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1688
	if (!GetIntFromConfig(iTestStepName, KToneOnLength, iToneOnLength))
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1689
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1690
		ERR_PRINTF2(KMsgErrorGetParameter, &KToneOnLength);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1691
		StopTest(KErrNotFound);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1692
		return;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1693
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1694
	if (!GetIntFromConfig(iTestStepName, KToneOffLength, iToneOffLength))
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1695
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1696
		ERR_PRINTF2(KMsgErrorGetParameter, &KToneOffLength);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1697
		StopTest(KErrNotFound);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1698
		return;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1699
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1700
	if (!GetIntFromConfig(iTestStepName, KPauseLength, iPauseLength))
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1701
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1702
		ERR_PRINTF2(KMsgErrorGetParameter, &KPauseLength);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1703
		StopTest(KErrNotFound);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1704
		return;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1705
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1706
	TPtrC DTMF;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1707
	if (!GetStringFromConfig(iTestStepName, KDTMFString, DTMF))
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1708
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1709
		ERR_PRINTF2(KMsgErrorGetParameter, &KDTMFString);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1710
		StopTest(KErrNotFound);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1711
		return;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1712
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1713
	iDTMFString.Copy(DTMF);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1714
	for(TInt i =0 ; i< iDTMFString.Length() ; i++)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1715
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1716
		if (iDTMFString[i] == ',')
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1717
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1718
			iDTMFPauses++;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1719
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1720
		else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1721
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1722
			iDTMFTones++;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1723
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1724
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1725
	iTimer = CPeriodic::NewL(CActive::EPriorityHigh);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1726
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1727
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1728
void RA3FDevSoundToneSetDTMFLengthsWhilePlayingTest::Fsm(TMmfDevSoundEvent aDevSoundEvent, TInt aError)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1729
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1730
	switch (iDevSoundState)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1731
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1732
		case EStateCreated:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1733
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1734
			__ASSERT_ALWAYS((aError == KErrNone), Panic(_L("RA3FDevSoundToneSetDTMFToneRepetitionsWhilePlayingConfigurationTest"), EFsmIncorrectErrorPassed));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1735
			if(aDevSoundEvent == EEventInitialize)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1736
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1737
				INFO_PRINTF1(_L("Calling CMMFDevSound::InitializeL"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1738
				TRAPD(err, iMMFDevSound->InitializeL(*this, EMMFStateTonePlaying));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1739
				if (err != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1740
					{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1741
					ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"), err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1742
					StopTest(err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1743
					break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1744
					}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1745
				INFO_PRINTF1(_L("DevSound State: EStateInitializing"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1746
				iDevSoundState = EStateInitializing;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1747
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1748
			else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1749
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1750
				ERR_PRINTF2(_L("DevSound EEventInitialize not received as expected. Received event: %d"), aDevSoundEvent);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1751
				StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1752
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1753
			break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1754
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1755
		case EStateInitializing:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1756
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1757
			if (aDevSoundEvent == EEventInitComplete && aError == KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1758
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1759
				iMMFDevSound->SetVolume(iMMFDevSound->MaxVolume());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1760
				iStartTime.HomeTime();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1761
				INFO_PRINTF2(_L("Calling CMMFDevSound::L %S"), &iDTMFString);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1762
				TRAPD(err, iMMFDevSound->PlayDTMFStringL(iDTMFString));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1763
				if (err != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1764
					{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1765
					ERR_PRINTF2(_L("CMMFDevSound::PlayDTMFStringL left with error : %d!"), err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1766
					StopTest(err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1767
					break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1768
					}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1769
				StartTimer(KMicroSecsTwoSec);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1770
				INFO_PRINTF1(_L("DevSound State: EStatePlaying"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1771
				iDevSoundState=EStatePlaying;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1772
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1773
			else if (aDevSoundEvent == EEventInitComplete && aError != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1774
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1775
				ERR_PRINTF2(_L("DevSound called CMMFDevSound::InitializeComplete with error = %d"), aError);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1776
				StopTest(aError);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1777
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1778
			else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1779
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1780
				ERR_PRINTF2(_L("DevSound EEventInitComplete not received as expected. Received event: %d"), aDevSoundEvent);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1781
				StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1782
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1783
			break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1784
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1785
		default:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1786
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1787
			ERR_PRINTF2(_L("Invalid DevSound state received: %d"), iDevSoundState);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1788
			StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1789
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1790
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1791
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1792
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1793
void RA3FDevSoundToneSetDTMFLengthsWhilePlayingTest::DoTimerCallback()
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1794
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1795
	iTimer->Cancel();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1796
	INFO_PRINTF1(_L("DevSound Event: EEventTimerComplete"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1797
	TTimeIntervalMicroSeconds32 ToneOnLength(iToneOnLength);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1798
	TTimeIntervalMicroSeconds32 ToneOffLength(iToneOffLength);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1799
	TTimeIntervalMicroSeconds32 PauseLength(iPauseLength);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1800
	INFO_PRINTF4(_L("Calling CMMFDevSound::SetDTMFLengths. ToneOnLength = %d, ToneOffLength = %d and PauseLength = %d"), ToneOnLength.Int(), ToneOffLength.Int(), PauseLength.Int());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1801
	iMMFDevSound->SetDTMFLengths(ToneOnLength, ToneOffLength, PauseLength);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1802
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1803
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1804
void RA3FDevSoundToneSetDTMFLengthsWhilePlayingTest::ToneFinished(TInt aError)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1805
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1806
	INFO_PRINTF1(_L("========== DevSound ToneFinished() callback =========="));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1807
	if (aError == KErrUnderflow)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1808
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1809
		iEndTime.HomeTime();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1810
		iPlayToneTime = iEndTime.MicroSecondsFrom(iStartTime);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1811
		if (!iFirstToneFinishedCall)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1812
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1813
			INFO_PRINTF1(_L("First play tone succeded"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1814
			INFO_PRINTF2(_L("Play time is %Ld microseconds"), iPlayToneTime.Int64());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1815
			iFirstToneFinishedCall = ETrue;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1816
			INFO_PRINTF2(_L("Calling CMMFDevSound::PlayDTMFStringL %S"), &iDTMFString);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1817
			TRAPD(err, iMMFDevSound->PlayDTMFStringL(iDTMFString));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1818
			if (err != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1819
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1820
				ERR_PRINTF2(_L("CMMFDevSound::PlayDTMFStringL left with error = %d"), err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1821
				StopTest(err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1822
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1823
			iTotalExpectedPlayToneTime = iToneOnLength*iDTMFTones + iToneOffLength * iDTMFTones + iDTMFPauses * iPauseLength + iPlayToneTime.Int64();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1824
			return;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1825
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1826
		if (iPlayToneTime.Int64() < iTotalExpectedPlayToneTime + KPlayVarianceTime && iPlayToneTime.Int64() > iTotalExpectedPlayToneTime - KPlayVarianceTime)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1827
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1828
			INFO_PRINTF1(_L("Calling CMMFDevSound::SetDTMFLengths succeded."));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1829
			INFO_PRINTF2(_L("Play time is %Ld microseconds"), iPlayToneTime.Int64());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1830
			StopTest();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1831
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1832
		else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1833
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1834
			ERR_PRINTF2(_L("Calling CMMFDevSound::SetDTMFLengths failed with %Ld"), iPlayToneTime.Int64());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1835
			ERR_PRINTF2(_L("Expected time %d"), iTotalExpectedPlayToneTime);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1836
			StopTest(KErrNone, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1837
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1838
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1839
	else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1840
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1841
		ERR_PRINTF2(_L("DevSound called ToneFinished with error = %d"), aError);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1842
		ERR_PRINTF2(_L("Expected error = %Ld"), KErrUnderflow);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1843
		StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1844
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1845
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1846
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1847
/*
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1848
 *========================================================================================================
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1849
 * MM-A3F-DEVSOUND-CHRTZ-TONE-0014
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1850
 */
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1851
RA3FDevSoundToneSetToneRepetitionsNotPlayingTonesModeTest::RA3FDevSoundToneSetToneRepetitionsNotPlayingTonesModeTest(const TDesC& aTestName)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1852
	:	RA3FDevSoundTestBase(aTestName), iDuration(0),
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1853
		iFrequencyTone1(0),
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1854
		iRepeatTrailingSilence(0), iRepeatCount(0),
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1855
		iInitializedToPlayTones(EFalse)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1856
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1857
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1858
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1859
RA3FDevSoundToneSetToneRepetitionsNotPlayingTonesModeTest* RA3FDevSoundToneSetToneRepetitionsNotPlayingTonesModeTest::NewL(const TDesC& aTestName)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1860
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1861
	RA3FDevSoundToneSetToneRepetitionsNotPlayingTonesModeTest * self = new(ELeave)RA3FDevSoundToneSetToneRepetitionsNotPlayingTonesModeTest(aTestName);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1862
	return self;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1863
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1864
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1865
void RA3FDevSoundToneSetToneRepetitionsNotPlayingTonesModeTest::DoKickoffTestL()
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1866
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1867
	if (!GetIntFromConfig(iTestStepName, KRepeatCount, iRepeatCount))
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1868
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1869
		ERR_PRINTF2(KMsgErrorGetParameter, &KRepeatCount);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1870
		StopTest(KErrNotFound);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1871
		return;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1872
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1873
	if (!GetIntFromConfig(iTestStepName, KRepeatTrailingSilence, iRepeatTrailingSilence))
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1874
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1875
		ERR_PRINTF2(KMsgErrorGetParameter, &KRepeatTrailingSilence);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1876
		StopTest(KErrNotFound);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1877
		return;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1878
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1879
	if (!GetIntFromConfig(iTestStepName, KDuration, iDuration))
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1880
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1881
		ERR_PRINTF2(KMsgErrorGetParameter, &KDuration);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1882
		StopTest(KErrNotFound);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1883
		return;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1884
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1885
	if (!GetIntFromConfig(iTestStepName, KFrequencyTone1, iFrequencyTone1))
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1886
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1887
		ERR_PRINTF2(KMsgErrorGetParameter, &KFrequencyTone1);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1888
		StopTest(KErrNotFound);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1889
		return;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1890
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1891
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1892
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1893
void RA3FDevSoundToneSetToneRepetitionsNotPlayingTonesModeTest::Fsm(TMmfDevSoundEvent aDevSoundEvent, TInt aError)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1894
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1895
	switch (iDevSoundState)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1896
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1897
		case EStateCreated:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1898
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1899
			__ASSERT_ALWAYS((aError == KErrNone), Panic(_L("RA3FDevSoundToneSetToneRepetitionsNotPlayingTonesModeConfigurationTest"), EFsmIncorrectErrorPassed));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1900
			if(aDevSoundEvent == EEventInitialize)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1901
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1902
				INFO_PRINTF1(_L("Calling CMMFDevSound::InitializeL"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1903
				TRAPD(err, iMMFDevSound->InitializeL(*this, EMMFStatePlaying));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1904
				if (err != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1905
					{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1906
					ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"), err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1907
					StopTest(err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1908
					break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1909
					}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1910
				INFO_PRINTF1(_L("DevSound State: EStateInitializing"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1911
				iDevSoundState = EStateInitializing;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1912
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1913
			else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1914
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1915
				ERR_PRINTF2(_L("DevSound EEventInitialize not received as expected. Received event: %d"), aDevSoundEvent);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1916
				StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1917
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1918
			break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1919
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1920
		case EStateInitializing:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1921
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1922
			if (aDevSoundEvent == EEventInitComplete && aError == KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1923
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1924
				if(!iInitializedToPlayTones)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1925
					{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1926
					INFO_PRINTF3(_L("Calling CMMFDevSound::SetToneRepeats using RepeatCount = %d and RepeatTrailingSilence = %d microsecs"), iRepeatCount, iRepeatTrailingSilence);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1927
					iMMFDevSound->SetToneRepeats(iRepeatCount, iRepeatTrailingSilence);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1928
					INFO_PRINTF1(_L("Calling CMMFDevSound::InitializeL for playing tones"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1929
					TRAPD(err, iMMFDevSound->InitializeL(*this, EMMFStateTonePlaying));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1930
					if (err != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1931
						{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1932
						ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"), err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1933
						StopTest(err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1934
						break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1935
						}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1936
					iInitializedToPlayTones = ETrue;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1937
					}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1938
				else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1939
					{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1940
					iMMFDevSound->SetVolume(iMMFDevSound->MaxVolume());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1941
					iStartTime.HomeTime();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1942
					INFO_PRINTF3(_L("Calling CMMFDevSound::PlayToneL %d Hz during %d secs "), iFrequencyTone1, iDuration);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1943
					TRAPD(err, iMMFDevSound->PlayToneL(iFrequencyTone1, iDuration*KMicroSecsInOneSec));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1944
					if (err != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1945
						{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1946
						ERR_PRINTF2(_L("CMMFDevSound::PlayToneL left with error : %d!"), err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1947
						StopTest(err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1948
						break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1949
						}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1950
					INFO_PRINTF1(_L("DevSound State: EStatePlaying"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1951
					iDevSoundState = EStatePlaying;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1952
					}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1953
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1954
			else if (aDevSoundEvent == EEventInitComplete && aError != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1955
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1956
				ERR_PRINTF2(_L("DevSound called CMMFDevSound::InitializeComplete with error = %d"), aError);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1957
				StopTest(aError);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1958
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1959
			else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1960
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1961
				ERR_PRINTF2(_L("DevSound EEventInitComplete not received as expected. Received event: %d"), aDevSoundEvent);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1962
				StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1963
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1964
			break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1965
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1966
		default:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1967
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1968
			ERR_PRINTF2(_L("Invalid DevSound state received: %d"), iDevSoundState);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1969
			StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1970
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1971
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1972
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1973
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1974
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1975
void RA3FDevSoundToneSetToneRepetitionsNotPlayingTonesModeTest::ToneFinished(TInt aError)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1976
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1977
	INFO_PRINTF1(_L("========== DevSound ToneFinished() callback =========="));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1978
	if (aError == KErrUnderflow)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1979
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1980
		iEndTime.HomeTime();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1981
		iPlayToneTime = iEndTime.MicroSecondsFrom(iStartTime);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1982
		TInt repeatTrailingSilenceToSecs = iRepeatTrailingSilence/KMicroSecsInOneSec;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1983
		TInt totalExpectedReproductionTime = (iDuration + iRepeatCount * iDuration+ (repeatTrailingSilenceToSecs*iRepeatCount)) * KMicroSecsInOneSec;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1984
		if(iPlayToneTime < (totalExpectedReproductionTime + KPlayVarianceTime) && iPlayToneTime > (totalExpectedReproductionTime - KPlayVarianceTime))
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1985
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1986
			INFO_PRINTF1(_L("Play tone repeats succeded."));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1987
			INFO_PRINTF2(_L("Play time is %Ld microseconds"), iPlayToneTime.Int64());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1988
			StopTest();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1989
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1990
		else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1991
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1992
			ERR_PRINTF1(_L("Play tone repeats did not work as planned."));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1993
			ERR_PRINTF3(_L("Play time is %Ld microseconds and it should have been %d microseconds"), iPlayToneTime.Int64(), totalExpectedReproductionTime);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1994
			StopTest(KErrNone, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1995
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1996
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1997
	else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1998
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  1999
		ERR_PRINTF2(_L("DevSound called ToneFinished with error = %d"), aError);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2000
		ERR_PRINTF2(_L("Expected error = %d"), KErrUnderflow);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2001
		StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2002
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2003
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2004
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2005
/*
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2006
 *========================================================================================================
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2007
 * MM-A3F-DEVSOUND-CHRTZ-TONE-0015
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2008
 */
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2009
RA3FDevSoundToneSetDTMFLengthsNotPlayingTonesModeTest::RA3FDevSoundToneSetDTMFLengthsNotPlayingTonesModeTest(const TDesC& aTestName)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2010
	:	RA3FDevSoundTestBase(aTestName), iInitializedToPlayTones(EFalse),
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2011
		iDTMFString(KNullDesC), iToneOnLength(0),
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2012
		iToneOffLength(0), iPauseLength(0),
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2013
		iDTMFPauses(0), iDTMFTones(0)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2014
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2015
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2016
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2017
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2018
RA3FDevSoundToneSetDTMFLengthsNotPlayingTonesModeTest* RA3FDevSoundToneSetDTMFLengthsNotPlayingTonesModeTest::NewL(const TDesC& aTestName)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2019
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2020
	RA3FDevSoundToneSetDTMFLengthsNotPlayingTonesModeTest * self = new(ELeave)RA3FDevSoundToneSetDTMFLengthsNotPlayingTonesModeTest(aTestName);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2021
	return self;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2022
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2023
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2024
void RA3FDevSoundToneSetDTMFLengthsNotPlayingTonesModeTest::DoKickoffTestL()
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2025
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2026
	if (!GetIntFromConfig(iTestStepName, KToneOnLength, iToneOnLength))
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2027
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2028
		ERR_PRINTF2(KMsgErrorGetParameter, &KToneOnLength);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2029
		StopTest(KErrNotFound);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2030
		return;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2031
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2032
	if (!GetIntFromConfig(iTestStepName, KToneOffLength, iToneOffLength))
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2033
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2034
		ERR_PRINTF2(KMsgErrorGetParameter, &KToneOffLength);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2035
		StopTest(KErrNotFound);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2036
		return;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2037
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2038
	if (!GetIntFromConfig(iTestStepName, KPauseLength, iPauseLength))
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2039
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2040
		ERR_PRINTF2(KMsgErrorGetParameter, &KPauseLength);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2041
		StopTest(KErrNotFound);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2042
		return;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2043
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2044
	TPtrC DTMF;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2045
	if (!GetStringFromConfig(iTestStepName, KDTMFString, DTMF))
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2046
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2047
		ERR_PRINTF2(KMsgErrorGetParameter, &KDTMFString);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2048
		StopTest(KErrNotFound);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2049
		return;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2050
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2051
	iDTMFString.Copy(DTMF);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2052
	for(TInt i =0 ; i< iDTMFString.Length() ; i++)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2053
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2054
		if (iDTMFString[i] == ',')
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2055
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2056
			iDTMFPauses++;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2057
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2058
		else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2059
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2060
			iDTMFTones++;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2061
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2062
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2063
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2064
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2065
void RA3FDevSoundToneSetDTMFLengthsNotPlayingTonesModeTest::Fsm(TMmfDevSoundEvent aDevSoundEvent, TInt aError)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2066
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2067
	switch (iDevSoundState)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2068
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2069
		case EStateCreated:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2070
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2071
			__ASSERT_ALWAYS((aError == KErrNone), Panic(_L("RA3FDevSoundToneSetDTMFLengthsNotPlayingTonesModeConfigurationTest"), EFsmIncorrectErrorPassed));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2072
			if(aDevSoundEvent == EEventInitialize)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2073
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2074
				INFO_PRINTF1(_L("Calling CMMFDevSound::InitializeL"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2075
				TRAPD(err, iMMFDevSound->InitializeL(*this, EMMFStateRecording));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2076
				if (err != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2077
					{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2078
					ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"), err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2079
					StopTest(err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2080
					break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2081
					}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2082
				INFO_PRINTF1(_L("DevSound State: EStateInitializing"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2083
				iDevSoundState = EStateInitializing;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2084
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2085
			else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2086
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2087
				ERR_PRINTF2(_L("DevSound EEventInitialize not received as expected. Received event: %d"),  aDevSoundEvent);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2088
				StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2089
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2090
			break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2091
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2092
		case EStateInitializing:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2093
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2094
			if (aDevSoundEvent == EEventInitComplete && aError == KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2095
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2096
				if(!iInitializedToPlayTones)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2097
					{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2098
					TTimeIntervalMicroSeconds32 ToneOnLength(iToneOnLength);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2099
					TTimeIntervalMicroSeconds32 ToneOffLength(iToneOffLength);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2100
					TTimeIntervalMicroSeconds32 PauseLength(iPauseLength);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2101
					INFO_PRINTF4(_L("Calling CMMFDevSound::SetDTMFLengths. ToneOnLength = %d, ToneOffLength = %d and PauseLength = %d"), ToneOnLength.Int(), ToneOffLength.Int(), PauseLength.Int());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2102
					iMMFDevSound->SetDTMFLengths(ToneOnLength, ToneOffLength, PauseLength);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2103
					INFO_PRINTF1(_L("Calling CMMFDevSound::InitializeL"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2104
					TRAPD(err, iMMFDevSound->InitializeL(*this, EMMFStateTonePlaying));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2105
					if (err != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2106
						{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2107
						ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"), err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2108
						StopTest(err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2109
						break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2110
						}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2111
					iInitializedToPlayTones = ETrue;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2112
					}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2113
				else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2114
					{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2115
					iMMFDevSound->SetVolume(iMMFDevSound->MaxVolume());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2116
					iStartTime.HomeTime();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2117
					INFO_PRINTF2(_L("Calling CMMFDevSound::PlayDTMFStringL %S"), &iDTMFString);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2118
					TRAPD(err, iMMFDevSound->PlayDTMFStringL(iDTMFString));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2119
					if (err != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2120
						{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2121
						ERR_PRINTF2(_L("Play DTMF string failed with error : %d!"), err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2122
						StopTest(err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2123
						break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2124
						}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2125
					INFO_PRINTF1(_L("DevSound State: EStatePlaying"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2126
					iDevSoundState = EStatePlaying;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2127
					}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2128
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2129
			else if (aDevSoundEvent == EEventInitComplete && aError != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2130
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2131
				ERR_PRINTF2(_L("DevSound called CMMFDevSound::InitializeComplete with error = %d"), aError);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2132
				StopTest(aError);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2133
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2134
			else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2135
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2136
				ERR_PRINTF2(_L("DevSound EEventInitComplete not received as expected. Received event: %d"), aDevSoundEvent);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2137
				StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2138
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2139
			break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2140
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2141
		default:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2142
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2143
			ERR_PRINTF2(_L("Invalid DevSound state received: %d"), iDevSoundState);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2144
			StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2145
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2146
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2147
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2148
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2149
void RA3FDevSoundToneSetDTMFLengthsNotPlayingTonesModeTest::ToneFinished(TInt aError)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2150
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2151
	INFO_PRINTF1(_L("========== DevSound ToneFinished() callback =========="));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2152
	if (aError == KErrUnderflow)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2153
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2154
		iEndTime.HomeTime();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2155
		iPlayToneTime = iEndTime.MicroSecondsFrom(iStartTime);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2156
		TInt totalExpectedReproductionTime = iToneOnLength*iDTMFTones + iToneOffLength * iDTMFTones + iDTMFPauses * iPauseLength;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2157
		if (iPlayToneTime.Int64() < totalExpectedReproductionTime + KPlayVarianceTime && iPlayToneTime.Int64() > totalExpectedReproductionTime - KPlayVarianceTime)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2158
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2159
			INFO_PRINTF1(_L("CMMFDevSound::SetDTMFLengths settings were remembered after re-initialization."));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2160
			INFO_PRINTF2(_L("Play time is %Ld microseconds"), iPlayToneTime.Int64());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2161
			StopTest();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2162
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2163
		else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2164
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2165
			ERR_PRINTF1(_L("CMMFDevSound::SetDTMFLengths settings were not remembered after re-initialization."));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2166
			ERR_PRINTF2(_L("Expected time %d"), totalExpectedReproductionTime);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2167
			StopTest(KErrNone, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2168
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2169
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2170
	else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2171
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2172
		ERR_PRINTF2(_L("DevSound called ToneFinished with error = %d"), aError);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2173
		ERR_PRINTF2(_L("Expected error = %d"), KErrUnderflow);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2174
		StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2175
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2176
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2177
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2178
/*
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2179
 *========================================================================================================
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2180
 * MM-A3F-DEVSOUND-CHRTZ-TONE-0016
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2181
 */
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2182
RA3FDevSoundToneSetConfigWhilePlayingTest::RA3FDevSoundToneSetConfigWhilePlayingTest(const TDesC& aTestName)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2183
	:	RA3FDevSoundTestBase(aTestName), iDuration(0),
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2184
		iVolume(0), iFrequencyTone1(0),
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2185
		iSampleRate(0), iChannels(0)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2186
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2187
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2188
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2189
RA3FDevSoundToneSetConfigWhilePlayingTest* RA3FDevSoundToneSetConfigWhilePlayingTest::NewL(const TDesC& aTestName)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2190
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2191
	RA3FDevSoundToneSetConfigWhilePlayingTest * self = new(ELeave)RA3FDevSoundToneSetConfigWhilePlayingTest(aTestName);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2192
	return self;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2193
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2194
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2195
void RA3FDevSoundToneSetConfigWhilePlayingTest::DoKickoffTestL()
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2196
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2197
	if (!GetIntFromConfig(iTestStepName, KSampleRate, iSampleRate))
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2198
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2199
		ERR_PRINTF2(KMsgErrorGetParameter, &KSampleRate);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2200
		StopTest(KErrNotFound);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2201
		return;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2202
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2203
	if (!GetIntFromConfig(iTestStepName, KChannel, iChannels))
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2204
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2205
		ERR_PRINTF2(KMsgErrorGetParameter, &KChannel);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2206
		StopTest(KErrNotFound);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2207
		return;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2208
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2209
	if (!GetIntFromConfig(iTestStepName, KDuration, iDuration))
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2210
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2211
		ERR_PRINTF2(KMsgErrorGetParameter, &KDuration);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2212
		StopTest(KErrNotFound);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2213
		return;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2214
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2215
	if (!GetIntFromConfig(iTestStepName, KFrequencyTone1, iFrequencyTone1))
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2216
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2217
		ERR_PRINTF2(KMsgErrorGetParameter, &KFrequencyTone1);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2218
		StopTest(KErrNotFound);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2219
		return;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2220
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2221
	iTimer = CPeriodic::NewL(CActive::EPriorityHigh);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2222
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2223
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2224
void RA3FDevSoundToneSetConfigWhilePlayingTest::Fsm(TMmfDevSoundEvent aDevSoundEvent,  TInt aError)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2225
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2226
	switch (iDevSoundState)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2227
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2228
		case EStateCreated:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2229
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2230
			__ASSERT_ALWAYS((aError == KErrNone), Panic(_L("RA3FDevSoundToneSetConfigWhilePlayingTest"), EFsmIncorrectErrorPassed));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2231
			if (aDevSoundEvent == EEventInitialize)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2232
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2233
				INFO_PRINTF1(_L("Calling CMMFDevSound::InitializeL"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2234
				TRAPD(err, iMMFDevSound->InitializeL(*this, EMMFStateTonePlaying));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2235
				if (err != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2236
					{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2237
					ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"), err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2238
					StopTest(err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2239
					break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2240
					}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2241
				StartTimer(KMicroSecsTwoSec);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2242
				INFO_PRINTF1(_L("DevSound State: EStateInitializing"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2243
				iDevSoundState = EStateInitializing;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2244
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2245
			else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2246
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2247
				ERR_PRINTF2(_L("DevSound EEventInitialize not received as expected. Received event: %d"), aDevSoundEvent);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2248
				StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2249
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2250
			break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2251
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2252
		case EStateInitializing:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2253
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2254
			if (aDevSoundEvent == EEventInitComplete && aError == KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2255
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2256
				INFO_PRINTF1(_L("CMMFDevSound::PlayToneL"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2257
				TRAPD(err, iMMFDevSound->PlayToneL(iFrequencyTone1,  iDuration*KMicroSecsInOneSec));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2258
				if (err != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2259
					{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2260
					ERR_PRINTF2(_L("CMMFDevSound::PlayToneL left with error : %d"), err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2261
					StopTest(err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2262
					break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2263
					}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2264
				INFO_PRINTF1(_L("DevSound State: EStatePlaying"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2265
				iDevSoundState = EStatePlaying;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2266
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2267
			else if (aDevSoundEvent == EEventInitComplete && aError != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2268
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2269
				ERR_PRINTF2(_L("DevSound called CMMFDevSound::InitializeComplete with error = %d"), aError);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2270
				StopTest(aError);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2271
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2272
			else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2273
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2274
				ERR_PRINTF2(_L("DevSound EEventInitComplete not received as expected. Received event: %d"), aDevSoundEvent);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2275
				StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2276
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2277
			break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2278
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2279
		default:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2280
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2281
			ERR_PRINTF2(_L("Invalid DevSound state received: %d"), iDevSoundState);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2282
			StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2283
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2284
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2285
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2286
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2287
void RA3FDevSoundToneSetConfigWhilePlayingTest::DoTimerCallback()
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2288
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2289
	iTimer->Cancel();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2290
	INFO_PRINTF1(_L("DevSound Event: EEventTimerComplete"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2291
	TMMFCapabilities capabilitiesSet;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2292
	TBuf<KMaxSampleRateStringLength> stringSampleRateSet;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2293
	TBuf<KMaxChannelsStringLength> stringChannelsSet;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2294
	TMMFSampleRate eSampleRate;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2295
	SampleRateFromTIntToTMMFSampleRate (iSampleRate, eSampleRate);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2296
	capabilitiesSet.iRate = eSampleRate;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2297
	capabilitiesSet.iChannels = iChannels;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2298
	SampleRateFromTUintToString (capabilitiesSet.iRate,	stringSampleRateSet);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2299
	ChannelsFromTUintToString (capabilitiesSet.iChannels, stringChannelsSet);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2300
	INFO_PRINTF3(_L("Calling CMMFDevSound::SetConfigL using sample rate = %S and channel mode = %S"), &stringSampleRateSet, &stringChannelsSet);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2301
	TRAPD(err, iMMFDevSound->SetConfigL(capabilitiesSet));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2302
	if (err == KErrNotReady)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2303
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2304
		INFO_PRINTF2(_L("CMMFDevSound::SetConfigL succeeded with error = %d"), err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2305
		StopTest(err, EPass);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2306
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2307
	else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2308
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2309
		ERR_PRINTF2(_L("CMMFDevSound::SetConfigL failed with error = %d"), err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2310
		ERR_PRINTF2(_L("Expected  error = %d"), KErrNotReady);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2311
		StopTest(err, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2312
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2313
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2314
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2315
/*
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2316
 *========================================================================================================
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2317
 * MM-A3F-DEVSOUND-CHRTZ-TONE-0017
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2318
 */
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2319
RA3FDevSoundToneSetPriorityWhilePlayingTest::RA3FDevSoundToneSetPriorityWhilePlayingTest(const TDesC& aTestName)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2320
	:	RA3FDevSoundTestBase(aTestName),
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2321
		iDuration(0), iFrequencyTone1(0)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2322
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2323
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2324
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2325
RA3FDevSoundToneSetPriorityWhilePlayingTest* RA3FDevSoundToneSetPriorityWhilePlayingTest::NewL(const TDesC& aTestName)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2326
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2327
	RA3FDevSoundToneSetPriorityWhilePlayingTest * self = new(ELeave)RA3FDevSoundToneSetPriorityWhilePlayingTest(aTestName);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2328
	return self;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2329
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2330
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2331
void RA3FDevSoundToneSetPriorityWhilePlayingTest::DoKickoffTestL()
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2332
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2333
	if (!GetIntFromConfig(iTestStepName, KDuration, iDuration))
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2334
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2335
		ERR_PRINTF2(KMsgErrorGetParameter, &KDuration);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2336
		StopTest(KErrNotFound);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2337
		return;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2338
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2339
	if (!GetIntFromConfig(iTestStepName, KFrequencyTone1, iFrequencyTone1))
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2340
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2341
		ERR_PRINTF2(KMsgErrorGetParameter, &KFrequencyTone1);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2342
		StopTest(KErrNotFound);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2343
		return;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2344
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2345
	iTimer = CPeriodic::NewL(CActive::EPriorityHigh);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2346
	iDevsoundToneClient = CA3FDevSoundToneClient::NewL(*this);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2347
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2348
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2349
void RA3FDevSoundToneSetPriorityWhilePlayingTest::Fsm(TMmfDevSoundEvent aDevSoundEvent, TInt aError)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2350
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2351
	switch(iDevSoundState)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2352
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2353
		case EStateCreated:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2354
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2355
			__ASSERT_ALWAYS((aError == KErrNone), Panic(_L("RA3FDevSoundToneSetPriorityWhilePlayingConfigurationTest"), EFsmIncorrectErrorPassed));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2356
			if(aDevSoundEvent == EEventInitialize)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2357
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2358
				INFO_PRINTF1(_L("Calling CMMFDevSound::InitializeL"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2359
				TRAPD(err, iMMFDevSound->InitializeL(*this, EMMFStateTonePlaying));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2360
				if (err != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2361
					{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2362
					ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"), err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2363
					StopTest(err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2364
					break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2365
					}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2366
				INFO_PRINTF1(_L("DevSound State: EStateInitializing"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2367
				iDevSoundState = EStateInitializing;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2368
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2369
			else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2370
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2371
				ERR_PRINTF2(_L("DevSound EEventInitialize not received as expected. Received event: %d"), aDevSoundEvent);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2372
				StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2373
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2374
			break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2375
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2376
		case EStateInitializing:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2377
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2378
			if (aDevSoundEvent == EEventInitComplete && aError == KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2379
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2380
				iMMFDevSound->SetVolume(iMMFDevSound->MaxVolume ());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2381
				INFO_PRINTF1(_L("Calling CMMFDevSound::PlayToneL"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2382
				TRAPD(err, iMMFDevSound->PlayToneL(iFrequencyTone1, iDuration*KMicroSecsInOneSec));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2383
				if (err != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2384
					{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2385
					ERR_PRINTF2(_L("CMMFDevSound::PlayToneL left with error : %d!"), err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2386
					StopTest(err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2387
					break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2388
					}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2389
				StartTimer(KMicroSecsTwoSec);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2390
				INFO_PRINTF1(_L("DevSound State: EStatePlaying"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2391
				iDevSoundState = EStatePlaying;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2392
				INFO_PRINTF2(_L("Calling CMMFDevSound::SetPrioritySettings using a priority(highest) value = %d"), KMaximumPriority);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2393
				TMMFPrioritySettings priority;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2394
				priority.iPriority = KMaximumPriority;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2395
				iMMFDevSound->SetPrioritySettings(priority);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2396
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2397
			else if (aDevSoundEvent == EEventInitComplete && aError != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2398
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2399
				ERR_PRINTF2(_L("DevSound called CMMFDevSound::InitializeComplete with error = %d"), aError);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2400
				StopTest(aError);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2401
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2402
			else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2403
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2404
				ERR_PRINTF2(_L("DevSound EEventInitComplete not received as expected. Received event: %d"), aDevSoundEvent);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2405
				StopTest(aError,  EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2406
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2407
			break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2408
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2409
		default:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2410
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2411
			ERR_PRINTF2(_L("Invalid DevSound state received: %d"), iDevSoundState);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2412
			StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2413
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2414
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2415
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2416
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2417
void RA3FDevSoundToneSetPriorityWhilePlayingTest::ClientInitializeCompleteCallback(TInt aError)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2418
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2419
	INFO_PRINTF1(_L("==========Second DevSound client called InitializeComplete()=========="));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2420
	if (aError == KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2421
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2422
		TInt err = iDevsoundToneClient->PlayTone ();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2423
		if (err != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2424
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2425
			ERR_PRINTF2(_L("Second Devsound client called PlayTone and failed with error = %d"), err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2426
			StopTest(err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2427
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2428
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2429
	else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2430
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2431
		ERR_PRINTF2(_L("Second Devsound InitializeComplete received an error = %d"), aError);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2432
		StopTest(aError);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2433
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2434
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2435
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2436
void RA3FDevSoundToneSetPriorityWhilePlayingTest::ClientToneFinishedCallback(TInt aError)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2437
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2438
	INFO_PRINTF1(_L("========== Second  DevSound client called ToneFinished()=========="));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2439
	if (aError == KErrUnderflow)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2440
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2441
		INFO_PRINTF2(_L("Second DevSound client called ToneFinished and succeeded with error = %d"), aError);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2442
		StopTest(aError, EPass);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2443
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2444
	else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2445
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2446
		ERR_PRINTF2(_L("Second DevSound client called ToneFinished and failed with error = %d"), aError);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2447
		StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2448
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2449
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2450
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2451
void RA3FDevSoundToneSetPriorityWhilePlayingTest::DoTimerCallback()
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2452
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2453
	INFO_PRINTF1(_L("TimerEvent called"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2454
	iTimer->Cancel();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2455
	INFO_PRINTF1(_L("Starting another devsound client using the highest priority"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2456
	iDevsoundToneClient->SetPriority(KMaximumPriority);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2457
	TInt err = iDevsoundToneClient->InitTonePlay(iFrequencyTone1, iDuration*KMicroSecsInOneSec);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2458
	if(err != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2459
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2460
		ERR_PRINTF1(_L("Initialization to play tone thru second devsound client failed"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2461
		StopTest(err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2462
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2463
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2464
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2465
void RA3FDevSoundToneSetPriorityWhilePlayingTest::ToneFinished(TInt aError)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2466
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2467
	INFO_PRINTF1(_L("========== DevSound ToneFinished() callback =========="));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2468
	if (aError == KErrInUse || aError == KErrDied || aError == KErrAccessDenied)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2469
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2470
		INFO_PRINTF1(_L("========== Preempting 1st DevSound Instance=========="));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2471
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2472
	else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2473
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2474
		ERR_PRINTF2(_L("DevSound called ToneFinished and failed with error = %d"), aError);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2475
		ERR_PRINTF4(_L("Expected errors posibilities %d %d %d"), KErrInUse, KErrDied, KErrAccessDenied);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2476
		StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2477
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2478
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2479
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2480
/*
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2481
 *========================================================================================================
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2482
 * MM-A3F-DEVSOUND-CHRTZ-TONE-0018
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2483
 */
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2484
RA3FDevSoundToneSetConfigTestToInvalidSampleRateValue::RA3FDevSoundToneSetConfigTestToInvalidSampleRateValue(const TDesC& aTestName)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2485
	:	RA3FDevSoundTestBase(aTestName), iSampleRate(0),
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2486
		iChannels(0)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2487
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2488
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2489
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2490
RA3FDevSoundToneSetConfigTestToInvalidSampleRateValue* RA3FDevSoundToneSetConfigTestToInvalidSampleRateValue::NewL(const TDesC& aTestName)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2491
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2492
	RA3FDevSoundToneSetConfigTestToInvalidSampleRateValue * self = new(ELeave)RA3FDevSoundToneSetConfigTestToInvalidSampleRateValue(aTestName);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2493
	return self;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2494
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2495
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2496
void RA3FDevSoundToneSetConfigTestToInvalidSampleRateValue::DoKickoffTestL()
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2497
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2498
	if (!GetIntFromConfig(iTestStepName, KSampleRate, iSampleRate))
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2499
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2500
		ERR_PRINTF2(KMsgErrorGetParameter, &KSampleRate);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2501
		StopTest(KErrNotFound);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2502
		return;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2503
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2504
	if (!GetIntFromConfig(iTestStepName, KChannel, iChannels))
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2505
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2506
		ERR_PRINTF2(KMsgErrorGetParameter, &KChannel);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2507
		StopTest(KErrNotFound);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2508
		return;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2509
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2510
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2511
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2512
void RA3FDevSoundToneSetConfigTestToInvalidSampleRateValue::Fsm(TMmfDevSoundEvent aDevSoundEvent, TInt aError)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2513
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2514
#ifdef MM_TB101_L
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2515
		//Reason: Check remains since this is a valid test case, but we need to know why we are not testing invalid rates.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2516
		INFO_PRINTF1(_L("MM_TB101_L defined: All sample rates are valid for MM_TB101_L (HW), therefore no invalid rates can be tested."));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2517
		StopTest(KErrNotSupported, EPass);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2518
#else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2519
	switch(iDevSoundState)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2520
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2521
		case EStateCreated:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2522
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2523
			if(aDevSoundEvent == EEventInitialize)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2524
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2525
				__ASSERT_ALWAYS((aError == KErrNone), Panic(_L("RA3FDevSoundToneSetConfigTestToInvalidSampleRateValue"), EFsmIncorrectErrorPassed));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2526
				INFO_PRINTF1(_L("Calling CMMFDevSound::InitializeL"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2527
				TRAPD(err, iMMFDevSound->InitializeL(*this, EMMFStateTonePlaying));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2528
				if (err != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2529
					{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2530
					ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"), err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2531
					StopTest(err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2532
					break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2533
					}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2534
				INFO_PRINTF1(_L("DevSound State: EStateInitializing"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2535
				iDevSoundState = EStateInitializing;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2536
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2537
			else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2538
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2539
				ERR_PRINTF2(_L("DevSound EEventInitialize not received as expected. Received event: %d"), aDevSoundEvent);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2540
				StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2541
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2542
			break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2543
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2544
		case EStateInitializing:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2545
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2546
			if (aDevSoundEvent == EEventInitComplete && aError == KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2547
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2548
				TMMFCapabilities capabilitiesSet;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2549
				TBuf<KMaxSampleRateStringLength> stringSampleRateSet;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2550
				TBuf<KMaxChannelsStringLength> stringChannelsSet;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2551
				TMMFSampleRate eSampleRate;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2552
				SampleRateFromTIntToTMMFSampleRate (iSampleRate, eSampleRate);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2553
				capabilitiesSet.iRate = eSampleRate;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2554
				capabilitiesSet.iChannels = iChannels;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2555
				SampleRateFromTUintToString (capabilitiesSet.iRate,	stringSampleRateSet);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2556
				ChannelsFromTUintToString (capabilitiesSet.iChannels, stringChannelsSet);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2557
				INFO_PRINTF3(_L("Calling CMMFDevSound::SetConfigL using an invalid sample rate = %S and channel mode = %S"), &stringSampleRateSet, &stringChannelsSet);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2558
				TRAPD(err, iMMFDevSound->SetConfigL(capabilitiesSet));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2559
				if (err == KErrNotSupported || err == KErrArgument)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2560
					{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2561
					INFO_PRINTF2(_L("CMMFDevSound::SetConfigL succeeded with error = %d"), err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2562
					StopTest(err, EPass);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2563
					}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2564
				else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2565
					{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2566
					ERR_PRINTF2(_L("CMMFDevSound::SetConfigL failed with error = %d"), err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2567
					ERR_PRINTF3(_L("Expected  error posibilities %d %d"), KErrArgument, KErrNotSupported);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2568
					StopTest(err, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2569
					}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2570
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2571
			else if (aDevSoundEvent == EEventInitComplete && aError != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2572
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2573
				ERR_PRINTF2(_L("DevSound called CMMFDevSound::InitializeComplete with error = %d"), aError);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2574
				StopTest(aError);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2575
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2576
			else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2577
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2578
				ERR_PRINTF2(_L("DevSound EEventInitComplete not received as expected. Received event: %d"), aDevSoundEvent);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2579
				StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2580
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2581
			break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2582
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2583
		default:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2584
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2585
			ERR_PRINTF2(_L("Invalid DevSound state received: %d"), iDevSoundState);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2586
			StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2587
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2588
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2589
#endif// MM_TB101_L
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2590
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2591
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2592
/*
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2593
 *========================================================================================================
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2594
 * MM-A3F-DEVSOUND-CHRTZ-TONE-0019
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2595
 */
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2596
RA3FDevSoundToneSetConfigTestToInvalidChannelValueTest::RA3FDevSoundToneSetConfigTestToInvalidChannelValueTest(const TDesC& aTestName)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2597
	:	RA3FDevSoundTestBase(aTestName), iSampleRate(0),
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2598
		iChannels(0)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2599
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2600
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2601
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2602
RA3FDevSoundToneSetConfigTestToInvalidChannelValueTest* RA3FDevSoundToneSetConfigTestToInvalidChannelValueTest::NewL(const TDesC& aTestName)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2603
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2604
	RA3FDevSoundToneSetConfigTestToInvalidChannelValueTest * self = new(ELeave)RA3FDevSoundToneSetConfigTestToInvalidChannelValueTest(aTestName);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2605
	return self;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2606
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2607
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2608
void RA3FDevSoundToneSetConfigTestToInvalidChannelValueTest::DoKickoffTestL()
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2609
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2610
	if (!GetIntFromConfig(iTestStepName, KSampleRate, iSampleRate))
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2611
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2612
		ERR_PRINTF2(KMsgErrorGetParameter, &KSampleRate);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2613
		StopTest(KErrNotFound);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2614
		return;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2615
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2616
	if (!GetIntFromConfig(iTestStepName, KChannel, iChannels))
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2617
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2618
		ERR_PRINTF2(KMsgErrorGetParameter, &KChannel);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2619
		StopTest(KErrNotFound);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2620
		return;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2621
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2622
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2623
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2624
void RA3FDevSoundToneSetConfigTestToInvalidChannelValueTest::Fsm(TMmfDevSoundEvent aDevSoundEvent, TInt aError)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2625
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2626
	switch(iDevSoundState)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2627
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2628
		case EStateCreated:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2629
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2630
			if(aDevSoundEvent == EEventInitialize)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2631
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2632
				__ASSERT_ALWAYS((aError == KErrNone), Panic(_L("RA3FDevSoundToneSetConfigTestToInvalidChannelValueTest"), EFsmIncorrectErrorPassed));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2633
				INFO_PRINTF1(_L("Calling CMMFDevSound::InitializeL"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2634
				TRAPD(err, iMMFDevSound->InitializeL(*this, EMMFStateTonePlaying));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2635
				if (err != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2636
					{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2637
					ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"), err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2638
					StopTest(err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2639
					break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2640
					}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2641
				INFO_PRINTF1(_L("DevSound State: EStateInitializing"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2642
				iDevSoundState = EStateInitializing;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2643
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2644
			else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2645
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2646
				ERR_PRINTF2(_L("DevSound EEventInitialize not received as expected. Received event: %d"), aDevSoundEvent);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2647
				StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2648
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2649
			break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2650
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2651
		case EStateInitializing:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2652
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2653
			if (aDevSoundEvent == EEventInitComplete && aError == KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2654
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2655
				TMMFCapabilities capabilitiesSet;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2656
				TBuf<KMaxSampleRateStringLength> stringSampleRateSet;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2657
				TBuf<KMaxChannelsStringLength> stringChannelsSet;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2658
				TMMFSampleRate eSampleRate;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2659
				SampleRateFromTIntToTMMFSampleRate (iSampleRate, eSampleRate);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2660
				capabilitiesSet.iRate = eSampleRate;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2661
				capabilitiesSet.iChannels = iChannels;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2662
				SampleRateFromTUintToString (capabilitiesSet.iRate,	stringSampleRateSet);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2663
				INFO_PRINTF3(_L("Calling CMMFDevSound::SetConfigL using a sample rate = %S and an invalid channel mode = %d"), &stringSampleRateSet, iChannels);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2664
				TRAPD(err, iMMFDevSound->SetConfigL(capabilitiesSet));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2665
				if (err == KErrNotSupported || err == KErrArgument)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2666
					{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2667
					INFO_PRINTF2(_L("CMMFDevSound::SetConfigL succeeded with error = %d"), err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2668
					StopTest(err, EPass);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2669
					}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2670
				else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2671
					{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2672
					ERR_PRINTF2(_L("CMMFDevSound::SetConfigL failed with error = %d"), err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2673
					ERR_PRINTF3(_L("Expected  error posibilities %d %d"), KErrArgument, KErrNotSupported);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2674
					StopTest(err, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2675
					}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2676
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2677
			else if (aDevSoundEvent == EEventInitComplete && aError != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2678
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2679
				ERR_PRINTF2(_L("DevSound called CMMFDevSound::InitializeComplete with error = %d"), aError);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2680
				StopTest(aError);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2681
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2682
			else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2683
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2684
				ERR_PRINTF2(_L("DevSound EEventInitComplete not received as expected. Received event: %d"), aDevSoundEvent);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2685
				StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2686
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2687
			break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2688
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2689
		default:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2690
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2691
			ERR_PRINTF2(_L("Invalid DevSound state received: %d"), iDevSoundState);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2692
			StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2693
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2694
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2695
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2696
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2697
/*
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2698
 *========================================================================================================
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2699
 * MM-A3F-DEVSOUND-CHRTZ-TONE-0020
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2700
 */
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2701
RA3FDevSoundToneSetDTMFLengthsToNegativeTest::RA3FDevSoundToneSetDTMFLengthsToNegativeTest(const TDesC& aTestName)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2702
	:	RA3FDevSoundTestBase(aTestName), iToneOnLength(0),
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2703
		iToneOffLength(0), iPauseLength(0),
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2704
		iDTMFString(KNullDesC)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2705
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2706
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2707
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2708
RA3FDevSoundToneSetDTMFLengthsToNegativeTest* RA3FDevSoundToneSetDTMFLengthsToNegativeTest::NewL(const TDesC& aTestName)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2709
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2710
	RA3FDevSoundToneSetDTMFLengthsToNegativeTest * self = new(ELeave)RA3FDevSoundToneSetDTMFLengthsToNegativeTest(aTestName);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2711
	return self;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2712
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2713
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2714
void RA3FDevSoundToneSetDTMFLengthsToNegativeTest::DoKickoffTestL()
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2715
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2716
	if ( !GetIntFromConfig(iTestStepName, KToneOnLength, iToneOnLength) )
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2717
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2718
		ERR_PRINTF2(KMsgErrorGetParameter, &KToneOnLength);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2719
		StopTest(KErrNotFound);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2720
		return;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2721
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2722
	if ( !GetIntFromConfig(iTestStepName, KToneOffLength, iToneOffLength) )
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2723
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2724
		ERR_PRINTF2(KMsgErrorGetParameter, &KToneOffLength);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2725
		StopTest(KErrNotFound);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2726
		return;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2727
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2728
	if ( !GetIntFromConfig(iTestStepName, KPauseLength, iPauseLength) )
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2729
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2730
		ERR_PRINTF2(KMsgErrorGetParameter, &KPauseLength);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2731
		StopTest(KErrNotFound);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2732
		return;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2733
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2734
	TPtrC DTMF;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2735
	if ( !GetStringFromConfig(iTestStepName,  KDTMFString,  DTMF) )
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2736
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2737
		ERR_PRINTF2(KMsgErrorGetParameter, &KDTMFString);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2738
		StopTest(KErrNotFound);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2739
		return;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2740
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2741
	iDTMFString.Copy(DTMF);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2742
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2743
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2744
void RA3FDevSoundToneSetDTMFLengthsToNegativeTest::Fsm(TMmfDevSoundEvent aDevSoundEvent, TInt aError)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2745
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2746
	switch (iDevSoundState)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2747
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2748
		case EStateCreated:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2749
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2750
			__ASSERT_ALWAYS((aError == KErrNone), Panic(_L("RA3FDevSoundToneSetDTMFLengthsToNegativeConfigurationTest"), EFsmIncorrectErrorPassed));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2751
			if (aDevSoundEvent == EEventInitialize)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2752
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2753
				INFO_PRINTF1(_L("Calling iMMFDevSound::InitializeL"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2754
				TRAPD(err, iMMFDevSound->InitializeL(*this, EMMFStateTonePlaying));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2755
				if (err != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2756
					{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2757
					ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"), err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2758
					StopTest(err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2759
					break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2760
					}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2761
				INFO_PRINTF1(_L("DevSound State: EStateInitializing"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2762
				iDevSoundState = EStateInitializing;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2763
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2764
			else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2765
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2766
				ERR_PRINTF2(_L("DevSound EEventInitialize not received as expected. Received event: %d"), aDevSoundEvent);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2767
				StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2768
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2769
			break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2770
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2771
		case EStateInitializing:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2772
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2773
			if (aDevSoundEvent == EEventInitComplete && aError == KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2774
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2775
				iMMFDevSound->SetVolume(iMMFDevSound->MaxVolume());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2776
				TTimeIntervalMicroSeconds32 ToneOnLength(iToneOnLength);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2777
				TTimeIntervalMicroSeconds32 ToneOffLength(iToneOffLength);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2778
				TTimeIntervalMicroSeconds32 PauseLength(iPauseLength);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2779
				INFO_PRINTF4(_L("Setting DTMF tone to negative lengths. ToneOnLength %d, ToneOffLength %d and PauseLength %d"), iToneOnLength, iToneOffLength, iPauseLength);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2780
				iMMFDevSound->SetDTMFLengths(ToneOnLength, ToneOffLength, PauseLength);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2781
				iStartTime.HomeTime();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2782
				INFO_PRINTF2(_L("Calling CMMFDevSound::PlayDTMFStringL %S"), &iDTMFString);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2783
				TRAPD(err, iMMFDevSound->PlayDTMFStringL(iDTMFString));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2784
				if (err != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2785
					{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2786
					ERR_PRINTF2(_L("CMMFDevSound::PlayDTMFStringL left with error : %d!"),  err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2787
					StopTest(err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2788
					break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2789
					}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2790
				INFO_PRINTF1(_L("DevSound State: EStatePlaying"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2791
				iDevSoundState = EStatePlaying;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2792
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2793
			else if (aDevSoundEvent == EEventInitComplete && aError != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2794
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2795
				ERR_PRINTF2(_L("DevSound called CMMFDevSound::InitializeComplete with error = %d"), aError);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2796
				StopTest(aError);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2797
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2798
			else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2799
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2800
				ERR_PRINTF2(_L("DevSound EEventInitComplete not received as expected. Received event: %d"), aDevSoundEvent);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2801
				StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2802
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2803
			break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2804
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2805
		default:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2806
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2807
			ERR_PRINTF2(_L("Invalid DevSound state received: %d"), iDevSoundState);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2808
			StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2809
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2810
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2811
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2812
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2813
void RA3FDevSoundToneSetDTMFLengthsToNegativeTest::ToneFinished(TInt aError)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2814
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2815
	INFO_PRINTF1(_L("========== DevSound ToneFinished() callback =========="));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2816
	INFO_PRINTF3(KMsgErrorDevSoundCallback, &KToneFinishedText, aError);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2817
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2818
	if (aError == KErrUnderflow)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2819
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2820
		iEndTime.HomeTime();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2821
		iPlayToneTime = iEndTime.MicroSecondsFrom(iStartTime);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2822
		if(iPlayToneTime <= KPlayVarianceTime)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2823
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2824
			INFO_PRINTF2(_L("Setting DTMF tone lengths to negative gives a reproduction time of %Ld microseconds which is the expected result"), iPlayToneTime.Int64());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2825
			StopTest(aError, EPass);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2826
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2827
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2828
	else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2829
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2830
		INFO_PRINTF2(_L("DevSound called ToneFinished with error = %d that was NOT expected"), aError);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2831
		StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2832
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2833
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2834
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2835
/*
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2836
 *========================================================================================================
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2837
 * MM-A3F-DEVSOUND-CHRTZ-TONE-0021
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2838
 */
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2839
RA3FDevSoundToneSetDTMFToneOnLengthToMinusOneTest::RA3FDevSoundToneSetDTMFToneOnLengthToMinusOneTest(const TDesC& aTestName)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2840
	:	RA3FDevSoundTestBase(aTestName),
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2841
		iFirstToneFinishedCall(EFalse),
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2842
		iToneOnLength(0), iToneOffLength(0),
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2843
		iPauseLength(0), iDTMFString(KNullDesC)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2844
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2845
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2846
RA3FDevSoundToneSetDTMFToneOnLengthToMinusOneTest* RA3FDevSoundToneSetDTMFToneOnLengthToMinusOneTest::NewL(const TDesC& aTestName)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2847
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2848
	RA3FDevSoundToneSetDTMFToneOnLengthToMinusOneTest * self = new(ELeave)RA3FDevSoundToneSetDTMFToneOnLengthToMinusOneTest(aTestName);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2849
	return self;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2850
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2851
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2852
void RA3FDevSoundToneSetDTMFToneOnLengthToMinusOneTest::DoKickoffTestL()
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2853
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2854
	if (!GetIntFromConfig(iTestStepName, KToneOnLength, iToneOnLength))
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2855
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2856
		ERR_PRINTF2(KMsgErrorGetParameter, &KToneOnLength);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2857
		StopTest(KErrNotFound);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2858
		return;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2859
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2860
	if (!GetIntFromConfig(iTestStepName, KToneOffLength, iToneOffLength))
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2861
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2862
		ERR_PRINTF2(KMsgErrorGetParameter, &KToneOffLength);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2863
		StopTest(KErrNotFound);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2864
		return;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2865
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2866
	if (!GetIntFromConfig(iTestStepName, KPauseLength, iPauseLength))
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2867
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2868
		ERR_PRINTF2(KMsgErrorGetParameter, &KPauseLength);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2869
		StopTest(KErrNotFound);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2870
		return;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2871
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2872
	TPtrC DTMF;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2873
	if (!GetStringFromConfig(iTestStepName, KDTMFString, DTMF))
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2874
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2875
		ERR_PRINTF2(KMsgErrorGetParameter, &KDTMFString);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2876
		StopTest(KErrNotFound);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2877
		return;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2878
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2879
	iDTMFString.Copy(DTMF);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2880
	iTimer = CPeriodic::NewL(CActive::EPriorityHigh);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2881
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2882
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2883
void RA3FDevSoundToneSetDTMFToneOnLengthToMinusOneTest::Fsm(TMmfDevSoundEvent aDevSoundEvent, TInt aError)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2884
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2885
	switch (iDevSoundState)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2886
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2887
		case EStateCreated:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2888
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2889
			__ASSERT_ALWAYS((aError == KErrNone), Panic(_L("RA3FDevSoundToneSetDTMFToneOnLengthToMinusOneTest"), EFsmIncorrectErrorPassed));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2890
			if(aDevSoundEvent == EEventInitialize)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2891
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2892
				INFO_PRINTF1(_L("Calling CMMFDevSound::InitializeL"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2893
				TRAPD(err, iMMFDevSound->InitializeL(*this, EMMFStateTonePlaying));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2894
				if (err != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2895
					{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2896
					ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"), err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2897
					StopTest(err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2898
					break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2899
					}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2900
				INFO_PRINTF1(_L("DevSound State: EStateInitializing"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2901
				iDevSoundState = EStateInitializing;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2902
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2903
			else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2904
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2905
				ERR_PRINTF2(_L("DevSound EEventInitialize not received as expected. Received event: %d"), aDevSoundEvent);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2906
				StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2907
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2908
			break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2909
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2910
		case EStateInitializing:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2911
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2912
			if (aDevSoundEvent == EEventInitComplete && aError == KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2913
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2914
				iMMFDevSound->SetVolume(iMMFDevSound->MaxVolume());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2915
				iStartTime.HomeTime();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2916
				TTimeIntervalMicroSeconds32 ToneOnLength(iToneOnLength);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2917
				TTimeIntervalMicroSeconds32 ToneOffLength(iToneOffLength);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2918
				TTimeIntervalMicroSeconds32 PauseLength(iPauseLength);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2919
				INFO_PRINTF4(_L("Calling CMMFDevSound::SetDTMFLengths. ToneOnLength = %Ld, ToneOffLength = %Ld and PauseLength = %Ld"), iToneOnLength, iToneOffLength, iPauseLength);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2920
				iMMFDevSound->SetDTMFLengths(ToneOnLength, ToneOffLength, PauseLength);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2921
				INFO_PRINTF2(_L("Calling CMMFDevSound::PlayDTMFStringL %S"), &iDTMFString);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2922
				TRAPD(err, iMMFDevSound->PlayDTMFStringL(iDTMFString));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2923
				if (err != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2924
					{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2925
					ERR_PRINTF2(_L("CMMFDevSound::PlayDTMFStringL left with error : %d!"), err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2926
					StopTest(err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2927
					break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2928
					}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2929
				StartTimer(KMicrosecsInTenSec);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2930
				INFO_PRINTF1(_L("DevSound State: EStatePlaying"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2931
				iDevSoundState=EStatePlaying;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2932
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2933
			else if (aDevSoundEvent == EEventInitComplete && aError != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2934
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2935
				ERR_PRINTF2(_L("DevSound called CMMFDevSound::InitializeComplete with error = %d"), aError);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2936
				StopTest(aError);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2937
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2938
			else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2939
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2940
				ERR_PRINTF2(_L("DevSound EEventInitComplete not received as expected. Received event: %d"), aDevSoundEvent);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2941
				StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2942
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2943
			break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2944
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2945
		default:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2946
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2947
			ERR_PRINTF2(_L("Invalid DevSound state received: %d"), iDevSoundState);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2948
			StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2949
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2950
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2951
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2952
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2953
void RA3FDevSoundToneSetDTMFToneOnLengthToMinusOneTest::DoTimerCallback()
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2954
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2955
	iTimer->Cancel();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2956
	INFO_PRINTF1(_L("DevSound Event: EEventTimerComplete"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2957
	iEndTime.HomeTime();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2958
	iPlayToneTime = iEndTime.MicroSecondsFrom(iStartTime);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2959
	INFO_PRINTF1(_L("SetDTMF lengths succeded."));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2960
	INFO_PRINTF2(_L("Play time is %Ld microseconds"), iPlayToneTime.Int64());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2961
	StopTest();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2962
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2963
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2964
void RA3FDevSoundToneSetDTMFToneOnLengthToMinusOneTest::ToneFinished(TInt aError)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2965
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2966
	INFO_PRINTF1(_L("========== DevSound ToneFinished() callback =========="));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2967
	if (aError == KErrUnderflow)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2968
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2969
		INFO_PRINTF1(_L("ToneFinished was called before the timer event."));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2970
		StopTest(aError);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2971
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2972
	else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2973
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2974
		ERR_PRINTF2(_L("DevSound called ToneFinished with error = %d"), aError);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2975
		ERR_PRINTF2(_L("Expected error = %d"), KErrUnderflow);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2976
		StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2977
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2978
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2979
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2980
/*
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2981
 *========================================================================================================
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2982
 * MM-A3F-DEVSOUND-CHRTZ-TONE-0022
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2983
 */
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2984
RA3FDevSoundToneSetToneRepetitionsRepeatTrailingSilenceToNegativeTest::RA3FDevSoundToneSetToneRepetitionsRepeatTrailingSilenceToNegativeTest(const TDesC& aTestName)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2985
	:	RA3FDevSoundTestBase(aTestName), iDuration(0),
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2986
		iFrequencyTone1(0),
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2987
		iRepeatTrailingSilence(0), iRepeatCount(0),
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2988
		iInitializedToPlayTones(EFalse)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2989
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2990
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2991
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2992
RA3FDevSoundToneSetToneRepetitionsRepeatTrailingSilenceToNegativeTest* RA3FDevSoundToneSetToneRepetitionsRepeatTrailingSilenceToNegativeTest::NewL(const TDesC& aTestName)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2993
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2994
	RA3FDevSoundToneSetToneRepetitionsRepeatTrailingSilenceToNegativeTest * self = new(ELeave)RA3FDevSoundToneSetToneRepetitionsRepeatTrailingSilenceToNegativeTest(aTestName);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2995
	return self;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2996
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2997
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2998
void RA3FDevSoundToneSetToneRepetitionsRepeatTrailingSilenceToNegativeTest::DoKickoffTestL()
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  2999
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3000
	if (!GetIntFromConfig(iTestStepName, KRepeatCount, iRepeatCount))
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3001
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3002
		ERR_PRINTF2(KMsgErrorGetParameter, &KRepeatCount);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3003
		StopTest(KErrNotFound);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3004
		return;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3005
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3006
	if (!GetIntFromConfig(iTestStepName, KRepeatTrailingSilence, iRepeatTrailingSilence))
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3007
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3008
		ERR_PRINTF2(KMsgErrorGetParameter, &KRepeatTrailingSilence);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3009
		StopTest(KErrNotFound);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3010
		return;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3011
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3012
	if (!GetIntFromConfig(iTestStepName, KDuration, iDuration))
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3013
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3014
		ERR_PRINTF2(KMsgErrorGetParameter, &KDuration);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3015
		StopTest(KErrNotFound);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3016
		return;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3017
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3018
	if (!GetIntFromConfig(iTestStepName, KFrequencyTone1, iFrequencyTone1))
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3019
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3020
		ERR_PRINTF2(KMsgErrorGetParameter, &KFrequencyTone1);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3021
		StopTest(KErrNotFound);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3022
		return;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3023
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3024
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3025
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3026
void RA3FDevSoundToneSetToneRepetitionsRepeatTrailingSilenceToNegativeTest::Fsm(TMmfDevSoundEvent aDevSoundEvent, TInt aError)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3027
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3028
	switch (iDevSoundState)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3029
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3030
		case EStateCreated:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3031
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3032
			__ASSERT_ALWAYS((aError == KErrNone), Panic(_L("RA3FDevSoundToneSetToneRepetitionsRepeatTrailingSilenceToNegativeTest"), EFsmIncorrectErrorPassed));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3033
			if(aDevSoundEvent == EEventInitialize)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3034
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3035
				INFO_PRINTF1(_L("Calling CMMFDevSound::InitializeL"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3036
				TRAPD(err, iMMFDevSound->InitializeL(*this, EMMFStateTonePlaying));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3037
				if (err != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3038
					{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3039
					ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"), err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3040
					StopTest(err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3041
					break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3042
					}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3043
				INFO_PRINTF1(_L("DevSound State: EStateInitializing"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3044
				iDevSoundState = EStateInitializing;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3045
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3046
			else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3047
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3048
				ERR_PRINTF2(_L("DevSound EEventInitialize not received as expected. Received event: %d"), aDevSoundEvent);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3049
				StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3050
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3051
			break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3052
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3053
		case EStateInitializing:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3054
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3055
			if (aDevSoundEvent == EEventInitComplete && aError == KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3056
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3057
				iMMFDevSound->SetVolume(iMMFDevSound->MaxVolume());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3058
				INFO_PRINTF3(_L("Calling CMMFDevSound::SetToneRepeats using RepeatCount = %d and RepeatTrailingSilence = %d microsecs"), iRepeatCount, iRepeatTrailingSilence);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3059
				iMMFDevSound->SetToneRepeats(iRepeatCount, iRepeatTrailingSilence);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3060
				iStartTime.HomeTime();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3061
				INFO_PRINTF3(_L("Calling CMMFDevSound::PlayToneL %d Hz during %d secs "), iFrequencyTone1, iDuration);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3062
				TRAPD(err, iMMFDevSound->PlayToneL(iFrequencyTone1, iDuration*KMicroSecsInOneSec));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3063
				if (err != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3064
					{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3065
					ERR_PRINTF2(_L("CMMFDevSound::PlayToneL left with error : %d!"), err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3066
					StopTest(err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3067
					break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3068
					}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3069
				INFO_PRINTF1(_L("DevSound State: EStatePlaying"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3070
				iDevSoundState = EStatePlaying;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3071
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3072
			else if (aDevSoundEvent == EEventInitComplete && aError != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3073
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3074
				ERR_PRINTF2(_L("DevSound called CMMFDevSound::InitializeComplete with error = %d"), aError);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3075
				StopTest(aError);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3076
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3077
			else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3078
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3079
				ERR_PRINTF2(_L("DevSound EEventInitComplete not received as expected. Received event: %d"), aDevSoundEvent);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3080
				StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3081
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3082
			break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3083
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3084
		default:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3085
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3086
			ERR_PRINTF2(_L("Invalid DevSound state received: %d"), iDevSoundState);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3087
			StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3088
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3089
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3090
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3091
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3092
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3093
void RA3FDevSoundToneSetToneRepetitionsRepeatTrailingSilenceToNegativeTest::ToneFinished(TInt aError)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3094
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3095
	INFO_PRINTF1(_L("========== DevSound ToneFinished() callback =========="));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3096
	if (aError == KErrUnderflow)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3097
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3098
		iEndTime.HomeTime();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3099
		iPlayToneTime = iEndTime.MicroSecondsFrom(iStartTime);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3100
		TInt repeatTrailingSilenceToSecs = iRepeatTrailingSilence/KMicroSecsInOneSec;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3101
		TInt totalExpectedReproductionTime = (iRepeatCount * iDuration + iDuration + (repeatTrailingSilenceToSecs*iRepeatCount))*KMicroSecsInOneSec;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3102
		if(iPlayToneTime < totalExpectedReproductionTime + KPlayVarianceTime && iPlayToneTime > totalExpectedReproductionTime - KPlayVarianceTime)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3103
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3104
			INFO_PRINTF1(_L("Play tone repeats succeded."));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3105
			INFO_PRINTF2(_L("Play time is %Ld microseconds"), iPlayToneTime.Int64());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3106
			StopTest();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3107
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3108
		else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3109
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3110
			ERR_PRINTF1(_L("Play tone repeats did not work as planned."));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3111
			ERR_PRINTF3(_L("Play time is %Ld microseconds and it should have been %d microseconds"), iPlayToneTime.Int64(), totalExpectedReproductionTime);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3112
			StopTest(KErrNone, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3113
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3114
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3115
	else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3116
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3117
		ERR_PRINTF2(_L("DevSound called ToneFinished with error = %d"), aError);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3118
		ERR_PRINTF2(_L("Expected error = %d"), KErrUnderflow);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3119
		StopTest(aError);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3120
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3121
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3122
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3123
/*
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3124
 *========================================================================================================
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3125
 * MM-A3F-DEVSOUND-CHRTZ-TONE-0023
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3126
 */
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3127
RA3FDevSoundToneSetToneRepetitionsRepeatCountToKMdaRepeatForeverTest::RA3FDevSoundToneSetToneRepetitionsRepeatCountToKMdaRepeatForeverTest(const TDesC& aTestName)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3128
	:	RA3FDevSoundTestBase(aTestName), iDuration(0),
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3129
		iFrequencyTone1(0),
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3130
		iRepeatTrailingSilence(0), iRepeatCount(0),
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3131
		iInitializedToPlayTones(EFalse)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3132
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3133
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3134
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3135
RA3FDevSoundToneSetToneRepetitionsRepeatCountToKMdaRepeatForeverTest* RA3FDevSoundToneSetToneRepetitionsRepeatCountToKMdaRepeatForeverTest::NewL(const TDesC& aTestName)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3136
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3137
	RA3FDevSoundToneSetToneRepetitionsRepeatCountToKMdaRepeatForeverTest * self = new(ELeave)RA3FDevSoundToneSetToneRepetitionsRepeatCountToKMdaRepeatForeverTest(aTestName);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3138
	return self;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3139
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3140
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3141
void RA3FDevSoundToneSetToneRepetitionsRepeatCountToKMdaRepeatForeverTest::DoKickoffTestL()
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3142
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3143
	if (!GetIntFromConfig(iTestStepName, KRepeatCount, iRepeatCount))
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3144
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3145
		ERR_PRINTF2(KMsgErrorGetParameter, &KRepeatCount);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3146
		StopTest(KErrNotFound);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3147
		return;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3148
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3149
	if (!GetIntFromConfig(iTestStepName, KRepeatTrailingSilence, iRepeatTrailingSilence))
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3150
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3151
		ERR_PRINTF2(KMsgErrorGetParameter, &KRepeatTrailingSilence);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3152
		StopTest(KErrNotFound);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3153
		return;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3154
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3155
	if (!GetIntFromConfig(iTestStepName, KDuration, iDuration))
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3156
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3157
		ERR_PRINTF2(KMsgErrorGetParameter, &KDuration);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3158
		StopTest(KErrNotFound);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3159
		return;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3160
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3161
	if (!GetIntFromConfig(iTestStepName, KFrequencyTone1, iFrequencyTone1))
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3162
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3163
		ERR_PRINTF2(KMsgErrorGetParameter, &KFrequencyTone1);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3164
		StopTest(KErrNotFound);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3165
		return;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3166
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3167
	iTimer = CPeriodic::NewL(CActive::EPriorityHigh);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3168
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3169
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3170
void RA3FDevSoundToneSetToneRepetitionsRepeatCountToKMdaRepeatForeverTest::Fsm(TMmfDevSoundEvent aDevSoundEvent, TInt aError)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3171
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3172
	switch (iDevSoundState)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3173
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3174
		case EStateCreated:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3175
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3176
			__ASSERT_ALWAYS((aError == KErrNone), Panic(_L("RA3FDevSoundToneSetToneRepetitionsRepeatCountToKMdaRepeatForeverTest"), EFsmIncorrectErrorPassed));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3177
			if(aDevSoundEvent == EEventInitialize)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3178
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3179
				INFO_PRINTF1(_L("Calling CMMFDevSound::InitializeL"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3180
				TRAPD(err, iMMFDevSound->InitializeL(*this, EMMFStateTonePlaying));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3181
				if (err != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3182
					{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3183
					ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"), err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3184
					StopTest(err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3185
					break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3186
					}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3187
				StartTimer(KMicrosecsInTenSec);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3188
				INFO_PRINTF1(_L("DevSound State: EStateInitializing"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3189
				iDevSoundState = EStateInitializing;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3190
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3191
			else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3192
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3193
				ERR_PRINTF2(_L("DevSound EEventInitialize not received as expected. Received event: %d"), aDevSoundEvent);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3194
				StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3195
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3196
			break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3197
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3198
		case EStateInitializing:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3199
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3200
			if (aDevSoundEvent == EEventInitComplete && aError == KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3201
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3202
				iMMFDevSound->SetVolume(iMMFDevSound->MaxVolume());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3203
				INFO_PRINTF3(_L("Calling CMMFDevSound::SetToneRepeats using RepeatCount = %d and RepeatTrailingSilence = %d microsecs"), iRepeatCount, iRepeatTrailingSilence);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3204
				iMMFDevSound->SetToneRepeats(iRepeatCount, iRepeatTrailingSilence);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3205
				iStartTime.HomeTime();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3206
				INFO_PRINTF3(_L("Calling CMMFDevSound::PlayToneL %d Hz during %d secs "), iFrequencyTone1, iDuration);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3207
				TRAPD(err, iMMFDevSound->PlayToneL(iFrequencyTone1, iDuration*KMicroSecsInOneSec));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3208
				if (err != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3209
					{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3210
					ERR_PRINTF2(_L("CMMFDevSound::PlayToneL left with error : %d!"), err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3211
					StopTest(err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3212
					break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3213
					}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3214
				INFO_PRINTF1(_L("DevSound State: EStatePlaying"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3215
				iDevSoundState = EStatePlaying;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3216
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3217
			else if (aDevSoundEvent == EEventInitComplete && aError != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3218
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3219
				ERR_PRINTF2(_L("DevSound called CMMFDevSound::InitializeComplete with error = %d"), aError);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3220
				StopTest(aError);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3221
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3222
			else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3223
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3224
				ERR_PRINTF2(_L("DevSound EEventInitComplete not received as expected. Received event: %d"), aDevSoundEvent);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3225
				StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3226
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3227
			break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3228
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3229
		default:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3230
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3231
			ERR_PRINTF2(_L("Invalid DevSound state received: %d"), iDevSoundState);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3232
			StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3233
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3234
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3235
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3236
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3237
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3238
void RA3FDevSoundToneSetToneRepetitionsRepeatCountToKMdaRepeatForeverTest::DoTimerCallback()
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3239
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3240
	iTimer->Cancel();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3241
	INFO_PRINTF1(_L("DevSound Event: EEventTimerComplete"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3242
	iEndTime.HomeTime();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3243
	iPlayToneTime = iEndTime.MicroSecondsFrom(iStartTime);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3244
	INFO_PRINTF1(_L("Setting repeatCount value to KMdaRepeatForeverTest succeded."));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3245
	INFO_PRINTF2(_L("Play time is %Ld microseconds"), iPlayToneTime.Int64());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3246
	iMMFDevSound->Stop();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3247
	StopTest();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3248
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3249
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3250
void RA3FDevSoundToneSetToneRepetitionsRepeatCountToKMdaRepeatForeverTest::ToneFinished(TInt aError)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3251
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3252
	INFO_PRINTF1(_L("========== DevSound ToneFinished() callback =========="));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3253
	if (aError == KErrUnderflow)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3254
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3255
		INFO_PRINTF1(_L("ToneFinished was called before the timer event."));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3256
		StopTest(aError);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3257
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3258
	else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3259
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3260
		ERR_PRINTF2(_L("DevSound called ToneFinished with error = %d"), aError);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3261
		ERR_PRINTF2(_L("Expected error = %d"), KErrUnderflow);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3262
		StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3263
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3264
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3265
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3266
/*
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3267
 *========================================================================================================
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3268
 * MM-A3F-DEVSOUND-CHRTZ-TONE-0024
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3269
 */
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3270
RA3FDevSoundToneCapsTest::RA3FDevSoundToneCapsTest(const TDesC& aTestName)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3271
	:	RA3FDevSoundTestBase(aTestName), iExCapRate(0), iExCapChannels(0)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3272
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3273
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3274
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3275
RA3FDevSoundToneCapsTest* RA3FDevSoundToneCapsTest::NewL(const TDesC& aTestName)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3276
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3277
	RA3FDevSoundToneCapsTest * self = new(ELeave)RA3FDevSoundToneCapsTest(aTestName);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3278
	return self;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3279
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3280
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3281
void RA3FDevSoundToneCapsTest::DoKickoffTestL()
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3282
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3283
	if (!GetIntFromConfig(iTestStepName, KExCapRate, iExCapRate))
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3284
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3285
		ERR_PRINTF2(KMsgErrorGetParameter, &KSampleRate);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3286
		StopTest(KErrNotFound);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3287
		return;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3288
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3289
	if (!GetIntFromConfig(iTestStepName, KExCapChannels, iExCapChannels))
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3290
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3291
		ERR_PRINTF2(KMsgErrorGetParameter, &KChannel);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3292
		StopTest(KErrNotFound);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3293
		return;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3294
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3295
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3296
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3297
void RA3FDevSoundToneCapsTest::Fsm(TMmfDevSoundEvent aDevSoundEvent, TInt aError)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3298
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3299
	switch(iDevSoundState)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3300
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3301
		case EStateCreated:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3302
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3303
			__ASSERT_ALWAYS((aError == KErrNone), Panic(_L("RA3FDevSoundToneCapsTest"), EFsmIncorrectErrorPassed));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3304
			if (aDevSoundEvent == EEventInitialize)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3305
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3306
				INFO_PRINTF1(_L("Calling CMMFDevSound::InitializeL"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3307
				TRAPD(err, iMMFDevSound->InitializeL(*this, EMMFStateTonePlaying));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3308
				if (err != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3309
					{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3310
					ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"), err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3311
					StopTest(err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3312
					break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3313
					}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3314
				INFO_PRINTF1(_L("DevSound State: EStateInitializing"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3315
				iDevSoundState = EStateInitializing;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3316
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3317
			else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3318
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3319
				ERR_PRINTF2(_L("DevSound EEventInitialize not received as expected. Received event: %d"), aDevSoundEvent);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3320
				StopTest(aError,  EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3321
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3322
			break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3323
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3324
		case EStateInitializing:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3325
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3326
			if (aDevSoundEvent == EEventInitComplete && aError == KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3327
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3328
				TMMFCapabilities capabilities;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3329
				INFO_PRINTF1(_L("Calling CMMFDevSound::Capabilities"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3330
				capabilities = iMMFDevSound->Capabilities();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3331
				PrintSupportedCapabilities(capabilities.iRate, capabilities.iChannels);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3332
				if(capabilities.iRate == iExCapRate)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3333
					{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3334
					INFO_PRINTF2(_L("The total of possible sample rate values is 0x%08x"), capabilities.iRate);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3335
					}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3336
				else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3337
					{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3338
					ERR_PRINTF2(_L("The total of possible sample rate values failed with 0x%08x"), capabilities.iRate);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3339
					ERR_PRINTF2(_L("Expected value = %d"), iExCapRate);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3340
					StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3341
					}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3342
				if(capabilities.iChannels == iExCapChannels)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3343
					{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3344
					INFO_PRINTF2(_L("The total of possible channel values is 0x%08x"),capabilities.iChannels );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3345
					StopTest();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3346
					}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3347
				else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3348
					{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3349
					ERR_PRINTF2(_L("The total of possible channel values failed with 0x%08x"), capabilities.iChannels );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3350
					ERR_PRINTF2(_L("Expected value = %d"), iExCapChannels);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3351
					StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3352
					}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3353
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3354
			else if (aDevSoundEvent == EEventInitComplete && aError != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3355
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3356
				ERR_PRINTF2(_L("DevSound called CMMFDevSound::InitializeComplete with error = %d"), aError);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3357
				StopTest(aError);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3358
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3359
			else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3360
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3361
				ERR_PRINTF2(_L("DevSound EEventInitComplete not received as expected. Received event: %d"), aDevSoundEvent);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3362
				StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3363
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3364
			break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3365
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3366
		default:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3367
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3368
			ERR_PRINTF2(_L("Invalid DevSound state received: %d"), iDevSoundState);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3369
			StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3370
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3371
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3372
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3373
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3374
/*
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3375
 *========================================================================================================
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3376
 * MM-A3F-DEVSOUND-CHRTZ-TONE-0025
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3377
 */
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3378
RA3FDevSoundToneConfigDefaultTest::RA3FDevSoundToneConfigDefaultTest(const TDesC& aTestName)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3379
	:	RA3FDevSoundTestBase(aTestName), iExCapRate(0),
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3380
		iExCapChannels(0)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3381
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3382
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3383
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3384
RA3FDevSoundToneConfigDefaultTest* RA3FDevSoundToneConfigDefaultTest::NewL(const TDesC& aTestName)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3385
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3386
	RA3FDevSoundToneConfigDefaultTest * self = new(ELeave)RA3FDevSoundToneConfigDefaultTest(aTestName);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3387
	return self;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3388
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3389
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3390
void RA3FDevSoundToneConfigDefaultTest::DoKickoffTestL()
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3391
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3392
	if (!GetIntFromConfig(iTestStepName, KExCapRate, iExCapRate))
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3393
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3394
			ERR_PRINTF2(KMsgErrorGetParameter, &KExCapRate);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3395
			StopTest(KErrNotFound);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3396
			return;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3397
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3398
	if (!GetIntFromConfig(iTestStepName, KExCapChannels, iExCapChannels))
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3399
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3400
		ERR_PRINTF2(KMsgErrorGetParameter, &KExCapChannels);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3401
		StopTest(KErrNotFound);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3402
		return;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3403
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3404
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3405
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3406
void RA3FDevSoundToneConfigDefaultTest::Fsm(TMmfDevSoundEvent aDevSoundEvent, TInt aError)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3407
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3408
		switch(iDevSoundState)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3409
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3410
		case EStateCreated:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3411
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3412
			__ASSERT_ALWAYS((aError == KErrNone), Panic(_L("RA3FDevSoundToneConfigDefaultTest"), EFsmIncorrectErrorPassed));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3413
			if (aDevSoundEvent == EEventInitialize)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3414
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3415
				INFO_PRINTF1(_L("Calling CMMFDevSound::InitializeL"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3416
				TRAPD(err, iMMFDevSound->InitializeL(*this, EMMFStateTonePlaying));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3417
				if (err != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3418
					{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3419
					ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"), err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3420
					StopTest(err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3421
					}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3422
				INFO_PRINTF1(_L("DevSound State: EStateInitializing"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3423
				iDevSoundState=EStateInitializing;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3424
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3425
			else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3426
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3427
				ERR_PRINTF2(_L("DevSound EEventInitialize not received as expected. Received event: %d"), aDevSoundEvent);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3428
				StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3429
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3430
			break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3431
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3432
		case EStateInitializing:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3433
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3434
			if (aDevSoundEvent == EEventInitComplete && aError == KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3435
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3436
				TMMFCapabilities capabilitiesGet;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3437
				TBuf<KMaxSampleRateStringLength> stringSampleRateGet;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3438
				TBuf<KMaxChannelsStringLength> stringChannelsGet;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3439
				TBuf<KMaxSampleRateStringLength> stringSampleRateExpected;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3440
				TBuf<KMaxChannelsStringLength> stringChannelsExpected;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3441
				INFO_PRINTF1(_L("Calling CMMFDevSound::Config"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3442
				capabilitiesGet=iMMFDevSound->Config();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3443
				SampleRateFromTUintToString (capabilitiesGet.iRate, stringSampleRateGet);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3444
				ChannelsFromTUintToString (capabilitiesGet.iChannels, stringChannelsGet);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3445
				SampleRateFromTIntToTMMFSampleRate (iExCapRate, iExSampleRate);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3446
				SampleRateFromTUintToString (iExSampleRate, stringSampleRateExpected);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3447
				ChannelsFromTUintToString (iExCapChannels, stringChannelsExpected);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3448
				if (stringSampleRateExpected.Compare(stringSampleRateGet) == 0)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3449
					{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3450
					INFO_PRINTF2(_L("Sample rate value match default as expected with %S"), &stringSampleRateGet);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3451
					if (stringChannelsExpected.Compare(stringChannelsGet) == 0)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3452
						{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3453
						INFO_PRINTF2(_L("Channel mode value match default as expected with %S"), &stringChannelsGet);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3454
						StopTest();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3455
						}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3456
					else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3457
						{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3458
						INFO_PRINTF2(_L("Channel mode value failed with %S"), &stringChannelsGet);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3459
						ERR_PRINTF2(_L("Expected channel mode %S"), &stringChannelsExpected);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3460
						StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3461
						}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3462
					}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3463
				else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3464
					{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3465
					ERR_PRINTF2(_L("Sample rate value failed with %S"), &stringSampleRateGet);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3466
					ERR_PRINTF2(_L("Expected sample rate %S"), &stringSampleRateExpected);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3467
					StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3468
					}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3469
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3470
			else if (aDevSoundEvent == EEventInitComplete && aError != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3471
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3472
				ERR_PRINTF2(_L("DevSound called CMMFDevSound::InitializeComplete with error = %d"), aError);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3473
				StopTest(aError);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3474
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3475
			else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3476
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3477
				ERR_PRINTF2(_L("DevSound EEventInitComplete not received as expected. Received event: %d"), aDevSoundEvent);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3478
				StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3479
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3480
			break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3481
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3482
		default:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3483
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3484
			ERR_PRINTF2(_L("Invalid DevSound state received: %d"), iDevSoundState);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3485
			StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3486
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3487
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3488
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3489
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3490
/*
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3491
 *========================================================================================================
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3492
 * MM-A3F-DEVSOUND-CHRTZ-TONE-0026
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3493
 */
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3494
RA3FDevSoundToneMaxVolumeTest::RA3FDevSoundToneMaxVolumeTest(const TDesC& aTestName)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3495
	:	RA3FDevSoundTestBase(aTestName), iExVolume(0)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3496
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3497
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3498
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3499
RA3FDevSoundToneMaxVolumeTest* RA3FDevSoundToneMaxVolumeTest::NewL(const TDesC& aTestName)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3500
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3501
	RA3FDevSoundToneMaxVolumeTest * self = new(ELeave)RA3FDevSoundToneMaxVolumeTest(aTestName);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3502
	return self;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3503
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3504
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3505
void RA3FDevSoundToneMaxVolumeTest::DoKickoffTestL()
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3506
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3507
	if (!GetIntFromConfig(iTestStepName, KExVolume, iExVolume))
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3508
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3509
		ERR_PRINTF2(KMsgErrorGetParameter, &KExVolume);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3510
		StopTest(KErrNotFound);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3511
		return;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3512
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3513
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3514
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3515
void RA3FDevSoundToneMaxVolumeTest::Fsm(TMmfDevSoundEvent aDevSoundEvent,  TInt aError)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3516
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3517
	switch(iDevSoundState)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3518
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3519
		case EStateCreated:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3520
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3521
			__ASSERT_ALWAYS((aError == KErrNone), Panic(_L("RA3FDevSoundToneMaxVolumeTest"), EFsmIncorrectErrorPassed));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3522
			if (aDevSoundEvent == EEventInitialize)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3523
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3524
				INFO_PRINTF1(_L("Calling CMMFDevSound::InitializeL"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3525
				TRAPD(err, iMMFDevSound->InitializeL(*this, EMMFStateTonePlaying));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3526
				if (err != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3527
					{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3528
					ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"), err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3529
					StopTest(err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3530
					break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3531
					}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3532
				INFO_PRINTF1(_L("DevSound State: EStateInitializing"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3533
				iDevSoundState = EStateInitializing;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3534
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3535
			else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3536
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3537
				ERR_PRINTF2(_L("DevSound EEventInitialize not received as expected. Received event: %d"), aDevSoundEvent);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3538
				StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3539
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3540
			break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3541
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3542
		case EStateInitializing:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3543
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3544
			if (aDevSoundEvent == EEventInitComplete && aError == KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3545
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3546
				INFO_PRINTF1(_L("Calling CMMFDevSound::MaxVolume"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3547
				TInt maxVolumeGet = iMMFDevSound->MaxVolume();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3548
				if (maxVolumeGet == iExVolume)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3549
					{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3550
					INFO_PRINTF2(_L("The max device supported volume is %d."), maxVolumeGet);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3551
					StopTest();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3552
					}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3553
				else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3554
					{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3555
					INFO_PRINTF2(_L("The max device supported volume failed with %d."), maxVolumeGet);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3556
					ERR_PRINTF2(_L("Expected value = %d."), iExVolume);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3557
					StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3558
					}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3559
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3560
			else if (aDevSoundEvent == EEventInitComplete && aError != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3561
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3562
				ERR_PRINTF2(_L("DevSound called CMMFDevSound::InitializeComplete with error = %d"), aError);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3563
				StopTest(aError);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3564
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3565
			else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3566
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3567
				ERR_PRINTF2(_L("DevSound EEventInitComplete not received as expected. Received event: %d"), aDevSoundEvent);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3568
				StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3569
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3570
			break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3571
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3572
		default:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3573
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3574
			ERR_PRINTF2(_L("Invalid DevSound state received: %d"), iDevSoundState);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3575
			StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3576
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3577
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3578
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3579
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3580
/*
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3581
 *========================================================================================================
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3582
 * MM-A3F-DEVSOUND-CHRTZ-TONE-0027
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3583
 */
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3584
RA3FDevSoundToneVolumeTest::RA3FDevSoundToneVolumeTest(const TDesC& aTestName)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3585
	:	RA3FDevSoundTestBase(aTestName), iExVolume(0)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3586
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3587
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3588
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3589
RA3FDevSoundToneVolumeTest* RA3FDevSoundToneVolumeTest::NewL(const TDesC& aTestName)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3590
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3591
	RA3FDevSoundToneVolumeTest * self = new(ELeave)RA3FDevSoundToneVolumeTest(aTestName);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3592
	return self;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3593
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3594
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3595
void RA3FDevSoundToneVolumeTest::DoKickoffTestL()
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3596
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3597
	if (!GetIntFromConfig(iTestStepName, KExVolume, iExVolume))
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3598
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3599
		ERR_PRINTF2(KMsgErrorGetParameter, &KExVolume);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3600
		StopTest(KErrNotFound);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3601
		return;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3602
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3603
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3604
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3605
void RA3FDevSoundToneVolumeTest::Fsm(TMmfDevSoundEvent aDevSoundEvent, TInt aError)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3606
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3607
	switch (iDevSoundState)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3608
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3609
		case EStateCreated:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3610
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3611
			__ASSERT_ALWAYS((aError == KErrNone), Panic(_L("RA3FDevSoundToneVolumeTest"), EFsmIncorrectErrorPassed));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3612
			if (aDevSoundEvent == EEventInitialize)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3613
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3614
				INFO_PRINTF1(_L("Calling CMMFDevSound::InitializeL"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3615
				TRAPD(err, iMMFDevSound->InitializeL(*this, EMMFStateTonePlaying));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3616
				if (err != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3617
					{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3618
					ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"), err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3619
					StopTest(err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3620
					break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3621
					}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3622
				INFO_PRINTF1(_L("DevSound State: EStateInitializing"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3623
				iDevSoundState = EStateInitializing;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3624
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3625
			else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3626
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3627
				ERR_PRINTF2(_L("DevSound EEventInitialize not received as expected. Received event: %d"), aDevSoundEvent);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3628
				StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3629
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3630
			break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3631
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3632
		case EStateInitializing:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3633
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3634
			if (aDevSoundEvent == EEventInitComplete && aError == KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3635
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3636
				INFO_PRINTF1(_L("Calling CMMFDevSound::Volume"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3637
				TInt volumeGet = iMMFDevSound->Volume();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3638
				if(volumeGet == iExVolume)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3639
					{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3640
					INFO_PRINTF2(_L("Default device volume succeeded with = %d"), volumeGet);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3641
					StopTest();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3642
					}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3643
				else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3644
					{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3645
					ERR_PRINTF2(_L("Default device volume failed with = %d"), volumeGet);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3646
					ERR_PRINTF2(_L("Expected value % d"), iExVolume);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3647
					StopTest(aError , EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3648
					}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3649
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3650
			else if (aDevSoundEvent == EEventInitComplete && aError != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3651
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3652
				ERR_PRINTF2(_L("DevSound called CMMFDevSound::InitializeComplete with error = %d"), aError);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3653
				StopTest(aError);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3654
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3655
			else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3656
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3657
				ERR_PRINTF2(_L("DevSound EEventInitComplete not received as expected. Received event: %d"), aDevSoundEvent);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3658
				StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3659
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3660
			break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3661
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3662
		default:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3663
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3664
			ERR_PRINTF2(_L("Invalid DevSound state received: %d"), iDevSoundState);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3665
			StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3666
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3667
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3668
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3669
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3670
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3671
/*
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3672
 *========================================================================================================
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3673
 * MM-A3F-DEVSOUND-CHRTZ-TONE-0028
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3674
 */
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3675
RA3FDevSoundToneQueryCapsWhilePlayingTest::RA3FDevSoundToneQueryCapsWhilePlayingTest(const TDesC& aTestName)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3676
	:	RA3FDevSoundTestBase(aTestName), iDuration(0),
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3677
		iFrequencyTone1(0), iExCapRate(0), iExCapChannels(0)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3678
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3679
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3680
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3681
RA3FDevSoundToneQueryCapsWhilePlayingTest* RA3FDevSoundToneQueryCapsWhilePlayingTest::NewL(const TDesC& aTestName)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3682
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3683
	RA3FDevSoundToneQueryCapsWhilePlayingTest * self = new(ELeave)RA3FDevSoundToneQueryCapsWhilePlayingTest(aTestName);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3684
	return self;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3685
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3686
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3687
void RA3FDevSoundToneQueryCapsWhilePlayingTest::DoKickoffTestL()
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3688
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3689
	if (!GetIntFromConfig(iTestStepName, KDuration, iDuration))
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3690
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3691
		ERR_PRINTF2(KMsgErrorGetParameter, &KDuration);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3692
		StopTest(KErrNotFound);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3693
		return;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3694
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3695
	if (!GetIntFromConfig(iTestStepName, KFrequencyTone1, iFrequencyTone1))
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3696
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3697
		ERR_PRINTF2(KMsgErrorGetParameter, &KFrequencyTone1);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3698
		StopTest(KErrNotFound);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3699
		return;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3700
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3701
	if (!GetIntFromConfig(iTestStepName, KExCapRate, iExCapRate))
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3702
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3703
		ERR_PRINTF2(KMsgErrorGetParameter, &KSampleRate);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3704
		StopTest(KErrNotFound);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3705
		return;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3706
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3707
	if (!GetIntFromConfig(iTestStepName, KExCapChannels, iExCapChannels))
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3708
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3709
		ERR_PRINTF2(KMsgErrorGetParameter, &KChannel);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3710
		StopTest(KErrNotFound);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3711
		return;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3712
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3713
	iTimer = CPeriodic::NewL(CActive::EPriorityHigh);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3714
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3715
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3716
void RA3FDevSoundToneQueryCapsWhilePlayingTest::Fsm(TMmfDevSoundEvent aDevSoundEvent, TInt aError)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3717
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3718
	switch (iDevSoundState)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3719
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3720
		case EStateCreated:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3721
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3722
			__ASSERT_ALWAYS((aError == KErrNone), Panic(_L("RA3FDevSoundToneQueryCapsWhilePlayingTest"), EFsmIncorrectErrorPassed));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3723
			if (aDevSoundEvent == EEventInitialize)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3724
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3725
				INFO_PRINTF1(_L("Calling CMMFDevSound::InitializeL"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3726
				TRAPD(err, iMMFDevSound->InitializeL(*this, EMMFStateTonePlaying));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3727
				if (err != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3728
					{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3729
					ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"), err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3730
					StopTest(err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3731
					break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3732
					}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3733
				INFO_PRINTF1(_L("DevSound State: EStateInitializing"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3734
				iDevSoundState = EStateInitializing;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3735
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3736
			else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3737
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3738
				ERR_PRINTF2(_L("DevSound EEventInitialize not received as expected. Received event: %d"), aDevSoundEvent);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3739
				StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3740
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3741
			break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3742
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3743
		case EStateInitializing:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3744
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3745
			if (aDevSoundEvent == EEventInitComplete && aError == KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3746
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3747
				INFO_PRINTF3(_L("Calling CMMFDevSound::PlayToneL using %d Hz during %d secs "), iFrequencyTone1, iDuration);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3748
				TRAPD(err, iMMFDevSound->PlayToneL(iFrequencyTone1, iDuration*KMicroSecsInOneSec));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3749
				if (err != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3750
					{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3751
					ERR_PRINTF2(_L("CMMFDevSound::PlayToneL left with error : %d!"), err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3752
					StopTest(err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3753
					break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3754
					}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3755
				StartTimer(KMicroSecsTwoSec);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3756
				INFO_PRINTF1(_L("DevSound State: EStatePlaying"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3757
				iDevSoundState = EStatePlaying;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3758
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3759
			else if (aDevSoundEvent == EEventInitComplete && aError != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3760
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3761
				ERR_PRINTF2(_L("DevSound called CMMFDevSound::InitializeComplete with error = %d"), aError);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3762
				StopTest(aError);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3763
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3764
			else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3765
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3766
				ERR_PRINTF2(_L("DevSound EEventInitComplete not received as expected. Received event: %d"), aDevSoundEvent);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3767
				StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3768
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3769
			break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3770
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3771
		default:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3772
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3773
			ERR_PRINTF2(_L("Invalid DevSound state received: %d"), iDevSoundState);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3774
			StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3775
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3776
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3777
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3778
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3779
void RA3FDevSoundToneQueryCapsWhilePlayingTest::DoTimerCallback()
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3780
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3781
	iTimer->Cancel();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3782
	INFO_PRINTF1(_L("DevSound Event: EEventTimerComplete"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3783
	TMMFCapabilities capabilities;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3784
	INFO_PRINTF1(_L("Calling CMMFDevSound::Capabilities"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3785
	capabilities = iMMFDevSound->Capabilities();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3786
	PrintSupportedCapabilities(capabilities.iRate, capabilities.iChannels);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3787
	if(capabilities.iRate == iExCapRate)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3788
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3789
		INFO_PRINTF2(_L("The total of possible sample rate values is 0x%08x"), capabilities.iRate);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3790
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3791
	else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3792
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3793
		ERR_PRINTF2(_L("The total of possible sample rate values failed with 0x%08x"), capabilities.iRate);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3794
		ERR_PRINTF2(_L("Expected value = %d"), iExCapRate);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3795
		StopTest(KErrNone, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3796
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3797
	if(capabilities.iChannels == iExCapChannels)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3798
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3799
		INFO_PRINTF2(_L("The total of possible channel values is 0x%08x"),capabilities.iChannels );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3800
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3801
	else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3802
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3803
		ERR_PRINTF2(_L("The total of possible channel values failed with 0x%08x"), capabilities.iChannels );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3804
		ERR_PRINTF2(_L("Expected value = %d"), iExCapChannels);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3805
		StopTest(KErrNone, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3806
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3807
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3808
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3809
/*
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3810
 *========================================================================================================
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3811
 * MM-A3F-DEVSOUND-CHRTZ-TONE-0029
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3812
 */
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3813
RA3FDevSoundToneConfigWhilePlayingTest::RA3FDevSoundToneConfigWhilePlayingTest(const TDesC& aTestName)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3814
	:	RA3FDevSoundTestBase(aTestName), iDuration(0),
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3815
		iFrequencyTone1(0)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3816
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3817
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3818
RA3FDevSoundToneConfigWhilePlayingTest* RA3FDevSoundToneConfigWhilePlayingTest::NewL(const TDesC& aTestName)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3819
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3820
	RA3FDevSoundToneConfigWhilePlayingTest * self = new(ELeave)RA3FDevSoundToneConfigWhilePlayingTest(aTestName);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3821
	return self;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3822
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3823
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3824
void RA3FDevSoundToneConfigWhilePlayingTest::DoKickoffTestL()
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3825
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3826
	if (!GetIntFromConfig(iTestStepName, KDuration, iDuration))
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3827
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3828
		ERR_PRINTF2(KMsgErrorGetParameter, &KDuration);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3829
		StopTest(KErrNotFound);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3830
		return;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3831
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3832
	if (!GetIntFromConfig(iTestStepName, KFrequencyTone1, iFrequencyTone1))
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3833
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3834
		ERR_PRINTF2(KMsgErrorGetParameter, &KFrequencyTone1);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3835
		StopTest(KErrNotFound);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3836
		return;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3837
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3838
	if (!GetIntFromConfig(iTestStepName, KExCapRate, iExCapRate))
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3839
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3840
			ERR_PRINTF2(KMsgErrorGetParameter, &KExCapRate);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3841
			StopTest(KErrNotFound);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3842
			return;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3843
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3844
	if (!GetIntFromConfig(iTestStepName, KExCapChannels, iExCapChannels))
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3845
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3846
		ERR_PRINTF2(KMsgErrorGetParameter, &KExCapChannels);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3847
		StopTest(KErrNotFound);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3848
		return;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3849
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3850
	iTimer = CPeriodic::NewL(CActive::EPriorityHigh);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3851
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3852
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3853
void RA3FDevSoundToneConfigWhilePlayingTest::Fsm(TMmfDevSoundEvent aDevSoundEvent, TInt aError)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3854
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3855
	switch(iDevSoundState)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3856
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3857
		case EStateCreated:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3858
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3859
			__ASSERT_ALWAYS((aError == KErrNone), Panic(_L("RA3FDevSoundToneConfigWhilePlayingTest"), EFsmIncorrectErrorPassed));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3860
			if (aDevSoundEvent == EEventInitialize)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3861
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3862
				INFO_PRINTF1(_L("Calling CMMFDevSound::InitializeL"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3863
				TRAPD(err, iMMFDevSound->InitializeL(*this, EMMFStateTonePlaying));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3864
				if (err != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3865
					{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3866
					ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"), err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3867
					StopTest(err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3868
					break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3869
					}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3870
				INFO_PRINTF1(_L("DevSound State: EStateInitializing"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3871
				iDevSoundState = EStateInitializing;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3872
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3873
			else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3874
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3875
				ERR_PRINTF2(_L("DevSound EEventInitialize not received as expected. Received event: %d"), aDevSoundEvent);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3876
				StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3877
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3878
			break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3879
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3880
		case EStateInitializing:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3881
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3882
			if (aDevSoundEvent == EEventInitComplete && aError == KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3883
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3884
				iStartTime.HomeTime();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3885
				INFO_PRINTF3(_L("Calling CMMFDevSound::PlayToneL using %d Hz during %d secs "), iFrequencyTone1, iDuration);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3886
				TRAPD(err, iMMFDevSound->PlayToneL(iFrequencyTone1, iDuration*KMicroSecsInOneSec));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3887
				if (err != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3888
					{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3889
					ERR_PRINTF2(_L("CMMFDevSound::PlayToneL left with error : %d!"),  err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3890
					StopTest(err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3891
					break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3892
					}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3893
				StartTimer(KMicroSecsTwoSec);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3894
				INFO_PRINTF1(_L("DevSound State: EStatePlaying"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3895
				iDevSoundState = EStatePlaying;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3896
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3897
			else if (aDevSoundEvent == EEventInitComplete && aError != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3898
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3899
				ERR_PRINTF2(_L("DevSound called CMMFDevSound::InitializeComplete with error = %d"), aError);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3900
				StopTest(aError);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3901
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3902
			else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3903
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3904
				ERR_PRINTF2(_L("DevSound EEventInitComplete not received as expected. Received event: %d"), aDevSoundEvent);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3905
				StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3906
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3907
			break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3908
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3909
		default:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3910
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3911
			ERR_PRINTF2(_L("Invalid DevSound state received: %d"), iDevSoundState);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3912
			StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3913
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3914
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3915
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3916
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3917
void RA3FDevSoundToneConfigWhilePlayingTest::DoTimerCallback()
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3918
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3919
	iTimer->Cancel();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3920
	INFO_PRINTF1(_L("DevSound Event: EEventTimerComplete"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3921
	TMMFCapabilities capabilitiesGet;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3922
	TBuf<KMaxSampleRateStringLength> stringSampleRateGet;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3923
	TBuf<KMaxChannelsStringLength> stringChannelsGet;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3924
	TBuf<KMaxSampleRateStringLength> stringSampleRateExpected;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3925
	TBuf<KMaxChannelsStringLength> stringChannelsExpected;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3926
	INFO_PRINTF1(_L("Calling CMMFDevSound::Config while playing"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3927
	capabilitiesGet=iMMFDevSound->Config();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3928
	SampleRateFromTUintToString (capabilitiesGet.iRate, stringSampleRateGet);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3929
	ChannelsFromTUintToString (capabilitiesGet.iChannels, stringChannelsGet);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3930
	SampleRateFromTIntToTMMFSampleRate (iExCapRate, iExSampleRate);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3931
	SampleRateFromTUintToString (iExSampleRate, stringSampleRateExpected);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3932
	ChannelsFromTUintToString (iExCapChannels, stringChannelsExpected);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3933
	if (stringSampleRateExpected.Compare(stringSampleRateGet) == 0)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3934
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3935
		INFO_PRINTF2(_L("Sample rate value match default as expected with %S"), &stringSampleRateGet);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3936
		if (stringChannelsExpected.Compare(stringChannelsGet) == 0)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3937
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3938
			INFO_PRINTF2(_L("Channel mode value match default as expected with %S"), &stringChannelsGet);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3939
			StopTest();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3940
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3941
		else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3942
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3943
			INFO_PRINTF2(_L("Channel mode value failed with %S"), &stringChannelsGet);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3944
			ERR_PRINTF2(_L("Expected channel mode %S"), &stringChannelsExpected);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3945
			StopTest(KErrNone, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3946
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3947
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3948
	else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3949
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3950
		ERR_PRINTF2(_L("Sample rate value failed with %S"), &stringSampleRateGet);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3951
		ERR_PRINTF2(_L("Expected sample rate %S"), &stringSampleRateExpected);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3952
		StopTest(KErrNone, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3953
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3954
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3955
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3956
void RA3FDevSoundToneConfigWhilePlayingTest::ToneFinished(TInt aError)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3957
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3958
	INFO_PRINTF1(_L("========== DevSound ToneFinished() callback =========="));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3959
	if (aError == KErrUnderflow)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3960
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3961
		iEndTime.HomeTime();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3962
		iPlayToneTime = iEndTime.MicroSecondsFrom(iStartTime);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3963
		TInt totalExpectedReproductionTime = iDuration * KMicroSecsInOneSec;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3964
		if(iPlayToneTime < totalExpectedReproductionTime + KPlayVarianceTime && iPlayToneTime > totalExpectedReproductionTime - KPlayVarianceTime)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3965
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3966
			INFO_PRINTF2(_L("Play time is %Ld microseconds"), iPlayToneTime.Int64());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3967
			StopTest();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3968
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3969
		else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3970
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3971
			ERR_PRINTF3(_L("Play time is %Ld microseconds and it should have been %d microseconds"), iPlayToneTime.Int64(), totalExpectedReproductionTime);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3972
			StopTest(KErrNone, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3973
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3974
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3975
	else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3976
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3977
		ERR_PRINTF2(_L("DevSound called ToneFinished with error = %d"), aError);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3978
		ERR_PRINTF2(_L("Expected error = %d"), KErrUnderflow);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3979
		StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3980
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3981
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3982
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3983
/*
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3984
 *========================================================================================================
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3985
 * MM-A3F-DEVSOUND-CHRTZ-TONE-0030
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3986
 */
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3987
RA3FDevSoundToneMaxVolumeWhilePlayingTest::RA3FDevSoundToneMaxVolumeWhilePlayingTest(const TDesC& aTestName)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3988
	:	RA3FDevSoundTestBase(aTestName), iDuration(0),
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3989
		iFrequencyTone1(0), iExVolume(0)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3990
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3991
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3992
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3993
RA3FDevSoundToneMaxVolumeWhilePlayingTest* RA3FDevSoundToneMaxVolumeWhilePlayingTest::NewL(const TDesC& aTestName)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3994
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3995
	RA3FDevSoundToneMaxVolumeWhilePlayingTest * self = new(ELeave)RA3FDevSoundToneMaxVolumeWhilePlayingTest(aTestName);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3996
	return self;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3997
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3998
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  3999
void RA3FDevSoundToneMaxVolumeWhilePlayingTest::DoKickoffTestL()
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4000
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4001
	if (!GetIntFromConfig(iTestStepName, KExVolume, iExVolume))
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4002
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4003
		ERR_PRINTF2(KMsgErrorGetParameter, &KExVolume);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4004
		StopTest(KErrNotFound);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4005
		return;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4006
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4007
	if (!GetIntFromConfig(iTestStepName, KDuration, iDuration))
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4008
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4009
		ERR_PRINTF2(KMsgErrorGetParameter, &KDuration);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4010
		StopTest(KErrNotFound);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4011
		return;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4012
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4013
	if (!GetIntFromConfig(iTestStepName, KFrequencyTone1, iFrequencyTone1))
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4014
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4015
		ERR_PRINTF2(KMsgErrorGetParameter, &KFrequencyTone1);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4016
		StopTest(KErrNotFound);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4017
		return;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4018
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4019
	iTimer = CPeriodic::NewL(CActive::EPriorityHigh);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4020
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4021
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4022
void RA3FDevSoundToneMaxVolumeWhilePlayingTest::Fsm(TMmfDevSoundEvent aDevSoundEvent, TInt aError)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4023
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4024
	switch (iDevSoundState)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4025
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4026
		case EStateCreated:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4027
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4028
			__ASSERT_ALWAYS((aError == KErrNone), Panic(_L("RA3FDevSoundToneMaxVolumeWhilePlayingTest"), EFsmIncorrectErrorPassed));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4029
			if (aDevSoundEvent == EEventInitialize)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4030
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4031
				INFO_PRINTF1(_L("Calling CMMFDevSound::InitializeL"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4032
				TRAPD(err, iMMFDevSound->InitializeL(*this, EMMFStateTonePlaying));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4033
				if (err != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4034
					{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4035
					ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"), err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4036
					StopTest(err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4037
					break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4038
					}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4039
				INFO_PRINTF1(_L("DevSound State: EStateInitializing"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4040
				iDevSoundState = EStateInitializing;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4041
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4042
			else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4043
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4044
				ERR_PRINTF2(_L("DevSound EEventInitialize not received as expected. Received event: %d"), aDevSoundEvent);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4045
				StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4046
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4047
			break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4048
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4049
		case EStateInitializing:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4050
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4051
			if (aDevSoundEvent == EEventInitComplete && aError == KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4052
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4053
				iMMFDevSound->SetVolume(iMMFDevSound->MaxVolume());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4054
				iStartTime.HomeTime();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4055
				INFO_PRINTF3(_L("Calling CMMFDevSound::PlayToneL using %d Hz during %d secs "), iFrequencyTone1, iDuration);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4056
				TRAPD(err, iMMFDevSound->PlayToneL(iFrequencyTone1, iDuration*KMicroSecsInOneSec));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4057
				if (err != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4058
					{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4059
					ERR_PRINTF2(_L("CMMFDevSound::PlayToneL left with error : %d!"),  err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4060
					StopTest(err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4061
					break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4062
					}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4063
				StartTimer(KMicroSecsTwoSec);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4064
				INFO_PRINTF1(_L("DevSound State: EStatePlaying"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4065
				iDevSoundState = EStatePlaying;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4066
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4067
			else if (aDevSoundEvent == EEventInitComplete && aError != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4068
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4069
				ERR_PRINTF2(_L("DevSound called CMMFDevSound::InitializeComplete with error = %d"), aError);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4070
				StopTest(aError);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4071
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4072
			else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4073
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4074
				ERR_PRINTF2(_L("DevSound EEventInitComplete not received as expected. Received event: %d"), aDevSoundEvent);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4075
				StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4076
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4077
			break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4078
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4079
		default:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4080
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4081
			ERR_PRINTF2(_L("Invalid DevSound state received: %d"), iDevSoundState);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4082
			StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4083
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4084
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4085
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4086
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4087
void RA3FDevSoundToneMaxVolumeWhilePlayingTest::DoTimerCallback()
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4088
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4089
	iTimer->Cancel();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4090
	INFO_PRINTF1(_L("DevSound Event: EEventTimerComplete"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4091
	INFO_PRINTF1(_L("Calling CMMFDevSound::MaxVolume"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4092
	TInt maxVolumeGet = iMMFDevSound->MaxVolume();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4093
	if (maxVolumeGet == iExVolume)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4094
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4095
		INFO_PRINTF2(_L("The max device supported volume is %d."), maxVolumeGet);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4096
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4097
	else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4098
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4099
		INFO_PRINTF2(_L("The max device supported volume failed with %d."), maxVolumeGet);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4100
		ERR_PRINTF2(_L("Expected value = %d."), iExVolume);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4101
		StopTest(KErrNone, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4102
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4103
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4104
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4105
void RA3FDevSoundToneMaxVolumeWhilePlayingTest::ToneFinished(TInt aError)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4106
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4107
	INFO_PRINTF1(_L("========== DevSound ToneFinished() callback =========="));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4108
	if (aError == KErrUnderflow)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4109
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4110
		iEndTime.HomeTime();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4111
		iPlayToneTime = iEndTime.MicroSecondsFrom(iStartTime);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4112
		TInt totalExpectedReproductionTime = iDuration * KMicroSecsInOneSec;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4113
		if(iPlayToneTime < totalExpectedReproductionTime + KPlayVarianceTime && iPlayToneTime > totalExpectedReproductionTime - KPlayVarianceTime)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4114
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4115
			INFO_PRINTF2(_L("Play time is %Ld microseconds"), iPlayToneTime.Int64());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4116
			StopTest();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4117
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4118
		else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4119
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4120
			ERR_PRINTF3(_L("Play time is %Ld microseconds and it should have been %d microseconds"), iPlayToneTime.Int64(), totalExpectedReproductionTime);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4121
			StopTest(KErrNone, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4122
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4123
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4124
	else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4125
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4126
		ERR_PRINTF2(_L("DevSound called ToneFinished with error = %d"), aError);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4127
		ERR_PRINTF2(_L("Expected error = %d"), KErrUnderflow);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4128
		StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4129
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4130
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4131
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4132
/*
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4133
 *========================================================================================================
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4134
 * MM-A3F-DEVSOUND-CHRTZ-TONE-0031
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4135
 */
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4136
RA3FDevSoundToneVolumeWhilePlayingTest::RA3FDevSoundToneVolumeWhilePlayingTest(const TDesC& aTestName)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4137
	:	RA3FDevSoundTestBase(aTestName), iDuration(0),
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4138
		iFrequencyTone1(0), iExVolume(0)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4139
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4140
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4141
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4142
RA3FDevSoundToneVolumeWhilePlayingTest* RA3FDevSoundToneVolumeWhilePlayingTest::NewL(const TDesC& aTestName)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4143
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4144
	RA3FDevSoundToneVolumeWhilePlayingTest * self = new(ELeave)RA3FDevSoundToneVolumeWhilePlayingTest(aTestName);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4145
	return self;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4146
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4147
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4148
void RA3FDevSoundToneVolumeWhilePlayingTest::DoKickoffTestL()
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4149
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4150
	if (!GetIntFromConfig(iTestStepName, KExVolume, iExVolume))
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4151
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4152
		ERR_PRINTF2(KMsgErrorGetParameter, &KExVolume);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4153
		StopTest(KErrNotFound);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4154
		return;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4155
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4156
	if (!GetIntFromConfig(iTestStepName, KDuration, iDuration))
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4157
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4158
		ERR_PRINTF2(KMsgErrorGetParameter, &KDuration);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4159
		StopTest(KErrNotFound);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4160
		return;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4161
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4162
	if (!GetIntFromConfig(iTestStepName, KFrequencyTone1, iFrequencyTone1))
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4163
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4164
		ERR_PRINTF2(KMsgErrorGetParameter, &KFrequencyTone1);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4165
		StopTest(KErrNotFound);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4166
		return;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4167
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4168
	iTimer = CPeriodic::NewL(CActive::EPriorityHigh);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4169
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4170
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4171
void RA3FDevSoundToneVolumeWhilePlayingTest::Fsm(TMmfDevSoundEvent aDevSoundEvent, TInt aError)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4172
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4173
	switch (iDevSoundState)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4174
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4175
		case EStateCreated:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4176
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4177
			__ASSERT_ALWAYS((aError == KErrNone), Panic(_L("RA3FDevSoundToneVolumeWhilePlayingTest"), EFsmIncorrectErrorPassed));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4178
			if (aDevSoundEvent == EEventInitialize)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4179
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4180
				INFO_PRINTF1(_L("Calling CMMFDevSound::InitializeL"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4181
				TRAPD(err, iMMFDevSound->InitializeL(*this, EMMFStateTonePlaying));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4182
				if (err != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4183
					{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4184
					ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"), err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4185
					StopTest(err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4186
					break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4187
					}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4188
				INFO_PRINTF1(_L("DevSound State: EStateInitializing"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4189
				iDevSoundState = EStateInitializing;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4190
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4191
			else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4192
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4193
				ERR_PRINTF2(_L("DevSound EEventInitialize not received as expected. Received event: %d"), aDevSoundEvent);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4194
				StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4195
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4196
			break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4197
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4198
		case EStateInitializing:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4199
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4200
			if (aDevSoundEvent == EEventInitComplete && aError == KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4201
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4202
				iStartTime.HomeTime();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4203
				INFO_PRINTF3(_L("Calling CMMFDevSound::PlayToneL using %d Hz during %d secs "), iFrequencyTone1, iDuration);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4204
				TRAPD(err, iMMFDevSound->PlayToneL(iFrequencyTone1, iDuration*KMicroSecsInOneSec));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4205
				if (err != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4206
					{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4207
					ERR_PRINTF2(_L("CMMFDevSound::PlayToneL left with error : %d!"), err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4208
					StopTest(err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4209
					break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4210
					}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4211
				StartTimer(KMicroSecsTwoSec);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4212
				INFO_PRINTF1(_L("DevSound State: EStatePlaying"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4213
				iDevSoundState = EStatePlaying;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4214
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4215
			else if (aDevSoundEvent == EEventInitComplete && aError != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4216
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4217
				ERR_PRINTF2(_L("DevSound called CMMFDevSound::InitializeComplete with error = %d"), aError);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4218
				StopTest(aError);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4219
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4220
			else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4221
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4222
				ERR_PRINTF2(_L("DevSound EEventInitComplete not received as expected. Received event: %d"), aDevSoundEvent);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4223
				StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4224
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4225
			break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4226
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4227
		default:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4228
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4229
			ERR_PRINTF2(_L("Invalid DevSound state received: %d"), iDevSoundState);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4230
			StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4231
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4232
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4233
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4234
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4235
void RA3FDevSoundToneVolumeWhilePlayingTest::DoTimerCallback()
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4236
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4237
	iTimer->Cancel();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4238
	INFO_PRINTF1(_L("DevSound Event: EEventTimerComplete"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4239
	INFO_PRINTF1(_L("Calling CMMFDevSound::Volume"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4240
	TInt maxVolumeGet = iMMFDevSound->Volume();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4241
	if (maxVolumeGet == iExVolume)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4242
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4243
		INFO_PRINTF2(_L("The device default supported volume value is %d."), maxVolumeGet);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4244
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4245
	else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4246
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4247
		INFO_PRINTF2(_L("The device default supported volume value failed with %d."), maxVolumeGet);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4248
		ERR_PRINTF2(_L("Expected value = %d."), iExVolume);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4249
		StopTest(KErrNone, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4250
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4251
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4252
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4253
void RA3FDevSoundToneVolumeWhilePlayingTest::ToneFinished(TInt aError)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4254
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4255
	INFO_PRINTF1(_L("========== DevSound ToneFinished() callback =========="));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4256
	if (aError == KErrUnderflow)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4257
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4258
		iEndTime.HomeTime();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4259
		iPlayToneTime = iEndTime.MicroSecondsFrom(iStartTime);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4260
		TInt totalExpectedReproductionTime = iDuration * KMicroSecsInOneSec;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4261
		if(iPlayToneTime < totalExpectedReproductionTime + KPlayVarianceTime && iPlayToneTime > totalExpectedReproductionTime - KPlayVarianceTime)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4262
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4263
			INFO_PRINTF2(_L("Play time is %Ld microseconds"), iPlayToneTime.Int64());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4264
			StopTest();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4265
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4266
		else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4267
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4268
			ERR_PRINTF3(_L("Play time is %Ld microseconds and it should have been %d microseconds"), iPlayToneTime.Int64(), totalExpectedReproductionTime);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4269
			StopTest(KErrNone, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4270
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4271
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4272
	else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4273
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4274
		ERR_PRINTF2(_L("DevSound called ToneFinished with error = %d"), aError);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4275
		ERR_PRINTF2(_L("Expected error = %d"), KErrUnderflow);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4276
		StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4277
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4278
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4279
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4280
/*
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4281
 *========================================================================================================
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4282
 * MM-A3F-DEVSOUND-CHRTZ-TONE-0032
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4283
 */
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4284
RA3FDevSoundToneQueryCapsWhilePausePlayingTest::RA3FDevSoundToneQueryCapsWhilePausePlayingTest(const TDesC& aTestName)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4285
	:	RA3FDevSoundTestBase(aTestName), iDuration(0),
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4286
		iFrequencyTone1(0), iExCapRate(0), iExCapChannels(0),
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4287
		iTimeToEnterPauseElapsed(EFalse)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4288
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4289
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4290
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4291
RA3FDevSoundToneQueryCapsWhilePausePlayingTest* RA3FDevSoundToneQueryCapsWhilePausePlayingTest::NewL(const TDesC& aTestName)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4292
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4293
	RA3FDevSoundToneQueryCapsWhilePausePlayingTest * self = new(ELeave)RA3FDevSoundToneQueryCapsWhilePausePlayingTest(aTestName);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4294
	return self;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4295
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4296
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4297
void RA3FDevSoundToneQueryCapsWhilePausePlayingTest::DoKickoffTestL()
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4298
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4299
	if (!GetIntFromConfig(iTestStepName, KDuration, iDuration))
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4300
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4301
		ERR_PRINTF2(KMsgErrorGetParameter, &KDuration);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4302
		StopTest(KErrNotFound);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4303
		return;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4304
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4305
	if (!GetIntFromConfig(iTestStepName, KFrequencyTone1, iFrequencyTone1))
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4306
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4307
		ERR_PRINTF2(KMsgErrorGetParameter, &KFrequencyTone1);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4308
		StopTest(KErrNotFound);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4309
		return;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4310
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4311
	if (!GetIntFromConfig(iTestStepName, KExCapRate, iExCapRate))
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4312
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4313
		ERR_PRINTF2(KMsgErrorGetParameter, &KSampleRate);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4314
		StopTest(KErrNotFound);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4315
		return;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4316
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4317
	if (!GetIntFromConfig(iTestStepName, KExCapChannels, iExCapChannels))
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4318
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4319
		ERR_PRINTF2(KMsgErrorGetParameter, &KChannel);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4320
		StopTest(KErrNotFound);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4321
		return;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4322
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4323
	iTimer = CPeriodic::NewL(CActive::EPriorityHigh);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4324
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4325
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4326
void RA3FDevSoundToneQueryCapsWhilePausePlayingTest::Fsm(TMmfDevSoundEvent aDevSoundEvent, TInt aError)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4327
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4328
	switch (iDevSoundState)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4329
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4330
		case EStateCreated:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4331
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4332
			__ASSERT_ALWAYS((aError == KErrNone), Panic(_L("RA3FDevSoundToneQueryCapsWhilePausePlayingTest"), EFsmIncorrectErrorPassed));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4333
			if (aDevSoundEvent == EEventInitialize)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4334
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4335
				INFO_PRINTF1(_L("Calling CMMFDevSound::InitializeL"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4336
				TRAPD(err, iMMFDevSound->InitializeL(*this, EMMFStateTonePlaying));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4337
				if (err != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4338
					{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4339
					ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"), err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4340
					StopTest(err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4341
					break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4342
					}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4343
				INFO_PRINTF1(_L("DevSound State: EStateInitializing"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4344
				iDevSoundState = EStateInitializing;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4345
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4346
			else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4347
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4348
				ERR_PRINTF2(_L("DevSound EEventInitialize not received as expected. Received event: %d"), aDevSoundEvent);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4349
				StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4350
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4351
			break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4352
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4353
		case EStateInitializing:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4354
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4355
			if (aDevSoundEvent == EEventInitComplete && aError == KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4356
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4357
				iMMFDevSound->SetVolume(iMMFDevSound->MaxVolume());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4358
				INFO_PRINTF3(_L("Calling CMMFDevSound::PlayToneL using %d Hz during %d secs "), iFrequencyTone1, iDuration);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4359
				TRAPD(err, iMMFDevSound->PlayToneL(iFrequencyTone1, iDuration*KMicroSecsInOneSec));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4360
				if (err != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4361
					{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4362
					ERR_PRINTF2(_L("CMMFDevSound::PlayToneL left with error : %d!"), err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4363
					StopTest(err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4364
					break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4365
					}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4366
				StartTimer(KMicroSecsTwoSec);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4367
				INFO_PRINTF1(_L("DevSound State: EStatePlaying"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4368
				iDevSoundState = EStatePlaying;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4369
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4370
			else if (aDevSoundEvent == EEventInitComplete && aError != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4371
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4372
				ERR_PRINTF2(_L("DevSound called CMMFDevSound::InitializeComplete with error = %d"), aError);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4373
				StopTest(aError);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4374
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4375
			else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4376
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4377
				ERR_PRINTF2(_L("DevSound EEventInitComplete not received as expected. Received event: %d"), aDevSoundEvent);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4378
				StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4379
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4380
			break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4381
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4382
		case EStatePlaying:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4383
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4384
			if(aDevSoundEvent == EEventTimerComplete)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4385
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4386
				INFO_PRINTF1(_L("Calling CMMFDevSound::Pause"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4387
				iMMFDevSound->Pause();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4388
				INFO_PRINTF1(_L("DevSound State: EStatePause"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4389
				iDevSoundState = EStatePause;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4390
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4391
			else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4392
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4393
				ERR_PRINTF2(_L("DevSound EEventTimerComplete not received as expected. Received event: %d"), aDevSoundEvent);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4394
				StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4395
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4396
			break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4397
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4398
		case EStatePause:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4399
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4400
			if(aDevSoundEvent == EEventTimerComplete)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4401
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4402
				TMMFCapabilities capabilities;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4403
				INFO_PRINTF1(_L("Calling CMMFDevSound::Capabilities"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4404
				capabilities = iMMFDevSound->Capabilities();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4405
				PrintSupportedCapabilities(capabilities.iRate, capabilities.iChannels);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4406
				if(capabilities.iRate == iExCapRate)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4407
					{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4408
					INFO_PRINTF2(_L("The total of possible sample rate values is 0x%08x"), capabilities.iRate);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4409
					if(capabilities.iChannels == iExCapChannels)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4410
						{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4411
						INFO_PRINTF2(_L("The total of possible channel values is 0x%08x"),capabilities.iChannels );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4412
						StopTest();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4413
						}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4414
					else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4415
						{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4416
						ERR_PRINTF2(_L("The total of possible channel values failed with 0x%08x"), capabilities.iChannels );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4417
						ERR_PRINTF2(_L("Expected value = %d"), iExCapChannels);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4418
						StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4419
						}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4420
					}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4421
				else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4422
					{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4423
					ERR_PRINTF2(_L("The total of possible sample rate values failed with 0x%08x"), capabilities.iRate);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4424
					ERR_PRINTF2(_L("Expected value = %d"), iExCapRate);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4425
					StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4426
					}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4427
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4428
			else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4429
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4430
				ERR_PRINTF2(_L("DevSound EEventTimerComplete not received as expected. Received event: %d"), aDevSoundEvent);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4431
				StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4432
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4433
			break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4434
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4435
		default:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4436
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4437
			ERR_PRINTF2(_L("Invalid DevSound state received: %d"), iDevSoundState);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4438
			StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4439
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4440
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4441
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4442
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4443
void RA3FDevSoundToneQueryCapsWhilePausePlayingTest::DoTimerCallback()
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4444
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4445
	INFO_PRINTF1(_L("TimerEvent called"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4446
	if(!iTimeToEnterPauseElapsed)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4447
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4448
		iTimeToEnterPauseElapsed = ETrue;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4449
		INFO_PRINTF1(_L("DevSound Event: EEventTimerComplete"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4450
		Fsm(EEventTimerComplete, KErrNone);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4451
		iTimeToEnterPauseElapsed = ETrue;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4452
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4453
	else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4454
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4455
		iTimer->Cancel();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4456
		INFO_PRINTF1(_L("DevSound Event: EEventTimerComplete"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4457
		Fsm(EEventTimerComplete, KErrNone);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4458
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4459
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4460
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4461
void RA3FDevSoundToneQueryCapsWhilePausePlayingTest::ToneFinished(TInt aError)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4462
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4463
	INFO_PRINTF1(_L("========== DevSound ToneFinished() callback =========="));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4464
	ERR_PRINTF1(_L("DevSound should not have called ToneFinished because it is supposed to be paused then stopped"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4465
	StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4466
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4467
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4468
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4469
/*
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4470
 *========================================================================================================
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4471
 * MM-A3F-DEVSOUND-CHRTZ-TONE-0033
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4472
 */
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4473
RA3FDevSoundToneConfigWhilePausePlayingTest::RA3FDevSoundToneConfigWhilePausePlayingTest(const TDesC& aTestName)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4474
	:	RA3FDevSoundTestBase(aTestName), iDuration(0),
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4475
		iFrequencyTone1(0), iTimeToEnterPauseElapsed(EFalse),
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4476
		iExCapRate(0), iExCapChannels(0)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4477
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4478
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4479
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4480
RA3FDevSoundToneConfigWhilePausePlayingTest* RA3FDevSoundToneConfigWhilePausePlayingTest::NewL(const TDesC& aTestName)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4481
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4482
	RA3FDevSoundToneConfigWhilePausePlayingTest * self = new(ELeave)RA3FDevSoundToneConfigWhilePausePlayingTest(aTestName);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4483
	return self;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4484
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4485
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4486
void RA3FDevSoundToneConfigWhilePausePlayingTest::DoKickoffTestL()
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4487
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4488
	if (!GetIntFromConfig(iTestStepName, KDuration, iDuration))
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4489
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4490
		ERR_PRINTF2(KMsgErrorGetParameter, &KDuration);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4491
		StopTest(KErrNotFound);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4492
		return;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4493
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4494
	if (!GetIntFromConfig(iTestStepName, KFrequencyTone1, iFrequencyTone1))
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4495
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4496
		ERR_PRINTF2(KMsgErrorGetParameter, &KFrequencyTone1);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4497
		StopTest(KErrNotFound);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4498
		return;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4499
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4500
	if (!GetIntFromConfig(iTestStepName, KExCapRate, iExCapRate))
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4501
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4502
			ERR_PRINTF2(KMsgErrorGetParameter, &KExCapRate);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4503
			StopTest(KErrNotFound);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4504
			return;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4505
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4506
	if (!GetIntFromConfig(iTestStepName, KExCapChannels, iExCapChannels))
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4507
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4508
		ERR_PRINTF2(KMsgErrorGetParameter, &KExCapChannels);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4509
		StopTest(KErrNotFound);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4510
		return;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4511
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4512
	iTimer = CPeriodic::NewL(CActive::EPriorityHigh);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4513
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4514
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4515
void RA3FDevSoundToneConfigWhilePausePlayingTest::Fsm(TMmfDevSoundEvent aDevSoundEvent, TInt aError)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4516
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4517
	switch (iDevSoundState)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4518
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4519
		case EStateCreated:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4520
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4521
			__ASSERT_ALWAYS((aError == KErrNone), Panic(_L("RA3FDevSoundToneConfigWhilePausePlayingTest"), EFsmIncorrectErrorPassed));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4522
			if (aDevSoundEvent == EEventInitialize)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4523
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4524
				INFO_PRINTF1(_L("Calling CMMFDevSound::InitializeL"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4525
				TRAPD(err, iMMFDevSound->InitializeL(*this, EMMFStateTonePlaying));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4526
				if (err != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4527
					{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4528
					ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"), err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4529
					StopTest(err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4530
					break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4531
					}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4532
				INFO_PRINTF1(_L("DevSound State: EStateInitializing"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4533
				iDevSoundState = EStateInitializing;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4534
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4535
			else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4536
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4537
				ERR_PRINTF2(_L("DevSound EEventInitialize not received as expected. Received event: %d"), aDevSoundEvent);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4538
				StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4539
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4540
			break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4541
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4542
		case EStateInitializing:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4543
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4544
			if (aDevSoundEvent == EEventInitComplete && aError == KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4545
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4546
				iMMFDevSound->SetVolume(iMMFDevSound->MaxVolume());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4547
				INFO_PRINTF3(_L("Calling CMMFDevSound::PlayToneL using %d Hz during %d secs "), iFrequencyTone1, iDuration);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4548
				TRAPD(err, iMMFDevSound->PlayToneL(iFrequencyTone1, iDuration*KMicroSecsInOneSec));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4549
				if (err != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4550
					{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4551
					ERR_PRINTF2(_L("CMMFDevSound::PlayToneL left with error : %d!"), err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4552
					StopTest(err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4553
					break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4554
					}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4555
				StartTimer(KMicroSecsTwoSec);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4556
				INFO_PRINTF1(_L("DevSound State: EStatePlaying"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4557
				iDevSoundState = EStatePlaying;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4558
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4559
			else if (aDevSoundEvent == EEventInitComplete && aError != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4560
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4561
				ERR_PRINTF2(_L("DevSound called CMMFDevSound::InitializeComplete with error = %d"), aError);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4562
				StopTest(aError);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4563
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4564
			else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4565
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4566
				ERR_PRINTF2(_L("DevSound EEventInitComplete not received as expected. Received event: %d"), aDevSoundEvent);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4567
				StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4568
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4569
			break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4570
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4571
		case EStatePlaying:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4572
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4573
			if(aDevSoundEvent == EEventTimerComplete)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4574
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4575
				INFO_PRINTF1(_L("Calling CMMFDevSound::Pause"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4576
				iMMFDevSound->Pause();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4577
				INFO_PRINTF1(_L("DevSound State: EStatePause"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4578
				iDevSoundState = EStatePause;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4579
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4580
			else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4581
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4582
				ERR_PRINTF2(_L("DevSound EEventTimerComplete not received as expected. Received event: %d"), aDevSoundEvent);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4583
				StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4584
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4585
			break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4586
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4587
		case EStatePause:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4588
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4589
			if(aDevSoundEvent == EEventTimerComplete)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4590
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4591
				TMMFCapabilities capabilitiesGet;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4592
				TBuf<KMaxSampleRateStringLength> stringSampleRateGet;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4593
				TBuf<KMaxChannelsStringLength> stringChannelsGet;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4594
				TBuf<KMaxSampleRateStringLength> stringSampleRateExpected;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4595
				TBuf<KMaxChannelsStringLength> stringChannelsExpected;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4596
				INFO_PRINTF1(_L("Calling CMMFDevSound::Config while playing"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4597
				capabilitiesGet=iMMFDevSound->Config();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4598
				SampleRateFromTUintToString (capabilitiesGet.iRate, stringSampleRateGet);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4599
				ChannelsFromTUintToString (capabilitiesGet.iChannels, stringChannelsGet);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4600
				SampleRateFromTIntToTMMFSampleRate (iExCapRate, iExSampleRate);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4601
				SampleRateFromTUintToString (iExSampleRate, stringSampleRateExpected);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4602
				ChannelsFromTUintToString (iExCapChannels, stringChannelsExpected);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4603
				if (stringSampleRateExpected.Compare(stringSampleRateGet) == 0)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4604
					{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4605
					INFO_PRINTF2(_L("Sample rate value match default as expected with %S"), &stringSampleRateGet);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4606
					if (stringChannelsExpected.Compare(stringChannelsGet) == 0)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4607
						{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4608
						INFO_PRINTF2(_L("Channel mode value match default as expected with %S"), &stringChannelsGet);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4609
						StopTest();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4610
						}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4611
					else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4612
						{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4613
						INFO_PRINTF2(_L("Channel mode value failed with %S"), &stringChannelsGet);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4614
						ERR_PRINTF2(_L("Expected channel mode %S"), &stringChannelsExpected);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4615
						StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4616
						}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4617
					}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4618
				else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4619
					{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4620
					ERR_PRINTF2(_L("Sample rate value failed with %S"), &stringSampleRateGet);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4621
					ERR_PRINTF2(_L("Expected sample rate %S"), &stringSampleRateExpected);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4622
					StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4623
					}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4624
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4625
			else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4626
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4627
				ERR_PRINTF2(_L("DevSound EEventTimerComplete not received as expected. Received event: %d"), aDevSoundEvent);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4628
				StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4629
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4630
			break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4631
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4632
		default:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4633
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4634
			ERR_PRINTF2(_L("Invalid DevSound state received: %d"), iDevSoundState);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4635
			StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4636
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4637
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4638
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4639
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4640
void RA3FDevSoundToneConfigWhilePausePlayingTest::DoTimerCallback()
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4641
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4642
	INFO_PRINTF1(_L("TimerEvent called"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4643
	if(!iTimeToEnterPauseElapsed)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4644
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4645
		iTimeToEnterPauseElapsed = ETrue;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4646
		INFO_PRINTF1(_L("DevSound Event: EEventTimerComplete"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4647
		Fsm(EEventTimerComplete, KErrNone);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4648
		iTimeToEnterPauseElapsed = ETrue;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4649
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4650
	else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4651
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4652
		iTimer->Cancel();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4653
		INFO_PRINTF1(_L("DevSound Event: EEventTimerComplete"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4654
		Fsm(EEventTimerComplete, KErrNone);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4655
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4656
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4657
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4658
void RA3FDevSoundToneConfigWhilePausePlayingTest::ToneFinished(TInt aError)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4659
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4660
	INFO_PRINTF1(_L("========== DevSound ToneFinished() callback =========="));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4661
	ERR_PRINTF1(_L("DevSound should not have called ToneFinished because it is supposed to be paused then stopped"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4662
	StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4663
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4664
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4665
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4666
/*
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4667
 *========================================================================================================
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4668
 * MM-A3F-DEVSOUND-CHRTZ-TONE-0034
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4669
 */
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4670
RA3FDevSoundToneMaxVolumeWhilePausePlayingTest::RA3FDevSoundToneMaxVolumeWhilePausePlayingTest(const TDesC& aTestName)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4671
	:	RA3FDevSoundTestBase(aTestName), iDuration(0),
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4672
		iFrequencyTone1(0), iExVolume(0),
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4673
		iTimeToEnterPauseElapsed(EFalse)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4674
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4675
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4676
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4677
RA3FDevSoundToneMaxVolumeWhilePausePlayingTest* RA3FDevSoundToneMaxVolumeWhilePausePlayingTest::NewL(const TDesC& aTestName)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4678
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4679
	RA3FDevSoundToneMaxVolumeWhilePausePlayingTest * self = new(ELeave)RA3FDevSoundToneMaxVolumeWhilePausePlayingTest(aTestName);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4680
	return self;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4681
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4682
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4683
void RA3FDevSoundToneMaxVolumeWhilePausePlayingTest::DoKickoffTestL()
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4684
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4685
	if (!GetIntFromConfig(iTestStepName, KDuration, iDuration))
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4686
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4687
		ERR_PRINTF2(KMsgErrorGetParameter, &KDuration);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4688
		StopTest(KErrNotFound);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4689
		return;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4690
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4691
	if (!GetIntFromConfig(iTestStepName, KFrequencyTone1, iFrequencyTone1))
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4692
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4693
		ERR_PRINTF2(KMsgErrorGetParameter, &KFrequencyTone1);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4694
		StopTest(KErrNotFound);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4695
		return;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4696
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4697
	if (!GetIntFromConfig(iTestStepName, KExVolume, iExVolume))
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4698
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4699
		ERR_PRINTF2(KMsgErrorGetParameter, &KExVolume);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4700
		StopTest(KErrNotFound);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4701
		return;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4702
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4703
	iTimer = CPeriodic::NewL(CActive::EPriorityHigh);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4704
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4705
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4706
void RA3FDevSoundToneMaxVolumeWhilePausePlayingTest::Fsm(TMmfDevSoundEvent aDevSoundEvent, TInt aError)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4707
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4708
	switch (iDevSoundState)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4709
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4710
		case EStateCreated:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4711
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4712
			__ASSERT_ALWAYS((aError == KErrNone), Panic(_L("RA3FDevSoundToneMaxVolumeWhilePausePlayingTest"), EFsmIncorrectErrorPassed));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4713
			if (aDevSoundEvent == EEventInitialize)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4714
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4715
				INFO_PRINTF1(_L("Calling CMMFDevSound::InitializeL"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4716
				TRAPD(err, iMMFDevSound->InitializeL(*this, EMMFStateTonePlaying));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4717
				if (err != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4718
					{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4719
					ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"), err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4720
					StopTest(err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4721
					break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4722
					}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4723
				INFO_PRINTF1(_L("DevSound State: EStateInitializing"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4724
				iDevSoundState = EStateInitializing;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4725
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4726
			else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4727
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4728
				ERR_PRINTF2(_L("DevSound EEventInitialize not received as expected. Received event: %d"), aDevSoundEvent);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4729
				StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4730
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4731
			break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4732
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4733
		case EStateInitializing:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4734
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4735
			if (aDevSoundEvent == EEventInitComplete && aError == KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4736
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4737
				iMMFDevSound->SetVolume(iMMFDevSound->MaxVolume());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4738
				INFO_PRINTF3(_L("Calling CMMFDevSound::PlayToneL using %d Hz during %d secs "), iFrequencyTone1, iDuration);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4739
				TRAPD(err, iMMFDevSound->PlayToneL(iFrequencyTone1, iDuration*KMicroSecsInOneSec));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4740
				if (err != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4741
					{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4742
					ERR_PRINTF2(_L("CMMFDevSound::PlayToneL left with error : %d!"), err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4743
					StopTest(err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4744
					break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4745
					}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4746
				StartTimer(KMicroSecsTwoSec);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4747
				INFO_PRINTF1(_L("DevSound State: EStatePlaying"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4748
				iDevSoundState = EStatePlaying;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4749
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4750
			else if (aDevSoundEvent == EEventInitComplete && aError != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4751
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4752
				ERR_PRINTF2(_L("DevSound called CMMFDevSound::InitializeComplete with error = %d"), aError);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4753
				StopTest(aError);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4754
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4755
			else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4756
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4757
				ERR_PRINTF2(_L("DevSound EEventInitComplete not received as expected. Received event: %d"), aDevSoundEvent);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4758
				StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4759
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4760
			break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4761
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4762
		case EStatePlaying:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4763
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4764
			if(aDevSoundEvent == EEventTimerComplete)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4765
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4766
				INFO_PRINTF1(_L("Calling CMMFDevSound::Pause"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4767
				iMMFDevSound->Pause();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4768
				INFO_PRINTF1(_L("DevSound State: EStatePause"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4769
				iDevSoundState = EStatePause;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4770
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4771
			else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4772
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4773
				ERR_PRINTF2(_L("DevSound EEventTimerComplete not received as expected. Received event: %d"), aDevSoundEvent);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4774
				StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4775
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4776
			break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4777
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4778
		case EStatePause:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4779
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4780
			if(aDevSoundEvent == EEventTimerComplete)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4781
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4782
				INFO_PRINTF1(_L("Calling CMMFDevSound::MaxVolume"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4783
				TInt maxVolumeGet = iMMFDevSound->MaxVolume();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4784
				if (maxVolumeGet == iExVolume)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4785
					{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4786
					INFO_PRINTF2(_L("The max device supported volume is %d."), maxVolumeGet);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4787
					StopTest();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4788
					}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4789
				else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4790
					{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4791
					INFO_PRINTF2(_L("The max device supported volume failed with %d."), maxVolumeGet);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4792
					ERR_PRINTF2(_L("Expected value = %d."), iExVolume);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4793
					StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4794
					}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4795
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4796
			else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4797
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4798
				ERR_PRINTF2(_L("DevSound EEventTimerComplete not received as expected. Received event: %d"), aDevSoundEvent);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4799
				StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4800
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4801
			break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4802
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4803
		default:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4804
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4805
			ERR_PRINTF2(_L("Invalid DevSound state received: %d"), iDevSoundState);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4806
			StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4807
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4808
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4809
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4810
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4811
void RA3FDevSoundToneMaxVolumeWhilePausePlayingTest::DoTimerCallback()
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4812
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4813
	INFO_PRINTF1(_L("TimerEvent called"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4814
	if(!iTimeToEnterPauseElapsed)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4815
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4816
		iTimeToEnterPauseElapsed = ETrue;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4817
		INFO_PRINTF1(_L("DevSound Event: EEventTimerComplete"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4818
		Fsm(EEventTimerComplete, KErrNone);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4819
		iTimeToEnterPauseElapsed = ETrue;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4820
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4821
	else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4822
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4823
		iTimer->Cancel();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4824
		INFO_PRINTF1(_L("DevSound Event: EEventTimerComplete"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4825
		Fsm(EEventTimerComplete, KErrNone);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4826
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4827
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4828
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4829
void RA3FDevSoundToneMaxVolumeWhilePausePlayingTest::ToneFinished(TInt aError)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4830
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4831
	INFO_PRINTF1(_L("========== DevSound ToneFinished() callback =========="));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4832
	ERR_PRINTF1(_L("DevSound should not have called ToneFinished because it is supposed to be paused then stopped"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4833
	StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4834
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4835
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4836
/*
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4837
 *========================================================================================================
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4838
 * MM-A3F-DEVSOUND-CHRTZ-TONE-0035
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4839
 */
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4840
RA3FDevSoundToneVolumeWhilePausePlayingTest::RA3FDevSoundToneVolumeWhilePausePlayingTest(const TDesC& aTestName)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4841
	:	RA3FDevSoundTestBase(aTestName), iDuration(0),
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4842
		iFrequencyTone1(0), iExVolume(0),
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4843
		iTimeToEnterPauseElapsed(EFalse)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4844
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4845
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4846
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4847
RA3FDevSoundToneVolumeWhilePausePlayingTest* RA3FDevSoundToneVolumeWhilePausePlayingTest::NewL(const TDesC& aTestName)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4848
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4849
	RA3FDevSoundToneVolumeWhilePausePlayingTest * self = new(ELeave)RA3FDevSoundToneVolumeWhilePausePlayingTest(aTestName);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4850
	return self;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4851
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4852
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4853
void RA3FDevSoundToneVolumeWhilePausePlayingTest::DoKickoffTestL()
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4854
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4855
	if (!GetIntFromConfig(iTestStepName, KDuration, iDuration))
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4856
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4857
		ERR_PRINTF2(KMsgErrorGetParameter, &KDuration);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4858
		StopTest(KErrNotFound);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4859
		return;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4860
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4861
	if (!GetIntFromConfig(iTestStepName, KFrequencyTone1, iFrequencyTone1))
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4862
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4863
		ERR_PRINTF2(KMsgErrorGetParameter, &KFrequencyTone1);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4864
		StopTest(KErrNotFound);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4865
		return;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4866
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4867
	if (!GetIntFromConfig(iTestStepName, KExVolume, iExVolume))
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4868
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4869
		ERR_PRINTF2(KMsgErrorGetParameter, &KExVolume);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4870
		StopTest(KErrNotFound);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4871
		return;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4872
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4873
	iTimer = CPeriodic::NewL(CActive::EPriorityHigh);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4874
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4875
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4876
void RA3FDevSoundToneVolumeWhilePausePlayingTest::Fsm(TMmfDevSoundEvent aDevSoundEvent, TInt aError)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4877
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4878
	switch (iDevSoundState)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4879
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4880
		case EStateCreated:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4881
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4882
			__ASSERT_ALWAYS((aError == KErrNone), Panic(_L("RA3FDevSoundToneVolumeWhilePausePlayingTest"), EFsmIncorrectErrorPassed));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4883
			if (aDevSoundEvent == EEventInitialize)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4884
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4885
				INFO_PRINTF1(_L("Calling CMMFDevSound::InitializeL"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4886
				TRAPD(err, iMMFDevSound->InitializeL(*this, EMMFStateTonePlaying));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4887
				if (err != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4888
					{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4889
					ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"), err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4890
					StopTest(err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4891
					break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4892
					}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4893
				INFO_PRINTF1(_L("DevSound State: EStateInitializing"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4894
				iDevSoundState = EStateInitializing;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4895
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4896
			else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4897
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4898
				ERR_PRINTF2(_L("DevSound EEventInitialize not received as expected. Received event: %d"), aDevSoundEvent);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4899
				StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4900
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4901
			break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4902
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4903
		case EStateInitializing:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4904
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4905
			if (aDevSoundEvent == EEventInitComplete && aError == KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4906
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4907
				INFO_PRINTF3(_L("Calling CMMFDevSound::PlayToneL using %d Hz during %d secs "), iFrequencyTone1, iDuration);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4908
				TRAPD(err, iMMFDevSound->PlayToneL(iFrequencyTone1, iDuration*KMicroSecsInOneSec));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4909
				if (err != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4910
					{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4911
					ERR_PRINTF2(_L("CMMFDevSound::PlayToneL left with error : %d!"), err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4912
					StopTest(err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4913
					break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4914
					}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4915
				StartTimer(KMicroSecsTwoSec);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4916
				INFO_PRINTF1(_L("DevSound State: EStatePlaying"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4917
				iDevSoundState = EStatePlaying;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4918
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4919
			else if (aDevSoundEvent == EEventInitComplete && aError != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4920
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4921
				ERR_PRINTF2(_L("DevSound called CMMFDevSound::InitializeComplete with error = %d"), aError);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4922
				StopTest(aError);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4923
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4924
			else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4925
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4926
				ERR_PRINTF2(_L("DevSound EEventInitComplete not received as expected. Received event: %d"), aDevSoundEvent);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4927
				StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4928
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4929
			break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4930
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4931
		case EStatePlaying:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4932
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4933
			if(aDevSoundEvent == EEventTimerComplete)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4934
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4935
				INFO_PRINTF1(_L("Calling CMMFDevSound::Pause"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4936
				iMMFDevSound->Pause();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4937
				INFO_PRINTF1(_L("DevSound State: EStatePause"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4938
				iDevSoundState = EStatePause;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4939
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4940
			else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4941
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4942
				ERR_PRINTF2(_L("DevSound EEventTimerComplete not received as expected. Received event: %d"), aDevSoundEvent);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4943
				StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4944
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4945
			break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4946
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4947
		case EStatePause:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4948
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4949
			if(aDevSoundEvent == EEventTimerComplete)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4950
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4951
				INFO_PRINTF1(_L("Calling CMMFDevSound::Volume"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4952
				TInt maxVolumeGet = iMMFDevSound->Volume();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4953
				if (maxVolumeGet == iExVolume)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4954
					{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4955
					INFO_PRINTF2(_L("The device default supported volume value is %d."), maxVolumeGet);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4956
					StopTest();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4957
					}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4958
				else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4959
					{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4960
					INFO_PRINTF2(_L("The device default supported volume value failed with %d."), maxVolumeGet);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4961
					ERR_PRINTF2(_L("Expected value = %d."), iExVolume);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4962
					StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4963
					}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4964
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4965
			else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4966
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4967
				ERR_PRINTF2(_L("DevSound EEventTimerComplete not received as expected. Received event: %d"), aDevSoundEvent);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4968
				StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4969
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4970
			break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4971
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4972
		default:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4973
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4974
			ERR_PRINTF2(_L("Invalid DevSound state received: %d"), iDevSoundState);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4975
			StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4976
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4977
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4978
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4979
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4980
void RA3FDevSoundToneVolumeWhilePausePlayingTest::DoTimerCallback()
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4981
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4982
	INFO_PRINTF1(_L("TimerEvent called"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4983
	if(!iTimeToEnterPauseElapsed)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4984
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4985
		iTimeToEnterPauseElapsed = ETrue;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4986
		INFO_PRINTF1(_L("DevSound Event: EEventTimerComplete"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4987
		Fsm(EEventTimerComplete, KErrNone);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4988
		iTimeToEnterPauseElapsed = ETrue;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4989
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4990
	else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4991
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4992
		iTimer->Cancel();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4993
		INFO_PRINTF1(_L("DevSound Event: EEventTimerComplete"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4994
		Fsm(EEventTimerComplete, KErrNone);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4995
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4996
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4997
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4998
void RA3FDevSoundToneVolumeWhilePausePlayingTest::ToneFinished(TInt aError)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  4999
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5000
	INFO_PRINTF1(_L("========== DevSound ToneFinished() callback =========="));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5001
	ERR_PRINTF1(_L("DevSound should not have called ToneFinished because it is supposed to be paused then stopped"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5002
	StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5003
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5004
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5005
/*
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5006
 *========================================================================================================
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5007
 * MM-A3F-DEVSOUND-CHRTZ-TONE-0036
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5008
 */
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5009
RA3FDevSoundTonePlayToneOnceTest::RA3FDevSoundTonePlayToneOnceTest(const TDesC& aTestName)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5010
	:	RA3FDevSoundTestBase(aTestName),
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5011
		iDuration(0), iFrequencyTone1(0)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5012
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5013
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5014
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5015
RA3FDevSoundTonePlayToneOnceTest* RA3FDevSoundTonePlayToneOnceTest::NewL(const TDesC& aTestName)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5016
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5017
	RA3FDevSoundTonePlayToneOnceTest * self = new(ELeave)RA3FDevSoundTonePlayToneOnceTest(aTestName);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5018
	return self;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5019
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5020
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5021
void RA3FDevSoundTonePlayToneOnceTest::DoKickoffTestL()
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5022
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5023
	if (!GetIntFromConfig(iTestStepName, KDuration, iDuration))
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5024
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5025
		ERR_PRINTF2(KMsgErrorGetParameter, &KDuration);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5026
		StopTest(KErrNotFound);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5027
		return;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5028
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5029
	if (!GetIntFromConfig(iTestStepName, KFrequencyTone1, iFrequencyTone1))
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5030
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5031
		ERR_PRINTF2(KMsgErrorGetParameter, &KFrequencyTone1);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5032
		StopTest(KErrNotFound);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5033
		return;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5034
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5035
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5036
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5037
void RA3FDevSoundTonePlayToneOnceTest::Fsm(TMmfDevSoundEvent aDevSoundEvent, TInt aError)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5038
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5039
	switch (iDevSoundState)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5040
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5041
		case EStateCreated:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5042
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5043
			__ASSERT_ALWAYS((aError == KErrNone), Panic(_L("RA3FDevSoundTonePlayToneOnceTest"), EFsmIncorrectErrorPassed));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5044
			if (aDevSoundEvent == EEventInitialize)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5045
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5046
				INFO_PRINTF1(_L("Calling CMMFDevSound::InitializeL"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5047
				TRAPD(err, iMMFDevSound->InitializeL(*this, EMMFStateTonePlaying));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5048
				if (err != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5049
					{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5050
					ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"), err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5051
					StopTest(err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5052
					break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5053
					}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5054
				INFO_PRINTF1(_L("DevSound State: EStateInitializing"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5055
				iDevSoundState = EStateInitializing;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5056
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5057
			else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5058
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5059
				ERR_PRINTF2(_L("DevSound EEventInitialize not received as expected. Received event: %d"), aDevSoundEvent);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5060
				StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5061
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5062
			break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5063
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5064
		case EStateInitializing:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5065
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5066
			if (aDevSoundEvent == EEventInitComplete && aError == KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5067
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5068
				iMMFDevSound->SetVolume(iMMFDevSound->MaxVolume());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5069
				INFO_PRINTF3(_L("Calling CMMFDevSound::PlayToneL using %d Hz  during %d secs "), iFrequencyTone1, iDuration);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5070
				iStartTime.HomeTime();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5071
				TRAPD(err, iMMFDevSound->PlayToneL(iFrequencyTone1, iDuration*KMicroSecsInOneSec));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5072
				if (err != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5073
					{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5074
					ERR_PRINTF2(_L("CMMFDevSound::PlayToneL failed with error : %d!"), err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5075
					StopTest(err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5076
					}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5077
				INFO_PRINTF1(_L("DevSound State: EStatePlaying"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5078
				iDevSoundState = EStatePlaying;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5079
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5080
			else if (aDevSoundEvent == EEventInitComplete && aError != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5081
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5082
				ERR_PRINTF2(_L("DevSound called CMMFDevSound::InitializeComplete with error = %d"), aError);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5083
				StopTest(aError);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5084
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5085
			else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5086
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5087
				ERR_PRINTF2(_L("DevSound EEventInitComplete not received as expected. Received event: %d"), aDevSoundEvent);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5088
				StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5089
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5090
			break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5091
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5092
		default:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5093
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5094
			ERR_PRINTF2(_L("Invalid DevSound state received: %d"), iDevSoundState);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5095
			StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5096
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5097
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5098
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5099
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5100
void RA3FDevSoundTonePlayToneOnceTest::ToneFinished(TInt aError)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5101
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5102
	INFO_PRINTF1(_L("========== DevSound ToneFinished() callback =========="));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5103
	if (aError == KErrUnderflow)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5104
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5105
		iEndTime.HomeTime();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5106
		iPlayToneTime = iEndTime.MicroSecondsFrom(iStartTime);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5107
		TInt totalExpectedReproductionTime = iDuration * KMicroSecsInOneSec;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5108
		if(iPlayToneTime < totalExpectedReproductionTime + KPlayVarianceTime && iPlayToneTime > totalExpectedReproductionTime - KPlayVarianceTime)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5109
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5110
			INFO_PRINTF2(_L("Play time is %Ld microseconds"), iPlayToneTime.Int64());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5111
			StopTest();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5112
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5113
		else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5114
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5115
			ERR_PRINTF3(_L("Play time is %Ld microseconds and it should have been %d microseconds"), iPlayToneTime.Int64(), totalExpectedReproductionTime);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5116
			StopTest(KErrNone, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5117
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5118
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5119
	else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5120
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5121
		ERR_PRINTF2(_L("DevSound called ToneFinished with error = %d"), aError);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5122
		ERR_PRINTF2(_L("Expected error = %d"), KErrUnderflow);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5123
		StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5124
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5125
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5126
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5127
/*
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5128
 *========================================================================================================
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5129
 * MM-A3F-DEVSOUND-CHRTZ-TONE-0037
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5130
 */
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5131
RA3FDevSoundTonePlayDualToneTest::RA3FDevSoundTonePlayDualToneTest(const TDesC& aTestName)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5132
	:	RA3FDevSoundTestBase(aTestName),
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5133
		iDuration(0), iFrequencyTone1(0),
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5134
		iFrequencyTone2(0)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5135
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5136
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5137
RA3FDevSoundTonePlayDualToneTest* RA3FDevSoundTonePlayDualToneTest::NewL(const TDesC& aTestName)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5138
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5139
	RA3FDevSoundTonePlayDualToneTest * self = new(ELeave)RA3FDevSoundTonePlayDualToneTest(aTestName);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5140
	return self;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5141
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5142
void RA3FDevSoundTonePlayDualToneTest::DoKickoffTestL()
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5143
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5144
	if (!GetIntFromConfig(iTestStepName, KDuration, iDuration))
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5145
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5146
		ERR_PRINTF2(KMsgErrorGetParameter, &KDuration);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5147
		StopTest(KErrNotFound);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5148
		return;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5149
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5150
	if (!GetIntFromConfig(iTestStepName, KFrequencyTone1, iFrequencyTone1))
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5151
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5152
		ERR_PRINTF2(KMsgErrorGetParameter, &KFrequencyTone1);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5153
		StopTest(KErrNotFound);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5154
		return;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5155
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5156
	if (!GetIntFromConfig(iTestStepName, KFrequencyTone2, iFrequencyTone2))
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5157
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5158
		ERR_PRINTF2(KMsgErrorGetParameter, &KFrequencyTone2);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5159
		StopTest(KErrNotFound);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5160
		return;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5161
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5162
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5163
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5164
void RA3FDevSoundTonePlayDualToneTest::Fsm(TMmfDevSoundEvent aDevSoundEvent, TInt aError)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5165
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5166
	switch (iDevSoundState)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5167
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5168
		case EStateCreated:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5169
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5170
			__ASSERT_ALWAYS((aError == KErrNone), Panic(_L("RA3FDevSoundTonePlayDualToneTest"), EFsmIncorrectErrorPassed));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5171
			if (aDevSoundEvent == EEventInitialize)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5172
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5173
				INFO_PRINTF1(_L("Calling CMMFDevSound::InitializeL"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5174
				TRAPD(err, iMMFDevSound->InitializeL(*this, EMMFStateTonePlaying));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5175
				if (err != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5176
					{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5177
					ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"), err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5178
					StopTest(err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5179
					break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5180
					}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5181
				INFO_PRINTF1(_L("DevSound State: EStateInitializing"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5182
				iDevSoundState = EStateInitializing;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5183
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5184
			else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5185
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5186
				ERR_PRINTF2(_L("DevSound EEventInitialize not received as expected. Received event: %d"), aDevSoundEvent);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5187
				StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5188
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5189
			break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5190
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5191
		case EStateInitializing:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5192
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5193
			if (aDevSoundEvent == EEventInitComplete && aError == KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5194
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5195
				iMMFDevSound->SetVolume(iMMFDevSound->MaxVolume());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5196
				iStartTime.HomeTime();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5197
				INFO_PRINTF4(_L("Calling CMMFDevSound::PlayDualToneL using %d Hz %d Hz during %d secs "), iFrequencyTone1, iFrequencyTone2, iDuration);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5198
				TRAPD(err, iMMFDevSound->PlayDualToneL(iFrequencyTone1, iFrequencyTone2, iDuration*KMicroSecsInOneSec));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5199
				if (err != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5200
					{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5201
					ERR_PRINTF2(_L("CMMFDevSound::PlayDualToneL left with error : %d!"),  err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5202
					StopTest(err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5203
					break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5204
					}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5205
				INFO_PRINTF1(_L("DevSound State: EStatePlaying"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5206
				iDevSoundState = EStatePlaying;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5207
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5208
			else if (aDevSoundEvent == EEventInitComplete && aError != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5209
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5210
				ERR_PRINTF2(_L("DevSound called CMMFDevSound::InitializeComplete with error = %d"), aError);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5211
				StopTest(aError);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5212
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5213
			else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5214
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5215
				ERR_PRINTF2(_L("DevSound EEventInitComplete not received as expected. Received event: %d"), aDevSoundEvent);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5216
				StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5217
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5218
			break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5219
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5220
		default:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5221
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5222
			ERR_PRINTF2(_L("Invalid DevSound state received: %d"), iDevSoundState);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5223
			StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5224
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5225
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5226
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5227
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5228
void RA3FDevSoundTonePlayDualToneTest::ToneFinished(TInt aError)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5229
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5230
	INFO_PRINTF1(_L("========== DevSound ToneFinished() callback =========="));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5231
	if (aError == KErrUnderflow)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5232
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5233
		iEndTime.HomeTime();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5234
		iPlayToneTime = iEndTime.MicroSecondsFrom(iStartTime);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5235
		TInt totalExpectedReproductionTime = iDuration * KMicroSecsInOneSec;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5236
		if(iPlayToneTime < totalExpectedReproductionTime + KPlayVarianceTime && iPlayToneTime > totalExpectedReproductionTime - KPlayVarianceTime)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5237
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5238
			INFO_PRINTF2(_L("Play time is %Ld microseconds"), iPlayToneTime.Int64());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5239
			StopTest();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5240
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5241
		else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5242
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5243
			ERR_PRINTF3(_L("Play time is %Ld microseconds and it should have been %d microseconds"), iPlayToneTime.Int64(), totalExpectedReproductionTime);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5244
			StopTest(KErrNone, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5245
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5246
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5247
	else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5248
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5249
		ERR_PRINTF2(_L("DevSound called ToneFinished with error = %d"), aError);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5250
		ERR_PRINTF2(_L("Expected error = %d"), KErrUnderflow);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5251
		StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5252
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5253
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5254
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5255
/*
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5256
 *========================================================================================================
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5257
 * MM-A3F-DEVSOUND-CHRTZ-TONE-0038
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5258
 */
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5259
RA3FDevSoundTonePlayDTMFToneTest::RA3FDevSoundTonePlayDTMFToneTest(const TDesC& aTestName)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5260
	:	RA3FDevSoundTestBase(aTestName),iDTMFString(KNullDesC),
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5261
		iDTMFPauses(0), iDTMFTones(0)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5262
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5263
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5264
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5265
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5266
RA3FDevSoundTonePlayDTMFToneTest* RA3FDevSoundTonePlayDTMFToneTest::NewL(const TDesC& aTestName)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5267
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5268
	RA3FDevSoundTonePlayDTMFToneTest * self = new(ELeave)RA3FDevSoundTonePlayDTMFToneTest(aTestName);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5269
	return self;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5270
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5271
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5272
void RA3FDevSoundTonePlayDTMFToneTest::DoKickoffTestL()
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5273
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5274
	TPtrC DTMF;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5275
	if (!GetStringFromConfig(iTestStepName, KDTMFString, DTMF))
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5276
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5277
		ERR_PRINTF2(KMsgErrorGetParameter, &KDTMFString);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5278
		StopTest(KErrNotFound);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5279
		return;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5280
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5281
	iDTMFString.Copy(DTMF);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5282
	for(TInt i =0 ; i< iDTMFString.Length() ; i++)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5283
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5284
		if (iDTMFString[i] == ',')
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5285
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5286
			iDTMFPauses++;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5287
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5288
		else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5289
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5290
			iDTMFTones++;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5291
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5292
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5293
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5294
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5295
void RA3FDevSoundTonePlayDTMFToneTest::Fsm(TMmfDevSoundEvent aDevSoundEvent, TInt aError)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5296
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5297
	switch (iDevSoundState)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5298
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5299
		case EStateCreated:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5300
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5301
			__ASSERT_ALWAYS((aError == KErrNone), Panic(_L("RA3FDevSoundTonePlayDTMFToneTest"), EFsmIncorrectErrorPassed));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5302
			if (aDevSoundEvent == EEventInitialize)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5303
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5304
				INFO_PRINTF1(_L("Calling CMMFDevSound::InitializeL"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5305
				TRAPD(err, iMMFDevSound->InitializeL(*this, EMMFStateTonePlaying));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5306
				if (err != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5307
					{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5308
					ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"),  err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5309
					StopTest(err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5310
					break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5311
					}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5312
				INFO_PRINTF1(_L("DevSound State: EStateInitializing"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5313
				iDevSoundState = EStateInitializing;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5314
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5315
			else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5316
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5317
				ERR_PRINTF2(_L("DevSound EEventInitialize not received as expected. Received event: %d"), aDevSoundEvent);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5318
				StopTest(aError,  EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5319
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5320
			break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5321
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5322
		case EStateInitializing:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5323
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5324
			if (aDevSoundEvent == EEventInitComplete && aError == KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5325
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5326
				iMMFDevSound->SetVolume(iMMFDevSound->MaxVolume());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5327
				iStartTime.HomeTime();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5328
				INFO_PRINTF2(_L("Calling CMMFDevSound::PlayDTMFStringL %S"), &iDTMFString);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5329
				TRAPD(err, iMMFDevSound->PlayDTMFStringL(iDTMFString));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5330
				if (err != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5331
					{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5332
					ERR_PRINTF2(_L("CMMFDevSound::PlayDTMFStringL left with error : %d!"), err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5333
					StopTest(err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5334
					break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5335
					}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5336
				INFO_PRINTF1(_L("DevSound State: EStatePlaying"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5337
				iDevSoundState = EStatePlaying;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5338
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5339
			else if (aDevSoundEvent == EEventInitComplete && aError != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5340
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5341
				ERR_PRINTF2(_L("DevSound called CMMFDevSound::InitializeComplete with error = %d"), aError);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5342
				StopTest(aError);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5343
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5344
			else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5345
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5346
				ERR_PRINTF2(_L("DevSound EEventInitComplete not received as expected. Received event: %d"), aDevSoundEvent);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5347
				StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5348
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5349
			break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5350
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5351
		default:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5352
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5353
			ERR_PRINTF2(_L("Invalid DevSound state received: %d"), iDevSoundState);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5354
			StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5355
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5356
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5357
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5358
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5359
void RA3FDevSoundTonePlayDTMFToneTest::ToneFinished(TInt aError)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5360
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5361
	INFO_PRINTF1(_L("========== DevSound ToneFinished() callback =========="));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5362
	if (aError == KErrUnderflow)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5363
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5364
		iEndTime.HomeTime();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5365
		iPlayToneTime = iEndTime.MicroSecondsFrom(iStartTime);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5366
		TInt defaultToneOn = 250000;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5367
		TInt defaultToneOff = 50000;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5368
		TInt defaultPauseLength = 250000;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5369
		TInt totalExpectedReproductionTime = defaultToneOn*iDTMFTones + defaultToneOff * iDTMFTones + iDTMFPauses * defaultPauseLength;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5370
		if (iPlayToneTime < totalExpectedReproductionTime + KPlayVarianceTime && iPlayToneTime > totalExpectedReproductionTime - KPlayVarianceTime)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5371
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5372
			INFO_PRINTF2(_L("Play time is %Ld microseconds"), iPlayToneTime.Int64());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5373
			StopTest();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5374
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5375
		else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5376
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5377
			ERR_PRINTF2(_L("Calling CMMFDevSound::PlayDTMFStringL failed with %Ld"), iPlayToneTime.Int64());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5378
			ERR_PRINTF2(_L("Expected time %d"), totalExpectedReproductionTime);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5379
			StopTest(KErrNone, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5380
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5381
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5382
	else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5383
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5384
		ERR_PRINTF2(_L("DevSound called ToneFinished with error = %d"), aError);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5385
		ERR_PRINTF2(_L("Expected error = %d"), KErrUnderflow);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5386
		StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5387
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5388
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5389
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5390
/*
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5391
 *========================================================================================================
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5392
 * MM-A3F-DEVSOUND-CHRTZ-TONE-0039
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5393
 */
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5394
RA3FDevSoundTonePlayToneSequenceTest::RA3FDevSoundTonePlayToneSequenceTest(const TDesC& aTestName)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5395
	:	RA3FDevSoundTestBase(aTestName)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5396
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5397
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5398
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5399
RA3FDevSoundTonePlayToneSequenceTest* RA3FDevSoundTonePlayToneSequenceTest::NewL(const TDesC& aTestName)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5400
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5401
	RA3FDevSoundTonePlayToneSequenceTest * self = new(ELeave)RA3FDevSoundTonePlayToneSequenceTest(aTestName);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5402
	return self;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5403
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5404
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5405
void RA3FDevSoundTonePlayToneSequenceTest::DoKickoffTestL()
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5406
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5407
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5408
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5409
void RA3FDevSoundTonePlayToneSequenceTest::Fsm(TMmfDevSoundEvent aDevSoundEvent, TInt aError)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5410
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5411
	switch(iDevSoundState)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5412
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5413
		case EStateCreated:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5414
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5415
			__ASSERT_ALWAYS((aError == KErrNone), Panic(_L("RA3FDevSoundTonePlayToneSequenceTest"), EFsmIncorrectErrorPassed));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5416
			if (aDevSoundEvent == EEventInitialize)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5417
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5418
				INFO_PRINTF1(_L("Calling MMFDevSound::InitializeL"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5419
				TRAPD(err, iMMFDevSound->InitializeL(*this,  EMMFStateTonePlaying));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5420
				if (err != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5421
					{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5422
					ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"), err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5423
					StopTest(err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5424
					break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5425
					}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5426
				INFO_PRINTF1(_L("DevSound State: EStateInitializing"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5427
				iDevSoundState = EStateInitializing;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5428
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5429
			else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5430
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5431
				ERR_PRINTF2(_L("DevSound EEventInitialize not received as expected. Received event: %d"), aDevSoundEvent);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5432
				StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5433
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5434
			break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5435
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5436
		case EStateInitializing:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5437
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5438
			if (aDevSoundEvent == EEventInitComplete && aError == KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5439
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5440
				iMMFDevSound->SetVolume(iMMFDevSound->MaxVolume());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5441
				TUint8* tablePointer = const_cast<TUint8*>(&(KFixedSequenceTestSequenceDataX[0]));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5442
				TPtrC8 KFixedSequenceData(tablePointer, sizeof(KFixedSequenceTestSequenceDataX));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5443
				INFO_PRINTF1(_L("Calling CMMFDevSound::PlayToneSequenceL"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5444
				TRAPD(err, iMMFDevSound->PlayToneSequenceL(KFixedSequenceData));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5445
				if (err != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5446
					{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5447
					ERR_PRINTF2(_L("Play tone sequence failed with error = %d!"), err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5448
					StopTest(err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5449
					break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5450
					}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5451
				INFO_PRINTF1(_L("DevSound State: EStatePlaying"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5452
				iDevSoundState = EStatePlaying;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5453
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5454
			else if (aDevSoundEvent == EEventInitComplete && aError != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5455
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5456
				ERR_PRINTF2(_L("DevSound called CMMFDevSound::InitializeComplete with error = %d"), aError);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5457
				StopTest(aError);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5458
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5459
			else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5460
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5461
				ERR_PRINTF2(_L("DevSound EEventInitComplete not received as expected. Received event: %d"), aDevSoundEvent);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5462
				StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5463
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5464
			break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5465
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5466
		default:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5467
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5468
			ERR_PRINTF2(_L("Invalid DevSound state received: %d"), iDevSoundState);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5469
			StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5470
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5471
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5472
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5473
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5474
/*
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5475
 *========================================================================================================
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5476
 * MM-A3F-DEVSOUND-CHRTZ-TONE-0040
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5477
 */
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5478
RA3FDevSoundToneNewToneRequestWhilePlayingTest::RA3FDevSoundToneNewToneRequestWhilePlayingTest(const TDesC& aTestName)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5479
	:	RA3FDevSoundTestBase(aTestName),
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5480
		iDuration(0), iFrequencyTone1(0)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5481
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5482
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5483
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5484
RA3FDevSoundToneNewToneRequestWhilePlayingTest* RA3FDevSoundToneNewToneRequestWhilePlayingTest::NewL(const TDesC& aTestName)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5485
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5486
	RA3FDevSoundToneNewToneRequestWhilePlayingTest * self = new(ELeave)RA3FDevSoundToneNewToneRequestWhilePlayingTest(aTestName);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5487
	return self;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5488
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5489
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5490
void RA3FDevSoundToneNewToneRequestWhilePlayingTest::DoKickoffTestL()
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5491
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5492
	if (!GetIntFromConfig(iTestStepName, KDuration, iDuration))
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5493
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5494
		ERR_PRINTF2(KMsgErrorGetParameter, &KDuration);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5495
		StopTest(KErrNotFound);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5496
		return;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5497
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5498
	if (!GetIntFromConfig(iTestStepName, KFrequencyTone1, iFrequencyTone1))
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5499
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5500
		ERR_PRINTF2(KMsgErrorGetParameter, &KFrequencyTone1);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5501
		StopTest(KErrNotFound);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5502
		return;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5503
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5504
	iTimer = CPeriodic::NewL(CActive::EPriorityHigh);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5505
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5506
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5507
void RA3FDevSoundToneNewToneRequestWhilePlayingTest::Fsm(TMmfDevSoundEvent aDevSoundEvent, TInt aError)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5508
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5509
	switch (iDevSoundState)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5510
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5511
		case EStateCreated:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5512
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5513
			if (aDevSoundEvent == EEventInitialize)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5514
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5515
				__ASSERT_ALWAYS((aError == KErrNone), Panic(_L("RA3FDevSoundToneNewToneRequestWhilePlayingTest"), EFsmIncorrectErrorPassed));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5516
				INFO_PRINTF1(_L("Calling CMMFDevSound::InitializeL"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5517
				TRAPD(err, iMMFDevSound->InitializeL(*this, EMMFStateTonePlaying));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5518
				if (err != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5519
					{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5520
					ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"), err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5521
					StopTest(err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5522
					break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5523
					}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5524
				INFO_PRINTF1(_L("DevSound State: EStateInitializing"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5525
				iDevSoundState = EStateInitializing;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5526
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5527
			else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5528
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5529
				ERR_PRINTF2(_L("DevSound EEventInitialize not received as expected. Received event: %d"), aDevSoundEvent);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5530
				StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5531
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5532
			break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5533
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5534
		case EStateInitializing:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5535
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5536
			if (aDevSoundEvent == EEventInitComplete && aError == KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5537
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5538
				iMMFDevSound->SetVolume(iMMFDevSound->MaxVolume());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5539
				iStartTime.HomeTime();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5540
				INFO_PRINTF3(_L("Calling CMMFDevSound::PlayToneL using %d Hz during %d secs "), iFrequencyTone1, iDuration);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5541
				TRAPD(err, iMMFDevSound->PlayToneL(iFrequencyTone1, iDuration*KMicroSecsInOneSec));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5542
				if (err != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5543
					{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5544
					ERR_PRINTF2(_L("CMMFDevSound::PlayToneL left with error : %d!"), err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5545
					StopTest(err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5546
					break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5547
					}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5548
				StartTimer(KMicroSecsTwoSec);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5549
				INFO_PRINTF1(_L("DevSound State: EStatePlaying"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5550
				iDevSoundState = EStatePlaying;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5551
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5552
			else if (aDevSoundEvent == EEventInitComplete && aError != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5553
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5554
				ERR_PRINTF2(_L("DevSound called CMMFDevSound::InitializeComplete with error = %d"), aError);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5555
				StopTest(aError);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5556
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5557
			else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5558
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5559
				ERR_PRINTF2(_L("DevSound EEventInitComplete not received as expected. Received event: %d"), aDevSoundEvent);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5560
				StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5561
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5562
			break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5563
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5564
		case EStatePlaying:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5565
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5566
			if(aDevSoundEvent == EEventTimerComplete)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5567
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5568
				INFO_PRINTF3(_L("Calling CMMFDevSound::PlayToneL using %d Hz during %d secs "), iFrequencyTone1, iDuration);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5569
				TRAPD(err, iMMFDevSound->PlayToneL(iFrequencyTone1, iDuration*KMicroSecsInOneSec));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5570
				if (err == KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5571
					{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5572
					INFO_PRINTF2(_L("CMMFDevSound::PlayToneL left with the expected error = %d"), err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5573
					}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5574
				else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5575
					{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5576
					ERR_PRINTF2(_L("CMMFDevSound::PlayToneL left with error = %d"), err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5577
					ERR_PRINTF2(_L("Expected error value = %d!"), KErrNotReady);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5578
					StopTest(err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5579
					break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5580
					}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5581
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5582
			break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5583
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5584
		default:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5585
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5586
			ERR_PRINTF2(_L("Invalid DevSound state received: %d"), iDevSoundState);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5587
			StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5588
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5589
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5590
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5591
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5592
void RA3FDevSoundToneNewToneRequestWhilePlayingTest::DoTimerCallback()
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5593
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5594
	INFO_PRINTF1(_L("TimerEvent called"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5595
	iTimer->Cancel();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5596
	INFO_PRINTF1(_L("DevSound Event: EEventTimerComplete"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5597
	Fsm(EEventTimerComplete, KErrNone);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5598
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5599
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5600
void RA3FDevSoundToneNewToneRequestWhilePlayingTest::ToneFinished(TInt aError)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5601
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5602
	INFO_PRINTF1(_L("========== DevSound ToneFinished() callback =========="));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5603
	if (aError == KErrUnderflow)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5604
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5605
		iEndTime.HomeTime();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5606
		iPlayToneTime = iEndTime.MicroSecondsFrom(iStartTime);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5607
		TInt totalExpectedReproductionTime = iDuration * KMicroSecsInOneSec;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5608
		if(iPlayToneTime < totalExpectedReproductionTime + KPlayVarianceTime && iPlayToneTime > totalExpectedReproductionTime - KPlayVarianceTime)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5609
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5610
			INFO_PRINTF2(_L("Play time is %Ld microseconds"), iPlayToneTime.Int64());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5611
			StopTest();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5612
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5613
		else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5614
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5615
			ERR_PRINTF3(_L("Play time is %Ld microseconds and it should have been %d microseconds"), iPlayToneTime.Int64(), totalExpectedReproductionTime);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5616
			StopTest(KErrNone, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5617
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5618
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5619
	else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5620
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5621
		ERR_PRINTF2(_L("DevSound called ToneFinished with error = %d"), aError);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5622
		ERR_PRINTF2(_L("Expected error = %d"), KErrUnderflow);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5623
		StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5624
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5625
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5626
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5627
/*
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5628
 *========================================================================================================
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5629
 * MM-A3F-DEVSOUND-CHRTZ-TONE-0041
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5630
 */
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5631
RA3FDevSoundTonePreemptionTest::RA3FDevSoundTonePreemptionTest(const TDesC& aTestName)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5632
	:	RA3FDevSoundTestBase(aTestName),
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5633
		iDuration(0), iFrequencyTone1(0)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5634
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5635
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5636
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5637
RA3FDevSoundTonePreemptionTest* RA3FDevSoundTonePreemptionTest::NewL(const TDesC& aTestName)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5638
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5639
	RA3FDevSoundTonePreemptionTest * self = new(ELeave)RA3FDevSoundTonePreemptionTest(aTestName);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5640
	return self;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5641
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5642
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5643
void RA3FDevSoundTonePreemptionTest::DoKickoffTestL()
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5644
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5645
	if (!GetIntFromConfig(iTestStepName, KDuration, iDuration))
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5646
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5647
		ERR_PRINTF2(KMsgErrorGetParameter, &KDuration);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5648
		StopTest(KErrNotFound);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5649
		return;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5650
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5651
	if (!GetIntFromConfig(iTestStepName, KFrequencyTone1, iFrequencyTone1))
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5652
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5653
		ERR_PRINTF2(KMsgErrorGetParameter, &KFrequencyTone1);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5654
		StopTest(KErrNotFound);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5655
		return;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5656
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5657
	iTimer = CPeriodic::NewL(CActive::EPriorityHigh);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5658
	iDevsoundToneClient = CA3FDevSoundToneClient::NewL(*this);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5659
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5660
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5661
void RA3FDevSoundTonePreemptionTest::Fsm(TMmfDevSoundEvent aDevSoundEvent, TInt aError)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5662
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5663
	switch (iDevSoundState)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5664
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5665
		case EStateCreated:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5666
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5667
			if (aDevSoundEvent == EEventInitialize)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5668
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5669
				__ASSERT_ALWAYS((aError == KErrNone), Panic(_L("RA3FDevSoundTonePreemptionTest"), EFsmIncorrectErrorPassed));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5670
				INFO_PRINTF1(_L("Calling CMMFDevSound::InitializeL"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5671
				TRAPD(err, iMMFDevSound->InitializeL(*this, EMMFStateTonePlaying));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5672
				if (err != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5673
					{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5674
					ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"), err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5675
					StopTest(err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5676
					break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5677
					}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5678
				INFO_PRINTF1(_L("DevSound State: EStateInitializing"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5679
				iDevSoundState = EStateInitializing;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5680
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5681
			else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5682
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5683
				ERR_PRINTF2(_L("DevSound EEventInitialize not received as expected. Received event: %d"), aDevSoundEvent);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5684
				StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5685
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5686
			break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5687
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5688
		case EStateInitializing:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5689
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5690
			if (aDevSoundEvent == EEventInitComplete && aError == KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5691
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5692
				iMMFDevSound->SetVolume(iMMFDevSound->MaxVolume());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5693
				TMMFPrioritySettings prioritySettings;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5694
				prioritySettings.iPriority = KMinimumPriority;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5695
				prioritySettings.iPref = EMdaPriorityPreferenceTime;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5696
				prioritySettings.iState = EMMFStateIdle;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5697
				iMMFDevSound->SetPrioritySettings(prioritySettings);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5698
				INFO_PRINTF3(_L("Calling CMMFDevSound::PlayToneL using %d Hz during %d secs "), iFrequencyTone1, iDuration);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5699
				TRAPD(err, iMMFDevSound->PlayToneL(iFrequencyTone1, iDuration*KMicroSecsInOneSec));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5700
				if (err != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5701
					{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5702
					ERR_PRINTF2(_L("CMMFDevSound::PlayToneL left with error : %d!"), err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5703
					StopTest(err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5704
					break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5705
					}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5706
				StartTimer(KMicroSecsTwoSec);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5707
				INFO_PRINTF1(_L("DevSound State: EStatePlaying"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5708
				iDevSoundState = EStatePlaying;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5709
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5710
			else if (aDevSoundEvent == EEventInitComplete && aError != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5711
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5712
				ERR_PRINTF2(_L("DevSound called CMMFDevSound::InitializeComplete with error = %d"), aError);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5713
				StopTest(aError);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5714
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5715
			else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5716
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5717
				ERR_PRINTF2(_L("DevSound EEventInitComplete not received as expected. Received event: %d"), aDevSoundEvent);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5718
				StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5719
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5720
			break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5721
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5722
		case EStatePlaying:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5723
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5724
			if(aDevSoundEvent == EEventTimerComplete)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5725
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5726
				INFO_PRINTF1(_L("Starting lower priority devsound client"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5727
				iDevsoundToneClient->SetPriority(KMaximumPriority);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5728
				TInt err = iDevsoundToneClient->InitTonePlay(iFrequencyTone1, iDuration*KMicroSecsInOneSec);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5729
				if(err != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5730
					{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5731
					ERR_PRINTF1(_L("Initialization to play tone thru second devsound client failed"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5732
					StopTest(err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5733
					}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5734
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5735
			break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5736
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5737
		default:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5738
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5739
			ERR_PRINTF2(_L("Invalid DevSound state received: %d"), iDevSoundState);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5740
			StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5741
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5742
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5743
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5744
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5745
void RA3FDevSoundTonePreemptionTest::DoTimerCallback()
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5746
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5747
	INFO_PRINTF1(_L("TimerEvent called"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5748
	iTimer->Cancel();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5749
	INFO_PRINTF1(_L("DevSound Event: EEventTimerComplete"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5750
	Fsm(EEventTimerComplete, KErrNone);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5751
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5752
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5753
void RA3FDevSoundTonePreemptionTest::ToneFinished(TInt aError)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5754
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5755
	INFO_PRINTF1(_L("========== DevSound ToneFinished() callback =========="));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5756
	if (aError == KErrInUse || aError == KErrDied || aError == KErrAccessDenied)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5757
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5758
		INFO_PRINTF1(_L("========== Preempting 1st DevSound Instance=========="));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5759
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5760
	else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5761
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5762
		ERR_PRINTF2(_L("First DevSound client called ToneFinished() and failed with error = %d "), aError);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5763
		ERR_PRINTF4(_L("Expected posibilities %d %d %d "), KErrInUse, KErrDied, KErrAccessDenied);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5764
		StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5765
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5766
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5767
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5768
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5769
void RA3FDevSoundTonePreemptionTest::ClientInitializeCompleteCallback(TInt aError)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5770
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5771
	INFO_PRINTF1(_L("========== Second Client DevSound InitializeComplete() callback =========="));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5772
	if (aError != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5773
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5774
		ERR_PRINTF2(_L("Second Devsound InitializeComplete received an error = %d"), aError);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5775
		StopTest(aError);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5776
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5777
	else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5778
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5779
		INFO_PRINTF1(_L("Starting to play audio thru second devsound client"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5780
		TInt err = iDevsoundToneClient->PlayTone();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5781
		if (err != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5782
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5783
			ERR_PRINTF2(_L("Starting to play tones thru second devsound client left with error = %d"), err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5784
			StopTest(err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5785
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5786
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5787
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5788
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5789
void RA3FDevSoundTonePreemptionTest::ClientToneFinishedCallback(TInt aError)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5790
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5791
	INFO_PRINTF1(_L("========== DevSound ToneFinished() callback =========="));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5792
		if (aError == KErrUnderflow)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5793
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5794
			INFO_PRINTF2(_L("Second DevSound instance called ToneFinished with error = %d"), aError);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5795
			StopTest(aError,EPass);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5796
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5797
		else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5798
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5799
			ERR_PRINTF2(_L("Second DevSound instance called ToneFinished with error = %d that was NOT expected"), aError);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5800
			ERR_PRINTF2(_L("Expected error = %d"), aError);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5801
			StopTest(aError);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5802
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5803
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5804
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5805
/*
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5806
 *========================================================================================================
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5807
 * MM-A3F-DEVSOUND-CHRTZ-TONE-0042
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5808
 */
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5809
RA3FDevSoundToneRejectionTest::RA3FDevSoundToneRejectionTest(const TDesC& aTestName)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5810
	:	RA3FDevSoundTestBase(aTestName),
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5811
		iDuration(0), iFrequencyTone1(0)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5812
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5813
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5814
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5815
RA3FDevSoundToneRejectionTest* RA3FDevSoundToneRejectionTest::NewL(const TDesC& aTestName)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5816
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5817
	RA3FDevSoundToneRejectionTest * self = new(ELeave)RA3FDevSoundToneRejectionTest(aTestName);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5818
	return self;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5819
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5820
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5821
void RA3FDevSoundToneRejectionTest::DoKickoffTestL()
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5822
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5823
	if (!GetIntFromConfig(iTestStepName, KDuration, iDuration))
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5824
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5825
		ERR_PRINTF2(KMsgErrorGetParameter, &KDuration);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5826
		StopTest(KErrNotFound);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5827
		return;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5828
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5829
	if (!GetIntFromConfig(iTestStepName, KFrequencyTone1, iFrequencyTone1))
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5830
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5831
		ERR_PRINTF2(KMsgErrorGetParameter, &KFrequencyTone1);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5832
		StopTest(KErrNotFound);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5833
		return;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5834
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5835
	iTimer = CPeriodic::NewL(CActive::EPriorityHigh);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5836
	iDevsoundToneClient = CA3FDevSoundToneClient::NewL(*this);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5837
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5838
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5839
void RA3FDevSoundToneRejectionTest::Fsm(TMmfDevSoundEvent aDevSoundEvent, TInt aError)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5840
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5841
	switch (iDevSoundState)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5842
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5843
		case EStateCreated:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5844
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5845
			if (aDevSoundEvent == EEventInitialize)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5846
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5847
				__ASSERT_ALWAYS((aError == KErrNone), Panic(_L("RA3FDevSoundToneRejectionTest"), EFsmIncorrectErrorPassed));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5848
				INFO_PRINTF1(_L("Calling CMMFDevSound::InitializeL"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5849
				TRAPD(err, iMMFDevSound->InitializeL(*this, EMMFStateTonePlaying));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5850
				if (err != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5851
					{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5852
					ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"), err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5853
					StopTest(err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5854
					break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5855
					}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5856
				INFO_PRINTF1(_L("DevSound State: EStateInitializing"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5857
				iDevSoundState = EStateInitializing;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5858
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5859
			else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5860
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5861
				ERR_PRINTF2(_L("DevSound EEventInitialize not received as expected. Received event: %d"), aDevSoundEvent);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5862
				StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5863
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5864
			break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5865
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5866
		case EStateInitializing:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5867
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5868
			if (aDevSoundEvent == EEventInitComplete && aError == KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5869
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5870
				iMMFDevSound->SetVolume(iMMFDevSound->MaxVolume());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5871
				TMMFPrioritySettings prioritySettings;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5872
				prioritySettings.iPriority = KMinimumPriority;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5873
				prioritySettings.iPref = EMdaPriorityPreferenceTime;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5874
				prioritySettings.iState = EMMFStateIdle;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5875
				iMMFDevSound->SetPrioritySettings(prioritySettings);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5876
				INFO_PRINTF3(_L("Calling CMMFDevSound::PlayToneL using %d Hz during %d secs "), iFrequencyTone1, iDuration);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5877
				TRAPD(err, iMMFDevSound->PlayToneL(iFrequencyTone1, iDuration*KMicroSecsInOneSec));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5878
				if (err != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5879
					{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5880
					ERR_PRINTF2(_L("CMMFDevSound::PlayToneL left with error : %d!"), err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5881
					StopTest(err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5882
					break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5883
					}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5884
				StartTimer(KMicroSecsTwoSec);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5885
				INFO_PRINTF1(_L("DevSound State: EStatePlaying"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5886
				iDevSoundState = EStatePlaying;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5887
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5888
			else if (aDevSoundEvent == EEventInitComplete && aError != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5889
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5890
				ERR_PRINTF2(_L("DevSound called CMMFDevSound::InitializeComplete with error = %d"), aError);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5891
				StopTest(aError);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5892
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5893
			else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5894
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5895
				ERR_PRINTF2(_L("DevSound EEventInitComplete not received as expected. Received event: %d"), aDevSoundEvent);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5896
				StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5897
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5898
			break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5899
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5900
		case EStatePlaying:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5901
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5902
			if(aDevSoundEvent == EEventTimerComplete)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5903
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5904
				INFO_PRINTF1(_L("Starting lower priority devsound client"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5905
				iDevsoundToneClient->SetPriority(KMinimumPriority);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5906
				TInt err = iDevsoundToneClient->InitTonePlay(iFrequencyTone1, iDuration*KMicroSecsInOneSec);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5907
				if(err != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5908
					{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5909
					ERR_PRINTF1(_L("Initialization to play tone thru second devsound client failed"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5910
					StopTest(err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5911
					}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5912
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5913
			break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5914
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5915
		default:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5916
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5917
			ERR_PRINTF2(_L("Invalid DevSound state received: %d"), iDevSoundState);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5918
			StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5919
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5920
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5921
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5922
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5923
void RA3FDevSoundToneRejectionTest::DoTimerCallback()
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5924
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5925
	INFO_PRINTF1(_L("TimerEvent called"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5926
	iTimer->Cancel();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5927
	INFO_PRINTF1(_L("DevSound Event: EEventTimerComplete"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5928
	Fsm(EEventTimerComplete, KErrNone);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5929
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5930
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5931
void RA3FDevSoundToneRejectionTest::ToneFinished(TInt aError)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5932
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5933
	INFO_PRINTF1(_L("========== DevSound ToneFinished() callback =========="));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5934
	if (aError == KErrUnderflow)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5935
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5936
		INFO_PRINTF2(_L("First DevSound instance called ToneFinished with error = %d"), aError);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5937
		StopTest(aError,EPass);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5938
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5939
	else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5940
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5941
		ERR_PRINTF2(_L("First DevSound instance called ToneFinished with error = %d that was NOT expected"), aError);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5942
		ERR_PRINTF2(_L("Expected error = %d"), aError);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5943
		StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5944
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5945
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5946
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5947
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5948
void RA3FDevSoundToneRejectionTest::ClientInitializeCompleteCallback(TInt aError)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5949
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5950
	INFO_PRINTF1(_L("========== Second Client DevSound InitializeComplete() callback =========="));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5951
	if (aError != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5952
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5953
		ERR_PRINTF2(_L("Second Devsound InitializeComplete received an error = %d"), aError);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5954
		StopTest(aError);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5955
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5956
	else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5957
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5958
		INFO_PRINTF1(_L("Starting to play audio thru second devsound client"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5959
		TInt err = iDevsoundToneClient->PlayTone();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5960
		if (err != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5961
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5962
			ERR_PRINTF2(_L("Starting to play tones thru second devsound client left with error = %d"), err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5963
			StopTest(err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5964
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5965
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5966
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5967
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5968
void RA3FDevSoundToneRejectionTest::ClientToneFinishedCallback(TInt aError)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5969
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5970
	INFO_PRINTF1(_L("========== DevSound ToneFinished() callback =========="));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5971
	if (aError == KErrInUse || aError == KErrDied || aError == KErrAccessDenied)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5972
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5973
		INFO_PRINTF1(_L("========== Rejection 2nd DevSound Instance=========="));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5974
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5975
	else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5976
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5977
		ERR_PRINTF2(_L("Second DevSound client called ToneFinished() and failed with error = %d "), aError);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5978
		ERR_PRINTF4(_L("Expected posibilities %d %d %d "), KErrInUse, KErrDied, KErrAccessDenied);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5979
		StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5980
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5981
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5982
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5983
/*
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5984
 *========================================================================================================
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5985
 * MM-A3F-DEVSOUND-CHRTZ-TONE-0043
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5986
 */
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5987
RA3FDevSoundTonePlayToneOnceAndStopTest::RA3FDevSoundTonePlayToneOnceAndStopTest(const TDesC& aTestName)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5988
	:	RA3FDevSoundTestBase(aTestName),
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5989
		iDuration(0), iFrequencyTone1(0),
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5990
		iToneStopped(EFalse)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5991
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5992
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5993
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5994
RA3FDevSoundTonePlayToneOnceAndStopTest* RA3FDevSoundTonePlayToneOnceAndStopTest::NewL(const TDesC& aTestName)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5995
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5996
	RA3FDevSoundTonePlayToneOnceAndStopTest * self = new(ELeave)RA3FDevSoundTonePlayToneOnceAndStopTest(aTestName);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5997
	return self;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5998
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  5999
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6000
void RA3FDevSoundTonePlayToneOnceAndStopTest::DoKickoffTestL()
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6001
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6002
	if (!GetIntFromConfig(iTestStepName, KDuration, iDuration))
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6003
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6004
		ERR_PRINTF2(KMsgErrorGetParameter, &KDuration);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6005
		StopTest(KErrNotFound);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6006
		return;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6007
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6008
	if (!GetIntFromConfig(iTestStepName, KFrequencyTone1, iFrequencyTone1))
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6009
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6010
		ERR_PRINTF2(KMsgErrorGetParameter, &KFrequencyTone1);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6011
		StopTest(KErrNotFound);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6012
		return;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6013
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6014
	iTimer = CPeriodic::NewL(CActive::EPriorityHigh);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6015
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6016
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6017
void RA3FDevSoundTonePlayToneOnceAndStopTest::Fsm(TMmfDevSoundEvent aDevSoundEvent, TInt aError)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6018
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6019
	switch (iDevSoundState)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6020
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6021
		case EStateCreated:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6022
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6023
			__ASSERT_ALWAYS((aError == KErrNone), Panic(_L("RA3FDevSoundTonePlayToneOnceAndStopTest"), EFsmIncorrectErrorPassed));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6024
			if (aDevSoundEvent == EEventInitialize)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6025
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6026
				INFO_PRINTF1(_L("Calling CMMFDevSound::InitializeL"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6027
				TRAPD(err, iMMFDevSound->InitializeL(*this,  EMMFStateTonePlaying));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6028
				if (err != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6029
					{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6030
					ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"),  err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6031
					StopTest(err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6032
					break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6033
					}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6034
				INFO_PRINTF1(_L("DevSound State: EStateInitializing"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6035
				iDevSoundState = EStateInitializing;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6036
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6037
			else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6038
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6039
				ERR_PRINTF2(_L("DevSound EEventInitialize not received as expected. Received event: %d"), aDevSoundEvent);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6040
				StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6041
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6042
			break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6043
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6044
		case EStateInitializing:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6045
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6046
			if (aDevSoundEvent == EEventInitComplete && aError == KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6047
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6048
				if (!iToneStopped)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6049
					{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6050
					iMMFDevSound->SetVolume(iMMFDevSound->MaxVolume());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6051
					INFO_PRINTF3(_L("Calling CMMFDevSound::PlayToneL using %d Hz during %d secs "), iFrequencyTone1, iDuration);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6052
					TRAPD(err, iMMFDevSound->PlayToneL(iFrequencyTone1, iDuration*KMicroSecsInOneSec));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6053
					if (err != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6054
						{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6055
						ERR_PRINTF2(_L("CMMFDevSound::PlayToneL left with error : %d!"), err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6056
						StopTest(err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6057
						break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6058
						}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6059
					StartTimer(KMicroSecsTwoSec);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6060
					INFO_PRINTF1(_L("DevSound State: EStatePlaying"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6061
					iDevSoundState = EStatePlaying;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6062
					}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6063
				else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6064
					{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6065
					INFO_PRINTF1(_L("Calling CMMFDevSound::Stop succeeded"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6066
					StopTest(aError);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6067
					}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6068
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6069
			else if (aDevSoundEvent == EEventInitComplete && aError != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6070
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6071
				ERR_PRINTF2(_L("DevSound called CMMFDevSound::InitializeComplete with error = %d"), aError);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6072
				StopTest(aError);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6073
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6074
			else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6075
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6076
				ERR_PRINTF2(_L("DevSound EEventInitComplete not received as expected. Received event: %d"), aDevSoundEvent);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6077
				StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6078
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6079
			break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6080
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6081
		case EStatePlaying:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6082
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6083
			if(aDevSoundEvent == EEventTimerComplete)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6084
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6085
				INFO_PRINTF1(_L("Calling CMMFDevSound::Stop"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6086
				iMMFDevSound->Stop();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6087
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6088
			else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6089
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6090
				ERR_PRINTF2(_L("DevSound EEventTimerComplete not received as expected. Received event: %d"), aDevSoundEvent);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6091
				StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6092
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6093
			break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6094
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6095
		default:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6096
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6097
			ERR_PRINTF2(_L("Invalid DevSound state received: %d"), iDevSoundState);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6098
			StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6099
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6100
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6101
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6102
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6103
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6104
void RA3FDevSoundTonePlayToneOnceAndStopTest::DoTimerCallback()
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6105
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6106
	INFO_PRINTF1(_L("TimerEvent called"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6107
	INFO_PRINTF1(_L("DevSound Event: EEventTimerComplete"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6108
	if(!iToneStopped)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6109
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6110
		Fsm(EEventTimerComplete, KErrNone);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6111
		iToneStopped = ETrue;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6112
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6113
	else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6114
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6115
		iTimer->Cancel();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6116
		INFO_PRINTF1(_L("Calling CMMFDevSound::InitializeL"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6117
		TRAPD(err, iMMFDevSound->InitializeL(*this, EMMFStateTonePlaying));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6118
		if (err != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6119
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6120
			ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"),  err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6121
			ERR_PRINTF2(_L("Expected error = %d"), KErrNone);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6122
			StopTest(err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6123
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6124
		INFO_PRINTF1(_L("DevSound State: EStateInitializing"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6125
		iDevSoundState = EStateInitializing;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6126
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6127
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6128
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6129
void RA3FDevSoundTonePlayToneOnceAndStopTest::ToneFinished(TInt aError)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6130
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6131
	INFO_PRINTF1(_L("========== DevSound ToneFinished() callback =========="));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6132
	ERR_PRINTF1(_L("DevSound should not have called ToneFinished because it is supposed to have been stopped"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6133
	StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6134
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6135
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6136
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6137
/*
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6138
 *========================================================================================================
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6139
 * MM-A3F-DEVSOUND-CHRTZ-TONE-0044
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6140
 */
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6141
RA3FDevSoundTonePlayDualToneOnceAndStopTest::RA3FDevSoundTonePlayDualToneOnceAndStopTest(const TDesC& aTestName)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6142
	:	RA3FDevSoundTestBase(aTestName),
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6143
		iDuration(0), iFrequencyTone1(0),
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6144
		iFrequencyTone2(0), iToneStopped(EFalse)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6145
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6146
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6147
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6148
RA3FDevSoundTonePlayDualToneOnceAndStopTest* RA3FDevSoundTonePlayDualToneOnceAndStopTest::NewL(const TDesC& aTestName)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6149
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6150
	RA3FDevSoundTonePlayDualToneOnceAndStopTest * self = new(ELeave)RA3FDevSoundTonePlayDualToneOnceAndStopTest(aTestName);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6151
	return self;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6152
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6153
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6154
void RA3FDevSoundTonePlayDualToneOnceAndStopTest::DoKickoffTestL()
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6155
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6156
	if (!GetIntFromConfig(iTestStepName, KDuration, iDuration))
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6157
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6158
		ERR_PRINTF2(KMsgErrorGetParameter, &KDuration);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6159
		StopTest(KErrNotFound);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6160
		return;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6161
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6162
	if (!GetIntFromConfig(iTestStepName, KFrequencyTone1, iFrequencyTone1))
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6163
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6164
		ERR_PRINTF2(KMsgErrorGetParameter, &KFrequencyTone1);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6165
		StopTest(KErrNotFound);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6166
		return;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6167
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6168
	if (!GetIntFromConfig(iTestStepName, KFrequencyTone2, iFrequencyTone2))
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6169
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6170
		ERR_PRINTF2(KMsgErrorGetParameter, &KFrequencyTone2);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6171
		StopTest(KErrNotFound);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6172
		return;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6173
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6174
	iTimer = CPeriodic::NewL(CActive::EPriorityHigh);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6175
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6176
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6177
void RA3FDevSoundTonePlayDualToneOnceAndStopTest::Fsm(TMmfDevSoundEvent aDevSoundEvent, TInt aError)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6178
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6179
	switch (iDevSoundState)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6180
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6181
		case EStateCreated:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6182
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6183
			__ASSERT_ALWAYS((aError == KErrNone), Panic(_L("RA3FDevSoundTonePlayDualToneOnceAndStopTest"), EFsmIncorrectErrorPassed));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6184
			if (aDevSoundEvent == EEventInitialize)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6185
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6186
				INFO_PRINTF1(_L("Calling CMMFDevSound::InitializeL"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6187
				TRAPD(err, iMMFDevSound->InitializeL(*this, EMMFStateTonePlaying));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6188
				if (err != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6189
					{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6190
					ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"),  err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6191
					StopTest(err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6192
					break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6193
					}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6194
				INFO_PRINTF1(_L("DevSound State: EStateInitializing"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6195
				iDevSoundState = EStateInitializing;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6196
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6197
			else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6198
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6199
				ERR_PRINTF2(_L("DevSound EEventInitialize not received as expected. Received event: %d"), aDevSoundEvent);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6200
				StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6201
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6202
			break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6203
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6204
		case EStateInitializing:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6205
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6206
			if (aDevSoundEvent == EEventInitComplete && aError == KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6207
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6208
				if (!iToneStopped)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6209
					{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6210
					iMMFDevSound->SetVolume(iMMFDevSound->MaxVolume());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6211
					INFO_PRINTF4(_L("Calling CMMFDevSound::PlayDualToneL using %d Hz %d Hz during %d secs "), iFrequencyTone1, iFrequencyTone2, iDuration);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6212
					TRAPD(err, iMMFDevSound->PlayDualToneL(iFrequencyTone1, iFrequencyTone2, iDuration*KMicroSecsInOneSec));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6213
					if (err != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6214
						{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6215
						ERR_PRINTF2(_L("CMMFDevSound::PlayDualToneL left with error = %d!"),  err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6216
						StopTest(err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6217
						break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6218
						}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6219
					StartTimer(KMicroSecsTwoSec);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6220
					INFO_PRINTF1(_L("DevSound State: EStatePlaying"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6221
					iDevSoundState = EStatePlaying;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6222
					}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6223
				else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6224
					{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6225
					INFO_PRINTF1(_L("Calling CMMFDevSound::Stop succeeded"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6226
					StopTest(aError);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6227
					}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6228
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6229
			else if (aDevSoundEvent == EEventInitComplete && aError != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6230
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6231
				ERR_PRINTF2(_L("DevSound called CMMFDevSound::InitializeComplete with error = %d"), aError);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6232
				StopTest(aError);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6233
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6234
			else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6235
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6236
				ERR_PRINTF2(_L("DevSound EEventInitComplete not received as expected. Received event: %d"), aDevSoundEvent);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6237
				StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6238
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6239
			break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6240
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6241
		case EStatePlaying:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6242
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6243
			if(aDevSoundEvent == EEventTimerComplete)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6244
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6245
				INFO_PRINTF1(_L("Calling CMMFDevSound::Stop"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6246
				iMMFDevSound->Stop();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6247
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6248
			else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6249
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6250
				ERR_PRINTF2(_L("DevSound EEventTimerComplete not received as expected. Received event: %d"), aDevSoundEvent);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6251
				StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6252
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6253
			break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6254
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6255
		default:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6256
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6257
			ERR_PRINTF2(_L("Invalid DevSound state received: %d"), iDevSoundState);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6258
			StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6259
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6260
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6261
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6262
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6263
void RA3FDevSoundTonePlayDualToneOnceAndStopTest::DoTimerCallback()
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6264
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6265
	INFO_PRINTF1(_L("TimerEvent called"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6266
	INFO_PRINTF1(_L("DevSound Event: EEventTimerComplete"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6267
	if(!iToneStopped)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6268
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6269
		Fsm(EEventTimerComplete, KErrNone);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6270
		iToneStopped = ETrue;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6271
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6272
	else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6273
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6274
		iTimer->Cancel();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6275
		INFO_PRINTF1(_L("Calling CMMFDevSound::InitializeL"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6276
		TRAPD(err, iMMFDevSound->InitializeL(*this, EMMFStateTonePlaying));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6277
		if (err != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6278
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6279
			ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"),  err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6280
			ERR_PRINTF2(_L("Expected error = %d"), KErrNone);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6281
			StopTest(err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6282
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6283
		INFO_PRINTF1(_L("DevSound State: EStateInitializing"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6284
		iDevSoundState = EStateInitializing;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6285
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6286
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6287
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6288
void RA3FDevSoundTonePlayDualToneOnceAndStopTest::ToneFinished(TInt aError)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6289
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6290
	INFO_PRINTF1(_L("========== DevSound ToneFinished() callback =========="));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6291
	ERR_PRINTF1(_L("DevSound should not have called ToneFinished because it is supposed to have been stopped"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6292
	StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6293
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6294
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6295
/*
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6296
 *========================================================================================================
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6297
 * MM-A3F-DEVSOUND-CHRTZ-TONE-0045
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6298
 */
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6299
RA3FDevSoundTonePlayDTMFStringOnceAndStopTest::RA3FDevSoundTonePlayDTMFStringOnceAndStopTest(const TDesC& aTestName)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6300
	:	RA3FDevSoundTestBase(aTestName),iDTMFString(KNullDesC),
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6301
		iToneStopped(EFalse)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6302
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6303
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6304
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6305
RA3FDevSoundTonePlayDTMFStringOnceAndStopTest* RA3FDevSoundTonePlayDTMFStringOnceAndStopTest::NewL(const TDesC& aTestName)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6306
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6307
	RA3FDevSoundTonePlayDTMFStringOnceAndStopTest * self = new(ELeave)RA3FDevSoundTonePlayDTMFStringOnceAndStopTest(aTestName);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6308
	return self;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6309
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6310
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6311
void RA3FDevSoundTonePlayDTMFStringOnceAndStopTest::DoKickoffTestL()
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6312
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6313
	TPtrC DTMF;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6314
	if ( !GetStringFromConfig(iTestStepName, KDTMFString, DTMF) )
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6315
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6316
		ERR_PRINTF2(KMsgErrorGetParameter, &KDTMFString);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6317
		StopTest(KErrNotFound);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6318
		return;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6319
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6320
	iDTMFString.Copy(DTMF);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6321
	iTimer = CPeriodic::NewL(CActive::EPriorityHigh);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6322
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6323
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6324
void RA3FDevSoundTonePlayDTMFStringOnceAndStopTest::Fsm(TMmfDevSoundEvent aDevSoundEvent, TInt aError)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6325
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6326
	switch(iDevSoundState)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6327
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6328
		case EStateCreated:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6329
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6330
			__ASSERT_ALWAYS((aError == KErrNone), Panic(_L("RA3FDevSoundTonePlayDTMFStringOnceAndStopTest"), EFsmIncorrectErrorPassed));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6331
			if (aDevSoundEvent == EEventInitialize)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6332
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6333
				INFO_PRINTF1(_L("Calling CMMFDevSound::InitializeL"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6334
				TRAPD(err, iMMFDevSound->InitializeL(*this, EMMFStateTonePlaying));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6335
				if (err != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6336
					{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6337
					ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"), err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6338
					StopTest(err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6339
					break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6340
					}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6341
				INFO_PRINTF1(_L("DevSound State: EStateInitializing"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6342
				iDevSoundState = EStateInitializing;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6343
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6344
			else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6345
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6346
				ERR_PRINTF2(_L("DevSound EEventInitialize not received as expected. Received event: %d"), aDevSoundEvent);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6347
				StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6348
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6349
			break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6350
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6351
		case EStateInitializing:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6352
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6353
			if (aDevSoundEvent == EEventInitComplete && aError == KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6354
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6355
				if (!iToneStopped)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6356
					{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6357
					iMMFDevSound->SetVolume(iMMFDevSound->MaxVolume());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6358
					INFO_PRINTF2(_L("Calling CMMFDevSound::PlayDTMFStringL %S"), &iDTMFString);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6359
					TRAPD(err, iMMFDevSound->PlayDTMFStringL(iDTMFString));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6360
					if (err != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6361
						{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6362
						ERR_PRINTF2(_L("CMMFDevSound::PlayDTMFStringL left with error = %d"), err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6363
						StopTest(err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6364
						break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6365
						}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6366
					StartTimer(KMicroSecsTwoSec);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6367
					INFO_PRINTF1(_L("DevSound State: EStatePlaying"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6368
					iDevSoundState = EStatePlaying;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6369
					}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6370
				else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6371
					{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6372
					INFO_PRINTF1(_L("Calling CMMFDevSound::Stop succeeded"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6373
					StopTest(aError);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6374
					}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6375
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6376
			else if (aDevSoundEvent == EEventInitComplete && aError != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6377
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6378
				ERR_PRINTF2(_L("DevSound called CMMFDevSound::InitializeComplete with error = %d"), aError);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6379
				StopTest(aError);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6380
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6381
			else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6382
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6383
				ERR_PRINTF2(_L("DevSound EEventInitComplete not received as expected. Received event: %d"), aDevSoundEvent);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6384
				StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6385
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6386
			break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6387
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6388
		case EStatePlaying:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6389
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6390
			if(aDevSoundEvent == EEventTimerComplete)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6391
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6392
				INFO_PRINTF1(_L("Calling CMMFDevSound::Stop"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6393
				iMMFDevSound->Stop();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6394
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6395
			else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6396
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6397
				ERR_PRINTF2(_L("DevSound EEventTimerComplete not received as expected. Received event: %d"), aDevSoundEvent);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6398
				StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6399
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6400
			break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6401
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6402
		default:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6403
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6404
			ERR_PRINTF2(_L("Invalid DevSound state received: %d"), iDevSoundState);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6405
			StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6406
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6407
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6408
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6409
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6410
void RA3FDevSoundTonePlayDTMFStringOnceAndStopTest::DoTimerCallback()
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6411
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6412
	INFO_PRINTF1(_L("TimerEvent called"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6413
	INFO_PRINTF1(_L("DevSound Event: EEventTimerComplete"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6414
	if(!iToneStopped)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6415
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6416
		Fsm(EEventTimerComplete, KErrNone);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6417
		iToneStopped = ETrue;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6418
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6419
	else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6420
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6421
		iTimer->Cancel();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6422
		INFO_PRINTF1(_L("Calling CMMFDevSound::InitializeL"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6423
		TRAPD(err, iMMFDevSound->InitializeL(*this, EMMFStateTonePlaying));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6424
		if (err != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6425
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6426
			ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"),  err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6427
			ERR_PRINTF2(_L("Expected error = %d"), KErrNone);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6428
			StopTest(err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6429
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6430
		INFO_PRINTF1(_L("DevSound State: EStateInitializing"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6431
		iDevSoundState = EStateInitializing;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6432
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6433
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6434
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6435
void RA3FDevSoundTonePlayDTMFStringOnceAndStopTest::ToneFinished(TInt aError)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6436
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6437
	INFO_PRINTF1(_L("========== DevSound ToneFinished() callback =========="));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6438
	ERR_PRINTF1(_L("DevSound should not have called ToneFinished because it is supposed to have been stopped"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6439
	StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6440
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6441
/*
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6442
 *========================================================================================================
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6443
 * MM-A3F-DEVSOUND-CHRTZ-TONE-0046
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6444
 */
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6445
RA3FDevSoundTonePlayToneSequenceOnceAndStopTest::RA3FDevSoundTonePlayToneSequenceOnceAndStopTest(const TDesC& aTestName)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6446
	:	RA3FDevSoundTestBase(aTestName), iToneStopped(EFalse)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6447
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6448
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6449
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6450
RA3FDevSoundTonePlayToneSequenceOnceAndStopTest* RA3FDevSoundTonePlayToneSequenceOnceAndStopTest::NewL(const TDesC& aTestName)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6451
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6452
	RA3FDevSoundTonePlayToneSequenceOnceAndStopTest * self = new(ELeave)RA3FDevSoundTonePlayToneSequenceOnceAndStopTest(aTestName);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6453
	return self;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6454
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6455
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6456
void RA3FDevSoundTonePlayToneSequenceOnceAndStopTest::DoKickoffTestL()
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6457
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6458
	iTimer = CPeriodic::NewL(CActive::EPriorityHigh);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6459
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6460
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6461
void RA3FDevSoundTonePlayToneSequenceOnceAndStopTest::Fsm(TMmfDevSoundEvent aDevSoundEvent, TInt aError)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6462
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6463
	switch (iDevSoundState)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6464
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6465
		case EStateCreated:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6466
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6467
			__ASSERT_ALWAYS((aError == KErrNone), Panic(_L("RA3FDevSoundTonePlayToneSequenceOnceAndStopTest"), EFsmIncorrectErrorPassed));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6468
			if (aDevSoundEvent == EEventInitialize)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6469
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6470
				INFO_PRINTF1(_L("Calling CMMFDevSound::InitializeL"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6471
				TRAPD(err, iMMFDevSound->InitializeL(*this, EMMFStateTonePlaying));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6472
				if (err != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6473
					{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6474
					ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"),  err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6475
					StopTest(err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6476
					break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6477
					}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6478
				INFO_PRINTF1(_L("DevSound State: EStateInitializing"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6479
				iDevSoundState = EStateInitializing;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6480
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6481
			else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6482
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6483
				ERR_PRINTF2(_L("DevSound EEventInitialize not received as expected. Received event: %d"), aDevSoundEvent);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6484
				StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6485
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6486
			break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6487
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6488
		case EStateInitializing:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6489
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6490
			if (aDevSoundEvent == EEventInitComplete && aError == KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6491
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6492
				if (!iToneStopped)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6493
					{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6494
					iMMFDevSound->SetVolume(iMMFDevSound->MaxVolume());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6495
					TUint8* tablePointer = const_cast<TUint8*>( &(KFixedSequenceTestSequenceDataX[0]));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6496
					TPtrC8 KFixedSequenceData(tablePointer,  sizeof(KFixedSequenceTestSequenceDataX));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6497
					INFO_PRINTF1(_L("Calling CMMFDevSound::PlayToneSequenceL"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6498
					TRAPD(err, iMMFDevSound->PlayToneSequenceL(KFixedSequenceData));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6499
					if (err != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6500
						{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6501
						ERR_PRINTF2(_L("CMMFDevSound::PlayToneSequenceL left with error = %d!"), err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6502
						StopTest(err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6503
						break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6504
						}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6505
					StartTimer(KMicroSecsTwoSec);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6506
					INFO_PRINTF1(_L("DevSound State: EStatePlaying"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6507
					iDevSoundState = EStatePlaying;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6508
					}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6509
				else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6510
					{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6511
					INFO_PRINTF1(_L("Calling CMMFDevSound::Stop succeeded"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6512
					StopTest(aError);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6513
					}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6514
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6515
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6516
			else if (aDevSoundEvent == EEventInitComplete && aError != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6517
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6518
				ERR_PRINTF2(_L("DevSound called CMMFDevSound::InitializeComplete with error = %d"), aError);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6519
				StopTest(aError);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6520
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6521
			else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6522
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6523
				ERR_PRINTF2(_L("DevSound EEventInitComplete not received as expected. Received event: %d"), aDevSoundEvent);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6524
				StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6525
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6526
			break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6527
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6528
		case EStatePlaying:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6529
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6530
			if(aDevSoundEvent == EEventTimerComplete)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6531
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6532
				INFO_PRINTF1(_L("Calling CMMFDevSound::Stop"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6533
				iMMFDevSound->Stop();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6534
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6535
			else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6536
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6537
				ERR_PRINTF2(_L("DevSound EEventTimerComplete not received as expected. Received event: %d"), aDevSoundEvent);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6538
				StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6539
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6540
			break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6541
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6542
		default:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6543
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6544
			ERR_PRINTF2(_L("Invalid DevSound state received: %d"),  iDevSoundState);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6545
			StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6546
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6547
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6548
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6549
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6550
void RA3FDevSoundTonePlayToneSequenceOnceAndStopTest::DoTimerCallback()
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6551
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6552
	INFO_PRINTF1(_L("TimerEvent called"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6553
	INFO_PRINTF1(_L("DevSound Event: EEventTimerComplete"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6554
	if(!iToneStopped)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6555
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6556
		Fsm(EEventTimerComplete, KErrNone);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6557
		iToneStopped = ETrue;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6558
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6559
	else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6560
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6561
		iTimer->Cancel();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6562
		INFO_PRINTF1(_L("Calling CMMFDevSound::InitializeL"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6563
		TRAPD(err, iMMFDevSound->InitializeL(*this, EMMFStateTonePlaying));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6564
		if (err != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6565
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6566
			ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"),  err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6567
			ERR_PRINTF2(_L("Expected error = %d"), KErrNone);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6568
			StopTest(err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6569
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6570
		INFO_PRINTF1(_L("DevSound State: EStateInitializing"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6571
		iDevSoundState = EStateInitializing;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6572
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6573
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6574
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6575
void RA3FDevSoundTonePlayToneSequenceOnceAndStopTest::ToneFinished(TInt aError)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6576
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6577
	INFO_PRINTF1(_L("========== DevSound ToneFinished() callback =========="));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6578
	ERR_PRINTF1(_L("DevSound should not have called ToneFinished because it is supposed to have been stopped"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6579
	StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6580
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6581
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6582
/*
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6583
 *========================================================================================================
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6584
 * MM-A3F-DEVSOUND-CHRTZ-TONE-0047
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6585
 */
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6586
RA3FDevSoundTonePlayToneOncePauseTest::RA3FDevSoundTonePlayToneOncePauseTest(const TDesC& aTestName)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6587
	:	RA3FDevSoundTestBase(aTestName),iDuration(0),
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6588
		iFrequencyTone1(0), iPaused(EFalse),
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6589
		iSamplesPlayedPaused(0)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6590
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6591
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6592
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6593
RA3FDevSoundTonePlayToneOncePauseTest* RA3FDevSoundTonePlayToneOncePauseTest::NewL(const TDesC& aTestName)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6594
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6595
	RA3FDevSoundTonePlayToneOncePauseTest * self = new(ELeave)RA3FDevSoundTonePlayToneOncePauseTest(aTestName);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6596
	return self;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6597
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6598
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6599
void RA3FDevSoundTonePlayToneOncePauseTest::DoKickoffTestL()
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6600
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6601
	if (!GetIntFromConfig(iTestStepName, KDuration, iDuration))
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6602
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6603
		ERR_PRINTF2(KMsgErrorGetParameter, &KDuration);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6604
		StopTest(KErrNotFound);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6605
		return;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6606
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6607
	if (!GetIntFromConfig(iTestStepName, KFrequencyTone1, iFrequencyTone1))
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6608
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6609
		ERR_PRINTF2(KMsgErrorGetParameter, &KFrequencyTone1);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6610
		StopTest(KErrNotFound);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6611
		return;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6612
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6613
	iTimer = CPeriodic::NewL(CActive::EPriorityHigh);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6614
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6615
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6616
void RA3FDevSoundTonePlayToneOncePauseTest::Fsm(TMmfDevSoundEvent aDevSoundEvent,  TInt aError)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6617
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6618
	switch (iDevSoundState)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6619
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6620
		case EStateCreated:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6621
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6622
			__ASSERT_ALWAYS((aError == KErrNone), Panic(_L("RA3FDevSoundTonePlayToneOncePauseTest"), EFsmIncorrectErrorPassed));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6623
			if (aDevSoundEvent == EEventInitialize)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6624
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6625
				INFO_PRINTF1(_L("Calling CMMFDevSound::InitializeL"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6626
				TRAPD(err, iMMFDevSound->InitializeL(*this, EMMFStateTonePlaying));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6627
				if (err != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6628
					{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6629
					ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"),  err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6630
					StopTest(err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6631
					break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6632
					}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6633
				INFO_PRINTF1(_L("DevSound State: EStateInitializing"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6634
				iDevSoundState = EStateInitializing;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6635
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6636
			else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6637
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6638
				ERR_PRINTF2(_L("DevSound EEventInitialize not received as expected. Received event: %d"), aDevSoundEvent);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6639
				StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6640
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6641
			break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6642
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6643
		case EStateInitializing:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6644
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6645
			if (aDevSoundEvent == EEventInitComplete && aError == KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6646
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6647
				iMMFDevSound->SetVolume(iMMFDevSound->MaxVolume());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6648
				INFO_PRINTF3(_L("Calling CMMFDevSound::PlayToneL using %d Hz during %d secs "), iFrequencyTone1, iDuration);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6649
				TRAPD(err, iMMFDevSound->PlayToneL(iFrequencyTone1, iDuration*KMicroSecsInOneSec));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6650
				if (err != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6651
					{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6652
					ERR_PRINTF2(_L("CMMFDevSound::PlayToneL left with error = %d!"),  err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6653
					StopTest(err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6654
					break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6655
					}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6656
				StartTimer(KMicroSecsTwoSec);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6657
				INFO_PRINTF1(_L("DevSound State: EStatePlaying"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6658
				iDevSoundState = EStatePlaying;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6659
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6660
			else if (aDevSoundEvent == EEventInitComplete && aError != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6661
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6662
				ERR_PRINTF2(_L("DevSound called CMMFDevSound::InitializeComplete with error = %d"), aError);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6663
				StopTest(aError);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6664
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6665
			else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6666
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6667
				ERR_PRINTF2(_L("DevSound EEventInitComplete not received as expected. Received event: %d"),  aDevSoundEvent);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6668
				StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6669
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6670
			break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6671
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6672
		case EStatePlaying:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6673
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6674
			if(aDevSoundEvent == EEventTimerComplete)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6675
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6676
				INFO_PRINTF1(_L("Calling CMMFDevSound::Pause"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6677
				iMMFDevSound->Pause();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6678
				INFO_PRINTF1(_L("DevSound State: EStatePause"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6679
				iDevSoundState = EStatePause;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6680
				INFO_PRINTF1(_L("Calling CMMFDevSound::SamplesPlayed"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6681
				iSamplesPlayedPaused = iMMFDevSound->SamplesPlayed();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6682
				INFO_PRINTF2(_L("The number of samples played is %d"), iSamplesPlayedPaused);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6683
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6684
			else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6685
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6686
				ERR_PRINTF2(_L("DevSound EEventTimerComplete not received as expected. Received event: %d"), aDevSoundEvent);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6687
				StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6688
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6689
			break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6690
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6691
		case EStatePause:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6692
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6693
			if (aDevSoundEvent == EEventTimerComplete)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6694
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6695
				TInt samplesPlayed = iMMFDevSound->SamplesPlayed();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6696
				if(iSamplesPlayedPaused == samplesPlayed)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6697
					{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6698
					INFO_PRINTF2(_L("After waiting a couple of seconds, the samples played are still being the same %d"), iSamplesPlayedPaused);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6699
					StopTest();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6700
					}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6701
				else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6702
					{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6703
					ERR_PRINTF2(_L("After waiting a couple of seconds, the samples played are not the same %d"), samplesPlayed);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6704
					ERR_PRINTF2(_L("Expected samples played = %d"), iSamplesPlayedPaused);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6705
					StopTest(aError,EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6706
					}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6707
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6708
			else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6709
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6710
				ERR_PRINTF2(_L("EEventTimerComplete not received as expected. Received event: %d"), aDevSoundEvent);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6711
				StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6712
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6713
			break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6714
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6715
		default:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6716
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6717
			ERR_PRINTF2(_L("Invalid DevSound state received: %d"), iDevSoundState);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6718
			StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6719
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6720
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6721
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6722
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6723
void RA3FDevSoundTonePlayToneOncePauseTest::DoTimerCallback()
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6724
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6725
	INFO_PRINTF1(_L("TimerEvent called"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6726
	if (!iPaused)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6727
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6728
		INFO_PRINTF1(_L("DevSound Event: EEventTimerComplete"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6729
		Fsm(EEventTimerComplete, KErrNone);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6730
		iPaused = ETrue;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6731
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6732
	else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6733
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6734
		iTimer->Cancel();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6735
		INFO_PRINTF1(_L("DevSound Event: EEventTimerComplete"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6736
		Fsm(EEventTimerComplete, KErrNone);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6737
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6738
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6739
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6740
void RA3FDevSoundTonePlayToneOncePauseTest::ToneFinished(TInt aError)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6741
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6742
	INFO_PRINTF1(_L("========== DevSound ToneFinished() callback =========="));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6743
	ERR_PRINTF1(_L("DevSound should not have called ToneFinished because it is supposed to be paused"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6744
	StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6745
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6746
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6747
/*
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6748
 *========================================================================================================
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6749
 * MM-A3F-DEVSOUND-CHRTZ-TONE-0048
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6750
 */
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6751
RA3FDevSoundTonePlayDualToneOncePauseTest::RA3FDevSoundTonePlayDualToneOncePauseTest(const TDesC& aTestName)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6752
	:	RA3FDevSoundTestBase(aTestName),
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6753
		iDuration(0),iFrequencyTone1(0),
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6754
		iFrequencyTone2(0), iPaused(EFalse),
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6755
		iSamplesPlayedPaused(0)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6756
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6757
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6758
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6759
RA3FDevSoundTonePlayDualToneOncePauseTest* RA3FDevSoundTonePlayDualToneOncePauseTest::NewL(const TDesC& aTestName)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6760
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6761
	RA3FDevSoundTonePlayDualToneOncePauseTest * self = new(ELeave)RA3FDevSoundTonePlayDualToneOncePauseTest(aTestName);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6762
	return self;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6763
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6764
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6765
void RA3FDevSoundTonePlayDualToneOncePauseTest::DoKickoffTestL()
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6766
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6767
	if (!GetIntFromConfig(iTestStepName, KDuration, iDuration))
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6768
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6769
		ERR_PRINTF2(KMsgErrorGetParameter, &KDuration);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6770
		StopTest(KErrNotFound);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6771
		return;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6772
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6773
	if (!GetIntFromConfig(iTestStepName, KFrequencyTone1, iFrequencyTone1))
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6774
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6775
		ERR_PRINTF2(KMsgErrorGetParameter, &KFrequencyTone1);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6776
		StopTest(KErrNotFound);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6777
		return;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6778
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6779
	if (!GetIntFromConfig(iTestStepName, KFrequencyTone2, iFrequencyTone2))
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6780
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6781
		ERR_PRINTF2(KMsgErrorGetParameter, &KFrequencyTone2);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6782
		StopTest(KErrNotFound);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6783
		return;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6784
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6785
	iTimer = CPeriodic::NewL(CActive::EPriorityHigh);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6786
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6787
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6788
void RA3FDevSoundTonePlayDualToneOncePauseTest::Fsm(TMmfDevSoundEvent aDevSoundEvent, TInt aError)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6789
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6790
	switch (iDevSoundState)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6791
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6792
		case EStateCreated:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6793
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6794
			__ASSERT_ALWAYS((aError == KErrNone), Panic(_L("RA3FDevSoundTonePlayDualToneOncePauseTest"), EFsmIncorrectErrorPassed));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6795
			if (aDevSoundEvent == EEventInitialize)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6796
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6797
				INFO_PRINTF1(_L("Calling CMMFDevSound::InitializeL"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6798
				TRAPD(err, iMMFDevSound->InitializeL(*this,  EMMFStateTonePlaying));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6799
				if (err != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6800
					{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6801
					ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"), err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6802
					StopTest(err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6803
					break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6804
					}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6805
				INFO_PRINTF1(_L("DevSound State: EStateInitializing"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6806
				iDevSoundState = EStateInitializing;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6807
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6808
			else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6809
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6810
				ERR_PRINTF2(_L("DevSound EEventInitialize not received as expected. Received event: %d"), aDevSoundEvent);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6811
				StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6812
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6813
			break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6814
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6815
		case EStateInitializing:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6816
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6817
			if (aDevSoundEvent == EEventInitComplete && aError == KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6818
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6819
				iMMFDevSound->SetVolume(iMMFDevSound->MaxVolume());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6820
				INFO_PRINTF4(_L("Calling CMMFDevSound::PlayDualToneL using %d Hz %d Hz during %d secs "), iFrequencyTone1, iFrequencyTone2, iDuration);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6821
				TRAPD(err, iMMFDevSound->PlayDualToneL(iFrequencyTone1, iFrequencyTone2, iDuration*KMicroSecsInOneSec));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6822
				if (err != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6823
					{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6824
					ERR_PRINTF2(_L("CMMFDevSound::PlayDualToneL left with error : %d!"),  err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6825
					StopTest(err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6826
					break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6827
					}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6828
				StartTimer(KMicroSecsTwoSec);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6829
				INFO_PRINTF1(_L("DevSound State: EStatePlaying"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6830
				iDevSoundState = EStatePlaying;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6831
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6832
			else if (aDevSoundEvent == EEventInitComplete && aError != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6833
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6834
				ERR_PRINTF2(_L("DevSound called CMMFDevSound::InitializeComplete with error = %d"), aError);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6835
				StopTest(aError);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6836
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6837
			else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6838
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6839
				ERR_PRINTF2(_L("DevSound EEventInitComplete not received as expected. Received event: %d"), aDevSoundEvent);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6840
				StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6841
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6842
			break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6843
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6844
		case EStatePlaying:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6845
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6846
			if(aDevSoundEvent == EEventTimerComplete)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6847
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6848
				INFO_PRINTF1(_L("Calling CMMFDevSound::Pause"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6849
				iMMFDevSound->Pause();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6850
				INFO_PRINTF1(_L("DevSound State: EStatePause"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6851
				iDevSoundState = EStatePause;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6852
				INFO_PRINTF1(_L("Calling CMMFDevSound::SamplesPlayed"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6853
				iSamplesPlayedPaused = iMMFDevSound->SamplesPlayed();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6854
				INFO_PRINTF2(_L("The number of samples played is %d"), iSamplesPlayedPaused);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6855
				StopTest();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6856
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6857
			else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6858
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6859
				ERR_PRINTF2(_L("DevSound EEventTimerComplete not received as expected. Received event: %d"), aDevSoundEvent);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6860
				StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6861
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6862
			break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6863
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6864
		case EStatePause:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6865
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6866
			if (aDevSoundEvent == EEventTimerComplete)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6867
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6868
				TInt samplesPlayed = iMMFDevSound->SamplesPlayed();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6869
				if(iSamplesPlayedPaused == samplesPlayed)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6870
					{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6871
					INFO_PRINTF2(_L("After waiting a couple of seconds, the samples played are still being the same %d"), iSamplesPlayedPaused);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6872
					StopTest();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6873
					}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6874
				else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6875
					{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6876
					ERR_PRINTF2(_L("After waiting a couple of seconds, the samples played are not the same %d"), samplesPlayed);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6877
					ERR_PRINTF2(_L("Expected samples played = %d"), iSamplesPlayedPaused);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6878
					StopTest(aError,EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6879
					}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6880
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6881
			else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6882
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6883
				ERR_PRINTF2(_L("EEventTimerComplete not received as expected. Received event: %d"), aDevSoundEvent);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6884
				StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6885
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6886
			break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6887
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6888
		default:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6889
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6890
			ERR_PRINTF2(_L("Invalid DevSound state received: %d"), iDevSoundState);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6891
			StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6892
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6893
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6894
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6895
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6896
void RA3FDevSoundTonePlayDualToneOncePauseTest::DoTimerCallback()
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6897
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6898
	INFO_PRINTF1(_L("TimerEvent called"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6899
	if (!iPaused)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6900
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6901
		INFO_PRINTF1(_L("DevSound Event: EEventTimerComplete"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6902
		Fsm(EEventTimerComplete, KErrNone);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6903
		iPaused = ETrue;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6904
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6905
	else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6906
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6907
		iTimer->Cancel();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6908
		INFO_PRINTF1(_L("DevSound Event: EEventTimerComplete"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6909
		Fsm(EEventTimerComplete, KErrNone);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6910
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6911
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6912
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6913
void RA3FDevSoundTonePlayDualToneOncePauseTest::ToneFinished(TInt aError)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6914
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6915
	INFO_PRINTF1(_L("========== DevSound ToneFinished() callback =========="));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6916
	ERR_PRINTF1(_L("DevSound should not have called ToneFinished because it is supposed to be paused"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6917
	StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6918
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6919
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6920
/*
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6921
 *========================================================================================================
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6922
 * MM-A3F-DEVSOUND-CHRTZ-TONE-0049
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6923
 */
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6924
RA3FDevSoundTonePlayDTMFStringOncePauseTest::RA3FDevSoundTonePlayDTMFStringOncePauseTest(const TDesC& aTestName)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6925
	:	RA3FDevSoundTestBase(aTestName),
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6926
		iDTMFString(KNullDesC),iPaused(EFalse),
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6927
		iSamplesPlayedPaused(0),iDTMFPauses(0),
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6928
		iDTMFTones(0)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6929
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6930
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6931
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6932
RA3FDevSoundTonePlayDTMFStringOncePauseTest* RA3FDevSoundTonePlayDTMFStringOncePauseTest::NewL(const TDesC& aTestName)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6933
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6934
	RA3FDevSoundTonePlayDTMFStringOncePauseTest * self = new(ELeave)RA3FDevSoundTonePlayDTMFStringOncePauseTest(aTestName);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6935
	return self;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6936
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6937
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6938
void RA3FDevSoundTonePlayDTMFStringOncePauseTest::DoKickoffTestL()
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6939
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6940
	TPtrC DTMF;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6941
	if ( !GetStringFromConfig(iTestStepName, KDTMFString, DTMF) )
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6942
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6943
		ERR_PRINTF2(KMsgErrorGetParameter, &KDTMFString);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6944
		StopTest(KErrNotFound);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6945
		return;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6946
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6947
	iDTMFString.Copy(DTMF);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6948
	for(TInt i =0 ; i< iDTMFString.Length() ; i++)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6949
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6950
		if (iDTMFString[i] == ',')
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6951
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6952
			iDTMFPauses++;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6953
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6954
		else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6955
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6956
			iDTMFTones++;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6957
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6958
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6959
	iTimer = CPeriodic::NewL(CActive::EPriorityHigh);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6960
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6961
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6962
void RA3FDevSoundTonePlayDTMFStringOncePauseTest::Fsm(TMmfDevSoundEvent aDevSoundEvent, TInt aError)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6963
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6964
	switch (iDevSoundState)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6965
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6966
		case EStateCreated:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6967
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6968
			__ASSERT_ALWAYS((aError == KErrNone), Panic(_L("RA3FDevSoundTonePlayDTMFStringOncePauseTest"), EFsmIncorrectErrorPassed));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6969
			if (aDevSoundEvent == EEventInitialize)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6970
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6971
				INFO_PRINTF1(_L("Calling CMMFDevSound::InitializeL"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6972
				TRAPD(err, iMMFDevSound->InitializeL(*this, EMMFStateTonePlaying));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6973
				if (err != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6974
					{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6975
					ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"), err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6976
					StopTest(err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6977
					break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6978
					}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6979
				INFO_PRINTF1(_L("DevSound State: EStateInitializing"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6980
				iDevSoundState = EStateInitializing;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6981
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6982
			else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6983
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6984
				ERR_PRINTF2(_L("DevSound EEventInitialize not received as expected. Received event: %d"), aDevSoundEvent);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6985
				StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6986
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6987
			break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6988
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6989
		case EStateInitializing:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6990
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6991
			if (aDevSoundEvent == EEventInitComplete && aError == KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6992
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6993
				iMMFDevSound->SetVolume(iMMFDevSound->MaxVolume());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6994
				INFO_PRINTF2(_L("Calling CMMFDevSound::PlayDTMFStringL %S"),  &iDTMFString);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6995
				TRAPD(err, iMMFDevSound->PlayDTMFStringL(iDTMFString));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6996
				if (err != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6997
					{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6998
					ERR_PRINTF2(_L("CMMFDevSound::PlayDTMFStringL left with error : %d!"),  err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  6999
					StopTest(err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7000
					}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7001
				StartTimer(KMicroSecsTwoSec);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7002
				INFO_PRINTF1(_L("DevSound State: EStatePlaying"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7003
				iDevSoundState = EStatePlaying;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7004
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7005
			else if (aDevSoundEvent == EEventInitComplete && aError != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7006
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7007
				ERR_PRINTF2(_L("DevSound called CMMFDevSound::InitializeComplete with error = %d"), aError);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7008
				StopTest(aError);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7009
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7010
			else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7011
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7012
				ERR_PRINTF2(_L("DevSound EEventInitComplete not received as expected. Received event: %d"), aDevSoundEvent);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7013
				StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7014
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7015
			break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7016
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7017
		case EStatePlaying:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7018
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7019
			if(aDevSoundEvent == EEventTimerComplete)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7020
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7021
				INFO_PRINTF1(_L("Calling CMMFDevSound::Pause"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7022
				iMMFDevSound->Pause();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7023
				INFO_PRINTF1(_L("DevSound State: EStatePause"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7024
				iDevSoundState = EStatePause;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7025
				INFO_PRINTF1(_L("Calling CMMFDevSound::SamplesPlayed"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7026
				iSamplesPlayedPaused = iMMFDevSound->SamplesPlayed();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7027
				INFO_PRINTF2(_L("The number of samples played is %d"), iSamplesPlayedPaused);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7028
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7029
			else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7030
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7031
				ERR_PRINTF2(_L("DevSound EEventTimerComplete not received as expected. Received event: %d"), aDevSoundEvent);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7032
				StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7033
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7034
			break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7035
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7036
		case EStatePause:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7037
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7038
			if (aDevSoundEvent == EEventTimerComplete)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7039
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7040
				TInt samplesPlayed = iMMFDevSound->SamplesPlayed();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7041
				if(iSamplesPlayedPaused == samplesPlayed)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7042
					{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7043
					INFO_PRINTF2(_L("After waiting a couple of seconds, the samples played are still being the same %d"), iSamplesPlayedPaused);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7044
					StopTest();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7045
					}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7046
				else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7047
					{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7048
					ERR_PRINTF2(_L("After waiting a couple of seconds, the samples played are not the same %d"), samplesPlayed);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7049
					ERR_PRINTF2(_L("Expected samples played = %d"), iSamplesPlayedPaused);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7050
					StopTest(aError,EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7051
					}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7052
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7053
			else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7054
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7055
				ERR_PRINTF2(_L("EEventTimerComplete not received as expected. Received event: %d"), aDevSoundEvent);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7056
				StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7057
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7058
			break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7059
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7060
		default:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7061
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7062
			ERR_PRINTF2(_L("Invalid DevSound state received: %d"), iDevSoundState);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7063
			StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7064
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7065
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7066
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7067
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7068
void RA3FDevSoundTonePlayDTMFStringOncePauseTest::DoTimerCallback()
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7069
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7070
	INFO_PRINTF1(_L("TimerEvent called"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7071
	if (!iPaused)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7072
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7073
		INFO_PRINTF1(_L("DevSound Event: EEventTimerComplete"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7074
		Fsm(EEventTimerComplete, KErrNone);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7075
		iPaused = ETrue;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7076
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7077
	else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7078
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7079
		iTimer->Cancel();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7080
		INFO_PRINTF1(_L("DevSound Event: EEventTimerComplete"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7081
		Fsm(EEventTimerComplete, KErrNone);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7082
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7083
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7084
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7085
void RA3FDevSoundTonePlayDTMFStringOncePauseTest::ToneFinished(TInt aError)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7086
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7087
	INFO_PRINTF1(_L("========== DevSound ToneFinished() callback =========="));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7088
	ERR_PRINTF1(_L("DevSound should not have called ToneFinished because it is supposed to be paused"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7089
	StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7090
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7091
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7092
/*
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7093
 *========================================================================================================
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7094
 * MM-A3F-DEVSOUND-CHRTZ-TONE-0050
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7095
 */
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7096
RA3FDevSoundTonePlayToneSequenceOncePauseTest::RA3FDevSoundTonePlayToneSequenceOncePauseTest(const TDesC& aTestName)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7097
	:	RA3FDevSoundTestBase(aTestName), iPaused(EFalse),
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7098
		iSamplesPlayedPaused(0)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7099
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7100
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7101
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7102
RA3FDevSoundTonePlayToneSequenceOncePauseTest* RA3FDevSoundTonePlayToneSequenceOncePauseTest::NewL(const TDesC& aTestName)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7103
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7104
	RA3FDevSoundTonePlayToneSequenceOncePauseTest * self = new(ELeave)RA3FDevSoundTonePlayToneSequenceOncePauseTest(aTestName);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7105
	return self;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7106
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7107
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7108
void RA3FDevSoundTonePlayToneSequenceOncePauseTest::DoKickoffTestL()
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7109
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7110
	iTimer = CPeriodic::NewL(CActive::EPriorityHigh);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7111
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7112
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7113
void RA3FDevSoundTonePlayToneSequenceOncePauseTest::Fsm(TMmfDevSoundEvent aDevSoundEvent, TInt aError)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7114
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7115
	switch(iDevSoundState)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7116
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7117
		case EStateCreated:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7118
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7119
			__ASSERT_ALWAYS((aError == KErrNone), Panic(_L("RA3FDevSoundTonePlayToneSequenceOncePauseTest"), EFsmIncorrectErrorPassed));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7120
			if (aDevSoundEvent == EEventInitialize)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7121
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7122
				INFO_PRINTF1(_L("Calling CMMFDevSound::InitializeL"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7123
				TRAPD(err, iMMFDevSound->InitializeL(*this, EMMFStateTonePlaying));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7124
				if (err != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7125
					{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7126
					ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"), err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7127
					StopTest(err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7128
					break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7129
					}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7130
				INFO_PRINTF1(_L("DevSound State: EStateInitializing"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7131
				iDevSoundState = EStateInitializing;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7132
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7133
			else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7134
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7135
				ERR_PRINTF2(_L("DevSound EEventInitialize not received as expected. Received event: %d"), aDevSoundEvent);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7136
				StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7137
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7138
			break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7139
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7140
		case EStateInitializing:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7141
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7142
			if (aDevSoundEvent == EEventInitComplete && aError == KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7143
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7144
				TUint8* tablePointer = const_cast<TUint8*>( &(KFixedSequenceTestSequenceDataX[0] ) );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7145
				TPtrC8 KFixedSequenceData(tablePointer, sizeof(KFixedSequenceTestSequenceDataX));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7146
				INFO_PRINTF1(_L("Calling CMMFDevSound::PlayToneSequenceL"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7147
				TRAPD(err, iMMFDevSound->PlayToneSequenceL(KFixedSequenceData));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7148
				if (err != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7149
					{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7150
					ERR_PRINTF2(_L("CMMFDevSound::PlayToneSequenceL left  with error : %d!"),  err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7151
					StopTest(err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7152
					break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7153
					}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7154
				StartTimer(KMicroSecsTwoSec);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7155
				INFO_PRINTF1(_L("DevSound State: EStatePlaying"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7156
				iDevSoundState = EStatePlaying;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7157
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7158
			else if (aDevSoundEvent == EEventInitComplete && aError != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7159
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7160
				ERR_PRINTF2(_L("DevSound called CMMFDevSound::InitializeComplete with error = %d"), aError);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7161
				StopTest(aError);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7162
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7163
			else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7164
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7165
				ERR_PRINTF2(_L("DevSound EEventInitComplete not received as expected. Received event: %d"), aDevSoundEvent);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7166
				StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7167
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7168
			break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7169
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7170
		case EStatePlaying:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7171
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7172
			if(aDevSoundEvent == EEventTimerComplete)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7173
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7174
				INFO_PRINTF1(_L("Calling CMMFDevSound::Pause"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7175
				iMMFDevSound->Pause();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7176
				INFO_PRINTF1(_L("DevSound State: EStatePause"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7177
				iDevSoundState = EStatePause;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7178
				INFO_PRINTF1(_L("Calling CMMFDevSound::SamplesPlayed"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7179
				iSamplesPlayedPaused = iMMFDevSound->SamplesPlayed();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7180
				INFO_PRINTF2(_L("The number of samples played is %d"), iSamplesPlayedPaused);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7181
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7182
			else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7183
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7184
				ERR_PRINTF2(_L("DevSound EEventTimerComplete not received as expected. Received event: %d"), aDevSoundEvent);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7185
				StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7186
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7187
			break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7188
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7189
		case EStatePause:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7190
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7191
			if (aDevSoundEvent == EEventTimerComplete)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7192
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7193
				TInt samplesPlayed = iMMFDevSound->SamplesPlayed();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7194
				if(iSamplesPlayedPaused == samplesPlayed)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7195
					{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7196
					INFO_PRINTF2(_L("After waiting a couple of seconds, the samples played are still being the same %d"), iSamplesPlayedPaused);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7197
					StopTest();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7198
					}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7199
				else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7200
					{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7201
					ERR_PRINTF2(_L("After waiting a couple of seconds, the samples played are not the same %d"), samplesPlayed);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7202
					ERR_PRINTF2(_L("Expected samples played = %d"), iSamplesPlayedPaused);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7203
					StopTest(aError,EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7204
					}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7205
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7206
			else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7207
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7208
				ERR_PRINTF2(_L("EEventTimerComplete not received as expected. Received event: %d"), aDevSoundEvent);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7209
				StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7210
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7211
			break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7212
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7213
		default:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7214
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7215
			ERR_PRINTF2(_L("Invalid DevSound state received: %d"), iDevSoundState);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7216
			StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7217
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7218
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7219
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7220
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7221
void RA3FDevSoundTonePlayToneSequenceOncePauseTest::DoTimerCallback()
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7222
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7223
	INFO_PRINTF1(_L("TimerEvent called"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7224
	if (!iPaused)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7225
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7226
		INFO_PRINTF1(_L("DevSound Event: EEventTimerComplete"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7227
		Fsm(EEventTimerComplete, KErrNone);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7228
		iPaused = ETrue;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7229
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7230
	else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7231
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7232
		iTimer->Cancel();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7233
		INFO_PRINTF1(_L("DevSound Event: EEventTimerComplete"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7234
		Fsm(EEventTimerComplete, KErrNone);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7235
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7236
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7237
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7238
void RA3FDevSoundTonePlayToneSequenceOncePauseTest::ToneFinished(TInt aError)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7239
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7240
	INFO_PRINTF1(_L("========== DevSound ToneFinished() callback =========="));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7241
	ERR_PRINTF1(_L("DevSound should not have called ToneFinished because it is supposed to be paused"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7242
	StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7243
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7244
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7245
/*
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7246
 *========================================================================================================
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7247
 * MM-A3F-DEVSOUND-CHRTZ-TONE-0051
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7248
 */
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7249
RA3FDevSoundTonePlayToneOnceInitializedToPlayAudioTest::RA3FDevSoundTonePlayToneOnceInitializedToPlayAudioTest(const TDesC& aTestName)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7250
	:	RA3FDevSoundTestBase(aTestName), iDuration(0),
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7251
		iFrequencyTone1(0)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7252
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7253
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7254
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7255
RA3FDevSoundTonePlayToneOnceInitializedToPlayAudioTest* RA3FDevSoundTonePlayToneOnceInitializedToPlayAudioTest::NewL(const TDesC& aTestName)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7256
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7257
	RA3FDevSoundTonePlayToneOnceInitializedToPlayAudioTest * self = new(ELeave)RA3FDevSoundTonePlayToneOnceInitializedToPlayAudioTest(aTestName);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7258
	return self;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7259
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7260
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7261
void RA3FDevSoundTonePlayToneOnceInitializedToPlayAudioTest::DoKickoffTestL()
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7262
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7263
	if (!GetIntFromConfig(iTestStepName, KDuration, iDuration))
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7264
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7265
		ERR_PRINTF2(KMsgErrorGetParameter, &KDuration);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7266
		StopTest(KErrNotFound);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7267
		return;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7268
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7269
	if (!GetIntFromConfig(iTestStepName, KFrequencyTone1, iFrequencyTone1))
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7270
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7271
		ERR_PRINTF2(KMsgErrorGetParameter, &KFrequencyTone1);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7272
		StopTest(KErrNotFound);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7273
		return;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7274
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7275
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7276
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7277
void RA3FDevSoundTonePlayToneOnceInitializedToPlayAudioTest::Fsm(TMmfDevSoundEvent aDevSoundEvent, TInt aError)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7278
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7279
	switch (iDevSoundState)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7280
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7281
		case EStateCreated:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7282
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7283
			__ASSERT_ALWAYS((aError == KErrNone), Panic(_L("RA3FDevSoundTonePlayToneOnceInitializedToPlayAudioTest"), EFsmIncorrectErrorPassed));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7284
			if (aDevSoundEvent == EEventInitialize)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7285
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7286
				INFO_PRINTF1(_L("Calling CMMFDevSound::InitializeL for playing audio files"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7287
				TRAPD(err, iMMFDevSound->InitializeL(*this, EMMFStatePlaying));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7288
				if (err != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7289
					{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7290
					ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"), err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7291
					StopTest(err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7292
					break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7293
					}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7294
				INFO_PRINTF1(_L("DevSound State: EStateInitializing"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7295
				iDevSoundState = EStateInitializing;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7296
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7297
			else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7298
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7299
				ERR_PRINTF2(_L("DevSound EEventInitialize not received as expected. Received event: %d"), aDevSoundEvent);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7300
				StopTest(aError,  EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7301
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7302
			break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7303
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7304
		case EStateInitializing:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7305
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7306
			if (aDevSoundEvent == EEventInitComplete && aError == KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7307
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7308
				INFO_PRINTF3(_L("Calling CMMFDevSound::PlayToneL using %d Hz during %d secs"), iFrequencyTone1, iDuration);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7309
				TRAPD(err, iMMFDevSound->PlayToneL(iFrequencyTone1, iDuration*KMicroSecsInOneSec));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7310
				if (err	== KErrNotSupported)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7311
					{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7312
					ERR_PRINTF2(_L("CMMFDevSound::PlayToneL left with KErrNotSupported %d which is the expected error"), err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7313
					StopTest();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7314
					}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7315
				else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7316
					{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7317
					ERR_PRINTF2(_L("CMMFDevSound::PlayToneL left with error = %d"), err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7318
					ERR_PRINTF2(_L("Expected error = %d"), KErrNotSupported);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7319
					StopTest(err, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7320
					}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7321
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7322
			else if (aDevSoundEvent == EEventInitComplete && aError != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7323
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7324
				ERR_PRINTF2(_L("DevSound called CMMFDevSound::InitializeComplete with error = %d"), aError);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7325
				StopTest(aError);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7326
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7327
			else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7328
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7329
				ERR_PRINTF2(_L("DevSound EEventInitComplete not received as expected. Received event: %d"), aDevSoundEvent);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7330
				StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7331
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7332
			break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7333
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7334
		default:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7335
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7336
			ERR_PRINTF2(_L("Invalid DevSound state received: %d"), iDevSoundState);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7337
			StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7338
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7339
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7340
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7341
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7342
/*
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7343
 *========================================================================================================
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7344
 * MM-A3F-DEVSOUND-CHRTZ-TONE-0052
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7345
 */
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7346
RA3FDevSoundTonePlayDualToneOnceInitializedToPlayAudioTest::RA3FDevSoundTonePlayDualToneOnceInitializedToPlayAudioTest(const TDesC& aTestName)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7347
	:	RA3FDevSoundTestBase(aTestName), iDuration(0),
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7348
		iFrequencyTone1(0), iFrequencyTone2(0)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7349
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7350
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7351
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7352
RA3FDevSoundTonePlayDualToneOnceInitializedToPlayAudioTest* RA3FDevSoundTonePlayDualToneOnceInitializedToPlayAudioTest::NewL(const TDesC& aTestName)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7353
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7354
	RA3FDevSoundTonePlayDualToneOnceInitializedToPlayAudioTest * self = new(ELeave)RA3FDevSoundTonePlayDualToneOnceInitializedToPlayAudioTest(aTestName);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7355
	return self;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7356
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7357
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7358
void RA3FDevSoundTonePlayDualToneOnceInitializedToPlayAudioTest::DoKickoffTestL()
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7359
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7360
	if (!GetIntFromConfig(iTestStepName, KDuration, iDuration))
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7361
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7362
		ERR_PRINTF2(KMsgErrorGetParameter, &KDuration);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7363
		StopTest(KErrNotFound);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7364
		return;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7365
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7366
	if (!GetIntFromConfig(iTestStepName, KFrequencyTone1, iFrequencyTone1))
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7367
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7368
		ERR_PRINTF2(KMsgErrorGetParameter, &KFrequencyTone1);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7369
		StopTest(KErrNotFound);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7370
		return;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7371
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7372
	if (!GetIntFromConfig(iTestStepName, KFrequencyTone2, iFrequencyTone2))
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7373
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7374
		ERR_PRINTF2(KMsgErrorGetParameter, &KFrequencyTone2);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7375
		StopTest(KErrNotFound);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7376
		return;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7377
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7378
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7379
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7380
void RA3FDevSoundTonePlayDualToneOnceInitializedToPlayAudioTest::Fsm(TMmfDevSoundEvent aDevSoundEvent, TInt aError)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7381
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7382
	switch(iDevSoundState)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7383
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7384
		case EStateCreated:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7385
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7386
			__ASSERT_ALWAYS((aError == KErrNone), Panic(_L("RA3FDevSoundTonePlayDualToneOnceInitializedToPlayAudioTest"), EFsmIncorrectErrorPassed));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7387
			if (aDevSoundEvent == EEventInitialize)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7388
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7389
				INFO_PRINTF1(_L("Calling CMMFDevSound::InitializeL for playing audio files"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7390
				TRAPD(err, iMMFDevSound->InitializeL(*this, EMMFStatePlaying));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7391
				if (err != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7392
					{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7393
					ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"), err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7394
					StopTest(err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7395
					break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7396
					}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7397
				INFO_PRINTF1(_L("DevSound State: EStateInitializing"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7398
				iDevSoundState = EStateInitializing;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7399
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7400
			else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7401
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7402
				ERR_PRINTF2(_L("DevSound EEventInitialize not received as expected. Received event: %d"), aDevSoundEvent);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7403
				StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7404
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7405
			break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7406
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7407
		case EStateInitializing:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7408
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7409
			if (aDevSoundEvent == EEventInitComplete && aError == KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7410
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7411
				INFO_PRINTF4(_L("Calling CMMFDevSound::PlayDualToneL using %d Hz %d Hz during %d secs "), iFrequencyTone1, iFrequencyTone2, iDuration);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7412
				TRAPD(err, iMMFDevSound->PlayDualToneL(iFrequencyTone1, iFrequencyTone2, iDuration*KMicroSecsInOneSec));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7413
				if (err	== KErrNotSupported)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7414
					{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7415
					ERR_PRINTF2(_L("CMMFDevSound::PlayDualToneL left with KErrNotSupported %d which is the expected error"), err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7416
					StopTest(err, EPass);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7417
					}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7418
				else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7419
					{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7420
					ERR_PRINTF2(_L("CMMFDevSound::PlayDualToneL left with error = %d"), err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7421
					ERR_PRINTF2(_L("Expected error = %d"), KErrNotSupported);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7422
					StopTest(err, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7423
					}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7424
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7425
			else if (aDevSoundEvent == EEventInitComplete && aError != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7426
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7427
				ERR_PRINTF2(_L("DevSound called CMMFDevSound::InitializeComplete with error = %d"), aError);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7428
				StopTest(aError);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7429
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7430
			else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7431
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7432
				ERR_PRINTF2(_L("DevSound EEventInitComplete not received as expected. Received event: %d"), aDevSoundEvent);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7433
				StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7434
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7435
			break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7436
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7437
		default:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7438
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7439
			ERR_PRINTF2(_L("Invalid DevSound state received: %d"), iDevSoundState);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7440
			StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7441
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7442
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7443
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7444
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7445
/*
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7446
 *========================================================================================================
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7447
 * MM-A3F-DEVSOUND-CHRTZ-TONE-0053
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7448
 */
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7449
RA3FDevSoundTonePlayDTMFStringOnceInitializedToPlayAudioTest::RA3FDevSoundTonePlayDTMFStringOnceInitializedToPlayAudioTest(const TDesC& aTestName)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7450
	:	RA3FDevSoundTestBase(aTestName), iDTMFString(KNullDesC)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7451
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7452
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7453
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7454
RA3FDevSoundTonePlayDTMFStringOnceInitializedToPlayAudioTest* RA3FDevSoundTonePlayDTMFStringOnceInitializedToPlayAudioTest::NewL(const TDesC& aTestName)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7455
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7456
	RA3FDevSoundTonePlayDTMFStringOnceInitializedToPlayAudioTest * self = new(ELeave)RA3FDevSoundTonePlayDTMFStringOnceInitializedToPlayAudioTest(aTestName);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7457
	return self;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7458
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7459
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7460
void RA3FDevSoundTonePlayDTMFStringOnceInitializedToPlayAudioTest::DoKickoffTestL()
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7461
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7462
	TPtrC DTMF;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7463
	if (!GetStringFromConfig(iTestStepName, KDTMFString, DTMF))
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7464
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7465
		ERR_PRINTF2(KMsgErrorGetParameter, &KDTMFString);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7466
		StopTest(KErrNotFound);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7467
		return;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7468
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7469
	iDTMFString.Copy(DTMF);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7470
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7471
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7472
void RA3FDevSoundTonePlayDTMFStringOnceInitializedToPlayAudioTest::Fsm(TMmfDevSoundEvent aDevSoundEvent, TInt aError)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7473
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7474
	switch(iDevSoundState)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7475
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7476
		case EStateCreated:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7477
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7478
			__ASSERT_ALWAYS((aError == KErrNone), Panic(_L("RA3FDevSoundTonePlayDTMFStringOnceInitializedToPlayAudioTest"), EFsmIncorrectErrorPassed));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7479
			if (aDevSoundEvent == EEventInitialize)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7480
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7481
				INFO_PRINTF1(_L("Calling iMMFDevSound::InitializeL for playing audio files"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7482
				TRAPD(err, iMMFDevSound->InitializeL(*this, EMMFStatePlaying));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7483
				if (err != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7484
					{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7485
					ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"), err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7486
					StopTest(err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7487
					break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7488
					}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7489
				INFO_PRINTF1(_L("DevSound State: EStateInitializing"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7490
				iDevSoundState = EStateInitializing;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7491
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7492
			else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7493
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7494
				ERR_PRINTF2(_L("DevSound EEventInitialize not received as expected. Received event: %d"), aDevSoundEvent);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7495
				StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7496
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7497
			break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7498
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7499
		case EStateInitializing:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7500
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7501
			if (aDevSoundEvent == EEventInitComplete && aError == KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7502
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7503
				INFO_PRINTF2(_L("Calling CMMFDevSound::PlayDTMFStringL %S "), &iDTMFString);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7504
				TRAPD(err, iMMFDevSound->PlayDTMFStringL(iDTMFString));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7505
				if (err	== KErrNotSupported)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7506
					{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7507
					ERR_PRINTF2(_L("CMMFDevSound::PlayDTMFStringL left with KErrNotSupported %d which is the expected error"), err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7508
					StopTest();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7509
					}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7510
				else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7511
					{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7512
					ERR_PRINTF2(_L("CMMFDevSound::PlayDTMFStringL left with error = %d"), err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7513
					ERR_PRINTF2(_L("Expected error = %d"), KErrNotSupported);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7514
					StopTest(err, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7515
					}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7516
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7517
			else if (aDevSoundEvent == EEventInitComplete && aError != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7518
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7519
				ERR_PRINTF2(_L("DevSound called CMMFDevSound::InitializeComplete with error = %d"), aError);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7520
				StopTest(aError);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7521
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7522
			else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7523
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7524
				ERR_PRINTF2(_L("DevSound EEventInitComplete not received as expected. Received event: %d"), aDevSoundEvent);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7525
				StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7526
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7527
			break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7528
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7529
		default:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7530
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7531
			ERR_PRINTF2(_L("Invalid DevSound state received: %d"), iDevSoundState);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7532
			StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7533
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7534
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7535
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7536
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7537
/*
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7538
 *========================================================================================================
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7539
 * MM-A3F-DEVSOUND-CHRTZ-TONE-0054
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7540
 */
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7541
RA3FDevSoundTonePlayToneSequenceOnceInitializedToPlayAudioTest::RA3FDevSoundTonePlayToneSequenceOnceInitializedToPlayAudioTest(const TDesC& aTestName)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7542
	:	RA3FDevSoundTestBase(aTestName)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7543
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7544
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7545
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7546
RA3FDevSoundTonePlayToneSequenceOnceInitializedToPlayAudioTest* RA3FDevSoundTonePlayToneSequenceOnceInitializedToPlayAudioTest::NewL(const TDesC& aTestName)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7547
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7548
	RA3FDevSoundTonePlayToneSequenceOnceInitializedToPlayAudioTest * self = new(ELeave)RA3FDevSoundTonePlayToneSequenceOnceInitializedToPlayAudioTest(aTestName);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7549
	return self;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7550
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7551
void RA3FDevSoundTonePlayToneSequenceOnceInitializedToPlayAudioTest::DoKickoffTestL()
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7552
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7553
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7554
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7555
void RA3FDevSoundTonePlayToneSequenceOnceInitializedToPlayAudioTest::Fsm(TMmfDevSoundEvent aDevSoundEvent,  TInt aError)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7556
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7557
	switch(iDevSoundState)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7558
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7559
		case EStateCreated:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7560
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7561
			__ASSERT_ALWAYS((aError == KErrNone), Panic(_L("RA3FDevSoundTonePlayToneSequenceOnceInitializedToPlayAudioTest"), EFsmIncorrectErrorPassed));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7562
			if (aDevSoundEvent == EEventInitialize)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7563
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7564
				INFO_PRINTF1(_L("Calling iMMFDevSound::InitializeL for playing audio files"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7565
				TRAPD(err, iMMFDevSound->InitializeL(*this,  EMMFStatePlaying));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7566
				if (err != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7567
					{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7568
					ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"), err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7569
					StopTest(err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7570
					break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7571
					}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7572
				INFO_PRINTF1(_L("DevSound State: EStateInitializing"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7573
				iDevSoundState = EStateInitializing;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7574
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7575
			else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7576
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7577
				ERR_PRINTF2(_L("DevSound EEventInitialize not received as expected. Received event: %d"), aDevSoundEvent);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7578
				StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7579
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7580
			break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7581
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7582
		case EStateInitializing:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7583
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7584
			if (aDevSoundEvent == EEventInitComplete && aError == KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7585
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7586
				TUint8* tablePointer = const_cast<TUint8*>( &(KFixedSequenceTestSequenceDataX[0] ) );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7587
				TPtrC8 KFixedSequenceData(tablePointer,  sizeof(KFixedSequenceTestSequenceDataX));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7588
				INFO_PRINTF1(_L("Calling CMMFDevSound::PlayToneSequenceL"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7589
				TRAPD(err,  iMMFDevSound->PlayToneSequenceL(KFixedSequenceData));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7590
				if (err == KErrNotSupported)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7591
					{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7592
					ERR_PRINTF2(_L("CMMFDevSound::PlayToneSequenceL left with KErrNotSupported %d which is the expected error"), err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7593
					StopTest(err, EPass);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7594
					}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7595
				else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7596
					{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7597
					ERR_PRINTF2(_L("Play  dual tone failed with error = %d"),  err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7598
					ERR_PRINTF2(_L("Expected error = %d"), KErrNotSupported);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7599
					StopTest(err, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7600
					}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7601
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7602
			else if (aDevSoundEvent == EEventInitComplete && aError != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7603
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7604
				ERR_PRINTF2(_L("DevSound called CMMFDevSound::InitializeComplete with error = %d"), aError);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7605
				StopTest(aError);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7606
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7607
			else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7608
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7609
				ERR_PRINTF2(_L("DevSound EEventInitComplete not received as expected. Received event: %d"), aDevSoundEvent);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7610
				StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7611
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7612
			break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7613
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7614
		default:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7615
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7616
			ERR_PRINTF2(_L("Invalid DevSound state received: %d"), iDevSoundState);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7617
			StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7618
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7619
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7620
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7621
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7622
/*
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7623
 *========================================================================================================
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7624
 * MM-A3F-DEVSOUND-CHRTZ-TONE-0055
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7625
 */
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7626
RA3FDevSoundTonePlayToneOnceInitializedToRecordAudioTest::RA3FDevSoundTonePlayToneOnceInitializedToRecordAudioTest(const TDesC& aTestName)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7627
	:	RA3FDevSoundTestBase(aTestName), iDuration(0),
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7628
		iFrequencyTone1(0)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7629
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7630
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7631
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7632
RA3FDevSoundTonePlayToneOnceInitializedToRecordAudioTest* RA3FDevSoundTonePlayToneOnceInitializedToRecordAudioTest::NewL(const TDesC& aTestName)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7633
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7634
	RA3FDevSoundTonePlayToneOnceInitializedToRecordAudioTest * self = new(ELeave)RA3FDevSoundTonePlayToneOnceInitializedToRecordAudioTest(aTestName);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7635
	return self;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7636
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7637
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7638
void RA3FDevSoundTonePlayToneOnceInitializedToRecordAudioTest::DoKickoffTestL()
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7639
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7640
	if (!GetIntFromConfig(iTestStepName, KDuration, iDuration))
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7641
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7642
		ERR_PRINTF2(KMsgErrorGetParameter, &KDuration);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7643
		StopTest(KErrNotFound);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7644
		return;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7645
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7646
	if (!GetIntFromConfig(iTestStepName, KFrequencyTone1, iFrequencyTone1))
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7647
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7648
		ERR_PRINTF2(KMsgErrorGetParameter, &KFrequencyTone1);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7649
		StopTest(KErrNotFound);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7650
		return;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7651
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7652
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7653
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7654
void RA3FDevSoundTonePlayToneOnceInitializedToRecordAudioTest::Fsm(TMmfDevSoundEvent aDevSoundEvent, TInt aError)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7655
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7656
	switch (iDevSoundState)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7657
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7658
		case EStateCreated:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7659
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7660
			__ASSERT_ALWAYS((aError == KErrNone), Panic(_L("RA3FDevSoundTonePlayToneOnceInitializedToRecordAudioTest"), EFsmIncorrectErrorPassed));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7661
			if (aDevSoundEvent == EEventInitialize)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7662
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7663
				INFO_PRINTF1(_L("Calling CMMFDevSound::InitializeL for recording audio files"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7664
				TRAPD(err, iMMFDevSound->InitializeL(*this, EMMFStateRecording));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7665
				if (err != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7666
					{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7667
					ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"), err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7668
					StopTest(err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7669
					break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7670
					}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7671
				INFO_PRINTF1(_L("DevSound State: EStateInitializing"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7672
				iDevSoundState = EStateInitializing;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7673
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7674
			else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7675
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7676
				ERR_PRINTF2(_L("DevSound EEventInitialize not received as expected. Received event: %d"), aDevSoundEvent);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7677
				StopTest(aError,  EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7678
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7679
			break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7680
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7681
		case EStateInitializing:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7682
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7683
			if (aDevSoundEvent == EEventInitComplete && aError == KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7684
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7685
				INFO_PRINTF3(_L("Calling CMMFDevSound::PlayToneL using %d Hz during %d secs"), iFrequencyTone1, iDuration);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7686
				TRAPD(err, iMMFDevSound->PlayToneL(iFrequencyTone1, iDuration*KMicroSecsInOneSec));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7687
				if (err	== KErrNotSupported)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7688
					{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7689
					ERR_PRINTF2(_L("CMMFDevSound::PlayToneL left with KErrNotSupported %d which is the expected error"), err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7690
					StopTest();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7691
					}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7692
				else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7693
					{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7694
					ERR_PRINTF2(_L("CMMFDevSound::PlayToneL left with error = %d"), err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7695
					ERR_PRINTF2(_L("Expected error = %d"), KErrNotSupported);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7696
					StopTest(err, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7697
					}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7698
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7699
			else if (aDevSoundEvent == EEventInitComplete && aError != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7700
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7701
				ERR_PRINTF2(_L("DevSound called CMMFDevSound::InitializeComplete with error = %d"), aError);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7702
				StopTest(aError);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7703
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7704
			else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7705
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7706
				ERR_PRINTF2(_L("DevSound EEventInitComplete not received as expected. Received event: %d"), aDevSoundEvent);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7707
				StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7708
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7709
			break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7710
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7711
		default:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7712
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7713
			ERR_PRINTF2(_L("Invalid DevSound state received: %d"), iDevSoundState);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7714
			StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7715
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7716
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7717
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7718
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7719
/*
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7720
 *========================================================================================================
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7721
 * MM-A3F-DEVSOUND-CHRTZ-TONE-0056
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7722
 */
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7723
RA3FDevSoundTonePlayDualToneOnceInitializedToRecordAudioTest::RA3FDevSoundTonePlayDualToneOnceInitializedToRecordAudioTest(const TDesC& aTestName)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7724
	:	RA3FDevSoundTestBase(aTestName), iDuration(0),
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7725
		iFrequencyTone1(0), iFrequencyTone2(0)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7726
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7727
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7728
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7729
RA3FDevSoundTonePlayDualToneOnceInitializedToRecordAudioTest* RA3FDevSoundTonePlayDualToneOnceInitializedToRecordAudioTest::NewL(const TDesC& aTestName)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7730
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7731
	RA3FDevSoundTonePlayDualToneOnceInitializedToRecordAudioTest * self = new(ELeave)RA3FDevSoundTonePlayDualToneOnceInitializedToRecordAudioTest(aTestName);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7732
	return self;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7733
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7734
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7735
void RA3FDevSoundTonePlayDualToneOnceInitializedToRecordAudioTest::DoKickoffTestL()
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7736
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7737
	if (!GetIntFromConfig(iTestStepName, KDuration, iDuration))
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7738
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7739
		ERR_PRINTF2(KMsgErrorGetParameter, &KDuration);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7740
		StopTest(KErrNotFound);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7741
		return;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7742
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7743
	if (!GetIntFromConfig(iTestStepName, KFrequencyTone1, iFrequencyTone1))
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7744
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7745
		ERR_PRINTF2(KMsgErrorGetParameter, &KFrequencyTone1);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7746
		StopTest(KErrNotFound);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7747
		return;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7748
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7749
	if (!GetIntFromConfig(iTestStepName, KFrequencyTone2, iFrequencyTone2))
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7750
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7751
		ERR_PRINTF2(KMsgErrorGetParameter, &KFrequencyTone2);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7752
		StopTest(KErrNotFound);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7753
		return;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7754
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7755
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7756
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7757
void RA3FDevSoundTonePlayDualToneOnceInitializedToRecordAudioTest::Fsm(TMmfDevSoundEvent aDevSoundEvent, TInt aError)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7758
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7759
	switch(iDevSoundState)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7760
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7761
		case EStateCreated:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7762
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7763
			__ASSERT_ALWAYS((aError == KErrNone), Panic(_L("RA3FDevSoundTonePlayDualToneOnceInitializedToRecordAudioTest"), EFsmIncorrectErrorPassed));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7764
			if (aDevSoundEvent == EEventInitialize)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7765
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7766
				INFO_PRINTF1(_L("Calling CMMFDevSound::InitializeL for recording audio files"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7767
				TRAPD(err, iMMFDevSound->InitializeL(*this, EMMFStateRecording));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7768
				if (err != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7769
					{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7770
					ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"), err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7771
					StopTest(err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7772
					break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7773
					}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7774
				INFO_PRINTF1(_L("DevSound State: EStateInitializing"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7775
				iDevSoundState = EStateInitializing;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7776
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7777
			else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7778
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7779
				ERR_PRINTF2(_L("DevSound EEventInitialize not received as expected. Received event: %d"), aDevSoundEvent);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7780
				StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7781
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7782
			break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7783
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7784
		case EStateInitializing:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7785
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7786
			if (aDevSoundEvent == EEventInitComplete && aError == KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7787
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7788
				INFO_PRINTF4(_L("Calling CMMFDevSound::PlayDualToneL using %d Hz %d Hz during %d secs "), iFrequencyTone1, iFrequencyTone2, iDuration);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7789
				TRAPD(err, iMMFDevSound->PlayDualToneL(iFrequencyTone1, iFrequencyTone2, iDuration*KMicroSecsInOneSec));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7790
				if (err	== KErrNotSupported)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7791
					{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7792
					ERR_PRINTF2(_L("CMMFDevSound::PlayDualToneL left with KErrNotSupported %d which is the expected error"), err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7793
					StopTest(err, EPass);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7794
					}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7795
				else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7796
					{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7797
					ERR_PRINTF2(_L("CMMFDevSound::PlayDualToneL left with error = %d"), err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7798
					ERR_PRINTF2(_L("Expected error = %d"), KErrNotSupported);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7799
					StopTest(err, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7800
					}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7801
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7802
			else if (aDevSoundEvent == EEventInitComplete && aError != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7803
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7804
				ERR_PRINTF2(_L("DevSound called CMMFDevSound::InitializeComplete with error = %d"), aError);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7805
				StopTest(aError);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7806
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7807
			else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7808
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7809
				ERR_PRINTF2(_L("DevSound EEventInitComplete not received as expected. Received event: %d"), aDevSoundEvent);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7810
				StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7811
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7812
			break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7813
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7814
		default:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7815
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7816
			ERR_PRINTF2(_L("Invalid DevSound state received: %d"), iDevSoundState);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7817
			StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7818
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7819
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7820
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7821
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7822
/*
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7823
 *========================================================================================================
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7824
 * MM-A3F-DEVSOUND-CHRTZ-TONE-0057
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7825
 */
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7826
RA3FDevSoundTonePlayDTMFStringOnceInitializedToRecordAudioTest::RA3FDevSoundTonePlayDTMFStringOnceInitializedToRecordAudioTest(const TDesC& aTestName)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7827
	:	RA3FDevSoundTestBase(aTestName), iDTMFString(KNullDesC)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7828
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7829
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7830
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7831
RA3FDevSoundTonePlayDTMFStringOnceInitializedToRecordAudioTest* RA3FDevSoundTonePlayDTMFStringOnceInitializedToRecordAudioTest::NewL(const TDesC& aTestName)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7832
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7833
	RA3FDevSoundTonePlayDTMFStringOnceInitializedToRecordAudioTest * self = new(ELeave)RA3FDevSoundTonePlayDTMFStringOnceInitializedToRecordAudioTest(aTestName);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7834
	return self;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7835
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7836
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7837
void RA3FDevSoundTonePlayDTMFStringOnceInitializedToRecordAudioTest::DoKickoffTestL()
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7838
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7839
	TPtrC DTMF;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7840
	if (!GetStringFromConfig(iTestStepName, KDTMFString, DTMF))
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7841
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7842
		ERR_PRINTF2(KMsgErrorGetParameter, &KDTMFString);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7843
		StopTest(KErrNotFound);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7844
		return;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7845
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7846
	iDTMFString.Copy(DTMF);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7847
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7848
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7849
void RA3FDevSoundTonePlayDTMFStringOnceInitializedToRecordAudioTest::Fsm(TMmfDevSoundEvent aDevSoundEvent, TInt aError)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7850
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7851
	switch(iDevSoundState)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7852
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7853
		case EStateCreated:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7854
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7855
			__ASSERT_ALWAYS((aError == KErrNone), Panic(_L("RA3FDevSoundTonePlayDTMFStringOnceInitializedToRecordAudioTest"), EFsmIncorrectErrorPassed));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7856
			if (aDevSoundEvent == EEventInitialize)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7857
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7858
				INFO_PRINTF1(_L("Calling iMMFDevSound::InitializeL for recording audio files"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7859
				TRAPD(err, iMMFDevSound->InitializeL(*this, EMMFStateRecording));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7860
				if (err != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7861
					{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7862
					ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"), err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7863
					StopTest(err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7864
					break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7865
					}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7866
				INFO_PRINTF1(_L("DevSound State: EStateInitializing"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7867
				iDevSoundState = EStateInitializing;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7868
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7869
			else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7870
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7871
				ERR_PRINTF2(_L("DevSound EEventInitialize not received as expected. Received event: %d"), aDevSoundEvent);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7872
				StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7873
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7874
			break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7875
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7876
		case EStateInitializing:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7877
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7878
			if (aDevSoundEvent == EEventInitComplete && aError == KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7879
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7880
				INFO_PRINTF2(_L("Calling CMMFDevSound::PlayDTMFStringL %S "), &iDTMFString);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7881
				TRAPD(err, iMMFDevSound->PlayDTMFStringL(iDTMFString));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7882
				if (err	== KErrNotSupported)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7883
					{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7884
					ERR_PRINTF2(_L("CMMFDevSound::PlayDTMFStringL left with KErrNotSupported %d which is the expected error"), err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7885
					StopTest();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7886
					}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7887
				else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7888
					{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7889
					ERR_PRINTF2(_L("CMMFDevSound::PlayDTMFStringL left with error = %d"), err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7890
					ERR_PRINTF2(_L("Expected error = %d"), KErrNotSupported);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7891
					StopTest(err, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7892
					}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7893
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7894
			else if (aDevSoundEvent == EEventInitComplete && aError != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7895
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7896
				ERR_PRINTF2(_L("DevSound called CMMFDevSound::InitializeComplete with error = %d"), aError);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7897
				StopTest(aError);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7898
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7899
			else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7900
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7901
				ERR_PRINTF2(_L("DevSound EEventInitComplete not received as expected. Received event: %d"), aDevSoundEvent);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7902
				StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7903
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7904
			break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7905
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7906
		default:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7907
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7908
			ERR_PRINTF2(_L("Invalid DevSound state received: %d"), iDevSoundState);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7909
			StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7910
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7911
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7912
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7913
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7914
/*
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7915
 *========================================================================================================
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7916
 * MM-A3F-DEVSOUND-CHRTZ-TONE-0058
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7917
 */
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7918
RA3FDevSoundTonePlayToneSequenceOnceInitializedToRecordAudioTest::RA3FDevSoundTonePlayToneSequenceOnceInitializedToRecordAudioTest(const TDesC& aTestName)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7919
	:	RA3FDevSoundTestBase(aTestName)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7920
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7921
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7922
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7923
RA3FDevSoundTonePlayToneSequenceOnceInitializedToRecordAudioTest* RA3FDevSoundTonePlayToneSequenceOnceInitializedToRecordAudioTest::NewL(const TDesC& aTestName)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7924
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7925
	RA3FDevSoundTonePlayToneSequenceOnceInitializedToRecordAudioTest * self = new(ELeave)RA3FDevSoundTonePlayToneSequenceOnceInitializedToRecordAudioTest(aTestName);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7926
	return self;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7927
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7928
void RA3FDevSoundTonePlayToneSequenceOnceInitializedToRecordAudioTest::DoKickoffTestL()
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7929
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7930
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7931
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7932
void RA3FDevSoundTonePlayToneSequenceOnceInitializedToRecordAudioTest::Fsm(TMmfDevSoundEvent aDevSoundEvent,  TInt aError)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7933
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7934
	switch(iDevSoundState)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7935
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7936
		case EStateCreated:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7937
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7938
			__ASSERT_ALWAYS((aError == KErrNone), Panic(_L("RA3FDevSoundTonePlayToneSequenceOnceInitializedToRecordAudioTest"), EFsmIncorrectErrorPassed));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7939
			if (aDevSoundEvent == EEventInitialize)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7940
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7941
				INFO_PRINTF1(_L("Calling iMMFDevSound::InitializeL for playing audio files"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7942
				TRAPD(err, iMMFDevSound->InitializeL(*this,  EMMFStateRecording));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7943
				if (err != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7944
					{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7945
					ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"), err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7946
					StopTest(err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7947
					break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7948
					}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7949
				INFO_PRINTF1(_L("DevSound State: EStateInitializing"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7950
				iDevSoundState = EStateInitializing;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7951
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7952
			else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7953
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7954
				ERR_PRINTF2(_L("DevSound EEventInitialize not received as expected. Received event: %d"), aDevSoundEvent);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7955
				StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7956
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7957
			break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7958
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7959
		case EStateInitializing:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7960
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7961
			if (aDevSoundEvent == EEventInitComplete && aError == KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7962
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7963
				TUint8* tablePointer = const_cast<TUint8*>( &(KFixedSequenceTestSequenceDataX[0] ) );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7964
				TPtrC8 KFixedSequenceData(tablePointer,  sizeof(KFixedSequenceTestSequenceDataX));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7965
				INFO_PRINTF1(_L("Calling CMMFDevSound::PlayToneSequenceL"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7966
				TRAPD(err,  iMMFDevSound->PlayToneSequenceL(KFixedSequenceData));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7967
				if (err == KErrNotSupported)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7968
					{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7969
					ERR_PRINTF2(_L("CMMFDevSound::PlayToneSequenceL left with KErrNotSupported %d which is the expected error"), err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7970
					StopTest(err, EPass);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7971
					}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7972
				else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7973
					{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7974
					ERR_PRINTF2(_L("Play  dual tone failed with error = %d"),  err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7975
					ERR_PRINTF2(_L("Expected error = %d"), KErrNotSupported);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7976
					StopTest(err, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7977
					}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7978
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7979
			else if (aDevSoundEvent == EEventInitComplete && aError != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7980
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7981
				ERR_PRINTF2(_L("DevSound called CMMFDevSound::InitializeComplete with error = %d"), aError);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7982
				StopTest(aError);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7983
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7984
			else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7985
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7986
				ERR_PRINTF2(_L("DevSound EEventInitComplete not received as expected. Received event: %d"), aDevSoundEvent);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7987
				StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7988
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7989
			break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7990
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7991
		default:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7992
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7993
			ERR_PRINTF2(_L("Invalid DevSound state received: %d"), iDevSoundState);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7994
			StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7995
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7996
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7997
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7998
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  7999
/*
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8000
 *========================================================================================================
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8001
 * MM-A3F-DEVSOUND-CHRTZ-TONE-0059
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8002
 */
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8003
RA3FDevSoundTonePlayToneWithoutCallingInitializeTest::RA3FDevSoundTonePlayToneWithoutCallingInitializeTest(const TDesC& aTestName)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8004
	:	RA3FDevSoundTestBase(aTestName), iDuration(0),
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8005
		iFrequencyTone1(0)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8006
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8007
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8008
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8009
RA3FDevSoundTonePlayToneWithoutCallingInitializeTest* RA3FDevSoundTonePlayToneWithoutCallingInitializeTest::NewL(const TDesC& aTestName)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8010
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8011
	RA3FDevSoundTonePlayToneWithoutCallingInitializeTest * self = new(ELeave)RA3FDevSoundTonePlayToneWithoutCallingInitializeTest(aTestName);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8012
	return self;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8013
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8014
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8015
void RA3FDevSoundTonePlayToneWithoutCallingInitializeTest::DoKickoffTestL()
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8016
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8017
	if (!GetIntFromConfig(iTestStepName, KDuration, iDuration))
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8018
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8019
		ERR_PRINTF2(KMsgErrorGetParameter, &KDuration);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8020
		StopTest(KErrNotFound);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8021
		return;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8022
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8023
	if (!GetIntFromConfig(iTestStepName, KFrequencyTone1, iFrequencyTone1))
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8024
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8025
		ERR_PRINTF2(KMsgErrorGetParameter, &KFrequencyTone1);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8026
		StopTest(KErrNotFound);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8027
		return;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8028
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8029
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8030
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8031
void RA3FDevSoundTonePlayToneWithoutCallingInitializeTest::Fsm(TMmfDevSoundEvent aDevSoundEvent,  TInt aError)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8032
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8033
	switch (iDevSoundState)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8034
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8035
		case EStateCreated:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8036
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8037
			__ASSERT_ALWAYS((aError == KErrNone), Panic(_L("RA3FDevSoundTonePlayToneWithoutCallingInitializeTest"), EFsmIncorrectErrorPassed));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8038
			if (aDevSoundEvent == EEventInitialize)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8039
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8040
				INFO_PRINTF3(_L("Calling CMMFDevSound::PlayToneL using %d Hz during %d secs"), iFrequencyTone1, iDuration);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8041
				TRAPD(err, iMMFDevSound->PlayToneL(iFrequencyTone1, iDuration*KMicroSecsInOneSec));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8042
				if (err	== KErrNotReady)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8043
					{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8044
					ERR_PRINTF2(_L("CMMFDevSound::PlayToneL left with KErrNotReady %d which is the expected error"), err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8045
					StopTest();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8046
					}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8047
				else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8048
					{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8049
					ERR_PRINTF2(_L("CMMFDevSound::PlayToneL left with error = %d"), err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8050
					ERR_PRINTF2(_L("Expected error = %d"), KErrNotReady);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8051
					StopTest(err, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8052
					}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8053
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8054
			else if (aDevSoundEvent == EEventInitComplete && aError != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8055
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8056
				ERR_PRINTF2(_L("DevSound called CMMFDevSound::InitializeComplete with error = %d"), aError);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8057
				StopTest(aError);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8058
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8059
			else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8060
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8061
				ERR_PRINTF2(_L("DevSound EEventInitComplete not received as expected. Received event: %d"), aDevSoundEvent);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8062
				StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8063
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8064
			break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8065
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8066
		default:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8067
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8068
			ERR_PRINTF2(_L("Invalid DevSound state received: %d"),  iDevSoundState);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8069
			StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8070
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8071
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8072
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8073
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8074
/*
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8075
 *========================================================================================================
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8076
 * MM-A3F-DEVSOUND-CHRTZ-TONE-0060
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8077
 */
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8078
RA3FDevSoundTonePlayDualToneWithoutCallingInitializeTest::RA3FDevSoundTonePlayDualToneWithoutCallingInitializeTest(const TDesC& aTestName)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8079
	:	RA3FDevSoundTestBase(aTestName), iDuration(0),
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8080
		iFrequencyTone1(0), iFrequencyTone2(0)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8081
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8082
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8083
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8084
RA3FDevSoundTonePlayDualToneWithoutCallingInitializeTest* RA3FDevSoundTonePlayDualToneWithoutCallingInitializeTest::NewL(const TDesC& aTestName)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8085
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8086
	RA3FDevSoundTonePlayDualToneWithoutCallingInitializeTest * self = new(ELeave)RA3FDevSoundTonePlayDualToneWithoutCallingInitializeTest(aTestName);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8087
	return self;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8088
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8089
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8090
void RA3FDevSoundTonePlayDualToneWithoutCallingInitializeTest::DoKickoffTestL()
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8091
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8092
	if (!GetIntFromConfig(iTestStepName, KDuration, iDuration))
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8093
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8094
		ERR_PRINTF2(KMsgErrorGetParameter, &KDuration);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8095
		StopTest(KErrNotFound);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8096
		return;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8097
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8098
	if (!GetIntFromConfig(iTestStepName, KFrequencyTone1, iFrequencyTone1))
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8099
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8100
		ERR_PRINTF2(KMsgErrorGetParameter, &KFrequencyTone1);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8101
		StopTest(KErrNotFound);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8102
		return;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8103
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8104
	if (!GetIntFromConfig(iTestStepName, KFrequencyTone2, iFrequencyTone2))
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8105
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8106
		ERR_PRINTF2(KMsgErrorGetParameter, &KFrequencyTone2);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8107
		StopTest(KErrNotFound);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8108
		return;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8109
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8110
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8111
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8112
void RA3FDevSoundTonePlayDualToneWithoutCallingInitializeTest::Fsm(TMmfDevSoundEvent aDevSoundEvent, TInt aError)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8113
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8114
	switch (iDevSoundState)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8115
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8116
		case EStateCreated:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8117
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8118
			__ASSERT_ALWAYS((aError == KErrNone), Panic(_L("RA3FDevSoundTonePlayDualToneWithoutCallingInitializeTest"), EFsmIncorrectErrorPassed));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8119
			if (aDevSoundEvent == EEventInitialize)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8120
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8121
				INFO_PRINTF4(_L("Calling CMMFDevSound::PlayDualToneL using %d Hz %d Hz during %d secs "), iFrequencyTone1, iFrequencyTone2, iDuration);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8122
				TRAPD(err, iMMFDevSound->PlayDualToneL(iFrequencyTone1, iFrequencyTone2, iDuration*KMicroSecsInOneSec));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8123
				if (err == KErrNotReady)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8124
					{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8125
					ERR_PRINTF2(_L("CMMFDevSound::PlayDualToneL left with KErrNotReady %d which is the expected error"), err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8126
					StopTest();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8127
					}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8128
				else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8129
					{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8130
					ERR_PRINTF2(_L("CMMFDevSound::PlayDualToneL left with error = %d"), err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8131
					ERR_PRINTF2(_L("Expected error = %d"), KErrNotReady);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8132
					StopTest(err, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8133
					}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8134
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8135
			else if (aDevSoundEvent == EEventInitComplete && aError != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8136
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8137
				ERR_PRINTF2(_L("DevSound called CMMFDevSound::InitializeComplete with error = %d"), aError);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8138
				StopTest(aError);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8139
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8140
			else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8141
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8142
				ERR_PRINTF2(_L("DevSound EEventInitComplete not received as expected. Received event: %d"), aDevSoundEvent);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8143
				StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8144
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8145
			break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8146
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8147
		default:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8148
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8149
			ERR_PRINTF2(_L("Invalid DevSound state received: %d"), iDevSoundState);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8150
			StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8151
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8152
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8153
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8154
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8155
/*
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8156
 *========================================================================================================
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8157
 * MM-A3F-DEVSOUND-CHRTZ-TONE-0061
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8158
 */
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8159
RA3FDevSoundTonePlayDTMFStringWithoutCallingInitializeTest::RA3FDevSoundTonePlayDTMFStringWithoutCallingInitializeTest(const TDesC& aTestName)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8160
	:	RA3FDevSoundTestBase(aTestName), iDTMFString(KNullDesC)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8161
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8162
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8163
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8164
RA3FDevSoundTonePlayDTMFStringWithoutCallingInitializeTest* RA3FDevSoundTonePlayDTMFStringWithoutCallingInitializeTest::NewL(const TDesC& aTestName)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8165
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8166
	RA3FDevSoundTonePlayDTMFStringWithoutCallingInitializeTest * self = new(ELeave)RA3FDevSoundTonePlayDTMFStringWithoutCallingInitializeTest(aTestName);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8167
	return self;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8168
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8169
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8170
void RA3FDevSoundTonePlayDTMFStringWithoutCallingInitializeTest::DoKickoffTestL()
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8171
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8172
	TPtrC DTMF;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8173
	if (!GetStringFromConfig(iTestStepName, KDTMFString, DTMF))
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8174
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8175
		ERR_PRINTF2(KMsgErrorGetParameter, &KDTMFString);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8176
		StopTest(KErrNotFound);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8177
		return;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8178
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8179
	iDTMFString.Copy(DTMF);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8180
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8181
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8182
void RA3FDevSoundTonePlayDTMFStringWithoutCallingInitializeTest::Fsm(TMmfDevSoundEvent aDevSoundEvent,  TInt aError)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8183
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8184
	switch (iDevSoundState)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8185
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8186
		case EStateCreated:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8187
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8188
			__ASSERT_ALWAYS((aError == KErrNone), Panic(_L("RA3FDevSoundTonePlayDTMFStringWithoutCallingInitializeTest"), EFsmIncorrectErrorPassed));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8189
			if (aDevSoundEvent == EEventInitialize)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8190
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8191
				INFO_PRINTF2(_L("Calling CMMFDevSound::PlayDTMFStringL %S"), &iDTMFString);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8192
				TRAPD(err, iMMFDevSound->PlayDTMFStringL(iDTMFString));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8193
				if (err == KErrNotReady)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8194
					{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8195
					ERR_PRINTF2(_L("CMMFDevSound::PlayDTMFStringL left with KErrNotReady %d which is the expected error"), err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8196
					StopTest();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8197
					}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8198
				else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8199
					{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8200
					ERR_PRINTF2(_L("CMMFDevSound::PlayDTMFStringL left with error = %d"), err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8201
					ERR_PRINTF2(_L("Expected error = %d"), KErrNotReady);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8202
					StopTest(err, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8203
					}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8204
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8205
			else if (aDevSoundEvent == EEventInitComplete && aError != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8206
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8207
				ERR_PRINTF2(_L("DevSound called CMMFDevSound::InitializeComplete with error = %d"), aError);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8208
				StopTest(aError);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8209
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8210
			else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8211
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8212
				ERR_PRINTF2(_L("DevSound EEventInitComplete not received as expected. Received event: %d"), aDevSoundEvent);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8213
				StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8214
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8215
			break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8216
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8217
		default:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8218
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8219
			ERR_PRINTF2(_L("Invalid DevSound state received: %d"), iDevSoundState);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8220
			StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8221
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8222
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8223
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8224
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8225
/*
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8226
 *========================================================================================================
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8227
 * MM-A3F-DEVSOUND-CHRTZ-TONE-0062
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8228
 */
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8229
RA3FDevSoundTonePlayToneSequenceWithoutCallingInitializeTest::RA3FDevSoundTonePlayToneSequenceWithoutCallingInitializeTest(const TDesC& aTestName)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8230
	:	RA3FDevSoundTestBase(aTestName)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8231
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8232
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8233
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8234
RA3FDevSoundTonePlayToneSequenceWithoutCallingInitializeTest* RA3FDevSoundTonePlayToneSequenceWithoutCallingInitializeTest::NewL(const TDesC& aTestName)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8235
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8236
	RA3FDevSoundTonePlayToneSequenceWithoutCallingInitializeTest * self = new(ELeave)RA3FDevSoundTonePlayToneSequenceWithoutCallingInitializeTest(aTestName);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8237
	return self;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8238
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8239
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8240
void RA3FDevSoundTonePlayToneSequenceWithoutCallingInitializeTest::DoKickoffTestL()
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8241
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8242
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8243
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8244
void RA3FDevSoundTonePlayToneSequenceWithoutCallingInitializeTest::Fsm(TMmfDevSoundEvent aDevSoundEvent, TInt aError)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8245
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8246
	switch (iDevSoundState)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8247
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8248
		case EStateCreated:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8249
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8250
			__ASSERT_ALWAYS((aError == KErrNone), Panic(_L("RA3FDevSoundTonePlayToneSequenceWithoutCallingInitializeTest"), EFsmIncorrectErrorPassed));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8251
			if (aDevSoundEvent == EEventInitialize)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8252
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8253
				TUint8* tablePointer = const_cast<TUint8*>( &(KFixedSequenceTestSequenceDataX[0] ) );
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8254
				TPtrC8 KFixedSequenceData(tablePointer,  sizeof(KFixedSequenceTestSequenceDataX));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8255
				INFO_PRINTF1(_L("Calling CMMFDevSound::PlayToneSequenceL"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8256
				TRAPD(err, iMMFDevSound->PlayToneSequenceL(KFixedSequenceData));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8257
				if (err == KErrNotReady)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8258
					{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8259
					ERR_PRINTF2(_L("CMMFDevSound::PlayToneSequenceL left with KErrNotReady %d which is the expected error"), err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8260
					StopTest();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8261
					}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8262
				else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8263
					{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8264
					ERR_PRINTF2(_L("CMMFDevSound::PlayToneSequenceL left with error = %d"), err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8265
					ERR_PRINTF2(_L("Expected error = %d"), KErrNotReady);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8266
					StopTest(err, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8267
					}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8268
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8269
			else if (aDevSoundEvent == EEventInitComplete && aError != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8270
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8271
				ERR_PRINTF2(_L("DevSound called CMMFDevSound::InitializeComplete with error = %d"), aError);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8272
				StopTest(aError);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8273
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8274
			else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8275
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8276
				ERR_PRINTF2(_L("DevSound EEventInitComplete not received as expected. Received event: %d"), aDevSoundEvent);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8277
				StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8278
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8279
			break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8280
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8281
		default:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8282
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8283
			ERR_PRINTF2(_L("Invalid DevSound state received: %d"), iDevSoundState);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8284
			StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8285
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8286
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8287
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8288
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8289
/*
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8290
 *========================================================================================================
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8291
 * MM-A3F-DEVSOUND-CHRTZ-TONE-0063
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8292
 */
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8293
RA3FDevSoundTonePlayToneSequenceUsingInvalidDescriptorTest::RA3FDevSoundTonePlayToneSequenceUsingInvalidDescriptorTest(const TDesC& aTestName)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8294
	:	RA3FDevSoundTestBase(aTestName), iInvalidToneSequence(KNullDesC8)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8295
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8296
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8297
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8298
RA3FDevSoundTonePlayToneSequenceUsingInvalidDescriptorTest* RA3FDevSoundTonePlayToneSequenceUsingInvalidDescriptorTest::NewL(const TDesC& aTestName)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8299
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8300
	RA3FDevSoundTonePlayToneSequenceUsingInvalidDescriptorTest * self = new(ELeave)RA3FDevSoundTonePlayToneSequenceUsingInvalidDescriptorTest(aTestName);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8301
	return self;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8302
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8303
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8304
void RA3FDevSoundTonePlayToneSequenceUsingInvalidDescriptorTest::DoKickoffTestL()
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8305
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8306
	TPtrC TS;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8307
	if ( !GetStringFromConfig(iTestStepName, KInvalidToneSequence,  TS) )
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8308
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8309
		ERR_PRINTF2(KMsgErrorGetParameter, &KInvalidToneSequence);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8310
		StopTest(KErrNotFound);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8311
		return;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8312
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8313
	iInvalidToneSequence.Copy(TS);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8314
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8315
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8316
void RA3FDevSoundTonePlayToneSequenceUsingInvalidDescriptorTest::Fsm(TMmfDevSoundEvent aDevSoundEvent,  TInt aError)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8317
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8318
	switch (iDevSoundState)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8319
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8320
		case EStateCreated:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8321
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8322
			__ASSERT_ALWAYS((aError == KErrNone), Panic(_L("RA3FDevSoundTonePlayToneSequenceUsingInvalidDescriptorTest"), EFsmIncorrectErrorPassed));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8323
			if (aDevSoundEvent == EEventInitialize)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8324
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8325
				INFO_PRINTF1(_L("Calling iMMFDevSound::InitializeL"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8326
				TRAPD(err, iMMFDevSound->InitializeL(*this, EMMFStateTonePlaying));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8327
				if (err != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8328
					{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8329
					ERR_PRINTF2(_L("CMMFDevSound::InitializeL left with error = %d"),  err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8330
					StopTest(err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8331
					break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8332
					}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8333
				INFO_PRINTF1(_L("DevSound State: EStateInitializing"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8334
				iDevSoundState = EStateInitializing;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8335
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8336
			else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8337
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8338
				ERR_PRINTF2(_L("DevSound EEventInitialize not received as expected. Received event: %d"), aDevSoundEvent);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8339
				StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8340
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8341
			break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8342
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8343
		case EStateInitializing:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8344
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8345
			if (aDevSoundEvent == EEventInitComplete && aError == KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8346
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8347
				INFO_PRINTF1(_L("Calling iMMFDevSound->PlayToneSequenceL with an invalid descriptor as argument"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8348
				TRAPD(err, iMMFDevSound->PlayToneSequenceL(iInvalidToneSequence));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8349
				if (err != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8350
					{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8351
					ERR_PRINTF2(_L("CMMFDevSound::PlayToneSequenceL left with error = %d and it should not leave"), err);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8352
					StopTest(err, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8353
					}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8354
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8355
			else if (aDevSoundEvent == EEventInitComplete && aError != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8356
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8357
				ERR_PRINTF2(_L("DevSound called CMMFDevSound::InitializeComplete with error = %d"), aError);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8358
				StopTest(aError);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8359
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8360
			else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8361
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8362
				ERR_PRINTF2(_L("DevSound EEventInitComplete not received as expected. Received event: %d"), aDevSoundEvent);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8363
				StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8364
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8365
			break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8366
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8367
		default:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8368
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8369
			ERR_PRINTF2(_L("Invalid DevSound state received: %d"), iDevSoundState);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8370
			StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8371
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8372
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8373
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8374
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8375
void RA3FDevSoundTonePlayToneSequenceUsingInvalidDescriptorTest::ToneFinished(TInt aError)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8376
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8377
	INFO_PRINTF1(_L("========== DevSound ToneFinished() callback =========="));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8378
	if (aError == KErrCorrupt)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8379
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8380
		INFO_PRINTF2(_L("ToneFinished called with KErrCorrupt %d which is the expected error"), aError);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8381
		StopTest();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8382
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8383
	else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8384
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8385
		ERR_PRINTF3(_L("ToneFinished called with error = %d, when the expected error is = %d"), aError, KErrCorrupt);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8386
		StopTest(aError, EFail);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8387
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8388
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
  8389
2
5c1df44f2eed 2010wk42_01
hgs
parents: 0
diff changeset
  8390
/*
5c1df44f2eed 2010wk42_01
hgs
parents: 0
diff changeset
  8391
 *========================================================================================================
5c1df44f2eed 2010wk42_01
hgs
parents: 0
diff changeset
  8392
 * MM-A3F-DEVSOUND-CHRTZ-TONE-0064
5c1df44f2eed 2010wk42_01
hgs
parents: 0
diff changeset
  8393
 */
5c1df44f2eed 2010wk42_01
hgs
parents: 0
diff changeset
  8394
5c1df44f2eed 2010wk42_01
hgs
parents: 0
diff changeset
  8395
RA3FDevSoundTonePlayToneFixedSequenceTest::RA3FDevSoundTonePlayToneFixedSequenceTest(const TDesC& aTestName)
5c1df44f2eed 2010wk42_01
hgs
parents: 0
diff changeset
  8396
    :   RA3FDevSoundTestBase(aTestName)
5c1df44f2eed 2010wk42_01
hgs
parents: 0
diff changeset
  8397
    {
5c1df44f2eed 2010wk42_01
hgs
parents: 0
diff changeset
  8398
    }
5c1df44f2eed 2010wk42_01
hgs
parents: 0
diff changeset
  8399
5c1df44f2eed 2010wk42_01
hgs
parents: 0
diff changeset
  8400
RA3FDevSoundTonePlayToneFixedSequenceTest* RA3FDevSoundTonePlayToneFixedSequenceTest::NewL(const TDesC& aTestName)
5c1df44f2eed 2010wk42_01
hgs
parents: 0
diff changeset
  8401
    {
5c1df44f2eed 2010wk42_01
hgs
parents: 0
diff changeset
  8402
    RA3FDevSoundTonePlayToneFixedSequenceTest * self = new(ELeave)RA3FDevSoundTonePlayToneFixedSequenceTest(aTestName);
5c1df44f2eed 2010wk42_01
hgs
parents: 0
diff changeset
  8403
    return self;
5c1df44f2eed 2010wk42_01
hgs
parents: 0
diff changeset
  8404
    }
5c1df44f2eed 2010wk42_01
hgs
parents: 0
diff changeset
  8405
5c1df44f2eed 2010wk42_01
hgs
parents: 0
diff changeset
  8406
void RA3FDevSoundTonePlayToneFixedSequenceTest::DoKickoffTestL()
5c1df44f2eed 2010wk42_01
hgs
parents: 0
diff changeset
  8407
    {
5c1df44f2eed 2010wk42_01
hgs
parents: 0
diff changeset
  8408
    }
5c1df44f2eed 2010wk42_01
hgs
parents: 0
diff changeset
  8409
5c1df44f2eed 2010wk42_01
hgs
parents: 0
diff changeset
  8410
void RA3FDevSoundTonePlayToneFixedSequenceTest::Fsm(TMmfDevSoundEvent aDevSoundEvent,  TInt aError)
5c1df44f2eed 2010wk42_01
hgs
parents: 0
diff changeset
  8411
    {
5c1df44f2eed 2010wk42_01
hgs
parents: 0
diff changeset
  8412
    switch (iDevSoundState)
5c1df44f2eed 2010wk42_01
hgs
parents: 0
diff changeset
  8413
        {
5c1df44f2eed 2010wk42_01
hgs
parents: 0
diff changeset
  8414
        case EStateCreated:
5c1df44f2eed 2010wk42_01
hgs
parents: 0
diff changeset
  8415
           {
5c1df44f2eed 2010wk42_01
hgs
parents: 0
diff changeset
  8416
           __ASSERT_ALWAYS((aError == KErrNone), Panic(_L("RA3FDevSoundTonePlayToneFixedSequenceTest"), EFsmIncorrectErrorPassed));
5c1df44f2eed 2010wk42_01
hgs
parents: 0
diff changeset
  8417
           if (aDevSoundEvent == EEventInitialize)
5c1df44f2eed 2010wk42_01
hgs
parents: 0
diff changeset
  8418
               {
5c1df44f2eed 2010wk42_01
hgs
parents: 0
diff changeset
  8419
               //FixedSequenceCount is deprecated and should return 0
5c1df44f2eed 2010wk42_01
hgs
parents: 0
diff changeset
  8420
               INFO_PRINTF1(_L("Calling CMMFDevSound->FixedSequenceCount()"));
5c1df44f2eed 2010wk42_01
hgs
parents: 0
diff changeset
  8421
               iFixedSequenceCount = iMMFDevSound->FixedSequenceCount();
5c1df44f2eed 2010wk42_01
hgs
parents: 0
diff changeset
  8422
               if(iFixedSequenceCount != 0)
5c1df44f2eed 2010wk42_01
hgs
parents: 0
diff changeset
  8423
                   {
5c1df44f2eed 2010wk42_01
hgs
parents: 0
diff changeset
  8424
                   INFO_PRINTF2(_L("CMMFDevSound->FixedSequenceCount() returned incorrect value %d"),iFixedSequenceCount);
5c1df44f2eed 2010wk42_01
hgs
parents: 0
diff changeset
  8425
                   StopTest(EFail);
5c1df44f2eed 2010wk42_01
hgs
parents: 0
diff changeset
  8426
                   break;
5c1df44f2eed 2010wk42_01
hgs
parents: 0
diff changeset
  8427
                   }
5c1df44f2eed 2010wk42_01
hgs
parents: 0
diff changeset
  8428
          
5c1df44f2eed 2010wk42_01
hgs
parents: 0
diff changeset
  8429
               //FixedSequenceName is deprecated and should return a Null descriptor
5c1df44f2eed 2010wk42_01
hgs
parents: 0
diff changeset
  8430
               INFO_PRINTF1(_L("Calling CMMFDevSound->FixedSequenceName()"));
5c1df44f2eed 2010wk42_01
hgs
parents: 0
diff changeset
  8431
               TDesC fSeqName = iMMFDevSound->FixedSequenceName(0);
5c1df44f2eed 2010wk42_01
hgs
parents: 0
diff changeset
  8432
               if(fSeqName != KNullDesC)
5c1df44f2eed 2010wk42_01
hgs
parents: 0
diff changeset
  8433
                   {
5c1df44f2eed 2010wk42_01
hgs
parents: 0
diff changeset
  8434
                   INFO_PRINTF1(_L("CMMFDevSound->FixedSequenceName() returned wrong name"));
5c1df44f2eed 2010wk42_01
hgs
parents: 0
diff changeset
  8435
                   StopTest(EFail);
5c1df44f2eed 2010wk42_01
hgs
parents: 0
diff changeset
  8436
                   break;
5c1df44f2eed 2010wk42_01
hgs
parents: 0
diff changeset
  8437
                   }
5c1df44f2eed 2010wk42_01
hgs
parents: 0
diff changeset
  8438
                   
5c1df44f2eed 2010wk42_01
hgs
parents: 0
diff changeset
  8439
               //PlayFixedSequenceL is not supported
5c1df44f2eed 2010wk42_01
hgs
parents: 0
diff changeset
  8440
               INFO_PRINTF1(_L("Calling iMMFDevSound->PlayFixedSequenceL()"));
5c1df44f2eed 2010wk42_01
hgs
parents: 0
diff changeset
  8441
               TRAPD(err, iMMFDevSound->PlayFixedSequenceL(0));
5c1df44f2eed 2010wk42_01
hgs
parents: 0
diff changeset
  8442
               if(err!=KErrNotSupported)
5c1df44f2eed 2010wk42_01
hgs
parents: 0
diff changeset
  8443
                   {
5c1df44f2eed 2010wk42_01
hgs
parents: 0
diff changeset
  8444
                   INFO_PRINTF1(_L("CMMFDevSound->PlayFixedSequenceL() did not leave with KErrNotSupported"));
5c1df44f2eed 2010wk42_01
hgs
parents: 0
diff changeset
  8445
                   StopTest(EFail);
5c1df44f2eed 2010wk42_01
hgs
parents: 0
diff changeset
  8446
                   break;
5c1df44f2eed 2010wk42_01
hgs
parents: 0
diff changeset
  8447
                   }
5c1df44f2eed 2010wk42_01
hgs
parents: 0
diff changeset
  8448
               StopTest(); 
5c1df44f2eed 2010wk42_01
hgs
parents: 0
diff changeset
  8449
               }
5c1df44f2eed 2010wk42_01
hgs
parents: 0
diff changeset
  8450
               break;
5c1df44f2eed 2010wk42_01
hgs
parents: 0
diff changeset
  8451
           }
5c1df44f2eed 2010wk42_01
hgs
parents: 0
diff changeset
  8452
           
5c1df44f2eed 2010wk42_01
hgs
parents: 0
diff changeset
  8453
           default:
5c1df44f2eed 2010wk42_01
hgs
parents: 0
diff changeset
  8454
                {
5c1df44f2eed 2010wk42_01
hgs
parents: 0
diff changeset
  8455
                ERR_PRINTF2(_L("Invalid DevSound state received: %d"), iDevSoundState);
5c1df44f2eed 2010wk42_01
hgs
parents: 0
diff changeset
  8456
                StopTest(aError, EFail);
5c1df44f2eed 2010wk42_01
hgs
parents: 0
diff changeset
  8457
                }
5c1df44f2eed 2010wk42_01
hgs
parents: 0
diff changeset
  8458
                   
5c1df44f2eed 2010wk42_01
hgs
parents: 0
diff changeset
  8459
        }
5c1df44f2eed 2010wk42_01
hgs
parents: 0
diff changeset
  8460
        
5c1df44f2eed 2010wk42_01
hgs
parents: 0
diff changeset
  8461
    }
5c1df44f2eed 2010wk42_01
hgs
parents: 0
diff changeset
  8462
5c1df44f2eed 2010wk42_01
hgs
parents: 0
diff changeset
  8463
5c1df44f2eed 2010wk42_01
hgs
parents: 0
diff changeset
  8464