graphicstest/uibench/s60/src/te_conestepbase.cpp
author Pat Downey <patd@symbian.org>
Tue, 04 May 2010 16:06:01 +0100
changeset 46 ca46a316904d
parent 0 5d03bc08d59c
permissions -rw-r--r--
Merge KhronosRI and bld.inf fix.

// Copyright (c) 2009 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:
//

/**
 @file
 @test
 @internalComponent - Internal Symbian test code 
*/


#include "te_conestepbase.h"


_LIT(KTestStepThread, "TestStepConeThread");


TVerdict CTe_ConeStepBase::doTestStepPreambleL()
	{
	CTe_graphicsperformanceSuiteStepBase::doTestStepPreambleL();
	
	TESTNOERRORL(iConeThread.Create(KTestStepThread, CTe_ConeStepBase::ConeThreadFunction,
	        KDefaultStackSize, NULL, this));
	
	iInitUISemaphore.CreateLocal(0);
	iConeThread.Resume(); // start the cone thread
	
	// wait for InitUIL() method to finish, that means test can start now
	iInitUISemaphore.Wait();
	
	return TestStepResult();
	}

TVerdict CTe_ConeStepBase::doTestStepPostambleL()
	{
	iProfiler->FreeResultsMemory(); // cleanup memory in the baseclass (otherwise heaptest panics)
	
	iConeThread.RequestComplete(iTestCompletionStatus, KErrNone); // informs conestopper
    
	TRequestStatus status;
	iConeThread.Rendezvous(status); // asynchronous, completes amongst others when thread terminates
	User::WaitForRequest(status); // waits for Rendevous() to finish
	iConeThread.Close();
	iInitUISemaphore.Close();
	
	return CTe_graphicsperformanceSuiteStepBase::doTestStepPostambleL();
	}


/**
 * Starts the CONE thread.
 */
TInt CTe_ConeStepBase::ConeThreadFunction(TAny* aParams)
     {
     CTe_ConeStepBase* testStep = static_cast<CTe_ConeStepBase*>(aParams);
     return testStep->StartControlEnvironment();     
     }

CCoeEnv* CTe_ConeStepBase::ConstructControlEnvironment()
    {
    CEikonEnv* eikonEnv = new CEikonEnv();
    if (eikonEnv)
        {
        TRAPD(err, eikonEnv->ConstructL());
        if (err != KErrNone)
            {
            delete eikonEnv;
            return NULL;
            }
        }    
    return eikonEnv;
    }

TInt CTe_ConeStepBase::StartControlEnvironment()
    {
    TInt err = KErrNoMemory;
    CConeThreadStopper* stopper = new CConeThreadStopper(*this);
    if (stopper)
        {
        CCoeEnv* coeEnv = ConstructControlEnvironment();
        if (coeEnv)
            {
            TRAP(err, InitUIL(coeEnv));
            if (err == KErrNone)
                {
                stopper->Start(iTestCompletionStatus);
                iInitUISemaphore.Signal();
                coeEnv->ExecuteD(); // runs until its terminated by the CConeThreadStopper
                coeEnv = NULL;
                }       
            delete coeEnv;
            }            
        delete stopper;
        }
    if (err != KErrNone)
        {
        SetTestStepResult(EAbort);
        iInitUISemaphore.Signal(); // also signal if an error occurs, otherwise test would be blocked
        }
    return err;
    }


void CTe_ConeStepBase::StopControlEnvironment()
   {
   CActiveScheduler::Stop();
   }



CConeThreadStopper::CConeThreadStopper(CTe_ConeStepBase& aTestStep) :
       CActive(EPriorityStandard), iTestStep(aTestStep)
   {
   // empty
   }

CConeThreadStopper::~CConeThreadStopper()
    {
    Cancel();
    }

void CConeThreadStopper::Start(TRequestStatus *&aStopStatus)
   {
   CActiveScheduler::Add(this);
   aStopStatus = &iStatus;
   iStatus = KRequestPending;
   SetActive();
   }

void CConeThreadStopper::DoCancel()
    {
    // empty
    }

void CConeThreadStopper::RunL()
   {
   iTestStep.StopControlEnvironment(); // stops the active scheduler of the CONE thread
   }