omadmadapters/email/tsrc/src/dmatest.cpp
author hgs
Fri, 06 Aug 2010 18:56:37 +0530
changeset 52 6e38e48ee756
parent 46 b9b00b134b0d
permissions -rw-r--r--
201031
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
46
hgs
parents:
diff changeset
     1
/*
hgs
parents:
diff changeset
     2
* Copyright (c) 2008 Nokia Corporation and/or its subsidiary(-ies). 
hgs
parents:
diff changeset
     3
* All rights reserved.
hgs
parents:
diff changeset
     4
* This component and the accompanying materials are made available
hgs
parents:
diff changeset
     5
* under the terms of "Eclipse Public License v1.0"
hgs
parents:
diff changeset
     6
* which accompanies this distribution, and is available
hgs
parents:
diff changeset
     7
* at the URL "http://www.eclipse.org/legal/epl-v10.html".
hgs
parents:
diff changeset
     8
*
hgs
parents:
diff changeset
     9
* Initial Contributors:
hgs
parents:
diff changeset
    10
* Nokia Corporation - initial contribution.
hgs
parents:
diff changeset
    11
*
hgs
parents:
diff changeset
    12
* Contributors:
hgs
parents:
diff changeset
    13
*
hgs
parents:
diff changeset
    14
* Description:  Implementation of DM adapter test component
hgs
parents:
diff changeset
    15
* 	This is part of omadmextensions/adapter test application.
hgs
parents:
diff changeset
    16
*
hgs
parents:
diff changeset
    17
*/
hgs
parents:
diff changeset
    18
hgs
parents:
diff changeset
    19
hgs
parents:
diff changeset
    20
hgs
parents:
diff changeset
    21
hgs
parents:
diff changeset
    22
hgs
parents:
diff changeset
    23
hgs
parents:
diff changeset
    24
// INCLUDE FILES
hgs
parents:
diff changeset
    25
#include "dmatest.h"
hgs
parents:
diff changeset
    26
hgs
parents:
diff changeset
    27
#include <StifParser.h>
hgs
parents:
diff changeset
    28
#include <Stiftestinterface.h>
hgs
parents:
diff changeset
    29
#include <S32FILE.H>
hgs
parents:
diff changeset
    30
#include <s32mem.h>
hgs
parents:
diff changeset
    31
#include <apgcli.h>
hgs
parents:
diff changeset
    32
#include <e32svr.h>
hgs
parents:
diff changeset
    33
#include <e32math.h>
hgs
parents:
diff changeset
    34
#include <f32file.h>
hgs
parents:
diff changeset
    35
#include <swinstapi.h>
hgs
parents:
diff changeset
    36
hgs
parents:
diff changeset
    37
#include "TestDmDDFObject.h"
hgs
parents:
diff changeset
    38
hgs
parents:
diff changeset
    39
_LIT8( KEmptyType, "" );
hgs
parents:
diff changeset
    40
_LIT8( KDefaultType, "text/plain" );
hgs
parents:
diff changeset
    41
_LIT( KMappingTableFile, "\\dmtestmappings.txt" );
hgs
parents:
diff changeset
    42
//_LIT8( KNSmlDMSeparator8, "/" );
hgs
parents:
diff changeset
    43
const TUint8 KNSmlDMUriSeparator = 0x2f; //forward slash
hgs
parents:
diff changeset
    44
hgs
parents:
diff changeset
    45
#define LEAVE_IF_ERROR(x,msg) \
hgs
parents:
diff changeset
    46
	{ TInt __xres = (x); if ( __xres < 0 ) { if ( iLog ) iLog->Log( (msg), __xres ); User::Leave( __xres );	} }
hgs
parents:
diff changeset
    47
hgs
parents:
diff changeset
    48
hgs
parents:
diff changeset
    49
// ============================ MEMBER FUNCTIONS ===============================
hgs
parents:
diff changeset
    50
hgs
parents:
diff changeset
    51
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
    52
// Cdmatest::Cdmatest
hgs
parents:
diff changeset
    53
// C++ default constructor can NOT contain any code, that
hgs
parents:
diff changeset
    54
// leave.
hgs
parents:
diff changeset
    55
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
    56
//
hgs
parents:
diff changeset
    57
Cdmatest::Cdmatest(CTestModuleIf& aTestModuleIf, TUid aUid ):
hgs
parents:
diff changeset
    58
        CScriptBase( aTestModuleIf ), iMappingTable(2), iUid( aUid )
hgs
parents:
diff changeset
    59
    {
hgs
parents:
diff changeset
    60
    
hgs
parents:
diff changeset
    61
    }
hgs
parents:
diff changeset
    62
hgs
parents:
diff changeset
    63
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
    64
// Cdmatest::ConstructL
hgs
parents:
diff changeset
    65
// Symbian 2nd phase constructor can leave.
hgs
parents:
diff changeset
    66
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
    67
//
hgs
parents:
diff changeset
    68
void Cdmatest::ConstructL()
hgs
parents:
diff changeset
    69
    {    
hgs
parents:
diff changeset
    70
    Adapter();
hgs
parents:
diff changeset
    71
	iEmptyMappingInfoArray = new ( ELeave ) CArrayFixFlat<TSmlDmMappingInfo>(1);
hgs
parents:
diff changeset
    72
	
hgs
parents:
diff changeset
    73
	TRAPD( err, LoadMappingsL() );
hgs
parents:
diff changeset
    74
	if (err != KErrEof && err != KErrNone && err != KErrNotFound)
hgs
parents:
diff changeset
    75
		{
hgs
parents:
diff changeset
    76
		User::Leave( err );
hgs
parents:
diff changeset
    77
		}
hgs
parents:
diff changeset
    78
    }
hgs
parents:
diff changeset
    79
    
hgs
parents:
diff changeset
    80
CNSmlDmEmailAdapter *Cdmatest::Adapter()  
hgs
parents:
diff changeset
    81
	{
hgs
parents:
diff changeset
    82
	if ( iAdapter == NULL )
hgs
parents:
diff changeset
    83
		{
hgs
parents:
diff changeset
    84
		if ( iLog )
hgs
parents:
diff changeset
    85
			{
hgs
parents:
diff changeset
    86
			iLog->Log( _L( "Loading Adapter" ) );
hgs
parents:
diff changeset
    87
			}
hgs
parents:
diff changeset
    88
  		
hgs
parents:
diff changeset
    89
  		TRAPD( err, iAdapter = (CNSmlDmEmailAdapter*) CSmlDmAdapter::NewL( iUid,*this ) );
hgs
parents:
diff changeset
    90
	if ( err == KErrNone )
hgs
parents:
diff changeset
    91
		{
hgs
parents:
diff changeset
    92
		if (iLog )
hgs
parents:
diff changeset
    93
			{
hgs
parents:
diff changeset
    94
			iLog->Log( _L( "Loaded" ) );	
hgs
parents:
diff changeset
    95
			}
hgs
parents:
diff changeset
    96
		}
hgs
parents:
diff changeset
    97
	else
hgs
parents:
diff changeset
    98
		{
hgs
parents:
diff changeset
    99
		if (iLog)
hgs
parents:
diff changeset
   100
			{
hgs
parents:
diff changeset
   101
			iLog->Log( _L( "Failed to load adapter: %d" ), err );
hgs
parents:
diff changeset
   102
			}
hgs
parents:
diff changeset
   103
		}
hgs
parents:
diff changeset
   104
		}
hgs
parents:
diff changeset
   105
	return iAdapter;
hgs
parents:
diff changeset
   106
	}
hgs
parents:
diff changeset
   107
    
hgs
parents:
diff changeset
   108
    
hgs
parents:
diff changeset
   109
void Cdmatest::LoadMappingsL()
hgs
parents:
diff changeset
   110
	{
hgs
parents:
diff changeset
   111
	TDataType type; 
hgs
parents:
diff changeset
   112
	HBufC8 *data = LoadFileLC( KMappingTableFile,  type );
hgs
parents:
diff changeset
   113
	RDesReadStream buf( *data );
hgs
parents:
diff changeset
   114
	CleanupClosePushL( buf );
hgs
parents:
diff changeset
   115
hgs
parents:
diff changeset
   116
	TInt len( data->Length() );
hgs
parents:
diff changeset
   117
	while (buf.Source()->TellL( MStreamBuf::ERead ).Offset() < len)
hgs
parents:
diff changeset
   118
		{
hgs
parents:
diff changeset
   119
		TUint32 val = buf.ReadUint32L();
hgs
parents:
diff changeset
   120
		TBuf8<256> uri;
hgs
parents:
diff changeset
   121
		TBuf8<64> luid;
hgs
parents:
diff changeset
   122
		buf.ReadL(uri, val);
hgs
parents:
diff changeset
   123
		val = buf.ReadUint32L();
hgs
parents:
diff changeset
   124
		buf.ReadL(luid, val);
hgs
parents:
diff changeset
   125
		TMapping m( uri, luid ) ;
hgs
parents:
diff changeset
   126
		TInt err( iMappingTable.Append( m )	);
hgs
parents:
diff changeset
   127
		if ( err == KErrNone )
hgs
parents:
diff changeset
   128
			{
hgs
parents:
diff changeset
   129
			iLog->Log( _L8( "Loaded mapping: '%S' : '%S'"), &m.iURI, &m.iLuid );
hgs
parents:
diff changeset
   130
			}
hgs
parents:
diff changeset
   131
		else
hgs
parents:
diff changeset
   132
			{
hgs
parents:
diff changeset
   133
			iLog->Log( _L8( "FAILED TO Load mapping: '%d' "), err );
hgs
parents:
diff changeset
   134
			}
hgs
parents:
diff changeset
   135
		}
hgs
parents:
diff changeset
   136
	CleanupStack::PopAndDestroy( &buf); // buf
hgs
parents:
diff changeset
   137
	CleanupStack::PopAndDestroy( data ); // data
hgs
parents:
diff changeset
   138
	}
