uifw/AvKon/tsrc/bc/bctestlauncher/src/bctestapplication.cpp
author Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
Tue, 02 Feb 2010 01:00:49 +0200
changeset 0 2f259fa3e83a
permissions -rw-r--r--
Revision: 201003 Kit: 201005

/*
* 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:  Test case.
*
*/


#include <apgtask.h>
#include <eikappui.h>
#include <sysutil.h>
#include <s32file.h>

#include "bctestapplication.h"
#include "bctestlauncher.hrh"
#include "bcteststrmlogger.h"

#include <e32property.h>
using namespace BCTest;

const TInt KDelay = 500*1000;   //500 ms
const TUid KPSUidAvkonDomainForBC = { 0x10207218 }; // Same as KPSUidAvkonDomain
const TUint32 KAknMenuOptionNoTaskSwapper = 0x10000002;

enum TAknMenuOptionNoTaskSwapper
    {
    ETaskSwapper,
    ENoTaskSwapper
    };

// ================================== local functions ========================
inline static void Wait(TInt aSec)
    {
    User::After(aSec*KDelay*2);
    }

inline static void Wait()
    {
    User::After( KDelay );
    }

static TInt ManualSDKVersion()
	{
	RFs fs;
    User::LeaveIfError( fs.Connect() );
    RFileReadStream readStream;
    if ( readStream.Open( fs, KSdkVerFile, EFileRead ) < 0 )
	    {
	    fs.Close();
	    readStream.Release ();
	    return 0;    		
	    }
    readStream.PushL();
    TInt ver = static_cast<TInt>(readStream.ReadInt32L());   
    readStream.Pop ();
    readStream.Release ();
    fs.Close();
	return ver;
	}
static TInt SDKVersion()
	{
	TInt swver = 30;
    TInt taskSwapper( ENoTaskSwapper ) ;// taskSwapper
    TInt result = RProperty::Get( KPSUidAvkonDomainForBC, 
            KAknMenuOptionNoTaskSwapper, taskSwapper );
    TInt ret = RProperty::Define( KPSUidAvkonDomainForBC,
            KAknMenuOptionNoTaskSwapper, RProperty::EInt );
    if (ret == KErrAlreadyExists)
        {
        if ( result == KErrNotFound )
            {
            swver = 30;
            }
        else
            {
            if ( taskSwapper == 0 )
                {
                swver = 50;
                }
            else
                {
                swver = 30;
                }
            }
        }
    else
        {
        RProperty::Set( KPSUidAvkonDomainForBC,
                KAknMenuOptionNoTaskSwapper, ENoTaskSwapper );
        }
    
    return swver;
	}

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

// ---------------------------------------------------------------------------
// Constructor
// ---------------------------------------------------------------------------
//
CBCTestApplication::CBCTestApplication(
    const TDesC& aName, TInt aAppUID, TInt aViewUID, 
	TInt aTimeout, TInt aVersion):
      iName(aName), iAppUID(aAppUID), iViewUID(aViewUID), iTimeout(aTimeout),
	  iVersion(aVersion),
	  iSelected(EFalse)
    {
    }

// ---------------------------------------------------------------------------
// CBCTestApplication::~CBCTestApplication()
// Destructor
// ---------------------------------------------------------------------------
//
CBCTestApplication::~CBCTestApplication()
    {
    }

// ---------------------------------------------------------------------------
// CBCTestApplication::NewL()
// 
// ---------------------------------------------------------------------------
//
CBCTestApplication* CBCTestApplication::NewL( const TDesC& aName, 
            TInt aAppUID, TInt aViewUID, TInt aTimeout, TInt aVersion )
    {
    CBCTestApplication* self= new ( ELeave ) CBCTestApplication( 
        aName, aAppUID, aViewUID, aTimeout, aVersion );
    return self;
    }

// ---------------------------------------------------------------------------
// CBCTestApplication::RunL. 
// ---------------------------------------------------------------------------
//
void CBCTestApplication::RunL( TInt aCommand )
    {
	if( iVersion > SDKVersion() )
		{
		if ( iVersion > ManualSDKVersion() )
			{
		return;
			}
		}
		
    if( iSelected || aCommand == EAutoTestAll )
        {
        SetupL();
        StartAutoTest();    
        WatchDogL();
        TearDown();
        }
    }

// ---------------------------------------------------------------------------
// CBCTestApplication::SetupL. 
// ---------------------------------------------------------------------------
//
void CBCTestApplication::SetupL()
    {
    TInt mem = GetFreeMem();
    
    CEikonEnv::Static()->EikAppUi()->ActivateViewL(
        TVwsViewId(TUid::Uid(iAppUID), TUid::Uid(iViewUID)));
    
    LOG<<iName<<_L("[SDK ")<<SDKVersion()<<_L("]: start, with memory: ")
        << mem << EndLine << End;
    }

// ---------------------------------------------------------------------------
// CBCTestApplication::StartAutoTest. 
// by simulate menu operations  
// ---------------------------------------------------------------------------
//
void CBCTestApplication::StartAutoTest()
    {
    Wait(2);
    KeyPress( EKeyDevice0, EStdKeyDevice0 ); // open menu
    
    TInt sdkVer = SDKVersion();
    TInt loop = 2;
    if ( ( sdkVer == 32 ) || ( sdkVer == 33 ) || ( sdkVer == 50 )  )
        {
        loop = 3;
        }
    for ( TInt i = 0; i < loop; i++ )
        {
        Wait();
        KeyPress( EKeyUpArrow, EStdKeyUpArrow );        
        }

    Wait();
    KeyPress( EKeyDevice0, EStdKeyDevice0 ); // start autotest
    }

// ---------------------------------------------------------------------------
// CBCTestApplication::WatchDogL. 
// ---------------------------------------------------------------------------
//
void CBCTestApplication::WatchDogL()
    {
    TInt durationCount = iTimeout*6*5;
    TApaTaskList taskList(CEikonEnv::Static()->WsSession());
    while (taskList.FindApp(TUid::Uid(iAppUID)).Exists() && durationCount--)
        {
        Wait(2);	//monitor every 2 seconds
        }

    if ( taskList.FindApp( TUid::Uid( iAppUID ) ).Exists() ) 
        {
        // still alive, kill it!
        taskList.FindApp( TUid::Uid( iAppUID ) ).KillTask();
        // wait for application actually killed
        while ( taskList.FindApp( TUid::Uid( iAppUID ) ).Exists() )
            {
            Wait();
            }
        User::Leave( KErrTimedOut );
        }
    }

void CBCTestApplication::TearDown()
    {
    LOG<<iName<<_L(": End with memory: ")
            <<GetFreeMem()<<EndLine<<End;
    }

// ---------------------------------------------------------------------------
// CBCTestRunner::KeyPress(TInt aCode, TInt aScanCode)
// Simulates keypress event
// ---------------------------------------------------------------------------
//
void CBCTestApplication::KeyPress( TInt aCode, TInt aScanCode )
    {
    User::ResetInactivityTime();// Reset user inactivity timers
    TKeyEvent event = { aCode, aScanCode, 0, 0 };
    CEikonEnv::Static()->WsSession().SimulateKeyEvent(event);
    CEikonEnv::Static()->WsSession().Flush();
    }

// ---------------------------------------------------------------------------
// CBCTestRunner::GetFreeMem()
// ---------------------------------------------------------------------------
//
TInt CBCTestApplication::GetFreeMem()
	{
	User::CompressAllHeaps();
	TMemoryInfoV1Buf meminfo;
	UserHal::MemoryInfo( meminfo );
	return meminfo().iFreeRamInBytes;
	}