mmappfw_plat/asx_parser_api/tsrc/AsxParserTest/src/AsxParserTestBlocks.cpp
author Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
Thu, 17 Dec 2009 08:55:47 +0200
changeset 0 a2952bb97e68
permissions -rw-r--r--
Revision: 200949 Kit: 200951

/*
* Copyright (c) 2002 Nokia Corporation and/or its subsidiary(-ies). 
* All rights reserved.
* This component and the accompanying materials are made available
* under the terms of "Eclipse Public License v1.0"
* which accompanies this distribution, and is available
* at the URL "http://www.eclipse.org/legal/epl-v10.html".
*
* Initial Contributors:
* Nokia Corporation - initial contribution.
*
* Contributors:
*
* Description:  AsxParserTestBlocks.cpp
*
*/

// Version : %version: 3.1.2 %




// [INCLUDE FILES] - do not remove
#include <e32svr.h>
#include <StifParser.h>
#include <Stiftestinterface.h>
#include "AsxParserTest.h"
#include "AsxParser.h"

#include <coeaui.h>
#include "EdwinTestControl.h"
#include <EIKENV.H>

// EXTERNAL DATA STRUCTURES
//extern  ?external_data;

// EXTERNAL FUNCTION PROTOTYPES  
//extern ?external_function( ?arg_type,?arg_type );

// CONSTANTS
//const ?type ?constant_var = ?constant;

// MACROS
//#define ?macro ?macro_def

// LOCAL CONSTANTS AND MACROS
//const ?type ?constant_var = ?constant;
//#define ?macro_name ?macro_def

// MODULE DATA STRUCTURES
//enum ?declaration
//typedef ?declaration

// LOCAL FUNCTION PROTOTYPES
//?type ?function_name( ?arg_type, ?arg_type );

// FORWARD DECLARATIONS
//class ?FORWARD_CLASSNAME;

// ============================= LOCAL FUNCTIONS ===============================

// -----------------------------------------------------------------------------
// ?function_name ?description.
// ?description
// Returns: ?value_1: ?description
//          ?value_n: ?description_line1
//                    ?description_line2
// -----------------------------------------------------------------------------
//
/*
?type ?function_name(
    ?arg_type arg,  // ?description
    ?arg_type arg)  // ?description
    {

    ?code  // ?comment

    // ?comment
    ?code
    }
*/

// ============================ MEMBER FUNCTIONS ===============================

// -----------------------------------------------------------------------------
// CAsxParserTest::Delete
// Delete here all resources allocated and opened from test methods. 
// Called from destructor. 
// -----------------------------------------------------------------------------
//
void CAsxParserTest::Delete() 
    {

    }

// -----------------------------------------------------------------------------
// CAsxParserTest::RunMethodL
// Run specified method. Contains also table of test mothods and their names.
// -----------------------------------------------------------------------------
//
TInt CAsxParserTest::RunMethodL( 
    CStifItemParser& aItem ) 
    {

    static TStifFunctionInfo const KFunctions[] =
        {  
        // Copy this line for every implemented function.
        // First string is the function name used in TestScripter script file.
        // Second is the actual implementation member function. 
        ENTRY( "Example", CAsxParserTest::ExampleL ),
        //ADD NEW ENTRY HERE
        // [test cases entries] - Do not remove
        // test cases for the header "AsxParser.h"
        ENTRY( "CreateNew",            CAsxParserTest::CreateNew ),
        ENTRY( "CreateNewRFile",       CAsxParserTest::CreateNewRFile ),
        ENTRY( "GetUrlCount",          CAsxParserTest::GetUrlCount ),
        ENTRY( "GetUrl",               CAsxParserTest::GetUrl ),
        ENTRY( "FileVersion",          CAsxParserTest::FileVersion ),
    	ENTRY( "PrintUrl",             CAsxParserTest::PrintUrl ),
    	ENTRY( "GetUrlCountRFile",     CAsxParserTest::GetUrlCountRFile ),
        ENTRY( "GetUrlRFile",          CAsxParserTest::GetUrlRFile ),
        ENTRY( "FileVersionRFile",     CAsxParserTest::FileVersionRFile ),
    	ENTRY( "PrintUrlRFile",        CAsxParserTest::PrintUrlRFile ),
    	ENTRY( "CAsxParserDestructor", CAsxParserTest::CAsxParserDestructor),
        ENTRY( "GetAsxStruct",         CAsxParserTest::GetAsxStruct )

    	  
        };

    const TInt count = sizeof( KFunctions ) / 
                        sizeof( TStifFunctionInfo );

    return RunInternalL( KFunctions, count, aItem );

    }