hgs
parents:
diff changeset
   139
    	
hgs
parents:
diff changeset
   140
	
hgs
parents:
diff changeset
   141
hgs
parents:
diff changeset
   142
void Cdmatest::SaveMappingsL()
hgs
parents:
diff changeset
   143
    {
hgs
parents:
diff changeset
   144
	TInt c( iMappingTable.Count() );
hgs
parents:
diff changeset
   145
	if ( c > 0 )
hgs
parents:
diff changeset
   146
	{
hgs
parents:
diff changeset
   147
    	RFs fs;
hgs
parents:
diff changeset
   148
    	User::LeaveIfError( fs.Connect() );
hgs
parents:
diff changeset
   149
    	CleanupClosePushL( fs );
hgs
parents:
diff changeset
   150
    	RFileWriteStream buf;
hgs
parents:
diff changeset
   151
    	User::LeaveIfError( buf.Replace( fs, KMappingTableFile, EFileWrite ) );
hgs
parents:
diff changeset
   152
    	CleanupClosePushL( buf );
hgs
parents:
diff changeset
   153
		
hgs
parents:
diff changeset
   154
		TInt i( 0 ) ;
hgs
parents:
diff changeset
   155
		do 
hgs
parents:
diff changeset
   156
			{
hgs
parents:
diff changeset
   157
			buf.WriteUint32L( iMappingTable[i].iURI.Length() );
hgs
parents:
diff changeset
   158
			buf.WriteL( iMappingTable[i].iURI );
hgs
parents:
diff changeset
   159
			buf.WriteUint32L( iMappingTable[i].iLuid.Length() );
hgs
parents:
diff changeset
   160
			buf.WriteL( iMappingTable[i].iLuid );
hgs
parents:
diff changeset
   161
			}
hgs
parents:
diff changeset
   162
		while ( ++i < c )	;
hgs
parents:
diff changeset
   163
		buf.CommitL();
hgs
parents:
diff changeset
   164
		buf.Close();
hgs
parents:
diff changeset
   165
	
hgs
parents:
diff changeset
   166
		CleanupStack::PopAndDestroy(); // buf
hgs
parents:
diff changeset
   167
		CleanupStack::PopAndDestroy(); // fs
hgs
parents:
diff changeset
   168
		}
hgs
parents:
diff changeset
   169
    }
hgs
parents:
diff changeset
   170
    	
hgs
parents:
diff changeset
   171
    
hgs
parents:
diff changeset
   172
// Destructor
hgs
parents:
diff changeset
   173
Cdmatest::~Cdmatest()
hgs
parents:
diff changeset
   174
    {
hgs
parents:
diff changeset
   175
    // Delete resources allocated from test methods
hgs
parents:
diff changeset
   176
    TRAPD(err, SaveMappingsL() );
hgs
parents:
diff changeset
   177
    if ( err != KErrNone )
hgs
parents:
diff changeset
   178
    	{
52
hgs
parents: 46
diff changeset
   179
    		if ( iLog )
hgs
parents: 46
diff changeset
   180
				{
hgs
parents: 46
diff changeset
   181
    			iLog->Log( _L8( "Failed to save mappings!: %d"), err );
hgs
parents: 46
diff changeset
   182
    		}
46
hgs
parents:
diff changeset
   183
    	}
hgs
parents:
diff changeset
   184
    Delete();
hgs
parents:
diff changeset
   185
    
hgs
parents:
diff changeset
   186
    // Delete logger
hgs
parents:
diff changeset
   187
    delete iLog;  
hgs
parents:
diff changeset
   188
    delete iEmptyMappingInfoArray;
hgs
parents:
diff changeset
   189
    delete iAdapter;
hgs
parents:
diff changeset
   190
    delete iURI;
hgs
parents:
diff changeset
   191
    iMappingTable.Reset();
hgs
parents:
diff changeset
   192
    REComSession::FinalClose();    
hgs
parents:
diff changeset
   193
    }
hgs
parents:
diff changeset
   194
hgs
parents:
diff changeset
   195
hgs
parents:
diff changeset
   196
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   197
// Camatest::Delete
hgs
parents:
diff changeset
   198
// Delete here all resources allocated and opened from test methods. 
hgs
parents:
diff changeset
   199
// Called from destructor. 
hgs
parents:
diff changeset
   200
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   201
//
hgs
parents:
diff changeset
   202
void Cdmatest::Delete() 
hgs
parents:
diff changeset
   203
    {
hgs
parents:
diff changeset
   204
    
hgs
parents:
diff changeset
   205
    }
hgs
parents:
diff changeset
   206
hgs
parents:
diff changeset
   207
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   208
// Cdmatest::?member_function
hgs
parents:
diff changeset
   209
// ?implementation_description
hgs
parents:
diff changeset
   210
// (other items were commented in a header).
hgs
parents:
diff changeset
   211
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   212
hgs
parents:
diff changeset
   213
hgs
parents:
diff changeset
   214
        
hgs
parents:
diff changeset
   215
HBufC8 *Cdmatest::GetNextStringLC ( CStifItemParser& aItem, const TDesC &aName )
hgs
parents:
diff changeset
   216
	{
hgs
parents:
diff changeset
   217
	TPtrC nodename( KNullDesC );
hgs
parents:
diff changeset
   218
hgs
parents:
diff changeset
   219
    TInt i( aItem.GetNextString ( nodename ) );
hgs
parents:
diff changeset
   220
    if ( i != KErrNone ) 
hgs
parents:
diff changeset
   221
	    {
hgs
parents:
diff changeset
   222
	    iLog->Log( _L( "ERROR Reading '%S' argument: 0x%X" ), &aName, i );
hgs
parents:
diff changeset
   223
	    }
hgs
parents:
diff changeset
   224
	else
hgs
parents:
diff changeset
   225
		{
hgs
parents:
diff changeset
   226
		iLog->Log( _L("%S: %S"), &aName, &nodename);
hgs
parents:
diff changeset
   227
		}
hgs
parents:
diff changeset
   228
	
hgs
parents:
diff changeset
   229
	HBufC8 *buf = HBufC8::NewLC( nodename.Length() ) ;
hgs
parents:
diff changeset
   230
	buf->Des().Copy( nodename );
hgs
parents:
diff changeset
   231
	return buf;
hgs
parents:
diff changeset
   232
	}
hgs
parents:
diff changeset
   233
	
hgs
parents:
diff changeset
   234
TInt Cdmatest::FetchNodeL( CStifItemParser& aItem )	
hgs
parents:
diff changeset
   235
	{
hgs
parents:
diff changeset
   236
hgs
parents:
diff changeset
   237
    TInt ret( KErrNone );
hgs
parents:
diff changeset
   238
    // Print to UI
hgs
parents:
diff changeset
   239
    TestModuleIf().Printf( 0, _L("Cdmatest"), _L("FetchNodeL") );
hgs
parents:
diff changeset
   240
hgs
parents:
diff changeset
   241
	iResultsFunction = FetchNodeResultsL;
hgs
parents:
diff changeset
   242
	
hgs
parents:
diff changeset
   243
    TPtrC8 nodename( GetNextStringLC( aItem, _L(" nodename" ) )->Des() ) ;
hgs
parents:
diff changeset
   244
		
hgs
parents:
diff changeset
   245
	SetURIL(nodename) ;//
hgs
parents:
diff changeset
   246
	HBufC8 *luid = GetLuidAllocLC( *iURI );
hgs
parents:
diff changeset
   247
hgs
parents:
diff changeset
   248
	Adapter()->ChildURIListL( *iURI, *luid, *iEmptyMappingInfoArray, 4, 5) ;
hgs
parents:
diff changeset
   249
hgs
parents:
diff changeset
   250
	if ( iStatus == MSmlDmAdapter::EOk )
hgs
parents:
diff changeset
   251
		{
hgs
parents:
diff changeset
   252
		}
hgs
parents:
diff changeset
   253
	else
hgs
parents:
diff changeset
   254
		{
hgs
parents:
diff changeset
   255
		iLog->Log( _L("FetchNodeL: ChildUriList Error ! %d" ), iStatus );	
hgs
parents:
diff changeset
   256
		ret = KErrGeneral ;
hgs
parents:
diff changeset
   257
		}
hgs
parents:
diff changeset
   258
	CleanupStack::PopAndDestroy( luid ) ; 
hgs
parents:
diff changeset
   259
	CleanupStack::PopAndDestroy() ; // nodename
hgs
parents:
diff changeset
   260
	iLog->Log( _L("FetchNodeL: Test Complete with status %d" ), ret );	
hgs
parents:
diff changeset
   261
hgs
parents:
diff changeset
   262
    return ret;
hgs
parents:
diff changeset
   263
	}
