uifw/AvKon/tsrc/bc/bctestlauncher/src/bctestrunner.cpp
branchRCL_3
changeset 56 d48ab3b357f1
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/uifw/AvKon/tsrc/bc/bctestlauncher/src/bctestrunner.cpp	Wed Sep 01 12:16:19 2010 +0100
@@ -0,0 +1,162 @@
+/*
+* Copyright (c) 2006-2007 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:  Base class for autotest application starters.
+*
+*/
+
+
+#include <vwsdef.h>
+
+#include "bctestrunner.h"
+#include "bctestlauncher.hrh"
+#include "bctestapplication.h"
+#include "bctestconf.h"
+#include "bcteststrmlogger.h"
+
+using namespace BCTest;
+
+// CONSTANTS
+_LIT( KTimeFormat, "%:0%J%:1%T%:2%S%:3%+B" );
+
+// ============================ MEMBER FUNCTIONS =============================
+
+// ---------------------------------------------------------------------------
+// CBCTestRunner::NewL
+// Two-phased constructor.
+// ---------------------------------------------------------------------------
+//
+CBCTestRunner* CBCTestRunner::NewL()
+    {
+    CBCTestRunner* self = new( ELeave ) CBCTestRunner();
+    CleanupStack::PushL( self );
+    self->ConstructL();
+    CleanupStack::Pop( self );
+    return self;
+    }
+
+// ---------------------------------------------------------------------------
+// CBCTestRunner::CBCTestRunner()
+// C++ default constructor can NOT contain any code, that
+// might leave.
+// ---------------------------------------------------------------------------
+//
+CBCTestRunner::CBCTestRunner()
+    {
+    }
+
+// ---------------------------------------------------------------------------
+// CBCTestRunner::~CBCTestRunner()
+// ---------------------------------------------------------------------------
+//
+CBCTestRunner::~CBCTestRunner()
+    {
+    for ( TInt i = 0; i < iTestApps.Count(); i++ )
+        {
+        delete iTestApps[ i ];
+        }
+    iTestApps.Close();
+    }
+
+// ---------------------------------------------------------------------------
+// CBCTestRunner::ConstructL
+// Symbian 2nd phase constructor can leave.
+// ---------------------------------------------------------------------------
+//
+void CBCTestRunner::ConstructL( /*CAknAtLogWriter* aLogWriter*/ )
+    {
+    CBCTestConf* conf = CBCTestConf::NewLC();
+    while( conf->NextL() )
+        {
+        AddTestAppL( CBCTestApplication::NewL(
+            conf->Name(), conf->AppUID(), conf->ViewUID(),
+            conf->Timeout(), conf->Version() ) );
+        }
+    CleanupStack::PopAndDestroy();  //conf
+    }
+
+// ---------------------------------------------------------------------------
+// CBCTestRunner::AddTestAppL(CBCTestApplication* aApp)
+// ---------------------------------------------------------------------------
+//
+void CBCTestRunner::AddTestAppL( CBCTestApplication* aApp )
+    {
+    iTestApps.AppendL( aApp );
+    }
+
+// ---------------------------------------------------------------------------
+// CBCTestRunner::RunTestL( TInt aCommand )
+// Starts test application and returns after test has been run
+// ---------------------------------------------------------------------------
+//
+TBool CBCTestRunner::RunL( TInt aCommand )
+    {
+    _LIT( KTEST, "test runner run." );
+    LOG << KTEST << EndLine << End;
+    for ( TInt i = 0; i < iTestApps.Count(); ++i )
+        {
+        if ( !( iTestApps[ i ]->IsSelect() || aCommand == EAutoTestAll ) )
+        	{
+            continue;
+        	}
+        TRAPD( errno, iTestApps[ i ]->RunL( aCommand ) );
+        switch( errno )
+        {
+        case KErrNone:
+        	{
+        	User::After(8000000);
+        	break;
+        	}
+        case KErrNotFound:
+            {
+            _LIT( KNOTFOUND, ": not found!" );
+            LOG << iTestApps[ i ]->Name() << KNOTFOUND << EndLine << End;
+            break;
+            }
+        case KErrTimedOut:
+            {
+            _LIT( KTIMEOUT, ": timeout." );
+            LOG << iTestApps[ i ]->Name() << KTIMEOUT << EndLine << End;
+            break;
+            }
+        default:
+            break;
+        }
+    }
+    return ETrue;
+    }
+
+// ---------------------------------------------------------------------------
+// CBCTestRunner::CreateTimeStamp
+// Creates time stamp.
+// ---------------------------------------------------------------------------
+//
+void CBCTestRunner::CreateTimeStamp()
+    {
+    _LIT( KTIMEFAILED, "Getting time failed" );
+    TTime homeTime;
+    homeTime.HomeTime();
+    TRAPD( err, homeTime.FormatL( iTempBuf, KTimeFormat ) );
+    if ( err != KErrNone ) // FormatL failed
+        iTempBuf = KTIMEFAILED();
+    iBuf.Append( iTempBuf );
+    }
+
+// ---------------------------------------------------------------------------
+// CBCTestRunner::Apps()
+// ---------------------------------------------------------------------------
+//
+RArray<CBCTestApplication*>* CBCTestRunner::Apps()
+    {
+    return &iTestApps;
+    }