// -----------------------------------------------------------------------------
// CAsxParserTest::ExampleL
// Example test method function.
// (other items were commented in a header).
// -----------------------------------------------------------------------------
//
TInt CAsxParserTest::ExampleL( CStifItemParser& aItem )
    {

    // Print to UI
    _LIT( KAsxParserTest, "AsxParserTest" );
    _LIT( KExample, "In Example" );
    TestModuleIf().Printf( 0, KAsxParserTest, KExample );
    // Print to log file
    iLog->Log( KExample );

    TInt i = 0;
    TPtrC string;
    _LIT( KParam, "Param[%i]: %S" );
    while ( aItem.GetNextString ( string ) == KErrNone )
        {
        TestModuleIf().Printf( i, KAsxParserTest, 
                                KParam, i, &string );
        i++;
        }

    return KErrNone;

    }

//
// -----------------------------------------------------------------------------
// CAsxParserTest::CreateNew
// GetUrlCount method function
// (other items were commented in a header).
// -----------------------------------------------------------------------------
//
TInt CAsxParserTest::CreateNew( CStifItemParser& aItem )
    {
    iLog->Log(_L("CAsxParserTest::CreateNew"));
    TInt err = KErrNone;
    TPtrC string;
    while ( aItem.GetNextString( string ) == KErrNone )
           {
			TBuf<120> KFrom;
			KFrom.Append(KAsxParserTest_testPath);
			KFrom.Append(string);		
		   	TRAP(err,iAsxParser=CAsxParser::NewL(KFrom));
		   	if ( err == KErrNone )
		   	{
		   		iLog->Log(_L("CreateNew returned no error"));
		   	}
		   	else 
		   	{
		   		iLog->Log(_L("Error: CreateNew returned: %d"), err);
		   	}
           }
    return err;
	}

//
// -----------------------------------------------------------------------------
// CAsxParserTest::CreateNewRFile
// GetUrl method function
// (other items were commented in a header).
// -----------------------------------------------------------------------------
//
TInt CAsxParserTest::CreateNewRFile( CStifItemParser& aItem )
    {
    iLog->Log(_L("CAsxParserTest::CreateNewRFile"));
    TInt err = KErrNone;
    TPtrC string;
    while ( aItem.GetNextString( string ) == KErrNone )
          {
   			TBuf<120> KFrom;
   			KFrom.Append(KAsxParserTest_testPath);
   			KFrom.Append(string);
   			
   			RFile file;
   			RFs fs;
   			TRAP(err, fs.Connect());
   		    file.Open(fs, KFrom, EFileRead | EFileShareReadersOnly );       
            TRAP(err, iAsxParser=CAsxParser::NewL(file));
            fs.Close();
   			
		   	if ( err == KErrNone )
			{
		   		iLog->Log(_L("CreateNewRFile returned no error %d"), err);
			}
		   	else 
			{
		   		iLog->Log(_L("Error: CreateNewRFile returned: %d"), err);
			}
		  
          }
   	 return err;
    }

//
// -----------------------------------------------------------------------------
// CAsxParserTest::GetUrlCount
// GetUrlCount method function
// (other items were commented in a header).
// -----------------------------------------------------------------------------
//
TInt CAsxParserTest::GetUrlCount( CStifItemParser& aItem )
    {
    iLog->Log(_L("CAsxParserTest::GetUrlCount"));
    TInt err = KErrNone;
    TPtrC string;
    while ( aItem.GetNextString( string ) == KErrNone )
           {
			TBuf<120> KFrom;
			KFrom.Append(KAsxParserTest_testPath);
			KFrom.Append(string);
			TRAP(err,iAsxParser=CAsxParser::NewL(KFrom));
		    TUint aHowManyUrls;
		    
		    if ( err == KErrNone )
		    {
		        iAsxParser->GetUrlCount(aHowManyUrls);
		    }
		   	
		    if ( err == KErrNone )
		   	{
		   		iLog->Log(_L("GetUrlCount returned no error"));
		   	}
		   	else 
		   	{
		   		iLog->Log(_L("Error: GetUrlCount returned: %d"), err);
		   	}
           }
    return err;
	}