hgs
parents:
diff changeset
   264
	
hgs
parents:
diff changeset
   265
TInt Cdmatest::StartAtomicL( CStifItemParser& /*aItem*/ )	
hgs
parents:
diff changeset
   266
	{
hgs
parents:
diff changeset
   267
	TRAPD( err, Adapter()->StartAtomicL() ) ;
hgs
parents:
diff changeset
   268
	iLog->Log( _L("StartAtomicL: Atomic started resulting error %d" ), err );	
hgs
parents:
diff changeset
   269
    return err;
hgs
parents:
diff changeset
   270
	}
hgs
parents:
diff changeset
   271
hgs
parents:
diff changeset
   272
TInt Cdmatest::RollbackAtomicL( CStifItemParser& /*aItem*/ )	
hgs
parents:
diff changeset
   273
	{
hgs
parents:
diff changeset
   274
	TRAPD( err, Adapter()->RollbackAtomicL() ) ;
hgs
parents:
diff changeset
   275
	iLog->Log( _L("RollbackAtomicL: Atomic rolled back resulting error %d" ), err );	
hgs
parents:
diff changeset
   276
    return err;
hgs
parents:
diff changeset
   277
	}
hgs
parents:
diff changeset
   278
	
hgs
parents:
diff changeset
   279
TInt Cdmatest::CommitAtomicL( CStifItemParser& /*aItem*/ )	
hgs
parents:
diff changeset
   280
	{
hgs
parents:
diff changeset
   281
	TRAPD( err, Adapter()->CommitAtomicL() ) ;
hgs
parents:
diff changeset
   282
	iLog->Log( _L("RollbackAtomicL: Atomic commited resulting error %d" ), err );	
hgs
parents:
diff changeset
   283
    return err;
hgs
parents:
diff changeset
   284
	}
hgs
parents:
diff changeset
   285
	
hgs
parents:
diff changeset
   286
hgs
parents:
diff changeset
   287
TInt Cdmatest::DDFStructureL( CStifItemParser& /*aItem*/ )	
hgs
parents:
diff changeset
   288
	{
hgs
parents:
diff changeset
   289
	CTestDmDDFObject* ddfRoot = CTestDmDDFObject::NewLC( iLog ); //, aNodeName );
hgs
parents:
diff changeset
   290
hgs
parents:
diff changeset
   291
	TRAPD( err, iAdapter->DDFStructureL( *ddfRoot ) ) ;
hgs
parents:
diff changeset
   292
	CleanupStack::PopAndDestroy( ddfRoot );
hgs
parents:
diff changeset
   293
	iLog->Log( _L("DDFStructureL: method called resulting error %d" ), err );	
hgs
parents:
diff changeset
   294
    return err;
hgs
parents:
diff changeset
   295
	}
hgs
parents:
diff changeset
   296
		
hgs
parents:
diff changeset
   297
		
hgs
parents:
diff changeset
   298
TInt Cdmatest::AddNodeL( CStifItemParser& aItem )	
hgs
parents:
diff changeset
   299
	{
hgs
parents:
diff changeset
   300
hgs
parents:
diff changeset
   301
    TInt ret( KErrNone );
hgs
parents:
diff changeset
   302
    // Print to UI
hgs
parents:
diff changeset
   303
    TestModuleIf().Printf( 0, _L("Cdmatest"), _L("AddNodeL") );
hgs
parents:
diff changeset
   304
hgs
parents:
diff changeset
   305
    
hgs
parents:
diff changeset
   306
    TPtrC8 nodename( GetNextStringLC ( aItem, _L("nodename" ) )->Des() ) ;
hgs
parents:
diff changeset
   307
    SetURIL( nodename );
hgs
parents:
diff changeset
   308
hgs
parents:
diff changeset
   309
	Adapter()->AddNodeObjectL( *iURI, KEmptyType, 8 ) ;
hgs
parents:
diff changeset
   310
	
hgs
parents:
diff changeset
   311
	if ( iStatus == MSmlDmAdapter::EOk )
hgs
parents:
diff changeset
   312
		{
hgs
parents:
diff changeset
   313
		iLog->Log( _L("AddNodeL: AddNodeObjectL Successful! %d" ), iStatus );	
hgs
parents:
diff changeset
   314
		}
hgs
parents:
diff changeset
   315
	else
hgs
parents:
diff changeset
   316
		{
hgs
parents:
diff changeset
   317
		iLog->Log( _L("AddNodeL: AddNodeObjectL Error ! %d" ), iStatus );	
hgs
parents:
diff changeset
   318
		ret = KErrGeneral ;
hgs
parents:
diff changeset
   319
		}
hgs
parents:
diff changeset
   320
		
hgs
parents:
diff changeset
   321
	CleanupStack::PopAndDestroy() ; // nodename
hgs
parents:
diff changeset
   322
	iLog->Log( _L("AddNodeL Test Complete with status %d" ), ret );	
hgs
parents:
diff changeset
   323
hgs
parents:
diff changeset
   324
    return ret;
hgs
parents:
diff changeset
   325
	}	
hgs
parents:
diff changeset
   326
		
hgs
parents:
diff changeset
   327
TInt Cdmatest::UpdateLeafL( CStifItemParser& aItem )	
hgs
parents:
diff changeset
   328
	{
hgs
parents:
diff changeset
   329
hgs
parents:
diff changeset
   330
    TInt ret( KErrNone );
hgs
parents:
diff changeset
   331
    // Print to UI
hgs
parents:
diff changeset
   332
    TestModuleIf().Printf( 0, _L("Cdmatest"), _L("UpdateLeafL") );
hgs
parents:
diff changeset
   333
hgs
parents:
diff changeset
   334
    TPtrC8 nodename( GetNextStringLC ( aItem, _L("Node name") )->Des() ) ;
hgs
parents:
diff changeset
   335
    TPtrC8 data (GetNextStringLC( aItem, _L("datafile"))->Des() );
hgs
parents:
diff changeset
   336
    
hgs
parents:
diff changeset
   337
	HBufC8 *mime = GetNextStringLC( aItem, _L("mime") ) ;
hgs
parents:
diff changeset
   338
    SetURIL( nodename );
hgs
parents:
diff changeset
   339
    
hgs
parents:
diff changeset
   340
    TPtrC8 parentURI(RemoveLastSeg(nodename));
hgs
parents:
diff changeset
   341
    HBufC8 *luid = GetLuidAllocLC( parentURI );
hgs
parents:
diff changeset
   342
    
hgs
parents:
diff changeset
   343
    TDataType type; 
hgs
parents:
diff changeset
   344
hgs
parents:
diff changeset
   345
	TPtrC8 mimePtr( *mime == KNullDesC8 ? type.Des8() : mime->Des() );
hgs
parents:
diff changeset
   346
hgs
parents:
diff changeset
   347
    /**
hgs
parents:
diff changeset
   348
    virtual void UpdateLeafObjectL( const TDesC8& aURI, const TDesC8& aLUID,
hgs
parents:
diff changeset
   349
									const TDesC8& aObject, const TDesC8& aType,
hgs
parents:
diff changeset
   350
									TInt aStatusRef ) = 0;
hgs
parents:
diff changeset
   351
    */
hgs
parents:
diff changeset
   352
    
hgs
parents:
diff changeset
   353
	Adapter()->UpdateLeafObjectL( *iURI , *luid, data, mimePtr, 3);
hgs
parents:
diff changeset
   354
hgs
parents:
diff changeset
   355
	if ( iStatus == MSmlDmAdapter::EOk )
hgs
parents:
diff changeset
   356
	{
hgs
parents:
diff changeset
   357
		iLog->Log( _L("UpdateLeafL: UpdateLeafObjectL Successful! %d" ), iStatus );	
hgs
parents:
diff changeset
   358
	}
hgs
parents:
diff changeset
   359
	else
hgs
parents:
diff changeset
   360
	{
hgs
parents:
diff changeset
   361
		iLog->Log( _L("UpdateLeafL UpdateLeafObjectL Error ! %d" ), iStatus );	
hgs
parents:
diff changeset
   362
		ret = KErrGeneral ;
hgs
parents:
diff changeset
   363
	}
hgs
parents:
diff changeset
   364
hgs
parents:
diff changeset
   365
	CleanupStack::PopAndDestroy(); // loadfile
hgs
parents:
diff changeset
   366
	CleanupStack::PopAndDestroy(); // luid
hgs
parents:
diff changeset
   367
	CleanupStack::PopAndDestroy(); // mime
hgs
parents:
diff changeset
   368
	CleanupStack::PopAndDestroy(); // nodename
hgs
parents:
diff changeset
   369
hgs
parents:
diff changeset
   370
	iLog->Log( _L("UpdateLeafL Test Complete with status %d" ), ret );	
hgs
parents:
diff changeset
   371
hgs
parents:
diff changeset
   372
    return ret;
hgs
parents:
diff changeset
   373
	}	
