devsound/devsoundrefplugin/tsrc/CIPlugins/src/teststepcigettimestamps.cpp
author hgs
Wed, 13 Oct 2010 12:08:48 +0100
changeset 3 28bdc4aca325
parent 0 79dd3e2336a0
permissions -rw-r--r--
2010wk42_01
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
0
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
     1
// Copyright (c) 2007-2009 Nokia Corporation and/or its subsidiary(-ies).
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
     2
// All rights reserved.
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
     3
// This component and the accompanying materials are made available
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
     4
// under the terms of "Eclipse Public License v1.0"
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
     5
// which accompanies this distribution, and is available
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
     6
// at the URL "http://www.eclipse.org/legal/epl-v10.html".
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
     7
//
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
     8
// Initial Contributors:
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
     9
// Nokia Corporation - initial contribution.
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    10
//
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    11
// Contributors:
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    12
//
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    13
// Description:
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    14
//
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    15
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    16
#include <f32file.h>
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    17
#include "teststepcigettimestamps.h"
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    18
#include "cidefine.h"
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    19
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    20
/*****************************************************************************/
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    21
CTestStepCICreateGetTimestamps::CTestStepCICreateGetTimestamps()
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    22
	{
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    23
	iTestStepName = _L("MM-MMF-DEVSOUNDCI-U-0085-HP");
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    24
	}
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    25
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    26
/*****************************************************************************/
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    27
TVerdict CTestStepCICreateGetTimestamps::DoTestStepL()
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    28
	{
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    29
	iTestStepResult = EFail;
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    30
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    31
	INFO_PRINTF1(_L("Initializing test CI device"));
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    32
	
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    33
	//Initialize - with the UID of our test HwDevice
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    34
	#ifndef SYMBIAN_MULTIMEDIA_A3FDEVSOUND
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    35
	TUid testUID = {KUidGetTimestampsTestDevice}; 
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    36
	#else
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    37
	TFourCC testUID('T','0','0','6');
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    38
	#endif
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    39
	
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    40
	MMMFGetTimestamps* interface = NULL;
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    41
	interface = static_cast<MMMFGetTimestamps*>(
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    42
							InitializeAndInstantiateInterfaceL(testUID, KUidGetTimestamps));
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    43
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    44
	if (interface)
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    45
		{
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    46
		iTestStepResult = EPass;
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    47
		INFO_PRINTF1(_L("Successfully retrieved the interface."));
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    48
		}
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    49
	else
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    50
		{
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    51
		iTestStepResult = EFail;
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    52
		ERR_PRINTF1(_L("Failed to retrieve the interface"));
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    53
		}
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    54
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    55
	return iTestStepResult;
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    56
	}
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    57
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    58
/*****************************************************************************/
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    59
CTestStepCIGetTimestampsEnable::CTestStepCIGetTimestampsEnable()
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    60
	{
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    61
	iTestStepName = _L("MM-MMF-DEVSOUNDCI-U-0086-HP");
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    62
	}
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    63
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    64
/*****************************************************************************/
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    65
TVerdict CTestStepCIGetTimestampsEnable::DoTestStepL()
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    66
	{
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    67
	iTestStepResult = EFail;
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    68
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    69
	INFO_PRINTF1(_L("Initializing test CI device"));
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    70
	
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    71
	//Initialize - with the UID of our test HwDevice
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    72
	#ifndef SYMBIAN_MULTIMEDIA_A3FDEVSOUND
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    73
	TUid testUID = {KUidGetTimestampsTestDevice}; 
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    74
	#else
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    75
	TFourCC testUID('T','0','0','6');
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    76
	#endif
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    77
	
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    78
	MMMFGetTimestamps* interface = NULL;
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    79
	interface = static_cast<MMMFGetTimestamps*>(InitializeAndInstantiateInterfaceL(testUID, KUidGetTimestamps));
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    80
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    81
	if (interface)
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    82
		{
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    83
		TBool enabled = ETrue;
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    84
		INFO_PRINTF1(_L("Calling test CI method"));
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    85
		TInt err = interface->MmgtSetRecordSystemTimestampsEnabled(enabled);
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    86
		TBool flag = EFalse;
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    87
		// Reset test result in case we leave...
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    88
		iTestStepResult = EFail;
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    89
		DoReadFromFileL(flag);
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    90
		if ((err == KErrNone) && (flag == enabled))
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    91
			{
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    92
			INFO_PRINTF1(_L("Test CI method call was successful"));
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    93
			iTestStepResult = EPass;
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    94
			}
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    95
		else
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    96
			{
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    97
			INFO_PRINTF4(_L("Test CI method call failed, error: %d, expected value: %d, \
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    98
								actual value: %d"), err, enabled, flag);
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    99
			}
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   100
		}
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   101
	else
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   102
		{
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   103
		INFO_PRINTF1(_L("Failed to retrieve the custom interface."));
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   104
		iTestStepResult = EInconclusive;
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   105
		}
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   106
			
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   107
	return iTestStepResult;
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   108
	}
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   109
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   110
void CTestStepCIGetTimestampsEnable::DoReadFromFileL(TBool& aFlag)
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   111
	{
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   112
	RFs fs;
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   113
	CleanupClosePushL(fs);
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   114
	User::LeaveIfError(fs.Connect());
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   115
	
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   116
	RFile file;
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   117
	CleanupClosePushL(file);
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   118
	
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   119
	// File should already exist
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   120
	User::LeaveIfError(file.Open(fs, KCITestFileName, EFileRead));
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   121
	// Size should be 1!
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   122
	TInt fileSize = 0;
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   123
	User::LeaveIfError(file.Size(fileSize));
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   124
	if (fileSize != KMaxCITestFileDataLength)
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   125
		{
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   126
		User::Leave(KErrCorrupt);
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   127
		}
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   128
	TBuf8<KMaxCITestFileDataLength> inputBuf;
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   129
	User::LeaveIfError(file.Read(inputBuf));
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   130
	TChar val = inputBuf[0];
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   131
	aFlag = val.GetNumericValue();
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   132
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   133
	CleanupStack::PopAndDestroy(); // file	
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   134
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   135
	// This function is responsible for the deletion of the file after use
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   136
	User::LeaveIfError(fs.Delete(KCITestFileName));
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   137
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   138
	CleanupStack::PopAndDestroy(); // fs
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   139
	}
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   140
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   141
/*****************************************************************************/
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   142
CTestStepCIGetTimestampsForBuffer::CTestStepCIGetTimestampsForBuffer()
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   143
	{
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   144
	iTestStepName = _L("MM-MMF-DEVSOUNDCI-U-0087-HP");
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   145
	}
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   146
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   147
/*****************************************************************************/
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   148
TVerdict CTestStepCIGetTimestampsForBuffer::DoTestStepL()
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   149
	{
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   150
	iTestStepResult = EFail;
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   151
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   152
	INFO_PRINTF1(_L("Initializing test CI device"));
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   153
	
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   154
	//Initialize - with the UID of our test HwDevice
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   155
	#ifndef SYMBIAN_MULTIMEDIA_A3FDEVSOUND
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   156
	TUid testUID = {KUidGetTimestampsTestDevice}; 
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   157
	#else
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   158
	TFourCC testUID('T','0','0','6');
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   159
	#endif
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   160
	
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   161
	MMMFGetTimestamps* interface = NULL;
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   162
	interface = static_cast<MMMFGetTimestamps*>(InitializeAndInstantiateInterfaceL(testUID, KUidGetTimestamps));
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   163
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   164
	if (interface)
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   165
		{
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   166
		INFO_PRINTF1(_L("Calling test CI method"));
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   167
		// Test device implementation expects this value:
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   168
		TTimeIntervalMicroSeconds bufferPosition(KTimestampPosition);
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   169
		TTime timestamp;
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   170
		TInt err = interface->MmgtGetSystemTimestampForBuffer(bufferPosition, timestamp);
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   171
		// and it should return this value:
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   172
		TTime testTimestamp(KTimestampValue);
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   173
		if ((err == KErrNone) && (testTimestamp == timestamp))
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   174
			{
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   175
			INFO_PRINTF1(_L("Test CI method call was successful"));
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   176
			iTestStepResult = EPass;
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   177
			}
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   178
		else
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   179
			{
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   180
			INFO_PRINTF3(_L("Expected timestamp: %d, actual timestamp: %d"), \
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   181
							timestamp.Int64(), testTimestamp.Int64());
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   182
			iTestStepResult = EFail;
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   183
			}				
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   184
		}
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   185
	else
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   186
		{
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   187
		INFO_PRINTF1(_L("Failed to retrieve the custom interface."));
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   188
		iTestStepResult = EInconclusive;
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   189
		}
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   190
					
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   191
	return iTestStepResult;
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   192
	}