//
// -----------------------------------------------------------------------------
// CAsxParserTest::GetUrl
// GetUrl method function
// (other items were commented in a header).
// -----------------------------------------------------------------------------
//
TInt CAsxParserTest::GetUrl( CStifItemParser& aItem )
    {
    iLog->Log(_L("CAsxParserTest::GetUrl"));
    TInt err = KErrNone;
    TPtrC string;
    while ( aItem.GetNextString( string ) == KErrNone )
          {
   			TBuf<120> KFrom;
   			KFrom.Append(KAsxParserTest_testPath);
   			KFrom.Append(string);
   			TRAP(err,iAsxParser=CAsxParser::NewL(KFrom));
   		    
   			if ( err == KErrNone )
   		    {
                TUint aHowManyUrls = 1;
                TPtrC8 aUrl;
                err = iAsxParser->GetUrl(aHowManyUrls,aUrl);
   		    }
   			
		   	if ( err == KErrNone )
		   	{
		   	   iLog->Log(_L("GetUrl returned no error"));
		   	}
		   	else 
		   	{
		   		iLog->Log(_L("Error: GetUrl returned: %d"), err);
		   	}
          }
   	 return err;
    }

//
// -----------------------------------------------------------------------------
// CAsxParserTest::FileVersion
// FileVersion method function
// (other items were commented in a header).
// -----------------------------------------------------------------------------
//
TInt CAsxParserTest::FileVersion( CStifItemParser& aItem )
    {
    iLog->Log(_L("CAsxParserTest::FileVersion"));
    TInt err = KErrNone;
    TPtrC string;
    while ( aItem.GetNextString( string ) == KErrNone )
          {
			TBuf<120> KFrom;
			KFrom.Append(KAsxParserTest_testPath);
			KFrom.Append(string);
			TRAP(err,iAsxParser=CAsxParser::NewL(KFrom));

			if ( err == KErrNone )
			{
			    iAsxParser->FileVersion();
			}
			
			if ( err == KErrNone )
		   	{
		   		
		   		iLog->Log(_L("FileVersion returned no error"));
		   	}
		   	else 
		   	{
		   		iLog->Log(_L("Error: FileVersion returned: %d"), err);
		   	}
          }
    return err;
    }

//
// -----------------------------------------------------------------------------
// CAsxParserTest::PrintUrl
// GetUrl method function
// (other items were commented in a header).
// -----------------------------------------------------------------------------
//
TInt CAsxParserTest::PrintUrl( CStifItemParser& aItem )
    {
    iLog->Log(_L("CAsxParserTest::PrintUrl"));
    TInt err = KErrNone;
    TPtrC string;
    while ( aItem.GetNextString( string ) == KErrNone )
          {
   			TBuf<120> KFrom;
   			KFrom.Append(KAsxParserTest_testPath);
   			KFrom.Append(string);
   			TRAP(err,iAsxParser=CAsxParser::NewL(KFrom));
   			
   			if ( err == KErrNone )
   			{
       		    TPtrC8 aUrl;
       		    HBufC16* urlBuffer = NULL;
       		    TUint aHowManyUrls = 1;
       		    
       		    err =iAsxParser->GetUrl(aHowManyUrls,aUrl);
    	    	
       		    if ( err == KErrNone )
       		    {
       		        TRAP(err, urlBuffer = HBufC16::NewL(100));
           		    TPtr16   url = urlBuffer->Des();
        		    iAsxParser->PrintUrl(aUrl, url);
       		    }
   			}
   		    	
		   	if ( err == KErrNone )
		   	{
		   		iLog->Log(_L("PrintUrl returned no error"));
		   	}
		   	else 
		   	{
		   		iLog->Log(_L("Error: PrintUrl returned: %d"), err);
		   	}
          }
   	 return err;
    }