hgs
parents:
diff changeset
   374
	
hgs
parents:
diff changeset
   375
hgs
parents:
diff changeset
   376
TInt Cdmatest::UpdateLeafDataURLL( CStifItemParser& aItem )	
hgs
parents:
diff changeset
   377
	{
hgs
parents:
diff changeset
   378
hgs
parents:
diff changeset
   379
    TInt ret( KErrNone );
hgs
parents:
diff changeset
   380
    // Print to UI
hgs
parents:
diff changeset
   381
    TestModuleIf().Printf( 0, _L("Cdmatest"), _L("UpdateLeafDataL") );
hgs
parents:
diff changeset
   382
hgs
parents:
diff changeset
   383
    TPtrC8 nodename( GetNextStringLC ( aItem, _L("Node name") )->Des() ) ;
hgs
parents:
diff changeset
   384
    TPtrC8 http (GetNextStringLC( aItem, _L("http"))->Des() );
hgs
parents:
diff changeset
   385
    TPtrC8 url (GetNextStringLC( aItem, _L("rest of url"))->Des() );
hgs
parents:
diff changeset
   386
	HBufC8 *mime = GetNextStringLC( aItem, _L("mime") ) ;
hgs
parents:
diff changeset
   387
    SetURIL( nodename );
hgs
parents:
diff changeset
   388
    
hgs
parents:
diff changeset
   389
    _LIT8( KTag, "://" );
hgs
parents:
diff changeset
   390
    
hgs
parents:
diff changeset
   391
    HBufC8 *fullurl = HBufC8::NewLC( http.Length() + KTag().Length() + url.Length() );
hgs
parents:
diff changeset
   392
    TPtr8 pfullurl( fullurl->Des() );
hgs
parents:
diff changeset
   393
    pfullurl.Copy( http ) ;
hgs
parents:
diff changeset
   394
    pfullurl.Append( KTag );
hgs
parents:
diff changeset
   395
    pfullurl.Append( url );
hgs
parents:
diff changeset
   396
    TPtrC8 mimePtr( *mime == KNullDesC8 ? KDefaultType() : mime->Des() );
hgs
parents:
diff changeset
   397
    
hgs
parents:
diff changeset
   398
    HBufC8 *luid = GetLuidAllocLC( *iURI );
hgs
parents:
diff changeset
   399
    /**
hgs
parents:
diff changeset
   400
    virtual void UpdateLeafObjectL( const TDesC8& aURI, const TDesC8& aLUID,
hgs
parents:
diff changeset
   401
									const TDesC8& aObject, const TDesC8& aType,
hgs
parents:
diff changeset
   402
									TInt aStatusRef ) = 0;
hgs
parents:
diff changeset
   403
    */
hgs
parents:
diff changeset
   404
	Adapter()->UpdateLeafObjectL( *iURI , *luid, pfullurl, mimePtr, 3);
hgs
parents:
diff changeset
   405
	if ( iStatus == MSmlDmAdapter::EOk )
hgs
parents:
diff changeset
   406
		{
hgs
parents:
diff changeset
   407
		iLog->Log( _L("UpdateLeafDataL: UpdateLeafObjectL Successful! %d" ), iStatus );	
hgs
parents:
diff changeset
   408
		}
hgs
parents:
diff changeset
   409
	else
hgs
parents:
diff changeset
   410
		{
hgs
parents:
diff changeset
   411
		iLog->Log( _L("UpdateLeafDataL UpdateLeafObjectL Error ! %d" ), iStatus );	
hgs
parents:
diff changeset
   412
		ret = KErrGeneral ;
hgs
parents:
diff changeset
   413
		}
hgs
parents:
diff changeset
   414
	CleanupStack::PopAndDestroy( luid ); // 
hgs
parents:
diff changeset
   415
	CleanupStack::PopAndDestroy( mime ); // mime
hgs
parents:
diff changeset
   416
	CleanupStack::PopAndDestroy(); // url
hgs
parents:
diff changeset
   417
	CleanupStack::PopAndDestroy(); // http
hgs
parents:
diff changeset
   418
	CleanupStack::PopAndDestroy(); // nodename
hgs
parents:
diff changeset
   419
	iLog->Log( _L("UpdateLeafDataL Test Complete with status %d" ), ret );	
hgs
parents:
diff changeset
   420
hgs
parents:
diff changeset
   421
    return ret;
hgs
parents:
diff changeset
   422
	}
hgs
parents:
diff changeset
   423
    
hgs
parents:
diff changeset
   424
TInt Cdmatest::UpdateLeafDataL( CStifItemParser& aItem )	
hgs
parents:
diff changeset
   425
	{
hgs
parents:
diff changeset
   426
hgs
parents:
diff changeset
   427
    TInt ret( KErrNone );
hgs
parents:
diff changeset
   428
    // Print to UI
hgs
parents:
diff changeset
   429
   TestModuleIf().Printf( 0, _L("Camtest"), _L("UpdateLeafDataL") );
hgs
parents:
diff changeset
   430
hgs
parents:
diff changeset
   431
    TPtrC8 nodename( GetNextStringLC ( aItem, _L("Node name") )->Des() ) ;
hgs
parents:
diff changeset
   432
    TPtrC8 data (GetNextStringLC( aItem, _L("data"))->Des() );
hgs
parents:
diff changeset
   433
	HBufC8 *mime = GetNextStringLC( aItem, _L("mime") ) ;
hgs
parents:
diff changeset
   434
	
hgs
parents:
diff changeset
   435
    SetURIL( nodename );
hgs
parents:
diff changeset
   436
    
hgs
parents:
diff changeset
   437
        
hgs
parents:
diff changeset
   438
    TPtrC8 mimePtr( *mime == KNullDesC8 ? KDefaultType() : mime->Des() );
hgs
parents:
diff changeset
   439
    
hgs
parents:
diff changeset
   440
    TPtrC8 parentURI(RemoveLastSeg(nodename));
hgs
parents:
diff changeset
   441
    HBufC8 *luid = GetLuidAllocLC( parentURI );
hgs
parents:
diff changeset
   442
     
hgs
parents:
diff changeset
   443
//    
hgs
parents:
diff changeset
   444
//    virtual void UpdateLeafObjectL( const TDesC8& aURI, const TDesC8& aLUID,
hgs
parents:
diff changeset
   445
//									const TDesC8& aObject, const TDesC8& aType,
hgs
parents:
diff changeset
   446
//									TInt aStatusRef ) = 0;
hgs
parents:
diff changeset
   447
//   
hgs
parents:
diff changeset
   448
	Adapter()->UpdateLeafObjectL( *iURI , *luid, data, mimePtr, 3);
hgs
parents:
diff changeset
   449
	if ( iStatus == MSmlDmAdapter::EOk )
hgs
parents:
diff changeset
   450
		{
hgs
parents:
diff changeset
   451
		iLog->Log( _L("UpdateLeafDataL: UpdateLeafObjectL Successful! %d" ), iStatus );	
hgs
parents:
diff changeset
   452
		}
hgs
parents:
diff changeset
   453
	else
hgs
parents:
diff changeset
   454
		{
hgs
parents:
diff changeset
   455
		iLog->Log( _L("UpdateLeafDataL UpdateLeafObjectL Error ! %d" ), iStatus );	
hgs
parents:
diff changeset
   456
		ret = KErrGeneral ;
hgs
parents:
diff changeset
   457
		}
hgs
parents:
diff changeset
   458
	
hgs
parents:
diff changeset
   459
	CleanupStack::PopAndDestroy(); // mime
hgs
parents:
diff changeset
   460
	CleanupStack::PopAndDestroy(); // luid
hgs
parents:
diff changeset
   461
	CleanupStack::PopAndDestroy(); // data
hgs
parents:
diff changeset
   462
	CleanupStack::PopAndDestroy(); // nodename
hgs
parents:
diff changeset
   463
	iLog->Log( _L("UpdateLeafDataL Test Complete with status %d" ), ret );	
hgs
parents:
diff changeset
   464
hgs
parents:
diff changeset
   465
    return ret;
hgs
parents:
diff changeset
   466
	}	
hgs
parents:
diff changeset
   467
			
hgs
parents:
diff changeset
   468
