mmlibs/mmfw/tsrc/mmfintegrationtest/ACLNT/testDRM.cpp
author hgs
Thu, 07 Oct 2010 22:34:12 +0100
changeset 0 b8ed18f6c07b
permissions -rw-r--r--
2010wk40
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
0
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
     1
// Copyright (c) 2004-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 "rightsdatabase.h"
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    17
#include "TestDRM.h"
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    18
#include <caf/caf.h>
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    19
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    20
const TInt KDefaultRightsID = 1;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    21
const TInt KDefaultRightsCount = 2;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    22
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    23
const TInt KMaxMimeLength = 256;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    24
/**
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    25
 * Constructor
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    26
 */
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    27
CTestMmfAclntDRMPlayerNoRights::CTestMmfAclntDRMPlayerNoRights()
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    28
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    29
	// store the name of this test case
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    30
	// this is the name that is used by the script file
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    31
	// Each test step initialises it's own name
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    32
	iTestStepName = _L("MM-MMF-ACLNT-I-9000-LP");
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    33
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    34
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    35
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    36
CTestMmfAclntDRMPlayerNoRights* CTestMmfAclntDRMPlayerNoRights::NewL()
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    37
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    38
	CTestMmfAclntDRMPlayerNoRights* self = new (ELeave) CTestMmfAclntDRMPlayerNoRights();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    39
	return self;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    40
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    41
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    42
CTestMmfAclntDRMPlayerNoRights* CTestMmfAclntDRMPlayerNoRights::NewLC()
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    43
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    44
	CTestMmfAclntDRMPlayerNoRights* self = CTestMmfAclntDRMPlayerNoRights::NewL();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    45
	CleanupStack::PushL(self);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    46
	return self;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    47
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    48
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    49
void CTestMmfAclntDRMPlayerNoRights::MapcInitComplete(TInt aError, const TTimeIntervalMicroSeconds &aDuration)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    50
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    51
	iError = aError;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    52
	iDuration = aDuration;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    53
	INFO_PRINTF1( _L("MMdaAudioPlayerCallback Init Complete"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    54
	CActiveScheduler::Stop();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    55
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    56
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    57
void CTestMmfAclntDRMPlayerNoRights::MapcPlayComplete(TInt aError)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    58
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    59
	iError = aError;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    60
	INFO_PRINTF1( _L("MMdaAudioPlayerCallback Play Complete"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    61
	CActiveScheduler::Stop();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    62
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    63
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    64
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    65
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    66
/** Load and initialise an audio file.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    67
 */
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    68
TVerdict CTestMmfAclntDRMPlayerNoRights::DoTestStepL( void )
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    69
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    70
	INFO_PRINTF1( _L("TestPlayerUtils : File"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    71
	TVerdict ret = EFail;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    72
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    73
	iError = KErrTimedOut;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    74
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    75
	CRightsDatabase* rights = CRightsDatabase::NewL(EFalse); // create new database overwriting current one
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    76
	delete rights; // the database will now be reset and have no entries in it
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    77
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    78
	TBuf<KSizeBuf>	filename;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    79
	TPtrC			filename1; 
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    80
	if(!GetStringFromConfig(_L("SectionDRM"),_L("DRMWavFile"),filename1))
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    81
		return EInconclusive;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    82
	GetDriveName(filename);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    83
	filename.Append(filename1);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    84
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    85
	CMdaAudioPlayerUtility* player = NULL;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    86
	player = CMdaAudioPlayerUtility::NewFilePlayerL(filename, *this);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    87
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    88
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    89
	// Wait for initialisation callback
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    90
	INFO_PRINTF1( _L("Initialise CMdaAudioPlayerUtility"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    91
	CActiveScheduler::Start();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    92
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    93
	if (iError == KErrCANoRights)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    94
		ret = EPass;			
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    95
	else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    96
		ret = EFail;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    97
	
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    98
	delete player;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    99
	User::After(KOneSecond); // wait for deletion to shut down devsound
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   100
	return	ret;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   101
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   102
//--------------------------------------------------------------------------------
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   103
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   104
/**
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   105
 * Constructor
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   106
 */
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   107
CTestMmfAclntDRMPlayerRightsCount::CTestMmfAclntDRMPlayerRightsCount()
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   108
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   109
	// store the name of this test case
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   110
	// this is the name that is used by the script file
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   111
	// Each test step initialises it's own name
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   112
	iTestStepName = _L("MM-MMF-ACLNT-I-9001-LP");
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   113
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   114
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   115
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   116
CTestMmfAclntDRMPlayerRightsCount* CTestMmfAclntDRMPlayerRightsCount::NewL()
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   117
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   118
	CTestMmfAclntDRMPlayerRightsCount* self = new (ELeave) CTestMmfAclntDRMPlayerRightsCount();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   119
	return self;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   120
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   121
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   122
CTestMmfAclntDRMPlayerRightsCount* CTestMmfAclntDRMPlayerRightsCount::NewLC()
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   123
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   124
	CTestMmfAclntDRMPlayerRightsCount* self = CTestMmfAclntDRMPlayerRightsCount::NewL();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   125
	CleanupStack::PushL(self);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   126
	return self;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   127
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   128
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   129
void CTestMmfAclntDRMPlayerRightsCount::MapcInitComplete(TInt aError, const TTimeIntervalMicroSeconds &aDuration)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   130
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   131
	iError = aError;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   132
	iDuration = aDuration;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   133
	INFO_PRINTF1( _L("MMdaAudioPlayerCallback Init Complete"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   134
	CActiveScheduler::Stop();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   135
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   136
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   137
void CTestMmfAclntDRMPlayerRightsCount::MapcPlayComplete(TInt aError)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   138
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   139
	iError = aError;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   140
	INFO_PRINTF1( _L("MMdaAudioPlayerCallback Play Complete"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   141
	CActiveScheduler::Stop();
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
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   146
/** Load and initialise an audio file.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   147
 */
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   148
TVerdict CTestMmfAclntDRMPlayerRightsCount::DoTestStepL( void )
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   149
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   150
	INFO_PRINTF1( _L("TestPlayerUtils : File"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   151
	TVerdict ret = EFail;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   152
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   153
	iError = KErrTimedOut;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   154
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   155
	CRightsDatabase* rights = CRightsDatabase::NewL(EFalse); // create new database overwriting current one
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   156
	CleanupStack::PushL(rights);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   157
	rights->AddRightsL(KDefaultRightsID,KDefaultRightsCount); // add rights count 
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   158
	CleanupStack::PopAndDestroy(rights); // cleanup rights object
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   159
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   160
	TBuf<KSizeBuf>	filename;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   161
	TPtrC			filename1; 
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   162
	if(!GetStringFromConfig(_L("SectionDRM"),_L("DRMWavFile"),filename1))
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   163
		return EInconclusive;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   164
	GetDriveName(filename);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   165
	filename.Append(filename1);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   166
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   167
	CMdaAudioPlayerUtility* player = NULL;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   168
	player = CMdaAudioPlayerUtility::NewFilePlayerL(filename, *this);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   169
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   170
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   171
	// Wait for initialisation callback
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   172
	INFO_PRINTF1( _L("Initialise CMdaAudioPlayerUtility"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   173
	CActiveScheduler::Start();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   174
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   175
	// Check for errors.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   176
	if (iError == KErrNone && player != NULL)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   177
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   178
		iError = KErrTimedOut;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   179
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   180
		for (TInt i=0;i<KDefaultRightsCount;i++)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   181
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   182
			player->Play();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   183
			
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   184
			// Wait for play callback
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   185
			INFO_PRINTF2( _L("Play CMdaAudioPlayerUtility: DRM play number %d"),i);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   186
			CActiveScheduler::Start();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   187
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   188
			if (iError != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   189
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   190
				INFO_PRINTF2(_L("Unexpected error %d"),iError);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   191
				break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   192
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   193
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   194
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   195
		if (iError == KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   196
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   197
			player->Play();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   198
			
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   199
			// Wait for play callback
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   200
			INFO_PRINTF1( _L("Play CMdaAudioPlayerUtility with expired rights"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   201
			CActiveScheduler::Start();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   202
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   203
			if (iError != KErrCANoPermission)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   204
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   205
				INFO_PRINTF3(_L("Unexpected error %d, expected %d"),iError,KErrCANoPermission);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   206
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   207
			else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   208
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   209
				INFO_PRINTF1(_L("Expected failure: rights denied"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   210
				ret = EPass;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   211
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   212
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   213
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   214
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   215
	
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   216
	delete player;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   217
	User::After(KOneSecond); // wait for deletion to shut down devsound
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   218
	return	ret;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   219
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   220
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   221
//----------------------------------------------------------------------------------------
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   222
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   223
/**
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   224
 * Constructor
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   225
 */
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   226
CTestMmfAclntDRMRecorderNoRights::CTestMmfAclntDRMRecorderNoRights()
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   227
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   228
	// store the name of this test case
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   229
	// this is the name that is used by the script file
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   230
	// Each test step initialises it's own name
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   231
	iTestStepName = _L("MM-MMF-ACLNT-I-9002-LP");
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   232
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   233
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   234
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   235
CTestMmfAclntDRMRecorderNoRights* CTestMmfAclntDRMRecorderNoRights::NewL()
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   236
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   237
	CTestMmfAclntDRMRecorderNoRights* self = new (ELeave) CTestMmfAclntDRMRecorderNoRights();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   238
	return self;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   239
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   240
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   241
CTestMmfAclntDRMRecorderNoRights* CTestMmfAclntDRMRecorderNoRights::NewLC()
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   242
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   243
	CTestMmfAclntDRMRecorderNoRights* self = CTestMmfAclntDRMRecorderNoRights::NewL();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   244
	CleanupStack::PushL(self);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   245
	return self;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   246
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   247
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   248
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   249
/** Load and initialise an audio file.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   250
 */
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   251
TVerdict CTestMmfAclntDRMRecorderNoRights::DoTestStepL( void )
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   252
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   253
	INFO_PRINTF1( _L("TestRecorderUtils : File"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   254
	TVerdict ret = EFail;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   255
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   256
	iError = KErrTimedOut;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   257
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   258
	CRightsDatabase* rights = CRightsDatabase::NewL(EFalse); // create new database overwriting current one
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   259
	delete rights; // the database will now be reset and have no entries in it
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   260
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   261
	TBuf<KSizeBuf>	filename;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   262
	TPtrC			filename1; 
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   263
	if(!GetStringFromConfig(_L("SectionDRM"),_L("DRMWavFile"),filename1))
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   264
		return EInconclusive;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   265
	GetDriveName(filename);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   266
	filename.Append(filename1);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   267
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   268
	CMdaAudioRecorderUtility* recorder = CMdaAudioRecorderUtility::NewL(*this);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   269
	CleanupStack::PushL(recorder);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   270
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   271
	recorder->OpenFileL(filename);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   272
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   273
	// Wait for initialisation callback
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   274
	INFO_PRINTF1( _L("Initialise CMdaAudioRecorderUtility"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   275
	CActiveScheduler::Start();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   276
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   277
	if (iError == KErrCANoRights)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   278
		ret = EPass;			
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   279
	else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   280
		ret = EFail;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   281
	
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   282
	CleanupStack::PopAndDestroy(recorder);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   283
	User::After(KOneSecond); // wait for deletion to shut down devsound
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   284
	return	ret;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   285
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   286
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   287
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   288
void CTestMmfAclntDRMRecorderNoRights::MoscoStateChangeEvent(CBase* /*aObject*/, TInt aPreviousState, TInt aCurrentState, TInt aErrorCode)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   289
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   290
	iError = aErrorCode;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   291
	//iObject = aObject;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   292
	iPreviousState = aPreviousState;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   293
	iCurrentState = aCurrentState;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   294
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   295
	INFO_PRINTF1( _L("CTestMmfAclntRecord : MMdaObjectStateChangeObserver Callback for CMdaAudioRecorderUtility complete"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   296
	INFO_PRINTF4( _L("iError %d iPreviousState %d iCurrentState %d"), iError, iPreviousState, iCurrentState);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   297
	CActiveScheduler::Stop();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   298
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   299
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   300
//--------------------------------------------------------------------------------
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   301
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   302
/**
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   303
 * Constructor
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   304
 */
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   305
CTestMmfAclntDRMRecorderRightsCount::CTestMmfAclntDRMRecorderRightsCount()
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   306
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   307
	// store the name of this test case
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   308
	// this is the name that is used by the script file
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   309
	// Each test step initialises it's own name
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   310
	iTestStepName = _L("MM-MMF-ACLNT-I-9003-LP");
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   311
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   312
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   313
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   314
CTestMmfAclntDRMRecorderRightsCount* CTestMmfAclntDRMRecorderRightsCount::NewL()
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   315
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   316
	CTestMmfAclntDRMRecorderRightsCount* self = new (ELeave) CTestMmfAclntDRMRecorderRightsCount();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   317
	return self;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   318
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   319
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   320
CTestMmfAclntDRMRecorderRightsCount* CTestMmfAclntDRMRecorderRightsCount::NewLC()
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   321
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   322
	CTestMmfAclntDRMRecorderRightsCount* self = CTestMmfAclntDRMRecorderRightsCount::NewL();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   323
	CleanupStack::PushL(self);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   324
	return self;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   325
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   326
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   327
/** Load and initialise an audio file.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   328
 */
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   329
TVerdict CTestMmfAclntDRMRecorderRightsCount::DoTestStepL( void )
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   330
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   331
	INFO_PRINTF1( _L("TestRecorderUtils : File"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   332
	TVerdict ret = EFail;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   333
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   334
	iError = KErrTimedOut;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   335
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   336
	CRightsDatabase* rights = CRightsDatabase::NewL(EFalse); // create new database overwriting current one
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   337
	CleanupStack::PushL(rights);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   338
	rights->AddRightsL(KDefaultRightsID,KDefaultRightsCount); // add rights count 
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   339
	CleanupStack::PopAndDestroy(rights); // cleanup rights object
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   340
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   341
	TBuf<KSizeBuf>	filename;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   342
	TPtrC			filename1; 
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   343
	if(!GetStringFromConfig(_L("SectionDRM"),_L("DRMWavFile"),filename1))
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   344
		return EInconclusive;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   345
	GetDriveName(filename);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   346
	filename.Append(filename1);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   347
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   348
	CMdaAudioRecorderUtility* recorder = CMdaAudioRecorderUtility::NewL(*this);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   349
	CleanupStack::PushL(recorder);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   350
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   351
	recorder->OpenFileL(filename);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   352
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   353
	// Wait for initialisation callback
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   354
	INFO_PRINTF1( _L("Initialise CMdaAudioRecorderUtility"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   355
	CActiveScheduler::Start();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   356
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   357
	// Check for errors.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   358
	if (iError == KErrNone && recorder != NULL)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   359
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   360
		iError = KErrTimedOut;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   361
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   362
		for (TInt i=0;i<KDefaultRightsCount;i++)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   363
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   364
			recorder->PlayL();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   365
			
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   366
			// Wait for play callback
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   367
			INFO_PRINTF2( _L("Play CMdaAudioRecorderUtility: DRM play number %d"),i);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   368
			CActiveScheduler::Start();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   369
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   370
			if (iError != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   371
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   372
				INFO_PRINTF2(_L("Unexpected error %d"),iError);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   373
				break;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   374
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   375
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   376
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   377
		if (iError == KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   378
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   379
			recorder->PlayL();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   380
			
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   381
			// Wait for play callback
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   382
			INFO_PRINTF1( _L("Play CMdaAudioRecorderUtility with expired rights"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   383
			CActiveScheduler::Start();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   384
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   385
			if (iError != KErrCANoPermission)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   386
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   387
				INFO_PRINTF3(_L("Unexpected error %d, expected %d"),iError,KErrCANoPermission);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   388
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   389
			else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   390
				{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   391
				INFO_PRINTF1(_L("Expected failure: rights denied"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   392
				ret = EPass;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   393
				}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   394
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   395
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   396
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   397
	
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   398
	CleanupStack::PopAndDestroy(recorder);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   399
	User::After(KOneSecond); // wait for deletion to shut down devsound
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   400
	return	ret;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   401
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   402
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   403
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   404
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   405
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   406
void CTestMmfAclntDRMRecorderRightsCount::MoscoStateChangeEvent(CBase* /*aObject*/, TInt aPreviousState, TInt aCurrentState, TInt aErrorCode)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   407
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   408
	iError = aErrorCode;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   409
	//iObject = aObject;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   410
	iPreviousState = aPreviousState;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   411
	iCurrentState = aCurrentState;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   412
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   413
	TBool busy = (iCurrentState == CMdaAudioClipUtility::ERecording || iCurrentState == CMdaAudioClipUtility::EPlaying);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   414
	if (!busy || iError!=KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   415
		CActiveScheduler::Stop();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   416
	
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   417
	INFO_PRINTF1( _L("CTestMmfAclntRecord : MMdaObjectStateChangeObserver Callback for CMdaAudioRecorderUtility complete"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   418
	INFO_PRINTF4( _L("iError %d iPreviousState %d iCurrentState %d"), iError, iPreviousState, iCurrentState);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   419
	
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   420
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   421
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   422
//--------------------------------------------------------------------------------
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   423
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   424
/**
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   425
 * Constructor
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   426
 */
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   427
CTestMmfAclntDRMPlayerOpen::CTestMmfAclntDRMPlayerOpen()
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   428
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   429
	// store the name of this test case
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   430
	// this is the name that is used by the script file
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   431
	// Each test step initialises it's own name
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   432
	iTestStepName = _L("MM-MMF-ACLNT-I-9004-LP");
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   433
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   434
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   435
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   436
CTestMmfAclntDRMPlayerOpen* CTestMmfAclntDRMPlayerOpen::NewL()
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   437
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   438
	CTestMmfAclntDRMPlayerOpen* self = new (ELeave) CTestMmfAclntDRMPlayerOpen();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   439
	return self;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   440
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   441
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   442
CTestMmfAclntDRMPlayerOpen* CTestMmfAclntDRMPlayerOpen::NewLC()
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   443
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   444
	CTestMmfAclntDRMPlayerOpen* self = CTestMmfAclntDRMPlayerOpen::NewL();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   445
	CleanupStack::PushL(self);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   446
	return self;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   447
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   448
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   449
void CTestMmfAclntDRMPlayerOpen::MapcInitComplete(TInt aError, const TTimeIntervalMicroSeconds &aDuration)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   450
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   451
	iError = aError;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   452
	iDuration = aDuration;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   453
	INFO_PRINTF1( _L("MMdaAudioPlayerCallback Init Complete"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   454
	CActiveScheduler::Stop();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   455
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   456
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   457
void CTestMmfAclntDRMPlayerOpen::MapcPlayComplete(TInt aError)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   458
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   459
	iError = aError;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   460
	INFO_PRINTF1( _L("MMdaAudioPlayerCallback Play Complete"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   461
	CActiveScheduler::Stop();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   462
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   463
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   464
/** Load and initialise an audio file.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   465
 */
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   466
TVerdict CTestMmfAclntDRMPlayerOpen::DoTestStepL( void )
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   467
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   468
	INFO_PRINTF1( _L("TestPlayerUtils : File"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   469
	TVerdict ret = EFail;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   470
	TInt err=KErrNone;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   471
	iError = KErrTimedOut;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   472
	
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   473
	//fectch MIME type from config file
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   474
	TBuf8<KMaxMimeLength> mimeType;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   475
	TPtrC				  mimeTypePtr; 
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   476
	if(!GetStringFromConfig(_L("SectionDRM"),_L("DRMWavMime"),mimeTypePtr))
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   477
		return EInconclusive;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   478
	mimeType.Copy(mimeTypePtr);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   479
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   480
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   481
	//setup file to open
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   482
	TBuf<KSizeBuf>	filename;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   483
	TPtrC			filename1; 
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   484
	if(!GetStringFromConfig(_L("SectionDRM"),_L("DRMWavFile"),filename1))
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   485
		return EInconclusive;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   486
	GetDriveName(filename);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   487
	filename.Append(filename1);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   488
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   489
	//setup DRM rights
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   490
	CRightsDatabase* rights = CRightsDatabase::NewL(EFalse); // create new database overwriting current one
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   491
	CleanupStack::PushL(rights);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   492
	rights->AddRightsL(KDefaultRightsID,KDefaultRightsCount,mimeType); // add rights count 
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   493
	CleanupStack::PopAndDestroy(rights); // cleanup rights object
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   494
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   495
	//create instance of Audio Player, which should try open the file as well
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   496
	CMdaAudioPlayerUtility* player = NULL;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   497
	TRAP(err, player = CMdaAudioPlayerUtility::NewFilePlayerL(filename, *this));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   498
	
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   499
	if (iError == KErrNone)//call back OK
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   500
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   501
		// Wait for initialisation callback
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   502
		INFO_PRINTF1( _L("Initialise CMdaAudioPlayerUtility"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   503
		CActiveScheduler::Start();
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
		INFO_PRINTF2(_L("Unexpected error %d"),iError);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   508
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   509
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   510
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   511
	if (err != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   512
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   513
			INFO_PRINTF3(_L("Unexpected error %d, expected %d"),iError,KErrCANoPermission);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   514
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   515
	else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   516
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   517
			INFO_PRINTF1(_L("Expected: PASS"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   518
			ret = EPass;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   519
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   520
		
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   521
	delete player;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   522
	User::After(KOneSecond); // wait for deletion to shut down devsound
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   523
	return	ret;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   524
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   525
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   526
//--------------------------------------------------------------------------------
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   527
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   528
/**
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   529
 * Constructor
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   530
 */
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   531
CTestMmfAclntDRMRecorderPlay::CTestMmfAclntDRMRecorderPlay()
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   532
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   533
	// store the name of this test case
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   534
	// this is the name that is used by the script file
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   535
	// Each test step initialises it's own name
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   536
	iTestStepName = _L("MM-MMF-ACLNT-I-9005-LP");
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   537
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   538
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   539
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   540
CTestMmfAclntDRMRecorderPlay* CTestMmfAclntDRMRecorderPlay::NewL()
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   541
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   542
	CTestMmfAclntDRMRecorderPlay* self = new (ELeave) CTestMmfAclntDRMRecorderPlay();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   543
	return self;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   544
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   545
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   546
CTestMmfAclntDRMRecorderPlay* CTestMmfAclntDRMRecorderPlay::NewLC()
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   547
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   548
	CTestMmfAclntDRMRecorderPlay* self = CTestMmfAclntDRMRecorderPlay::NewL();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   549
	CleanupStack::PushL(self);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   550
	return self;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   551
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   552
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   553
/** Load and initialise an audio file.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   554
 */
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   555
TVerdict CTestMmfAclntDRMRecorderPlay::DoTestStepL( void )
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   556
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   557
	INFO_PRINTF1( _L("TestRecorderUtils : File"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   558
	TVerdict ret = EFail;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   559
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   560
	iError = KErrTimedOut;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   561
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   562
	//fectch MIME type from config file
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   563
	TBuf8<KMaxMimeLength> mimeType;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   564
	TPtrC				  mimeTypePtr; 
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   565
	if(!GetStringFromConfig(_L("SectionDRM"),_L("DRMWavMime"),mimeTypePtr))
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   566
		return EInconclusive;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   567
	mimeType.Copy(mimeTypePtr);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   568
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   569
	//setup DRM rights
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   570
	CRightsDatabase* rights = CRightsDatabase::NewL(EFalse); // create new database overwriting current one
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   571
	CleanupStack::PushL(rights);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   572
	rights->AddRightsL(KDefaultRightsID,KDefaultRightsCount,mimeType); // add rights count 
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   573
	CleanupStack::PopAndDestroy(rights); // cleanup rights object
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   574
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   575
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   576
	TBuf<KSizeBuf>	filename;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   577
	TPtrC			filename1; 
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   578
	if(!GetStringFromConfig(_L("SectionDRM"),_L("DRMWavFile"),filename1))
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   579
		return EInconclusive;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   580
	GetDriveName(filename);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   581
	filename.Append(filename1);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   582
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   583
	CMdaAudioRecorderUtility* recorder = CMdaAudioRecorderUtility::NewL(*this);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   584
	CleanupStack::PushL(recorder);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   585
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   586
	recorder->OpenFileL(filename);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   587
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   588
	// Wait for initialisation callback
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   589
	INFO_PRINTF1( _L("Initialise CMdaAudioRecorderUtility"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   590
	CActiveScheduler::Start();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   591
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   592
	// Check for errors.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   593
	if (iError == KErrNone && recorder != NULL)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   594
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   595
		iError = KErrTimedOut;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   596
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   597
		recorder->PlayL();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   598
			
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   599
		// Wait for play callback
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   600
		INFO_PRINTF1( _L("Play DRM protected file with CMdaAudioRecorderUtility(with sufficient permission)"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   601
		CActiveScheduler::Start();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   602
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   603
		if (iError != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   604
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   605
			INFO_PRINTF2(_L("Unexpected error trying to play protected file %d"),iError);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   606
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   607
		else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   608
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   609
			INFO_PRINTF1(_L("DRM Protected file played successfully"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   610
			ret = EPass;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   611
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   612
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   613
	
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   614
	CleanupStack::PopAndDestroy(recorder);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   615
	User::After(KOneSecond); // wait for deletion to shut down devsound
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   616
	return	ret;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   617
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   618
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   619
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   620
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   621
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   622
void CTestMmfAclntDRMRecorderPlay::MoscoStateChangeEvent(CBase* /*aObject*/, TInt aPreviousState, TInt aCurrentState, TInt aErrorCode)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   623
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   624
	iError = aErrorCode;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   625
	//iObject = aObject;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   626
	iPreviousState = aPreviousState;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   627
	iCurrentState = aCurrentState;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   628
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   629
	TBool busy = (iCurrentState == CMdaAudioClipUtility::ERecording || iCurrentState == CMdaAudioClipUtility::EPlaying);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   630
	if (!busy || iError!=KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   631
		CActiveScheduler::Stop();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   632
	
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   633
	INFO_PRINTF1( _L("CTestMmfAclntRecord : MMdaObjectStateChangeObserver Callback for CMdaAudioRecorderUtility complete"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   634
	INFO_PRINTF4( _L("iError %d iPreviousState %d iCurrentState %d"), iError, iPreviousState, iCurrentState);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   635
	
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   636
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   637
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   638
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   639
//--------------------------------------------------------------------------------
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   640
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   641
/**
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   642
 * Constructor
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   643
 */
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   644
CTestMmfAclntDRMConverterFail::CTestMmfAclntDRMConverterFail()
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   645
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   646
	// store the name of this test case
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   647
	// this is the name that is used by the script file
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   648
	// Each test step initialises it's own name
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   649
	iTestStepName = _L("MM-MMF-ACLNT-I-9006-LP");
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   650
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   651
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   652
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   653
CTestMmfAclntDRMConverterFail* CTestMmfAclntDRMConverterFail::NewL()
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   654
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   655
	CTestMmfAclntDRMConverterFail* self = new (ELeave) CTestMmfAclntDRMConverterFail();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   656
	return self;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   657
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   658
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   659
CTestMmfAclntDRMConverterFail* CTestMmfAclntDRMConverterFail::NewLC()
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   660
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   661
	CTestMmfAclntDRMConverterFail* self = CTestMmfAclntDRMConverterFail::NewL();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   662
	CleanupStack::PushL(self);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   663
	return self;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   664
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   665
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   666
/** Load and initialise an audio file.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   667
 */
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   668
TVerdict CTestMmfAclntDRMConverterFail::DoTestStepL( void )
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   669
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   670
	INFO_PRINTF1( _L("TestconverterUtils : File"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   671
	TVerdict ret = EFail;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   672
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   673
	iError = KErrTimedOut;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   674
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   675
	//fectch MIME type from config file
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   676
	TBuf8<KMaxMimeLength> mimeType;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   677
	TPtrC				  mimeTypePtr; 
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   678
	if(!GetStringFromConfig(_L("SectionDRM"),_L("DRMWavMime"),mimeTypePtr))
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   679
		return EInconclusive;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   680
	mimeType.Copy(mimeTypePtr);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   681
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   682
	//setup DRM rights
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   683
	CRightsDatabase* rights = CRightsDatabase::NewL(EFalse); // create new database overwriting current one
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   684
	CleanupStack::PushL(rights);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   685
	rights->AddRightsL(KDefaultRightsID,KDefaultRightsCount,mimeType); // add rights count 
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   686
	CleanupStack::PopAndDestroy(rights); // cleanup rights object
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   687
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   688
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   689
	TBuf<KSizeBuf>	filename;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   690
	TBuf<KSizeBuf>	destFilename;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   691
	TPtrC			filename1; 
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   692
	TPtrC			filename2;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   693
	if(!GetStringFromConfig(_L("SectionDRM"),_L("DRMWavFile"),filename1))
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   694
		return EInconclusive;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   695
	if(!GetStringFromConfig(_L("SectionDRM"),_L("TestConvertFile"),filename2))
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   696
		return EInconclusive;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   697
	GetDriveName(filename);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   698
	filename.Append(filename1);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   699
	GetDriveName(destFilename);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   700
	destFilename.Append(filename2);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   701
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   702
	RFs		theFs;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   703
	theFs.Connect();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   704
	theFs.Delete(destFilename);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   705
	theFs.Close();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   706
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   707
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   708
	iError = KErrTimedOut;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   709
	TMdaFileClipLocation location(destFilename);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   710
	TMdaWavClipFormat	format;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   711
	TMdaPcmWavCodec		codec;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   712
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   713
	CMdaAudioConvertUtility* converter = CMdaAudioConvertUtility::NewL(*this);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   714
	CleanupStack::PushL(converter);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   715
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   716
	converter->OpenL(filename, &location, &format, &codec);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   717
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   718
	// Wait for initialisation callback
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   719
	INFO_PRINTF1( _L("Initialise CMdaAudioConvertUtility"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   720
	CActiveScheduler::Start();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   721
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   722
	// Check for errors.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   723
	if (iError == KErrNone && converter != NULL)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   724
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   725
		iError = KErrTimedOut;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   726
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   727
		converter->ConvertL();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   728
			
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   729
		// Wait for convert callback
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   730
		INFO_PRINTF1( _L("Convert CMdaAudioconverterUtility: DRM play number"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   731
		CActiveScheduler::Start();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   732
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   733
		if (iError == KErrNotSupported)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   734
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   735
			INFO_PRINTF1(_L("Correctly received KErrNotSupported, for converting protected file"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   736
			ret = EPass;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   737
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   738
		else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   739
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   740
			INFO_PRINTF3(_L("Unexpected error %d, expecting %d"),iError, KErrNotSupported);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   741
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   742
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   743
	
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   744
	CleanupStack::PopAndDestroy(converter);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   745
	User::After(KOneSecond); // wait for deletion to shut down devsound
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   746
	return	ret;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   747
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   748
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   749
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   750
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   751
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   752
void CTestMmfAclntDRMConverterFail::MoscoStateChangeEvent(CBase* /*aObject*/, TInt aPreviousState, TInt aCurrentState, TInt aErrorCode)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   753
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   754
	iError = aErrorCode;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   755
	//iObject = aObject;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   756
	iPreviousState = aPreviousState;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   757
	iCurrentState = aCurrentState;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   758
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   759
	TBool busy = (iCurrentState == CMdaAudioClipUtility::ERecording || iCurrentState == CMdaAudioClipUtility::EPlaying);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   760
	if (!busy || iError!=KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   761
		CActiveScheduler::Stop();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   762
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   763
	INFO_PRINTF1( _L("CTestMmfAclntRecord : MMdaObjectStateChangeObserver Callback for CMdaAudioconverterUtility complete"));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   764
	INFO_PRINTF4( _L("iError %d iPreviousState %d iCurrentState %d"), iError, iPreviousState, iCurrentState);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   765
	
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   766
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   767