//
// -----------------------------------------------------------------------------
// CAsxParserTest::GetUrlCountRFile
// GetUrlCount method function
// (other items were commented in a header).
// -----------------------------------------------------------------------------
//
TInt CAsxParserTest::GetUrlCountRFile( CStifItemParser& aItem )
    {
    iLog->Log(_L("CAsxParserTest::GetUrlCountRFile"));
    TInt err = KErrNone;
    TPtrC string;
    while ( aItem.GetNextString( string ) == KErrNone )
           {
			TBuf<120> KFrom;
			KFrom.Append(KAsxParserTest_testPath);
			KFrom.Append(string);
			
			RFile file;
            RFs fs;
            User::LeaveIfError(fs.Connect());
            file.Open(fs, KFrom, EFileRead | EFileShareReadersOnly );       
            TRAP(err, iAsxParser=CAsxParser::NewL(file));
            fs.Close();
			      
            if ( err == KErrNone )
            {
		        TUint aHowManyUrls;
		   	    iAsxParser->GetUrlCount(aHowManyUrls);
            }
            
		   	if ( err == KErrNone )
		   	{
		   		iLog->Log(_L("GetUrlCountRFile returned no error"));
		   	}
		   	else 
		   	{
		   		iLog->Log(_L("Error: GetUrlCountRFile returned: %d"), err);
		   	}
           }
    return err;
	}

//
// -----------------------------------------------------------------------------
// CAsxParserTest::GetUrlRFile
// GetUrl method function
// (other items were commented in a header).
// -----------------------------------------------------------------------------
//
TInt CAsxParserTest::GetUrlRFile( CStifItemParser& aItem )
    {
    iLog->Log(_L("CAsxParserTest::GetUrlRFile"));
    TInt err = KErrNone;
    TPtrC string;
    while ( aItem.GetNextString( string ) == KErrNone )
          {
   			TBuf<120> KFrom;
   			KFrom.Append(KAsxParserTest_testPath);
   			KFrom.Append(string);
   			
   			RFile file;
            RFs fs;
            User::LeaveIfError(fs.Connect());
            file.Open(fs, KFrom, EFileRead | EFileShareReadersOnly );       
            TRAP(err, iAsxParser=CAsxParser::NewL(file));
            fs.Close();
   		    
            if ( err == KErrNone )
            {
       		    TUint aHowManyUrls = 1;
    		    TPtrC8 aUrl;
    		    iAsxParser->GetUrl(aHowManyUrls,aUrl);
            }
            
		   	if ( err == KErrNone )
		   	{
		   		iLog->Log(_L("GetUrlRFile returned no error"));
		   	}
		   	else 
		   	{
		   		iLog->Log(_L("Error: GetUrlRFile returned: %d"), err);
		   	}
          }
   	 return err;
    }

//
// -----------------------------------------------------------------------------
// CAsxParserTest::FileVersionRFile
// FileVersion method function
// (other items were commented in a header).
// -----------------------------------------------------------------------------
//
TInt CAsxParserTest::FileVersionRFile( CStifItemParser& aItem )
    {
    iLog->Log(_L("CAsxParserTest::FileVersionRFile"));
    TInt err = KErrNone;
    TPtrC string;
    while ( aItem.GetNextString( string ) == KErrNone )
          {
			TBuf<120> KFrom;
			KFrom.Append(KAsxParserTest_testPath);
			KFrom.Append(string);
			
			RFile file;
            RFs fs;
            User::LeaveIfError(fs.Connect());
            file.Open(fs, KFrom, EFileRead | EFileShareReadersOnly );       
            TRAP(err, iAsxParser=CAsxParser::NewL(file));
            fs.Close();
			
            if ( err == KErrNone )
            {
		        iAsxParser->FileVersion();
            }
            
		   	if ( err == KErrNone )
		   	{
		   		iLog->Log(_L("FileVersionRFile returned no error"));
		   	}
		   	else 
		   	{
		   		iLog->Log(_L("Error: FileVersionRFile returned: %d"), err);
		   	}
          }
    return err;
    }