TInt Cdmatest::FetchLeafL( CStifItemParser& aItem )	
hgs
parents:
diff changeset
   469
	{
hgs
parents:
diff changeset
   470
hgs
parents:
diff changeset
   471
    TInt ret( KErrNone );
hgs
parents:
diff changeset
   472
    // Print to UI
hgs
parents:
diff changeset
   473
    TestModuleIf().Printf( 0, _L("Camtest"), _L("FetchLeafL") );
hgs
parents:
diff changeset
   474
hgs
parents:
diff changeset
   475
	iResultsFunction = NULL;
hgs
parents:
diff changeset
   476
	
hgs
parents:
diff changeset
   477
    TInt i( 0 );
hgs
parents:
diff changeset
   478
    TPtrC8 nodename ( GetNextStringLC( aItem, _L( "nodename" ) )->Des() ) ;
hgs
parents:
diff changeset
   479
    
hgs
parents:
diff changeset
   480
    //TPtrC datafile;
hgs
parents:
diff changeset
   481
    TPtrC datafile( KNullDesC );
hgs
parents:
diff changeset
   482
    i = aItem.GetNextString ( datafile ) ;
hgs
parents:
diff changeset
   483
    if ( i != KErrNone ) 
hgs
parents:
diff changeset
   484
	    {
hgs
parents:
diff changeset
   485
	    iLog->Log(_L("FetchLeafL: ERROR Reading outfile argument: 0x%X"), i );
hgs
parents:
diff changeset
   486
	    //return i;
hgs
parents:
diff changeset
   487
	    }
hgs
parents:
diff changeset
   488
	else
hgs
parents:
diff changeset
   489
		{
hgs
parents:
diff changeset
   490
		iSaveFileName = datafile;
hgs
parents:
diff changeset
   491
		iLog->Log( _L( " Save file nameis '%S'" ), &iSaveFileName );
hgs
parents:
diff changeset
   492
		iResultsFunction = SaveDataL;
hgs
parents:
diff changeset
   493
		}
hgs
parents:
diff changeset
   494
    
hgs
parents:
diff changeset
   495
	SetURIL(nodename) ;
hgs
parents:
diff changeset
   496
		
hgs
parents:
diff changeset
   497
		/*
hgs
parents:
diff changeset
   498
			void FetchLeafObjectL( const TDesC8& aURI, const TDesC8& aLUID,
hgs
parents:
diff changeset
   499
								   const TDesC8& aType, TInt aResultsRef,
hgs
parents:
diff changeset
   500
								   TInt aStatusRef );
hgs
parents:
diff changeset
   501
		*/
hgs
parents:
diff changeset
   502
    TPtrC8 parentURI(RemoveLastSeg(nodename));
hgs
parents:
diff changeset
   503
    HBufC8 *luid = GetLuidAllocLC( parentURI );
hgs
parents:
diff changeset
   504
hgs
parents:
diff changeset
   505
	Adapter()->FetchLeafObjectL( *iURI, *luid, KEmptyType, 7, 8 ) ;
hgs
parents:
diff changeset
   506
	if ( iStatus == MSmlDmAdapter::EOk )
hgs
parents:
diff changeset
   507
		{
hgs
parents:
diff changeset
   508
		iLog->Log( _L("FetchLeafL: FetchLeafObjectL Successful! %d" ), iStatus );	
hgs
parents:
diff changeset
   509
		}
hgs
parents:
diff changeset
   510
	else
hgs
parents:
diff changeset
   511
		{
hgs
parents:
diff changeset
   512
		iLog->Log( _L("FetchLeafL: FetchLeafObjectL Error ! %d" ), iStatus );	
hgs
parents:
diff changeset
   513
		ret = KErrGeneral ;
hgs
parents:
diff changeset
   514
		}
hgs
parents:
diff changeset
   515
	CleanupStack::PopAndDestroy( luid );
hgs
parents:
diff changeset
   516
	CleanupStack::PopAndDestroy(  ); // nodename
hgs
parents:
diff changeset
   517
	iLog->Log( _L("FetchLeafL Test Complete with status %d" ), ret );	
hgs
parents:
diff changeset
   518
    return ret;
hgs
parents:
diff changeset
   519
	}	
hgs
parents:
diff changeset
   520
hgs
parents:
diff changeset
   521
hgs
parents:
diff changeset
   522
TInt Cdmatest::ExecuteLeafL( CStifItemParser& aItem )		
hgs
parents:
diff changeset
   523
	{
hgs
parents:
diff changeset
   524
	TInt ret( KErrNone );
hgs
parents:
diff changeset
   525
    // Print to UI
hgs
parents:
diff changeset
   526
    TestModuleIf().Printf( 0, _L("Camtest"), _L("ExecuteLeafL") );
hgs
parents:
diff changeset
   527
hgs
parents:
diff changeset
   528
	iResultsFunction = NULL;
hgs
parents:
diff changeset
   529
	
hgs
parents:
diff changeset
   530
    TPtrC8 nodename( GetNextStringLC ( aItem, _L("Nodename") )->Des() ) ;
hgs
parents:
diff changeset
   531
    TPtrC8 data( GetNextStringLC ( aItem, _L("Input file") )->Des() ) ;
hgs
parents:
diff changeset
   532
	
hgs
parents:
diff changeset
   533
	SetURIL(nodename) ;
hgs
parents:
diff changeset
   534
hgs
parents:
diff changeset
   535
		/*
hgs
parents:
diff changeset
   536
			virtual void ExecuteCommandL( const TDesC8& aURI, const TDesC8& aLUID,
hgs
parents:
diff changeset
   537
							      const TDesC8& aArgument, const TDesC8& aType,
hgs
parents:
diff changeset
   538
								  TInt aStatusRef ) = 0;
hgs
parents:
diff changeset
   539
		*/
hgs
parents:
diff changeset
   540
	TDataType type;
hgs
parents:
diff changeset
   541
	
hgs
parents:
diff changeset
   542
    TPtrC8 parentURI(RemoveLastSeg(nodename));
hgs
parents:
diff changeset
   543
    HBufC8 *luid = GetLuidAllocLC( parentURI );
hgs
parents:
diff changeset
   544
hgs
parents:
diff changeset
   545
	Adapter()->ExecuteCommandL( *iURI, *luid, data, KEmptyType, 11 ) ;
hgs
parents:
diff changeset
   546
	if ( iStatus == MSmlDmAdapter::EOk )
hgs
parents:
diff changeset
   547
		{
hgs
parents:
diff changeset
   548
		iLog->Log( _L("ExecuteLeafL: ExecuteCommandL Successful! %d" ), iStatus );	
hgs
parents:
diff changeset
   549
		}
hgs
parents:
diff changeset
   550
	else
hgs
parents:
diff changeset
   551
		{
hgs
parents:
diff changeset
   552
		iLog->Log( _L("ExecuteLeafL: ExecuteCommandL FetchLeafObjectL Error ! %d" ), iStatus );	
hgs
parents:
diff changeset
   553
		ret = KErrGeneral ;
hgs
parents:
diff changeset
   554
		}
hgs
parents:
diff changeset
   555
	CleanupStack::PopAndDestroy( luid ); // luid
hgs
parents:
diff changeset
   556
	CleanupStack::PopAndDestroy(); // data
hgs
parents:
diff changeset
   557
	CleanupStack::PopAndDestroy(); // nodename
hgs
parents:
diff changeset
   558
	
hgs
parents:
diff changeset
   559
	iLog->Log( _L("ExecuteLeafL: Test Complete with status %d" ), ret );	
hgs
parents:
diff changeset
   560
hgs
parents:
diff changeset
   561
    return ret;
hgs
parents:
diff changeset
   562
	}
hgs
parents:
diff changeset
   563
	
hgs
parents:
diff changeset
   564
TInt Cdmatest::CompleteCommandsL( CStifItemParser& /*aItem*/ )
hgs
parents:
diff changeset
   565
	{
hgs
parents:
diff changeset
   566
	TRAPD( err, Adapter()->CompleteOutstandingCmdsL() );
hgs
parents:
diff changeset
   567
	delete iAdapter;
hgs
parents:
diff changeset
   568
	iAdapter = NULL;
hgs
parents:
diff changeset
   569
	return err;
hgs
parents:
diff changeset
   570
	}
hgs
parents:
diff changeset
   571
TInt Cdmatest::DeleteObjectL( CStifItemParser& aItem )
hgs
parents:
diff changeset
   572
{
hgs
parents:
diff changeset
   573
	TInt ret( KErrNone );
hgs
parents:
diff changeset
   574
    // Print to UI
hgs
parents:
diff changeset
   575
    TestModuleIf().Printf( 0, _L("Camtest"), _L("DeleteObjectL") );
hgs
parents:
diff changeset
   576
hgs
parents:
diff changeset
   577
    TPtrC8 nodename( GetNextStringLC ( aItem, _L("Nodename") )->Des() ) ;
hgs
parents:
diff changeset
   578
hgs
parents:
diff changeset
   579
	SetURIL(nodename) ;
hgs
parents:
diff changeset
   580
hgs
parents:
diff changeset
   581
	HBufC8 *luid = GetLuidAllocLC( *iURI );
hgs
parents:
diff changeset
   582
	Adapter()->DeleteObjectL( *iURI, *luid, 11 ) ;
hgs
parents:
diff changeset
   583
	if ( iStatus == MSmlDmAdapter::EOk )
hgs
parents:
diff changeset
   584
		{
hgs
parents:
diff changeset
   585
		iLog->Log( _L("DeleteNode: DeleteObjectL Successful! %d" ), iStatus );	
hgs
parents:
diff changeset
   586
		}
hgs
parents:
diff changeset
   587
	else
hgs
parents:
diff changeset
   588
		{
hgs
parents:
diff changeset
   589
		iLog->Log( _L("DeleteNode: DeleteObjectL FetchLeafObjectL Error ! %d" ), iStatus );	
hgs
parents:
diff changeset
   590
		ret = KErrGeneral ;
hgs
parents:
diff changeset
   591
		}
hgs
parents:
diff changeset
   592
	CleanupStack::PopAndDestroy( luid ); // luid
hgs
parents:
diff changeset
   593
	CleanupStack::PopAndDestroy(); // nodename	
hgs
parents:
diff changeset
   594
	iLog->Log( _L("ExecuteLeafDataL Test Complete with status %d" ), ret );	
hgs
parents:
diff changeset
   595
hgs
parents:
diff changeset
   596
    return ret;	
hgs
parents:
diff changeset
   597
}
hgs
parents:
diff changeset
   598
	
