mmappfw_plat/harvester_metadata_extractor_api/tsrc/harvestermetadataextractortest/src/harvestermetadataextractortestBlocks.cpp
changeset 0 a2952bb97e68
equal deleted inserted replaced
-1:000000000000 0:a2952bb97e68
       
     1 /*
       
     2 * Copyright (c) 2002 - 2007 Nokia Corporation and/or its subsidiary(-ies).
       
     3 * All rights reserved.
       
     4 * This component and the accompanying materials are made available
       
     5 * under the terms of "Eclipse Public License v1.0"
       
     6 * which accompanies this distribution, and is available
       
     7 * at the URL "http://www.eclipse.org/legal/epl-v10.html".
       
     8 *
       
     9 * Initial Contributors:
       
    10 * Nokia Corporation - initial contribution.
       
    11 *
       
    12 * Contributors:
       
    13 *
       
    14 * Description: harvestermetadataextractortest block implementation for STIF Test Framework TestScripter
       
    15 *
       
    16 */
       
    17 
       
    18 
       
    19 
       
    20 // [INCLUDE FILES] - do not remove
       
    21 #include <e32svr.h>
       
    22 #include <StifParser.h>
       
    23 #include <Stiftestinterface.h>
       
    24 #include "harvestermetadataextractortest.h"
       
    25 #include <f32file.h>
       
    26 
       
    27 #include <mpxmediageneraldefs.h>
       
    28 #include <mpxmediaaudiodefs.h>
       
    29 #include <mpxmediamusicdefs.h>
       
    30 #include <mpxmediadrmdefs.h>
       
    31 #include <mpxharvesterutility.h>
       
    32 #include <mpxcollectionutility.h>
       
    33 
       
    34 
       
    35 
       
    36 // ============================ MEMBER FUNCTIONS ===============================
       
    37 
       
    38 // -----------------------------------------------------------------------------
       
    39 // Charvestermetadataextractortest::Delete
       
    40 // Delete here all resources allocated and opened from test methods. 
       
    41 // Called from destructor. 
       
    42 // -----------------------------------------------------------------------------
       
    43 //
       
    44 void Charvestermetadataextractortest::Delete() 
       
    45     {
       
    46     
       
    47     }
       
    48 
       
    49 // -----------------------------------------------------------------------------
       
    50 // Charvestermetadataextractortest::RunMethodL
       
    51 // Run specified method. Contains also table of test mothods and their names.
       
    52 // -----------------------------------------------------------------------------
       
    53 //
       
    54 TInt Charvestermetadataextractortest::RunMethodL( 
       
    55     CStifItemParser& aItem ) 
       
    56     {
       
    57 
       
    58     static TStifFunctionInfo const KFunctions[] =
       
    59         {  
       
    60         // Copy this line for every implemented function.
       
    61         // First string is the function name used in TestScripter script file.
       
    62         // Second is the actual implementation member function. 
       
    63         ENTRY( "Example", Charvestermetadataextractortest::ExampleL ),
       
    64         ENTRY( "CMPXMetadataExtractorCreateInstance", Charvestermetadataextractortest::CMPXMetadataExtractorCreateInstance ),
       
    65         ENTRY( "CMPXMetadataExtractorCreateMediaL", Charvestermetadataextractortest::CMPXMetadataExtractorCreateMediaL ),
       
    66         ENTRY( "CMPXMetadataExtractorExtractAlbumArtL", Charvestermetadataextractortest::CMPXMetadataExtractorExtractAlbumArtL ),
       
    67         //ADD NEW ENTRY HERE
       
    68         // [test cases entries] - Do not remove
       
    69 
       
    70         };
       
    71 
       
    72     const TInt count = sizeof( KFunctions ) / 
       
    73                         sizeof( TStifFunctionInfo );
       
    74 
       
    75     return RunInternalL( KFunctions, count, aItem );
       
    76 
       
    77     }
       
    78 
       
    79 // ---------------------------------------------------------------------------
       
    80 // Cmpxharvestertest::HandleCollectionMediaL
       
    81 // ---------------------------------------------------------------------------
       
    82 //
       
    83 void Charvestermetadataextractortest::HandleCollectionMediaL( const CMPXMedia& /*aMedia*/, TInt aError )
       
    84 	{
       
    85 	iLog->Log(_L("Charvestermetadataextractortest::HandleCollectionMediaL: %d"), aError);
       
    86 	}
       
    87 
       
    88 // ---------------------------------------------------------------------------
       
    89 // Cmpxharvestertest::HandleCollectionMessage
       
    90 // ---------------------------------------------------------------------------
       
    91 //
       
    92 void Charvestermetadataextractortest::HandleCollectionMessage( CMPXMessage* /*aMsg*/, TInt aError )
       
    93 	{
       
    94 	iLog->Log(_L("Charvestermetadataextractortest::HandleCollectionMessage: %d"), aError);
       
    95 	}
       
    96 	
       
    97 // ---------------------------------------------------------------------------
       
    98 // Cmpxharvestertest::HandleOpenL
       
    99 // ---------------------------------------------------------------------------
       
   100 //
       
   101 void Charvestermetadataextractortest::HandleOpenL( const CMPXMedia& /*aEntries*/, TInt /*aIndex*/, TBool /*aComplete*/, TInt aError )
       
   102 	{
       
   103 	iLog->Log(_L("Charvestermetadataextractortest::HandleOpenL: %d"), aError);
       
   104 	}
       
   105 // ---------------------------------------------------------------------------
       
   106 // Cmpxharvestertest::HandleOpenL
       
   107 // ---------------------------------------------------------------------------
       
   108 //
       
   109 void Charvestermetadataextractortest::HandleOpenL( const CMPXCollectionPlaylist& /*aPlaylist*/, TInt aError ) 
       
   110 	{
       
   111 	iLog->Log(_L("Charvestermetadataextractortest::HandleOpenL: %d"), aError);
       
   112 	}
       
   113 
       
   114 // ---------------------------------------------------------------------------
       
   115 // Charvestermetadataextractortest::HandlePlaylistExportCompletedL
       
   116 // ---------------------------------------------------------------------------
       
   117 //
       
   118 void Charvestermetadataextractortest::HandlePlaylistExportCompletedL( CMPXMedia* /*aMedia*/, TInt aErr )
       
   119 	{
       
   120 	if ( RemoveExpectedEvent(EEventHandlePlaylistExportCompletedL) )
       
   121 		{
       
   122 		iLog->Log(_L("Charvestermetadataextractortest::HandlePlaylistExportCompletedL: %d [EXPECTED]"), aErr);
       
   123 		}
       
   124 	else
       
   125 		{
       
   126 		iLog->Log(_L("Charvestermetadataextractortest::HandlePlaylistExportCompletedL: %d"), aErr);
       
   127 		}
       
   128 	}
       
   129 
       
   130 // ---------------------------------------------------------------------------
       
   131 // Charvestermetadataextractortest::HandlePlaylistImportCompletedL
       
   132 // ---------------------------------------------------------------------------
       
   133 //
       
   134 void Charvestermetadataextractortest::HandlePlaylistImportCompletedL( CMPXMedia* aMedia, TInt aErr )
       
   135 	{
       
   136 	if ( RemoveExpectedEvent(EEventHandlePlaylistImportCompletedL) )
       
   137 		{
       
   138 		iLog->Log(_L("Cmpxharvestertest::HandleFileImportCompletedL: %d [EXPECTED]"), aErr);
       
   139 		}
       
   140 	else
       
   141 		{
       
   142 		iLog->Log(_L("Cmpxharvestertest::HandleFileImportCompletedL: %d"), aErr);
       
   143 		}
       
   144 
       
   145 	if ( aErr == KErrNone )
       
   146 		{
       
   147 		iLog->Log(_L("Number of attributes: %d"), aMedia->Count() );
       
   148 		delete aMedia;
       
   149 		aMedia = NULL;
       
   150 		}
       
   151 	if ( (iResult && (aErr == KErrNone )) || (!iResult && (aErr != KErrNone)) )
       
   152 		{
       
   153 		Signal();
       
   154 		}
       
   155 	else
       
   156 		{
       
   157 		Signal(aErr);
       
   158 		}
       
   159 	}
       
   160 
       
   161 // ---------------------------------------------------------------------------
       
   162 // Charvestermetadataextractortest::HandleFileAddCompletedL
       
   163 // ---------------------------------------------------------------------------
       
   164 //
       
   165 void Charvestermetadataextractortest::HandleFileAddCompletedL( CMPXMedia* aMedia, TInt aErr )
       
   166 	{
       
   167 	if ( RemoveExpectedEvent(EEventHandleFileAddCompletedL) )
       
   168 		{
       
   169 		iLog->Log(_L("Charvestermetadataextractortest::HandleFileAddCompletedL: %d [EXPECTED]"), aErr);
       
   170 		}
       
   171 	else
       
   172 		{
       
   173 		iLog->Log(_L("Charvestermetadataextractortest::HandleFileAddCompletedL: %d"), aErr);
       
   174 		}
       
   175 
       
   176 	if ( aErr == KErrNone )
       
   177 		{
       
   178 		iLog->Log(_L("Number of attributes: %d"), aMedia->Count() );
       
   179 		delete aMedia;
       
   180 		aMedia = NULL;
       
   181 		}
       
   182 	Signal();
       
   183 	}
       
   184 
       
   185 // ---------------------------------------------------------------------------
       
   186 // Charvestermetadataextractortest::HandleDeleteCompletedL
       
   187 // ---------------------------------------------------------------------------
       
   188 //
       
   189 void Charvestermetadataextractortest::HandleDeleteCompletedL( TInt aErr )
       
   190 	{
       
   191 	if ( RemoveExpectedEvent(EEventHandleDeleteCompletedL) )
       
   192 		{
       
   193 		iLog->Log(_L("Charvestermetadataextractortest::HandleDeleteCompletedL: %d [EXPECTED]"), aErr);
       
   194 		}
       
   195 	else
       
   196 		{
       
   197 		iLog->Log(_L("Charvestermetadataextractortest::HandleDeleteCompletedL: %d"), aErr);
       
   198 		}
       
   199 
       
   200 	if ( aErr == KErrNone )
       
   201 		{
       
   202 		Signal();
       
   203 		}
       
   204 	else
       
   205 		{
       
   206 		Signal(aErr);
       
   207 		}
       
   208 	}
       
   209 
       
   210 // ---------------------------------------------------------------------------
       
   211 // Charvestermetadataextractortest::HandleFileImportCompletedL
       
   212 // ---------------------------------------------------------------------------
       
   213 //
       
   214 void Charvestermetadataextractortest::HandleFileImportCompletedL( CMPXMedia* aMedia, TInt aErr )
       
   215 	{
       
   216 	if ( RemoveExpectedEvent(EEventHandleFileImportCompletedL) )
       
   217 		{
       
   218 		iLog->Log(_L("Charvestermetadataextractortest::EEventHandleFileImportCompletedL: %d [EXPECTED]"), aErr);
       
   219 		}
       
   220 	else
       
   221 		{
       
   222 		iLog->Log(_L("Charvestermetadataextractortest::EEventHandleFileImportCompletedL: %d"), aErr);
       
   223 		}
       
   224 
       
   225 	if ( aErr == KErrNone )
       
   226 		{
       
   227 		iLog->Log(_L("Number of attributes: %d"), aMedia->Count() );
       
   228 		delete aMedia;
       
   229 		aMedia = NULL;
       
   230 		}
       
   231 	if ( (iResult && (aErr == KErrNone )) || (!iResult && (aErr != KErrNone)) )
       
   232 		{
       
   233 		Signal();
       
   234 		}
       
   235 	else
       
   236 		{
       
   237 		Signal(aErr);
       
   238 		}
       
   239 	}
       
   240 
       
   241 // ---------------------------------------------------------------------------
       
   242 // Charvestermetadataextractortest::HandleFileImportCompletedL
       
   243 // ---------------------------------------------------------------------------
       
   244 //
       
   245 void Charvestermetadataextractortest::HandleFileGetMediaCompletedL( CMPXMedia* aMedia, TInt aErr )
       
   246 	{
       
   247 	if ( RemoveExpectedEvent(EEventHandleFileGetMediaCompletedL) )
       
   248 			{
       
   249 			iLog->Log(_L("Charvestermetadataextractortest::HandleFileGetMediaCompletedL: %d [EXPECTED]"), aErr);
       
   250 			}
       
   251 		else
       
   252 			{
       
   253 			iLog->Log(_L("Charvestermetadataextractortest::HandleFileGetMediaCompletedL: %d"), aErr);
       
   254 			}
       
   255 
       
   256 		if ( aErr == KErrNone )
       
   257 			{
       
   258 			iLog->Log(_L("Number of attributes: %d"), aMedia->Count() );
       
   259 			delete aMedia;
       
   260 			aMedia = NULL;
       
   261 			}
       
   262 		Signal();
       
   263 		
       
   264 	}
       
   265 
       
   266 
       
   267 // -----------------------------------------------------------------------------
       
   268 // Charvestermetadataextractortest::RemoveExpectedEvent
       
   269 // Remove the event from the expected event list
       
   270 // Returns: ETrue: Event found.
       
   271 //          EFalse: Event not found.
       
   272 // -----------------------------------------------------------------------------
       
   273 TBool Charvestermetadataextractortest::RemoveExpectedEvent( TExpectedEvents aEvent )
       
   274 	{
       
   275 	iLog->Log(_L("Charvestermetadataextractortest::RemoveExpectedEvent: %d"), aEvent);
       
   276 	TBool match = EFalse;
       
   277 	TInt index = iExpectedEvents.Find(aEvent);
       
   278 	if ( index != KErrNotFound )
       
   279 		{
       
   280 		iExpectedEvents.Remove(index);
       
   281 		match = ETrue;
       
   282 		}
       
   283 	return match;
       
   284 	}
       
   285 
       
   286 // -----------------------------------------------------------------------------
       
   287 // Charvestermetadataextractortest::ExampleL
       
   288 // Example test method function.
       
   289 // (other items were commented in a header).
       
   290 // -----------------------------------------------------------------------------
       
   291 //
       
   292 TInt Charvestermetadataextractortest::ExampleL( CStifItemParser& aItem )
       
   293     {
       
   294 
       
   295     // Print to UI
       
   296     _LIT( Kharvestermetadataextractortest, "harvestermetadataextractortest" );
       
   297     _LIT( KExample, "In Example" );
       
   298     TestModuleIf().Printf( 0, Kharvestermetadataextractortest, KExample );
       
   299     // Print to log file
       
   300     iLog->Log( KExample );
       
   301 
       
   302     TInt i = 0;
       
   303     TPtrC string;
       
   304     _LIT( KParam, "Param[%i]: %S" );
       
   305     while ( aItem.GetNextString ( string ) == KErrNone )
       
   306         {
       
   307         TestModuleIf().Printf( i, Kharvestermetadataextractortest, 
       
   308                                 KParam, i, &string );
       
   309         i++;
       
   310         }
       
   311 
       
   312     return KErrNone;
       
   313 
       
   314     }
       
   315 
       
   316 // -----------------------------------------------------------------------------
       
   317 // Charvestermetadataextractortest::CMPXMetadataExtractorCreateInstance
       
   318 // CMPXMetadataExtractor::NewL function
       
   319 // (other items were commented in a header).
       
   320 // -----------------------------------------------------------------------------
       
   321 //
       
   322 TInt Charvestermetadataextractortest::CMPXMetadataExtractorCreateInstance( CStifItemParser& /*aItem*/ )
       
   323     {
       
   324     iLog->Log(_L("Charvestermetadataextractortest::CMPXMetadataExtractorCreateInstance"));
       
   325     TInt err = KErrNone;
       
   326     RFs fs;
       
   327     User::LeaveIfError( fs.Connect() );
       
   328     RApaLsSession appArcSession;
       
   329     User::LeaveIfError(appArcSession.Connect());   
       
   330     RPointerArray<CMPXCollectionType> dummy;
       
   331     CleanupClosePushL( dummy );
       
   332     
       
   333     TRAP(err, iMetadataExtractor = CMPXMetadataExtractor::NewL( fs, appArcSession, dummy ));
       
   334     dummy.ResetAndDestroy();
       
   335     CleanupStack::PopAndDestroy( &dummy );
       
   336     fs.Close();
       
   337     appArcSession.Close();    
       
   338  
       
   339     // delete iMetadataExtractor;
       
   340     if ( iMetadataExtractor != NULL )
       
   341     	{
       
   342     	delete iMetadataExtractor;
       
   343     	iMetadataExtractor = NULL;
       
   344     	}
       
   345     
       
   346 	if ( err != KErrNone )
       
   347    		{
       
   348    		iLog->Log(_L("Error: CMPXMetadataExtractor::CMPXMetadataExtractorCreateInstance returned: %d"), err);
       
   349    		}
       
   350     return err; 
       
   351     }
       
   352 // -----------------------------------------------------------------------------
       
   353 // Charvestermetadataextractortest::CMPXMetadataExtractorCreateMediaL
       
   354 // CMPXMetadataExtractor::CreateMediaL
       
   355 // (other items were commented in a header).
       
   356 // -----------------------------------------------------------------------------
       
   357 //
       
   358 TInt Charvestermetadataextractortest::CMPXMetadataExtractorCreateMediaL( CStifItemParser& aItem )
       
   359     {
       
   360     iLog->Log(_L("Charvestermetadataextractortest::CreateMediaL"));
       
   361   
       
   362     TInt err = KErrNone;
       
   363     TPtrC string;
       
   364     while ( aItem.GetNextString( string ) == KErrNone )
       
   365        {
       
   366 		TBuf<120> KFile;
       
   367 		KFile.Append(KmpxMetadataExtractor_digitalPath);
       
   368 		KFile.Append(string);
       
   369 	
       
   370 		CMPXMedia* media = NULL;
       
   371 		RFile file;
       
   372 		RFs fs;
       
   373 		User::LeaveIfError(fs.Connect());
       
   374 		file.Open(fs,KFile,EFileStreamText|EFileShareAny);  
       
   375 
       
   376 	    RApaLsSession appArcSession;
       
   377 	    User::LeaveIfError(appArcSession.Connect());  
       
   378 	    
       
   379 	   
       
   380 	    CMPXCollectionType* collectionType;
       
   381 	    collectionType=new(ELeave) CMPXCollectionType();
       
   382 	    	          
       
   383 	    RPointerArray <CMPXCollectionType> mpxcollectiontypetest;
       
   384 	    mpxcollectiontypetest.AppendL(collectionType);
       
   385 	 
       
   386 	    iMetadataExtractor = CMPXMetadataExtractor::NewL( fs, appArcSession, mpxcollectiontypetest );
       
   387 	
       
   388 	    TRAP(err,iMetadataExtractor->CreateMediaL( KFile, media, ETrue ));
       
   389 		
       
   390 	    file.Close();  
       
   391 		fs.Close();
       
   392 	    appArcSession.Close();
       
   393 	    
       
   394 	    if ( iMetadataExtractor != NULL )
       
   395 	    	{
       
   396 	    	delete iMetadataExtractor;
       
   397 	    	iMetadataExtractor = NULL;
       
   398 	    	}
       
   399 	    if ( media != NULL )
       
   400 	    	{
       
   401 	    	delete media;
       
   402 	    	media = NULL;
       
   403 	    	}
       
   404 		if ( err != KErrNone )
       
   405 	   		{
       
   406 	   		iLog->Log(_L("Error: CreateMediaL returned: %d"), err);
       
   407 	   		}		    
       
   408 	   }
       
   409     return err;
       
   410     }
       
   411 
       
   412 
       
   413 // -----------------------------------------------------------------------------
       
   414 // Charvestermetadataextractortest::CMPXMetadataExtractorExtractAlbumArtL
       
   415 // CMPXMetadataExtractor::NewL function
       
   416 // (other items were commented in a header).
       
   417 // -----------------------------------------------------------------------------
       
   418 //
       
   419 TInt Charvestermetadataextractortest::CMPXMetadataExtractorExtractAlbumArtL( CStifItemParser& aItem )
       
   420     {
       
   421     iLog->Log(_L("Charvestermetadataextractortest::CMPXMetadataExtractorExtractAlbumArtL"));
       
   422     TInt err = KErrNone;
       
   423     TPtrC string;
       
   424     RFs fs;
       
   425 	if ( KErrNone == aItem.GetNextString(string) )
       
   426 	 {
       
   427 		TBuf<120> uri;
       
   428 		uri.Append(KmpxMetadataExtractor_digitalPath);
       
   429 		uri.Append(string);
       
   430 	    
       
   431 	    User::LeaveIfError( fs.Connect() );
       
   432 	    RApaLsSession apaLsSession;
       
   433 	    User::LeaveIfError(apaLsSession.Connect());   
       
   434 	    RPointerArray<CMPXCollectionType> pointArray;
       
   435 	    CleanupClosePushL( pointArray );
       
   436 	    
       
   437 	    TRAP(err, iMetadataExtractor = CMPXMetadataExtractor::NewL( fs, apaLsSession, pointArray ));
       
   438 	    CMPXMedia* media=CMPXMedia::NewL(); 
       
   439 	    CleanupStack::PushL(media);
       
   440 	    media->SetTextValueL(KMPXMediaGeneralUri,uri);
       
   441 //	    media->SetTextValueL(KMPXMediaGeneralMimeType,_L("image/jpeg"));
       
   442 	    TRAP( err , iMetadataExtractor->ExtractAlbumArtL(media) );
       
   443 		CleanupStack::PopAndDestroy(media);
       
   444 		pointArray.ResetAndDestroy();
       
   445 	    CleanupStack::PopAndDestroy( &pointArray );
       
   446 	    fs.Close();
       
   447 	    apaLsSession.Close();    
       
   448 	    
       
   449 	    // delete iMetadataExtractor;
       
   450 	    if ( iMetadataExtractor != NULL )
       
   451 	    	{
       
   452 	    	delete iMetadataExtractor;
       
   453 	    	iMetadataExtractor = NULL;
       
   454 	    	}
       
   455 	    
       
   456 		if ( err != KErrNone )
       
   457 	   		{
       
   458 	   		iLog->Log(_L("Error: CMPXMetadataExtractor::CMPXMetadataExtractorExtractAlbumArtL returned: %d"), err);
       
   459 	   		}
       
   460 	}
       
   461     return err; 
       
   462     }
       
   463 
       
   464 // ========================== OTHER EXPORTED FUNCTIONS =========================
       
   465 // None
       
   466 
       
   467 //  [End of File] - Do not remove