//
// -----------------------------------------------------------------------------
// CAsxParserTest::PrintUrlRFile
// GetUrl method function
// (other items were commented in a header).
// -----------------------------------------------------------------------------
//
TInt CAsxParserTest::PrintUrlRFile( CStifItemParser& aItem )
    {
    iLog->Log(_L("CAsxParserTest::PrintUrlRFile"));
    TInt err = KErrNone;
    TPtrC string;
    while ( aItem.GetNextString( string ) == KErrNone )
          {
   			TBuf<120> KFrom;
   			KFrom.Append(KAsxParserTest_testPath);
   			KFrom.Append(string);
   			
   			RFile file;
            RFs fs;
            User::LeaveIfError(fs.Connect());
            file.Open(fs, KFrom, EFileRead | EFileShareReadersOnly );       
            TRAP(err, iAsxParser=CAsxParser::NewL(file));
            fs.Close();
   			  
            if ( err == KErrNone )
            {
       		    TPtrC8 aUrl;
       		    HBufC16* urlBuffer = NULL;
       		    TUint aHowManyUrls = 1;
       		    err =iAsxParser->GetUrl(aHowManyUrls,aUrl);
    	    	
       		    if ( err == KErrNone )
       		    {
           		    TRAP(err, urlBuffer = HBufC16::NewL(100));
           		    TPtr16   url = urlBuffer->Des();
        		    iAsxParser->PrintUrl(aUrl, url);
       		    }
            }
   		    	
		   	if ( err == KErrNone )
		   	{
		   		iLog->Log(_L("PrintUrlRFile returned no error"));
		   	}
		   	else 
		   	{
		   		iLog->Log(_L("Error: PrintUrlRFile returned: %d"), err);
		   	}
          }
   	 return err;
    }

// -----------------------------------------------------------------------------
//  CAsxParserTest::CAsxParserDestructor
// (other items were commented in a header).
// -----------------------------------------------------------------------------
TInt CAsxParserTest::CAsxParserDestructor(CStifItemParser& /*aItem*/)
    {
    TInt err = KErrNone;
    delete iAsxParser;
    iAsxParser = NULL;
	iLog->Log(_L("CAsxParserTest::CAsxParserDestructor testing CAsxParser::~ end err=%d"), err);
	return KErrNone;
    }


//
// -----------------------------------------------------------------------------
// CAsxParserTest::GetUrl
// GetUrl method function
// (other items were commented in a header).
// -----------------------------------------------------------------------------
//
TInt CAsxParserTest::GetAsxStruct( CStifItemParser& aItem )
    {
    iLog->Log(_L("CAsxParserTest::GetAsxStruct"));
    TInt err = KErrNone;
    TPtrC string;
    AsxStruct* asxStruct = NULL;
    
    while ( aItem.GetNextString( string ) == KErrNone )
          {
            TBuf<120> KFrom;
            KFrom.Append(KAsxParserTest_testPath);
            KFrom.Append(string);
            TRAP(err,iAsxParser=CAsxParser::NewL(KFrom));
            
            if ( err == KErrNone )
            {
                TUint aHowManyUrls = 1;
                TPtrC8 aUrl;
                asxStruct = iAsxParser->GetUrl(aHowManyUrls);
            }
            
            if ( asxStruct )
            {
               iLog->Log(_L("GetUrl returned no error"));
            }
            else 
            {
                err = KErrGeneral;
                iLog->Log(_L("Error: GetUrl returned: %d"), err);
            }
          }
     return err;
    }

// -----------------------------------------------------------------------------
// CAsxParserTest::?member_function
// ?implementation_description
// (other items were commented in a header).
// -----------------------------------------------------------------------------
//
/*
TInt CAsxParserTest::?member_function(
   CItemParser& aItem )
   {

   ?code

   }
*/

// ========================== OTHER EXPORTED FUNCTIONS =========================
// None

//  [End of File] - Do not remove