hgs
parents:
diff changeset
   599
TInt Cdmatest::ExecuteLeafDataL( CStifItemParser& aItem )		
hgs
parents:
diff changeset
   600
	{
hgs
parents:
diff changeset
   601
	TInt ret( KErrNone );
hgs
parents:
diff changeset
   602
hgs
parents:
diff changeset
   603
    // Print to UI
hgs
parents:
diff changeset
   604
    TestModuleIf().Printf( 0, _L("Camtest"), _L("ExecuteLeafL") );
hgs
parents:
diff changeset
   605
hgs
parents:
diff changeset
   606
	iResultsFunction = NULL;
hgs
parents:
diff changeset
   607
	
hgs
parents:
diff changeset
   608
    TPtrC8 nodename( GetNextStringLC ( aItem, _L("Nodename") )->Des() ) ;
hgs
parents:
diff changeset
   609
    TPtrC8 data( GetNextStringLC ( aItem, _L("Input data") )->Des() ) ;
hgs
parents:
diff changeset
   610
    
hgs
parents:
diff changeset
   611
	SetURIL(nodename) ;
hgs
parents:
diff changeset
   612
hgs
parents:
diff changeset
   613
		/*
hgs
parents:
diff changeset
   614
			virtual void ExecuteCommandL( const TDesC8& aURI, const TDesC8& aLUID,
hgs
parents:
diff changeset
   615
							      const TDesC8& aArgument, const TDesC8& aType,
hgs
parents:
diff changeset
   616
								  TInt aStatusRef ) = 0;
hgs
parents:
diff changeset
   617
		*/
hgs
parents:
diff changeset
   618
	HBufC8 *luid = GetLuidAllocLC( *iURI );
hgs
parents:
diff changeset
   619
	Adapter()->ExecuteCommandL( *iURI, *luid, data, KEmptyType, 11 ) ;
hgs
parents:
diff changeset
   620
	if ( iStatus == MSmlDmAdapter::EOk )
hgs
parents:
diff changeset
   621
		{
hgs
parents:
diff changeset
   622
		iLog->Log( _L("ExecuteLeafDataL: ExecuteCommandL Successful! %d" ), iStatus );	
hgs
parents:
diff changeset
   623
		}
hgs
parents:
diff changeset
   624
	else
hgs
parents:
diff changeset
   625
		{
hgs
parents:
diff changeset
   626
		iLog->Log( _L("ExecuteLeafDataL: ExecuteCommandL FetchLeafObjectL Error ! %d" ), iStatus );	
hgs
parents:
diff changeset
   627
		ret = KErrGeneral ;
hgs
parents:
diff changeset
   628
		}
hgs
parents:
diff changeset
   629
	CleanupStack::PopAndDestroy(); // luid
hgs
parents:
diff changeset
   630
	CleanupStack::PopAndDestroy(); // data		
hgs
parents:
diff changeset
   631
	CleanupStack::PopAndDestroy(); // nodename	
hgs
parents:
diff changeset
   632
	iLog->Log( _L("ExecuteLeafDataL Test Complete with status %d" ), ret );	
hgs
parents:
diff changeset
   633
hgs
parents:
diff changeset
   634
    return ret;
hgs
parents:
diff changeset
   635
	}
hgs
parents:
diff changeset
   636
hgs
parents:
diff changeset
   637
hgs
parents:
diff changeset
   638
HBufC8 *Cdmatest::LoadFileLC( const TDesC &aFileName, TDataType &aType )	
hgs
parents:
diff changeset
   639
	{
hgs
parents:
diff changeset
   640
	RFs fs ;
hgs
parents:
diff changeset
   641
	LEAVE_IF_ERROR( fs.Connect(), _L( "Could not connect fileserver: %d"  ) );
hgs
parents:
diff changeset
   642
	
hgs
parents:
diff changeset
   643
	CleanupClosePushL( fs );
hgs
parents:
diff changeset
   644
	RFile file ;
hgs
parents:
diff changeset
   645
	LEAVE_IF_ERROR( file.Open(fs,aFileName,EFileRead), _L( "Could not open file: %d" ) );
hgs
parents:
diff changeset
   646
	
hgs
parents:
diff changeset
   647
	
hgs
parents:
diff changeset
   648
	
hgs
parents:
diff changeset
   649
	CleanupClosePushL( file );
hgs
parents:
diff changeset
   650
	TInt dataSize ;
hgs
parents:
diff changeset
   651
	LEAVE_IF_ERROR( file.Size( dataSize ), _L( "Could not get file size: %d" ) );
hgs
parents:
diff changeset
   652
	HBufC8 *nodedata = HBufC8::NewL ( dataSize );
hgs
parents:
diff changeset
   653
	CleanupStack::PushL( nodedata );
hgs
parents:
diff changeset
   654
	TPtr8 nodedataptr( nodedata->Des() );
hgs
parents:
diff changeset
   655
	LEAVE_IF_ERROR( file.Read( nodedataptr ), _L( "Could not read file: %d" ) );
hgs
parents:
diff changeset
   656
	TDataRecognitionResult aDataType;
hgs
parents:
diff changeset
   657
	RApaLsSession ls ;
hgs
parents:
diff changeset
   658
	TInt err( ls.Connect() );
hgs
parents:
diff changeset
   659
	if ( err == KErrNone )
hgs
parents:
diff changeset
   660
		{
hgs
parents:
diff changeset
   661
		CleanupClosePushL( ls );
hgs
parents:
diff changeset
   662
		err = ls.RecognizeData(aFileName, nodedataptr, aDataType)  ;
hgs
parents:
diff changeset
   663
		if ( err == KErrNone )
hgs
parents:
diff changeset
   664
			{
hgs
parents:
diff changeset
   665
			aType = aDataType.iDataType;
hgs
parents:
diff changeset
   666
			}
hgs
parents:
diff changeset
   667
		else
hgs
parents:
diff changeset
   668
			{
hgs
parents:
diff changeset
   669
			iLog->Log( _L("LoadFileLC: WARNING Failed to get type: %d" ), err );
hgs
parents:
diff changeset
   670
			aType = TDataType( KDefaultType );
hgs
parents:
diff changeset
   671
			}	
hgs
parents:
diff changeset
   672
		CleanupStack::PopAndDestroy( &ls ); 
hgs
parents:
diff changeset
   673
		}
hgs
parents:
diff changeset
   674
	else
hgs
parents:
diff changeset
   675
		{
hgs
parents:
diff changeset
   676
		iLog->Log( _L("LoadFileLC: WARNING Failed to connect rapalssession: %d" ), err );
hgs
parents:
diff changeset
   677
		}	
hgs
parents:
diff changeset
   678
	CleanupStack::Pop( nodedata );
hgs
parents:
diff changeset
   679
	CleanupStack::PopAndDestroy( &file ); 
hgs
parents:
diff changeset
   680
	CleanupStack::PopAndDestroy( &fs ); 
hgs
parents:
diff changeset
   681
	CleanupStack::PushL( nodedata );
hgs
parents:
diff changeset
   682
	return nodedata ;
hgs
parents:
diff changeset
   683
	}
hgs
parents:
diff changeset
   684
hgs
parents:
diff changeset
   685
HBufC8 *Cdmatest::LoadFileLC( const TDesC8 &aFileName, TDataType &aType )	
hgs
parents:
diff changeset
   686
	{
hgs
parents:
diff changeset
   687
	TFileName fn ;
hgs
parents:
diff changeset
   688
	fn.Copy( aFileName );
hgs
parents:
diff changeset
   689
	return LoadFileLC( fn, aType );
hgs
parents:
diff changeset
   690
	}
hgs
parents:
diff changeset
   691
	
hgs
parents:
diff changeset
   692
hgs
parents:
diff changeset
   693
void Cdmatest::SaveDataL( TInt /*aResultsRef*/, CBufBase& aObject,
hgs
parents:
diff changeset
   694
							  const TDesC8& aType ) 
