videofeeds/server/tsrc/IptvTestUtility/src/CIptvTestDlFileInfo.cpp
changeset 0 96612d01cf9f
equal deleted inserted replaced
-1:000000000000 0:96612d01cf9f
       
     1 /*
       
     2 * Copyright (c) 2002-2004 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 the License "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:   implements functionality for storing and logging*
       
    15 */
       
    16 
       
    17 
       
    18 
       
    19 
       
    20 // INCLUDE FILES
       
    21 #include "CIptvTestDlFileInfo.h"
       
    22 #include "VCXTestLog.h"
       
    23 
       
    24 
       
    25 
       
    26 // EXTERNAL DATA STRUCTURES
       
    27 
       
    28 // EXTERNAL FUNCTION PROTOTYPES  
       
    29 
       
    30 // CONSTANTS
       
    31 
       
    32 // MACROS
       
    33 
       
    34 // LOCAL CONSTANTS AND MACROS
       
    35 _LIT(KIPTVTestLoggerFolder,"IPTV");
       
    36 _LIT(KIPTVTestLoggerFile,"IptvDlLog.txt");
       
    37 // MODULE DATA STRUCTURES
       
    38 
       
    39 // LOCAL FUNCTION PROTOTYPES
       
    40 
       
    41 // FORWARD DECLARATIONS
       
    42 
       
    43 // ============================= LOCAL FUNCTIONS ===============================
       
    44 
       
    45 // ============================ MEMBER FUNCTIONS ===============================
       
    46 
       
    47 // -----------------------------------------------------------------------------
       
    48 // CIptvTestDlFileInfo::NewL
       
    49 //  
       
    50 // -----------------------------------------------------------------------------
       
    51 //
       
    52 EXPORT_C CIptvTestDlFileInfo* CIptvTestDlFileInfo::NewL()
       
    53     {
       
    54     VCXLOGLO1(">>>CIptvTestDlFileInfo::NewL");   
       
    55     CIptvTestDlFileInfo* self = new (ELeave) CIptvTestDlFileInfo();
       
    56     CleanupStack::PushL(self);
       
    57     self->ConstructL( );
       
    58     CleanupStack::Pop();
       
    59     VCXLOGLO1("<<<CIptvTestDlFileInfo::NewL");   
       
    60     return self;    
       
    61     }
       
    62 // -----------------------------------------------------------------------------
       
    63 // CIptvTestDlFileInfo::~CIptvTestDlFileInfo
       
    64 // destructor
       
    65 // -----------------------------------------------------------------------------
       
    66 //    
       
    67 EXPORT_C CIptvTestDlFileInfo::~CIptvTestDlFileInfo()
       
    68     {
       
    69     VCXLOGLO1(">>>CIptvTestDlFileInfo::~CIptvTestDlFileInfo");
       
    70     if(iDlFileInfoError==EDlFileInfoDlGoing) 
       
    71         {
       
    72         iDlFileInfoError=EDlFileInfoDestructorCalled;
       
    73         iStopTime.HomeTime();
       
    74         Print();
       
    75         }
       
    76     
       
    77     iDlEvents.Close();
       
    78     
       
    79     if(iContentUrl)
       
    80         {
       
    81         delete iContentUrl;
       
    82         iContentUrl = NULL;
       
    83         }
       
    84         
       
    85     if(iIptvTestLogger)
       
    86 	    {
       
    87 	    delete iIptvTestLogger;
       
    88 	    iIptvTestLogger=NULL;	
       
    89 	    }
       
    90 	    
       
    91     VCXLOGLO1("<<<CIptvTestDlFileInfo::~CIptvTestDlFileInfo");   
       
    92     }
       
    93 
       
    94 // -----------------------------------------------------------------------------
       
    95 // CIptvTestDlFileInfo::CIptvTestDlFileInfo
       
    96 // 
       
    97 // -----------------------------------------------------------------------------
       
    98 //
       
    99 CIptvTestDlFileInfo::CIptvTestDlFileInfo()
       
   100     {
       
   101     VCXLOGLO1(">>>CIptvTestDlFileInfo::CIptvTestDlFileInfo");   
       
   102     
       
   103     VCXLOGLO1("<<<CIptvTestDlFileInfo::CIptvTestDlFileInfo");       
       
   104     }
       
   105 // -----------------------------------------------------------------------------
       
   106 // CIptvTestDlFileInfo::ConstructL()
       
   107 // 
       
   108 // -----------------------------------------------------------------------------
       
   109 //    
       
   110 void CIptvTestDlFileInfo::ConstructL( )
       
   111     {
       
   112     VCXLOGLO1(">>>CIptvTestDlFileInfo::ConstructL");   
       
   113     iIptvTestLogger = CIptvTestLogger::NewL(KIPTVTestLoggerFolder(), KIPTVTestLoggerFile());
       
   114     iDlSucceed = EFalse;
       
   115     VCXLOGLO1("<<<CIptvTestDlFileInfo::ConstructL");       
       
   116     }
       
   117 
       
   118 
       
   119 // -----------------------------------------------------------------------------
       
   120 // CIptvTestDlFileInfo::DlStarted
       
   121 // stores download information
       
   122 // -----------------------------------------------------------------------------
       
   123 //
       
   124 void CIptvTestDlFileInfo::DlStarted(
       
   125         							TUint32 aIapId,
       
   126         							TDesC& aIapName,
       
   127         							TIptvServiceId aServiceId,
       
   128         							TDesC& aServiceName,
       
   129         							TIptvContentId aContentId,
       
   130         							TIptvDownloadType aDlType,
       
   131         							HBufC* aDlUrl 
       
   132         							)
       
   133     {
       
   134     VCXLOGLO1(">>>CIptvTestDlFileInfo::DlStarted"); 
       
   135       
       
   136     iStartTime.HomeTime();	
       
   137     iDlFileInfoError = EDlFileInfoDlGoing;
       
   138  	iIapId = aIapId;
       
   139  	iIapName.Append(aIapName);
       
   140  	iServiceId = aServiceId;
       
   141  	iServiceName.Append(aServiceName);
       
   142  	iContentId = aContentId;
       
   143  	iDlType = aDlType;
       
   144  	
       
   145  	if(!iContentUrl)
       
   146  	    {
       
   147  	    iContentUrl = aDlUrl;
       
   148  	    }
       
   149  	else
       
   150      	{
       
   151      	// panic?!
       
   152      	VCXLOGLO1("Pointer lost -> memory leak!!!!!!!!!!!!!!!!!!");       
       
   153      	}   
       
   154  	VCXLOGLO1("<<<CIptvTestDlFileInfo::DlStarted");   
       
   155 	}
       
   156 // -----------------------------------------------------------------------------
       
   157 // CIptvTestDlFileInfo::DlUpdateState
       
   158 // stores download information
       
   159 // -----------------------------------------------------------------------------
       
   160 //	        
       
   161 void CIptvTestDlFileInfo::DlUpdateState( 
       
   162         						TUint32 aState,
       
   163         						TIptvDlError aError)
       
   164 	{
       
   165 	VCXLOGLO1(">>>CIptvTestDlFileInfo::DlUpdateState");
       
   166 	
       
   167 	TIptvTestDlEvents dlEvent;	
       
   168 	dlEvent.SetValues(aState,aError);
       
   169     iDlEvents.Append(dlEvent);	  
       
   170 	
       
   171 	if(aState == KIptvVodDlDownloadSucceeded)
       
   172 	{
       
   173 	    iDlSucceed = ETrue;
       
   174 	}
       
   175 	
       
   176 	VCXLOGLO1("<<<CIptvTestDlFileInfo::DlUpdateState");   	
       
   177 	}
       
   178 // -----------------------------------------------------------------------------
       
   179 // CIptvTestDlFileInfo::DlGoing
       
   180 // stores download information
       
   181 // -----------------------------------------------------------------------------
       
   182 //	        
       
   183 void CIptvTestDlFileInfo::DlGoing( TDesC& aFullPath,
       
   184 								TUint32 aState, 
       
   185 								TIptvDlError aError )
       
   186     {
       
   187     VCXLOGLO1(">>>CIptvTestDlFileInfo::DlGoing"); 
       
   188     iFullPath.Zero();  
       
   189 	iFullPath.Append(aFullPath);
       
   190 	TIptvTestDlEvents dlEvent;	
       
   191 	dlEvent.SetValues(aState,aError);
       
   192     iDlEvents.Append(dlEvent);
       
   193 	VCXLOGLO1("<<<CIptvTestDlFileInfo::DlGoing");   
       
   194     }
       
   195 // -----------------------------------------------------------------------------
       
   196 // CIptvTestDlFileInfo::DlStopped
       
   197 // stores download information
       
   198 // -----------------------------------------------------------------------------
       
   199 //        						
       
   200 void CIptvTestDlFileInfo::DlStopped(
       
   201 						TUint32	aFileSize,
       
   202         				TUint32 aState, 
       
   203         				TIptvDlError aError)
       
   204     {
       
   205     VCXLOGLO1(">>>CIptvTestDlFileInfo::NewL");   
       
   206 	iStopTime.HomeTime();
       
   207 	if(iDlFileInfoError==EDlFileInfoDlGoing)
       
   208 	    {
       
   209 	    iDlFileInfoError = EDlFileInfoIdle;
       
   210         }
       
   211 	iFileSize = aFileSize;
       
   212 	TIptvTestDlEvents dlEvent;	
       
   213 	dlEvent.SetValues(aState,aError);
       
   214     iDlEvents.Append(dlEvent);
       
   215 	VCXLOGLO1("<<<CIptvTestDlFileInfo::NewL");   
       
   216     }
       
   217 // -----------------------------------------------------------------------------
       
   218 // CIptvTestDlFileInfo::DlStartFailed
       
   219 // stores download information
       
   220 // -----------------------------------------------------------------------------
       
   221 //        						
       
   222 void CIptvTestDlFileInfo::DlStartFailed(
       
   223         				TIptvDlError aError)
       
   224     {
       
   225     VCXLOGLO1(">>>CIptvTestDlFileInfo::DlStartFailed");   
       
   226 	iStopTime.HomeTime();
       
   227 	TIptvTestDlEvents dlEvent;	
       
   228 	dlEvent.SetValues(0,aError);
       
   229     iDlEvents.Append(dlEvent);
       
   230 	iDlFileInfoError = EDlFileInfoStartFailed;
       
   231 	VCXLOGLO1("<<<CIptvTestDlFileInfo::DlStartFailed");   
       
   232     }
       
   233 // -----------------------------------------------------------------------------
       
   234 // CIptvTestDlFileInfo::GetFileName
       
   235 // retuns fullpath of the file
       
   236 // -----------------------------------------------------------------------------
       
   237 //
       
   238 TDesC& CIptvTestDlFileInfo::GetFileName()
       
   239     {
       
   240     VCXLOGLO1(">>>CIptvTestDlFileInfo::GetFileName");   
       
   241     VCXLOGLO1("<<<CIptvTestDlFileInfo::GetFileName");   
       
   242     return iFullPath;
       
   243     }
       
   244 // -----------------------------------------------------------------------------
       
   245 // CIptvTestDlFileInfo::DlTimeOut
       
   246 // Prints and removes download information when download didn't get ready in time.
       
   247 // -----------------------------------------------------------------------------
       
   248 //        							
       
   249 void CIptvTestDlFileInfo::DlTimeOut()
       
   250     {
       
   251     VCXLOGLO1(">>>CIptvTestDlFileInfo::DlTimeOut"); 
       
   252     iStopTime.HomeTime();
       
   253     iDlFileInfoError = EDlFileInfoTimeOut;
       
   254     VCXLOGLO1("<<<CIptvTestDlFileInfo::DlTimeOut"); 
       
   255     }
       
   256 // -----------------------------------------------------------------------------
       
   257 // CIptvTestDlFileInfo::Print
       
   258 // Print information about download to log
       
   259 // -----------------------------------------------------------------------------
       
   260 //        							
       
   261 void CIptvTestDlFileInfo::Print()
       
   262 {
       
   263     VCXLOGLO1(">>>CIptvTestDlFileInfo::Print");   
       
   264 	_LIT(KDateString,"%D%M%Y%/0%1%/1%2%/2%3%/3");
       
   265     _LIT(KTimeString,"%-B%:0%H%:1%T%:2%S%.%*C2%:3%-B");
       
   266 
       
   267     TBuf<255> logBuf;
       
   268 
       
   269 	TBuf<30> startDateString;
       
   270     TBuf<30> startTimeString;    
       
   271     
       
   272     TBuf<30> endDateString;
       
   273     TBuf<30> endTimeString;
       
   274     
       
   275     TBuf<30> eventTimeString;
       
   276     
       
   277     TTimeIntervalSeconds tTimeSeconds;
       
   278     TUint32 dlTime = 0;
       
   279     TUint32 dlSpeed = 0;
       
   280     TInt i = 0;
       
   281     
       
   282     iStartTime.FormatL(startDateString,KDateString);
       
   283     iStartTime.FormatL(startTimeString,KTimeString);
       
   284     
       
   285     iStopTime.FormatL(endDateString,KDateString);
       
   286     iStopTime.FormatL(endTimeString,KTimeString);
       
   287 	
       
   288 	iIptvTestLogger->Log(_L("--------------------------------------------------------------------------"));
       
   289     iIptvTestLogger->Log(_L("Download start: %S %S"),&startDateString, &startTimeString);
       
   290     logBuf.AppendFormat(_L("serviceid: %d, Servicename: %S"),iServiceId, &iServiceName);    
       
   291     iIptvTestLogger->Log(_L("%S"),&logBuf);
       
   292     logBuf.Zero();
       
   293     
       
   294     logBuf.AppendFormat(_L("IapId: %d, Iapname: %S"),iIapId, &iIapName);
       
   295     iIptvTestLogger->Log(_L("%S"),&logBuf);
       
   296     logBuf.Zero();
       
   297     
       
   298     logBuf.AppendFormat(_L("ContentId: %d"),iContentId);
       
   299     iIptvTestLogger->Log(_L("%S"),&logBuf);
       
   300     logBuf.Zero();
       
   301     if(iContentUrl)
       
   302         {
       
   303         iIptvTestLogger->Log(_L("Download URL: %S"),iContentUrl);
       
   304         }
       
   305     else
       
   306         {
       
   307         iIptvTestLogger->Log(_L("Download URL: not found"));    
       
   308         }
       
   309     iIptvTestLogger->Log(_L("Videoname: %S"),&iFullPath);
       
   310     
       
   311     logBuf.AppendFormat(_L("Filesize (bytes): %d"),iFileSize);
       
   312     iIptvTestLogger->Log(_L("%S"),&logBuf);
       
   313     logBuf.Zero();
       
   314      
       
   315     iIptvTestLogger->Log(_L("Download stop: %S %S"),&endDateString, &endTimeString);
       
   316     
       
   317     //Download time
       
   318     iStopTime.SecondsFrom(iStartTime,tTimeSeconds);//calculates time difference
       
   319     dlTime = tTimeSeconds.Int();
       
   320     logBuf.AppendFormat(_L("Download time (sec): %d"),dlTime);
       
   321     iIptvTestLogger->Log(_L("%S"),&logBuf);
       
   322     logBuf.Zero();
       
   323     
       
   324     //Download speed  
       
   325     if(dlTime>0)
       
   326         {
       
   327         dlSpeed = iFileSize / dlTime;    
       
   328         }
       
   329     logBuf.AppendFormat(_L("Download speed (bytes/sec): %d"),dlSpeed);
       
   330     iIptvTestLogger->Log(_L("%S"),&logBuf);
       
   331     logBuf.Zero();
       
   332     
       
   333     iIptvTestLogger->Log(_L("Events from Iptvserver:"));
       
   334     
       
   335     for(i = 0; i < iDlEvents.Count(); i++)
       
   336         {
       
   337         iDlEvents[i].iTime.FormatL(eventTimeString,KTimeString);
       
   338         logBuf.AppendFormat(_L("time: %S state: %d   error: %d"),&eventTimeString, iDlEvents[i].iState,iDlEvents[i].iError);
       
   339         iIptvTestLogger->Log(_L("%S"),&logBuf);
       
   340         logBuf.Zero();
       
   341         }
       
   342         
       
   343     if(iDlSucceed)
       
   344         {
       
   345         iIptvTestLogger->Log(_L("Download succeeded"));
       
   346         }
       
   347     else
       
   348         {
       
   349         iIptvTestLogger->Log(_L("Download didn't succeed"));
       
   350         }
       
   351     
       
   352     if(iDlFileInfoError==EDlFileInfoTimeOut)
       
   353         {
       
   354         iIptvTestLogger->Log(_L("Timeout, download didn't get ready!"));
       
   355         }
       
   356     else if(iDlFileInfoError==EDlFileInfoStartFailed)
       
   357         {
       
   358         iIptvTestLogger->Log(_L("Download didn't start at all!"));
       
   359         }
       
   360     else if(iDlFileInfoError==EDlFileInfoDestructorCalled)
       
   361         {
       
   362         iIptvTestLogger->Log(_L("Destructor of testcase called, download didn't get ready!"));
       
   363         }
       
   364     else
       
   365         {
       
   366         //do nothing    
       
   367         }
       
   368     
       
   369     iIptvTestLogger->Log(_L("--------------------------------------------------------------------------"));   
       
   370     VCXLOGLO1("<<<CIptvTestDlFileInfo::Print");   
       
   371 }
       
   372 TIptvTestDlEvents::TIptvTestDlEvents()
       
   373     {
       
   374     iState = 0;
       
   375     }
       
   376 
       
   377 TIptvTestDlEvents::~TIptvTestDlEvents()
       
   378     {
       
   379     }
       
   380     
       
   381 void TIptvTestDlEvents::SetValues(
       
   382                                 TUint32 aState,
       
   383                                 TIptvDlError aError)
       
   384     {
       
   385     iTime.HomeTime();
       
   386 	iState = aState;
       
   387 	iError  = aError; 
       
   388     }
       
   389 //  End of File  
       
   390 /*
       
   391 --------------------------------------------------------------------------
       
   392 Download start failed: 22/06/2006 16:38:33.05
       
   393 Serviceid: 0, Servicename: Kärppäkanava
       
   394 IapId: 11, Iapname: Ethernet with Daemon Dynamic IP
       
   395 ContentId = 2
       
   396 Dltype = 2
       
   397 error = 4
       
   398 --------------------------------------------------------------------------
       
   399 
       
   400 --------------------------------------------------------------------------
       
   401 Download start: 22/06/2006 16:38:33.05
       
   402 Serviceid: 0, Servicename: Kärppäkanava
       
   403 IapId: 11, Iapname: Ethernet with Daemon Dynamic IP
       
   404 ContentId = 2
       
   405 Videoname: Karpat-Assat 2-1
       
   406 Filename: e:\E147423941116553376000000003.3gp
       
   407 Filesize (bytes):1942653
       
   408 Download time (s):102
       
   409 Download stop: 22/06/2006 16:39:14.28
       
   410 error = 133
       
   411 Downloads going start: 1    end: 1
       
   412 --------------------------------------------------------------------------
       
   413 
       
   414 */