os/graphics/egl/egltest/endpointtestsuite/automated/tsrc/egltest_endpoint_util.cpp
author sl
Tue, 10 Jun 2014 14:32:02 +0200
changeset 1 260cb5ec6c19
permissions -rw-r--r--
Update contrib.
     1 // Copyright (c) 2009 Nokia Corporation and/or its subsidiary(-ies).
     2 // All rights reserved.
     3 // This component and the accompanying materials are made available
     4 // under the terms of "Eclipse Public License v1.0"
     5 // which accompanies this distribution, and is available
     6 // at the URL "http://www.eclipse.org/legal/epl-v10.html".
     7 //
     8 // Initial Contributors:
     9 // Nokia Corporation - initial contribution.
    10 //
    11 // Contributors:
    12 //
    13 // Description:
    14 //
    15 
    16 /**
    17  @file
    18  @test
    19  @internalComponent - Internal Symbian test code
    20 */
    21 
    22 // A "utility class" that contains a number of static functions that don't 
    23 // have anywhere else obvious to live.
    24 
    25 #include "egltest_endpoint_util.h"
    26 #include <test/testexecuteserverbase.h>
    27 
    28 
    29 /**
    30 Cut and paste from CTestStep::SetLogger() - which is not exported
    31 As the name suggests, this is for use by the egl test process wrapper
    32 */
    33 void TEndpointUtil::SetLoggerForProcessWrapperL(CTestExecuteLogger& aLogger)
    34     {
    35     // Create a cinidata object for parsing the testexecute.ini
    36     CTestExecuteIniData* parseTestExecuteIni = NULL;
    37     TBuf<KMaxTestExecuteNameLength> resultFilePath;
    38     TBuf<KMaxTestExecuteNameLength> xmlFilePath;
    39     TInt logMode;
    40     TInt logLevel;
    41 
    42     TRAPD(err,parseTestExecuteIni = CTestExecuteIniData::NewL());
    43     if (err == KErrNone)
    44         {
    45         CleanupStack::PushL(parseTestExecuteIni);
    46         parseTestExecuteIni->ExtractValuesFromIni();
    47         parseTestExecuteIni->GetKeyValueFromIni(KTEFHtmlKey, resultFilePath);
    48         parseTestExecuteIni->GetKeyValueFromIni(KTEFXmlKey, xmlFilePath);
    49         parseTestExecuteIni->GetKeyValueFromIni(KTEFLogMode, logMode);
    50         parseTestExecuteIni->GetKeyValueFromIni(KTEFLogSeverityKey, logLevel);
    51         }
    52     else
    53         {
    54         resultFilePath.Copy(KTestExecuteLogPath);
    55         xmlFilePath.Copy(KTestExecuteLogPath);
    56         logMode = TLoggerOptions(ELogHTMLOnly);
    57         logLevel = RFileFlogger::TLogSeverity(ESevrAll);
    58         }
    59     aLogger.SetLoggerOptions(logMode);
    60 
    61     // Initialise a handle to the file logger
    62     User::LeaveIfError(aLogger.Connect());
    63     RFs fS;
    64     User::LeaveIfError(fS.Connect());
    65     CleanupClosePushL(fS);
    66     RFile file;
    67     TBuf<KMaxTestExecuteNameLength> xmlLogFile(xmlFilePath);
    68     TBuf<KMaxTestExecuteNameLength> logFile;
    69     TBuf<KMaxTestExecuteNameLength> logFileNameFile(resultFilePath);
    70     logFileNameFile.Append(KTestExecuteScheduleTestLogCompatibilityNameFile);
    71     if(file.Open(fS,logFileNameFile,EFileRead | EFileShareAny) != KErrNone)
    72         {
    73         User::Panic(_L("Unsupported"), -1);
    74         }
    75     else
    76         {
    77         CleanupClosePushL(file);
    78         TBuf8<KMaxTestExecuteNameLength> logFile8;
    79         TInt fileSize;
    80         User::LeaveIfError(file.Size(fileSize));
    81         User::LeaveIfError(file.Read(logFile8,fileSize));
    82         logFile.Copy(logFile8);
    83         xmlLogFile.Append(logFile);
    84         _LIT(KXmlExtension,".xml");
    85         xmlLogFile.Append(KXmlExtension);
    86         _LIT(KHtmExtension,".htm");
    87         logFile.Append(KHtmExtension);
    88         CleanupStack::Pop(&file);
    89         file.Close();
    90         }
    91     TBuf<KMaxTestExecuteLogFilePath> logFilePath(resultFilePath);
    92     logFilePath.Append(logFile);
    93     CleanupStack::Pop(&fS);
    94     fS.Close();
    95 
    96     if (logMode == 0 || logMode == 2)
    97         {
    98         User::LeaveIfError(aLogger.HtmlLogger().CreateLog(logFilePath,RTestExecuteLogServ::ELogModeAppend));
    99         aLogger.HtmlLogger().SetLogLevel(TLogSeverity(logLevel));
   100         }
   101     if (logMode == 1 || logMode == 2)
   102         {
   103         User::LeaveIfError(aLogger.XmlLogger().CreateLog(xmlLogFile,RFileFlogger::ELogModeAppend));
   104         aLogger.XmlLogger().SetLogLevel(RFileFlogger::TLogSeverity(logLevel));
   105         }
   106     if (parseTestExecuteIni != NULL)
   107         {
   108         CleanupStack::PopAndDestroy(parseTestExecuteIni);
   109         }
   110     }