hgs
parents:
diff changeset
   695
	{
hgs
parents:
diff changeset
   696
	iLog->Log( _L8( "Saving data of type: '%S'" ), &aType );
hgs
parents:
diff changeset
   697
	RFs fs;
hgs
parents:
diff changeset
   698
	User::LeaveIfError( fs.Connect() );
hgs
parents:
diff changeset
   699
	CleanupClosePushL( fs );
hgs
parents:
diff changeset
   700
	RFile file;
hgs
parents:
diff changeset
   701
	User::LeaveIfError( file.Replace ( fs, iSaveFileName, EFileWrite ) );
hgs
parents:
diff changeset
   702
	CleanupClosePushL( file );
hgs
parents:
diff changeset
   703
	TPtrC8 p( aObject.Ptr( 0 ) );
hgs
parents:
diff changeset
   704
	User::LeaveIfError( file.Write( p ) );
hgs
parents:
diff changeset
   705
	CleanupStack::PopAndDestroy( 2 ); // file, fs
hgs
parents:
diff changeset
   706
	}
hgs
parents:
diff changeset
   707
							  
hgs
parents:
diff changeset
   708
		
hgs
parents:
diff changeset
   709
	
hgs
parents:
diff changeset
   710
void Cdmatest::FetchNodeResultsL( TInt /*aResultsRef*/, CBufBase& aObject,
hgs
parents:
diff changeset
   711
							  const TDesC8& /*aType*/ )
hgs
parents:
diff changeset
   712
	{
hgs
parents:
diff changeset
   713
	TPtrC8 ptr( aObject.Ptr( 0 ) );	
hgs
parents:
diff changeset
   714
	iLog->Log( _L8("FetchNodeResultsL for '%S': '%S'" ), iURI, &ptr );
hgs
parents:
diff changeset
   715
	
hgs
parents:
diff changeset
   716
	if ( ptr.Length() > 0 )
hgs
parents:
diff changeset
   717
		{
hgs
parents:
diff changeset
   718
		TPtrC8 last( LastURISeg( ptr ) );
hgs
parents:
diff changeset
   719
		HBufC8 *oldUri = HBufC8::NewL( iURI->Length() );
hgs
parents:
diff changeset
   720
		(*oldUri) = *iURI; 
hgs
parents:
diff changeset
   721
		do 
hgs
parents:
diff changeset
   722
			{
hgs
parents:
diff changeset
   723
			iLog->Log ( _L8( " Node: '%S' "), &last );
hgs
parents:
diff changeset
   724
			HBufC8 *nUri = HBufC8::NewLC( oldUri->Length() + 1 + last.Length() );
hgs
parents:
diff changeset
   725
			nUri->Des().Copy( *oldUri ) ;
hgs
parents:
diff changeset
   726
			nUri->Des().Append( '/' );
hgs
parents:
diff changeset
   727
			nUri->Des().Append( last );
hgs
parents:
diff changeset
   728
			
hgs
parents:
diff changeset
   729
			SetURIL( nUri );
hgs
parents:
diff changeset
   730
			//iResultsFunction = FetchNodeResultsL;
hgs
parents:
diff changeset
   731
			
hgs
parents:
diff changeset
   732
		    //TPtrC8 parentURI(RemoveLastSeg(*nUri));
hgs
parents:
diff changeset
   733
		    //HBufC8 *luid = GetLuidAllocLC( parentURI );
hgs
parents:
diff changeset
   734
		    CleanupStack::Pop( nUri );
hgs
parents:
diff changeset
   735
			
hgs
parents:
diff changeset
   736
			HBufC8 *luid = GetLuidAllocLC( *iURI );
hgs
parents:
diff changeset
   737
			
hgs
parents:
diff changeset
   738
			Adapter()->ChildURIListL( *nUri, KNullDesC8, *iEmptyMappingInfoArray, 4, 5 );//Dipak
hgs
parents:
diff changeset
   739
			
hgs
parents:
diff changeset
   740
			CleanupStack::PopAndDestroy( luid ); 			
hgs
parents:
diff changeset
   741
			
hgs
parents:
diff changeset
   742
			ptr.Set( RemoveLastURISeg( ptr ) );
hgs
parents:
diff changeset
   743
			last.Set( LastURISeg( ptr ) );
hgs
parents:
diff changeset
   744
			
hgs
parents:
diff changeset
   745
			}
hgs
parents:
diff changeset
   746
		while (last != KNullDesC8);	
hgs
parents:
diff changeset
   747
		}
hgs
parents:
diff changeset
   748
	
hgs
parents:
diff changeset
   749
	}
hgs
parents:
diff changeset
   750
	
hgs
parents:
diff changeset
   751
hgs
parents:
diff changeset
   752
	
hgs
parents:
diff changeset
   753
TPtrC8 Cdmatest::LastURISeg( const TDesC8& aURI )
hgs
parents:
diff changeset
   754
	{
hgs
parents:
diff changeset
   755
	TInt i;
hgs
parents:
diff changeset
   756
	for( i = aURI.Length() - 1; i >= 0; i-- ) 
hgs
parents:
diff changeset
   757
		{
hgs
parents:
diff changeset
   758
		if( aURI[i] == '/' )
hgs
parents:
diff changeset
   759
			{
hgs
parents:
diff changeset
   760
			break;
hgs
parents:
diff changeset
   761
			}
hgs
parents:
diff changeset
   762
		}
hgs
parents:
diff changeset
   763
hgs
parents:
diff changeset
   764
	if( i == 0 )
hgs
parents:
diff changeset
   765
		{
hgs
parents:
diff changeset
   766
		return aURI;
hgs
parents:
diff changeset
   767
		}
hgs
parents:
diff changeset
   768
	else
hgs
parents:
diff changeset
   769
		{
hgs
parents:
diff changeset
   770
		return aURI.Mid( i+1 );
hgs
parents:
diff changeset
   771
		}
hgs
parents:
diff changeset
   772
	}
hgs
parents:
diff changeset
   773
TPtrC8 Cdmatest::RemoveLastSeg(const TDesC8& aURI)
hgs
parents:
diff changeset
   774
	{
hgs
parents:
diff changeset
   775
	TInt i;
hgs
parents:
diff changeset
   776
	for(i=aURI.Length()-1;i>=0;i--)
hgs
parents:
diff changeset
   777
		{
hgs
parents:
diff changeset
   778
		if(aURI[i]==KNSmlDMUriSeparator)
hgs
parents:
diff changeset
   779
			{
hgs
parents:
diff changeset
   780
			break;
hgs
parents:
diff changeset
   781
			}
hgs
parents:
diff changeset
   782
		}
hgs
parents:
diff changeset
   783
hgs
parents:
diff changeset
   784
	if(i>0)
hgs
parents:
diff changeset
   785
		{
hgs
parents:
diff changeset
   786
		return aURI.Left(i);
hgs
parents:
diff changeset
   787
		}
hgs
parents:
diff changeset
   788
	else
hgs
parents:
diff changeset
   789
		{
hgs
parents:
diff changeset
   790
		return KNullDesC8();
hgs
parents:
diff changeset
   791
		}
hgs
parents:
diff changeset
   792
	}
hgs
parents:
diff changeset
   793
hgs
parents:
diff changeset
   794
// ------------------------------------------------------------------------------------------------
hgs
parents:
diff changeset
   795
// TPtrC8 Cdmatest::RemoveLastURISeg(const TDesC8& aURI)
hgs
parents:
diff changeset
   796
// returns parent uri, i.e. removes last uri segment
hgs
parents:
diff changeset
   797
// ------------------------------------------------------------------------------------------------
hgs
parents:
diff changeset
   798
TPtrC8 Cdmatest::RemoveLastURISeg( const TDesC8& aURI )
hgs
parents:
diff changeset
   799
	{
hgs
parents:
diff changeset
   800
	TInt i;
hgs
parents:
diff changeset
   801
	for ( i = aURI.Length() - 1; i >= 0 ; i-- )
hgs
parents:
diff changeset
   802
		{
hgs
parents:
diff changeset
   803
		if( aURI[i] == '/' )
hgs
parents:
diff changeset
   804
			{
hgs
parents:
diff changeset
   805
			break;
hgs
parents:
diff changeset
   806
			}
hgs
parents:
diff changeset
   807
		}
hgs
parents:
diff changeset
   808
	if ( i > -1 )
hgs
parents:
diff changeset
   809
		{
hgs
parents:
diff changeset
   810
		return aURI.Left( i );	
hgs
parents:
diff changeset
   811
		}
hgs
parents:
diff changeset
   812
	else
hgs
parents:
diff changeset
   813
		{
hgs
parents:
diff changeset
   814
		return KNullDesC8();
hgs
parents:
diff changeset
   815
		}
hgs
parents:
diff changeset
   816
	}	
hgs
parents:
diff changeset
   817
	
hgs
parents:
diff changeset
   818
TPtrC Cdmatest::RemoveLastURISeg( const TDesC& aURI )
hgs
parents:
diff changeset
   819
	{
hgs
parents:
diff changeset
   820
	TInt i;
hgs
parents:
diff changeset
   821
	for ( i = aURI.Length() - 1; i >= 0 ; i-- )
hgs
parents:
diff changeset
   822
		{
hgs
parents:
diff changeset
   823
		if( aURI[i] == '/' )
hgs
parents:
diff changeset
   824
			{
hgs
parents:
diff changeset
   825
			break;
hgs
parents:
diff changeset
   826
			}
hgs
parents:
diff changeset
   827
		}
hgs
parents:
diff changeset
   828
	if ( i > -1 )
hgs
parents:
diff changeset
   829
		{
hgs
parents:
diff changeset
   830
		return aURI.Left( i );	
hgs
parents:
diff changeset
   831
		}
hgs
parents:
diff changeset
   832
	else
hgs
parents:
diff changeset
   833
hgs
parents:
diff changeset
   834
		{
hgs
parents:
diff changeset
   835
		return KNullDesC();
hgs
parents:
diff changeset
   836
		}
hgs
parents:
diff changeset
   837
	}		
hgs
parents:
diff changeset
   838
	
hgs
parents:
diff changeset
   839
void Cdmatest::SetURIL( const TDesC& aURI )
hgs
parents:
diff changeset
   840
	{
hgs
parents:
diff changeset
   841
	if ( iURI != NULL )
hgs
parents:
diff changeset
   842
		{
hgs
parents:
diff changeset
   843
		delete iURI ;
hgs
parents:
diff changeset
   844
		iURI = NULL;
hgs
parents:
diff changeset
   845
		}
hgs
parents:
diff changeset
   846
	iURI = HBufC8::NewL( aURI.Length() ) ;
hgs
parents:
diff changeset
   847
	iURI->Des().Copy( aURI );
hgs
parents:
diff changeset
   848
	}
hgs
parents:
diff changeset
   849
	
hgs
parents:
diff changeset
   850
void Cdmatest::SetURIL( const TDesC8& aURI )
hgs
parents:
diff changeset
   851
	{
hgs
parents:
diff changeset
   852
	if ( iURI != NULL )
hgs
parents:
diff changeset
   853
		{
hgs
parents:
diff changeset
   854
		delete iURI ;
hgs
parents:
diff changeset
   855
		iURI = NULL;
hgs
parents:
diff changeset
   856
		}
hgs
parents:
diff changeset
   857
	iURI = HBufC8::NewL( aURI.Length() ) ;
hgs
parents:
diff changeset
   858
	iURI->Des().Copy( aURI );
hgs
parents:
diff changeset
   859
	}	
hgs
parents:
diff changeset
   860
hgs
parents:
diff changeset
   861
void Cdmatest::SetURIL( HBufC8* aURI )
hgs
parents:
diff changeset
   862
	{
hgs
parents:
diff changeset
   863
	if ( iURI != NULL )
hgs
parents:
diff changeset
   864
		{
hgs
parents:
diff changeset
   865
		delete iURI ;
hgs
parents:
diff changeset
   866
		iURI = NULL;
hgs
parents:
diff changeset
   867
		}
hgs
parents:
diff changeset
   868
	iURI = aURI ;
hgs
parents:
diff changeset
   869
	}
hgs
parents:
diff changeset
   870
		
hgs
parents:
diff changeset
   871
		
hgs
parents:
diff changeset
   872
		
hgs
parents:
diff changeset
   873
void Cdmatest::SetResultsL( 
hgs
parents:
diff changeset
   874
	TInt aResultsRef, 
hgs
parents:
diff changeset
   875
	CBufBase& aObject,
hgs
parents:
diff changeset
   876
	const TDesC8& aType )
hgs
parents:
diff changeset
   877
	{
hgs
parents:
diff changeset
   878
	TPtrC8 ptr( aObject.Ptr(0) );
hgs
parents:
diff changeset
   879
	iLog->Log( _L8( "SetResults, ref=%d, object='%S', type='%S'" ), aResultsRef, &ptr, &aType );
hgs
parents:
diff changeset
   880
	if ( iResultsFunction )
hgs
parents:
diff changeset
   881
		{
hgs
parents:
diff changeset
   882
		(this->*iResultsFunction)( aResultsRef, aObject, aType );
hgs
parents:
diff changeset
   883
		iResultsFunction = NULL ;
hgs
parents:
diff changeset
   884
		}
hgs
parents:
diff changeset
   885
	
hgs
parents:
diff changeset
   886
	}
hgs
parents:
diff changeset
   887
hgs
parents:
diff changeset
   888
hgs
parents:
diff changeset
   889
void Cdmatest::SetStatusL( TInt aStatusRef,
hgs
parents:
diff changeset
   890
							 MSmlDmAdapter::TError aErrorCode ) 
hgs
parents:
diff changeset
   891
	{
hgs
parents:
diff changeset
   892
	iStatus = aErrorCode ;
hgs
parents:
diff changeset
   893
	iLog->Log( _L( "SetStatusL, ref=%d, code=%d" ), aStatusRef, aErrorCode );
hgs
parents:
diff changeset
   894
	
hgs
parents:
diff changeset
   895
	
hgs
parents:
diff changeset
   896
	}
hgs
parents:
diff changeset
   897
	
hgs
parents:
diff changeset
   898
void Cdmatest::SetMappingL( const TDesC8& aURI, const TDesC8& aLUID ) 
hgs
parents:
diff changeset
   899
	{
hgs
parents:
diff changeset
   900
	iLog->Log( _L8( "SetMappingL, aURI='%s', aLUID='%s'" ), aURI.Ptr(), aLUID.Ptr() );	
hgs
parents:
diff changeset
   901
	
hgs
parents:
diff changeset
   902
	iMappingTable.Append(TMapping( aURI, aLUID ) )	;
hgs
parents:
diff changeset
   903
	}
hgs
parents:
diff changeset
   904
	
hgs
parents:
diff changeset
   905
HBufC8* Cdmatest::GetLuidAllocL( const TDesC8& aURI ) 
hgs
parents:
diff changeset
   906
	{
hgs
parents:
diff changeset
   907
	iLog->Log( _L8( "GetLuidAllocL, aURI='%S'" ), &aURI );		
hgs
parents:
diff changeset
   908
	HBufC8 *res = NULL;		
hgs
parents:
diff changeset
   909
	for( TInt i(0); i < iMappingTable.Count(); i++ )	
hgs
parents:
diff changeset
   910
		{
hgs
parents:
diff changeset
   911
		if ( aURI == iMappingTable[i].iURI )
hgs
parents:
diff changeset
   912
			{
hgs
parents:
diff changeset
   913
			res = iMappingTable[i].iLuid.AllocL();
hgs
parents:
diff changeset
   914
			}
hgs
parents:
diff changeset
   915
		}
hgs
parents:
diff changeset
   916
	if ( res == NULL )
hgs
parents:
diff changeset
   917
		{
hgs
parents:
diff changeset
   918
		res = HBufC8::NewL( 0 );
hgs
parents:
diff changeset
   919
		}
hgs
parents:
diff changeset
   920
	iLog->Log( _L8( "GetLuidAllocL, response='%S'" ), res );
hgs
parents:
diff changeset
   921
	return res;
hgs
parents:
diff changeset
   922
	}	    
hgs
parents:
diff changeset
   923
    
hgs
parents:
diff changeset
   924
HBufC8* Cdmatest::GetLuidAllocLC( const TDesC8& aURI ) 
hgs
parents:
diff changeset
   925
	{
hgs
parents:
diff changeset
   926
	iLog->Log( _L8( "GetLuidAllocL, aURI='%S'" ), &aURI );
hgs
parents:
diff changeset
   927
	HBufC8 *res = NULL;		
hgs
parents:
diff changeset
   928
	for( TInt i(0); i < iMappingTable.Count(); i++ )	
hgs
parents:
diff changeset
   929
		{
hgs
parents:
diff changeset
   930
		if ( aURI == iMappingTable[i].iURI )
hgs
parents:
diff changeset
   931
			{
hgs
parents:
diff changeset
   932
			res = iMappingTable[i].iLuid.AllocLC();
hgs
parents:
diff changeset
   933
			break;
hgs
parents:
diff changeset
   934
			}
hgs
parents:
diff changeset
   935
		}
hgs
parents:
diff changeset
   936
	if ( res == NULL )
hgs
parents:
diff changeset
   937
		{
hgs
parents:
diff changeset
   938
		res = HBufC8::NewLC( 0 );
hgs
parents:
diff changeset
   939
		}
hgs
parents:
diff changeset
   940
	iLog->Log( _L8( "GetLuidAllocLC, response='%S'" ), res );
hgs
parents:
diff changeset
   941
	return res ;
hgs
parents:
diff changeset
   942
	}	
hgs
parents:
diff changeset
   943
    	
hgs
parents:
diff changeset
   944
#ifdef __TARM_SYMBIAN_CONVERGENCY
hgs
parents:
diff changeset
   945
    
hgs
parents:
diff changeset
   946
void Cdmatest::GetMappingInfoListL( const TDesC8& /*aURI*/,
hgs
parents:
diff changeset
   947
								CArrayFix<TSmlDmMappingInfo>& /*aSegmentList*/ )
hgs
parents:
diff changeset
   948
	{
hgs
parents:
diff changeset
   949
	// do nothing
hgs
parents:
diff changeset
   950
	}								
hgs
parents:
diff changeset
   951
hgs
parents:
diff changeset
   952
#else
hgs
parents:
diff changeset
   953
// nothing
hgs
parents:
diff changeset
   954
#endif
hgs
parents:
diff changeset
   955
//***************************************************************************
hgs
parents:
diff changeset
   956
//  End of File