graphicstest/uibench/src/tredrawstoreperf.cpp
author Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
Tue, 27 Apr 2010 17:59:32 +0300 (2010-04-27)
branchRCL_3
changeset 41 de3d5b6102ac
parent 0 5d03bc08d59c
permissions -rw-r--r--
Revision: 201013 Kit: 201017
// Copyright (c) 2008-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 "tredrawstoreperf.h"

const TInt KIterationsToTest = 100; // Number of iterations to run tests
TRect seg1;
TRect seg2;
TRect seg3;
TRect seg4;
TRect seg5;
TRect seg6;

CTRedrawstorePerf::CTRedrawstorePerf()
	{
	SetTestStepName(KTRedrawstorePerf);
	}

CTRedrawstorePerf::~CTRedrawstorePerf()
	{
	delete iGc;
	delete iScreenDevice;
	iWin.Close();
	iWinGroup.Close();
	iWs.Close();
	}

void CTRedrawstorePerf::CreateRWindowL()
	{
	iWin = RWindow(iWs);
	User::LeaveIfError(iWin.Construct(iWinGroup, 2));
	User::LeaveIfError(iWin.SetTransparencyAlphaChannel());	
	iWin.SetBackgroundColor(TRgb(255,255,255,128 ));
	iWin.Activate();
	Init();
	}

void CTRedrawstorePerf::Init()
	{
	// Create RedrawStore segments
	seg1=TRect( TSize( iWin.Size() ) );	
	seg2=TRect( TPoint(50,0), seg1.Center()-TPoint(20,20) );
	seg3=TRect( TPoint(seg1.Width()/2 + 20, 0), TPoint(seg1.Width()-50, seg1.Height()/2 -20 ) );
	seg4=TRect( TPoint(50, seg1.Height()/2 + 20 ), TPoint(seg1.Width()/2 - 20, seg1.Height() ) );
	seg5=TRect( seg1.Center()+TPoint(20,20), TPoint( seg1.Width()-50, seg1.Height()) );
	seg6=TRect( seg1.Center()-TPoint(75,75), TSize(150,150) );
	}

/**
Override of base class virtual

@return - TVerdict code
*/
TVerdict CTRedrawstorePerf::doTestStepPreambleL()
	{
	CTe_graphicsperformanceSuiteStepBase::doTestStepPreambleL();
	return TestStepResult();
	}

/**
Override of base class pure virtual
Our implementation only gets called if the base class doTestStepPreambleL() did
not leave. That being the case, the current test result value will be EPass.

@return TVerdict code
*/
TVerdict CTRedrawstorePerf::doTestStepL()
	{
	User::LeaveIfError(iWs.Connect());	
	iScreenDevice = new(ELeave) CWsScreenDevice(iWs);
	User::LeaveIfError(iScreenDevice->Construct(0)); // screen number (0 is first screen)
	iGc = new(ELeave) CWindowGc(iScreenDevice);
	User::LeaveIfError(iGc->Construct());
	iWinGroup = RWindowGroup(iWs);
	User::LeaveIfError(iWinGroup.Construct(1, EFalse));

	SetTestStepID(_L("GRAPHICS-UI-BENCH-0137"));
	TestStoreWithFewRectsL();
	RecordTestResultL();
	SetTestStepID(_L("GRAPHICS-UI-BENCH-0167"));
	TestStoreWithManyRectsL();
	RecordTestResultL();
	SetTestStepID(_L("GRAPHICS-UI-BENCH-0139"));
	TestPlaybackWithFewRectsL();
	RecordTestResultL();
	SetTestStepID(_L("GRAPHICS-UI-BENCH-0168"));
	TestPlaybackWithManyRectsL();
	RecordTestResultL();
	SetTestStepID(_L("GRAPHICS-UI-BENCH-0141"));
	TestStoreAndPlaybackWithFewRectsL();
	RecordTestResultL();
	SetTestStepID(_L("GRAPHICS-UI-BENCH-0142"));
	TestStoreAndPlaybackWithManyRectsL();
	RecordTestResultL();
	
	return TestStepResult();
	}

void CTRedrawstorePerf::TestStoringL(const TDesC& aTestName, TRedrawstoreTestCase aTestCase)
	{
	iProfiler->InitResults();
	for (TInt count=0; count<KIterationsToTest; count++)
		{
		CreateRWindowL();
		iWin.SetVisible(EFalse); // To make sure no playing back occurs
		iWs.Finish();		
		iGc->Activate(iWin);
		iProfiler->StartTimer();		
		if (aTestCase==EFragmentStore)
			{
			PopulateRedrawStore();
			}
		else if (aTestCase==EFragmentStoreWithManyRects)
			{
			PopulateRedrawStoreWithManyRects();
			}			
		iProfiler->MarkResultSetL();		
		iGc->Deactivate();	
		iWin.Close();
		}
	iProfiler->ResultsAnalysis(aTestName, 0, 0, iScreenDevice->DisplayMode(), KIterationsToTest);
	}

void CTRedrawstorePerf::TestPlayingbackL(const TDesC& aTestName, TRedrawstoreTestCase aTestCase)
	{
	iProfiler->InitResults();
	for (TInt count=0; count<KIterationsToTest; count++)
		{
		CreateRWindowL();
		iGc->Activate(iWin);
		if (aTestCase==EFragmentStore)
			{
			PopulateRedrawStore();
			}
		else if (aTestCase==EFragmentStoreWithManyRects)
			{
			PopulateRedrawStoreWithManyRects();
			}			
		iWin.SetVisible( EFalse );
		iWs.Finish();		
		iProfiler->StartTimer();
		iWin.SetVisible( ETrue );	// Make iWin visible to trigger playing back of redraw cmds
		iWs.Finish();
		iProfiler->MarkResultSetL();
		iGc->Deactivate();	
		iWin.Close();
		}
	iProfiler->ResultsAnalysis(aTestName, 0, 0, iScreenDevice->DisplayMode(), KIterationsToTest);
	}

void CTRedrawstorePerf::TestStoringAndPlayingbackL(const TDesC& aTestName, TRedrawstoreTestCase aTestCase)
	{
	iProfiler->InitResults();
	for (TInt count=0; count<KIterationsToTest; count++)
		{
		CreateRWindowL();
		iGc->Activate(iWin);
		iProfiler->StartTimer();		
		if (aTestCase==EFragmentStore)
			{
			PopulateRedrawStore();
			}
		else if (aTestCase==EFragmentStoreWithManyRects)
			{
			PopulateRedrawStoreWithManyRects();
			}				
		iWs.Finish();
		iProfiler->MarkResultSetL();
		iGc->Deactivate();	
		iWin.Close();
		}
	iProfiler->ResultsAnalysis(aTestName, 0, 0, iScreenDevice->DisplayMode(), KIterationsToTest);
	}


// Fragments the fullscreen window by creating segments and drawing overlaping rects across the whole window 
void CTRedrawstorePerf::PopulateRedrawStoreWithManyRects()
	{
	iWin.Invalidate();
	iWin.BeginRedraw();
	iGc->SetBrushColor(KRgbCyan);
	iGc->Clear();
	iWin.EndRedraw();

	TInt x=0;
	TBool offset=EFalse;
	for(TInt y=0; y<=seg1.Height(); y+=20)
		{
		if (offset)
			{
			x=x+20;
			offset=EFalse;
			}
		else
			{
			offset=ETrue;
			}
		
		for(; x<=seg1.Width(); x+=40)
			{
			TRect seg(TPoint(x,y),TSize(30,30));
			iWin.Invalidate(seg);
			iWin.BeginRedraw(seg);
			iGc->SetPenColor(KRgbRed);
			iGc->DrawRect(seg);
			iWin.EndRedraw();
			}
		x=0;
		}
	}

void CTRedrawstorePerf::PopulateRedrawStore()
	{
	iWin.Invalidate(seg1);
	iWin.BeginRedraw();
	iGc->SetPenColor(KRgbBlack);
	iGc->Reset();
	iGc->DrawRect(seg1);	
	iWin.EndRedraw();
	
	iWin.Invalidate(seg2);
	iWin.BeginRedraw(seg2);
	iGc->SetPenColor(KRgbBlack);
	iGc->DrawRect(seg2);
	iWin.EndRedraw();	
	
	iWin.Invalidate(seg3);
	iWin.BeginRedraw(seg3);
	iGc->SetBrushStyle(CGraphicsContext::ESolidBrush);
	iGc->SetBrushColor(KRgbBlue);
	iGc->DrawRect(seg3);
	iWin.EndRedraw();
	
	iWin.Invalidate(seg4);
	iWin.BeginRedraw(seg4);
	iGc->SetBrushStyle(CGraphicsContext::ESolidBrush);
	iGc->SetBrushColor(KRgbGreen);
	iGc->DrawRect(seg4);
	iWin.EndRedraw();
		
	iWin.Invalidate(seg5);
	iWin.BeginRedraw(seg5);
	iGc->SetBrushStyle(CGraphicsContext::ESolidBrush);
	iGc->SetBrushColor(KRgbRed);
	iGc->DrawRect(seg5);
	iWin.EndRedraw();	
		
	iWin.Invalidate(seg6);
	iWin.BeginRedraw(seg6);
	iGc->Reset();
	iGc->DrawRect(seg6);
	iWin.EndRedraw();
	}
	
/**
	@SYMTestCaseID
	GRAPHICS-UI-BENCH-0137

	@SYMTestCaseDesc
	The test case mesures the time it takes to store redraw commands  

	@SYMTestActions
	A fullscreen window(RWindow) is created and made invisible. The window is then segmented
 	6 times, drawn to storing the corresponding Redraw Commands and destroyed.

	@SYMTestExpectedResults
	Test should pass and display average test time per iteration
*/
void CTRedrawstorePerf::TestStoreWithFewRectsL()
	{
	_LIT(KTestName, "TestStoreWithFewRectsL");
	TestStoringL(KTestName,EFragmentStore);
	}

/**
	@SYMTestCaseID
	GRAPHICS-UI-BENCH-0167

	@SYMTestCaseDesc
	A pathological test case. It measures the time it takes to store Redraw commands corresponding to 
	hundereds of overlapping segments

	@SYMTestActions
	A fullscreen window(RWindow) is created and made invisible. The window is then segmented
 	a few hundered times, drawn to storing the corresponding Redraw Commands and destroyed.

	@SYMTestExpectedResults
	Test should pass and display average test time per iteration
*/
void CTRedrawstorePerf::TestStoreWithManyRectsL()
	{
	_LIT(KTestName, "TestStoreWithManyRectsL");
	TestStoringL(KTestName,EFragmentStoreWithManyRects);
	}

/**
	@SYMTestCaseID
	GRAPHICS-UI-BENCH-0139

	@SYMTestCaseDesc
	This test case measures the time it takes to play back the commands from the RedrawStore

	@SYMTestActions
	A fullscreen window(RWindow) is created, segmented 6 times and drawn to storing the corresponding
	Redraw Commands. It is made invisible and then visible again which triggers the playing back of 
	commands.The time is measured between when the window is made visible and the screen has been rendered.
	The time is logged and window is destroyed.
	
	@SYMTestExpectedResults
	Test should pass and display average test time per iteration
*/
void CTRedrawstorePerf::TestPlaybackWithFewRectsL()
	{
	_LIT(KTestName, "TestPlaybackWithFewRectsL");
	TestPlayingbackL(KTestName,EFragmentStore);
	}

/**
	@SYMTestCaseID
	GRAPHICS-UI-BENCH-0168

	@SYMTestCaseDesc
	A pathological test case. It measures the time it takes to play back the commands corresponding to 
	hundereds of overlapping segments, from the RedrawStore

	@SYMTestActions
	A fullscreen window(RWindow) is created, segmented a few hundered times and drawn to storing the
	corresponding Redraw Commands. It is made invisible and then visible again which triggers the playing
	back of commands.The time is measured between when the window is made visible and the screen has been
	rendered. The time is logged and window is destroyed.

	@SYMTestExpectedResults
	Test should pass and display average test time per iteration
*/
void CTRedrawstorePerf::TestPlaybackWithManyRectsL()
	{
	_LIT(KTestName, "TestPlaybackWithManyRectsL");
	TestPlayingbackL(KTestName,EFragmentStoreWithManyRects);
	}

/**
	@SYMTestCaseID
	GRAPHICS-UI-BENCH-0141

	@SYMTestCaseDesc
	This test cases measures the time it takes to store and play back redraw commands from the RedrawStore

	@SYMTestActions
	A fullscreen window(RWindow) is created, segmented 6 times and drawn to storing the corresponding
	Redraw Commands. Finish() is called then to trigger the playing back from RedrawStore. The time it takes
	to store and play back commands is logged and window is destroyed. 

	@SYMTestExpectedResults
	Test should pass and display average test time per iteration
*/
void CTRedrawstorePerf::TestStoreAndPlaybackWithFewRectsL()
	{
	_LIT(KTestName, "TestStoreAndPlaybackWithFewRectsL");
	TestStoringAndPlayingbackL(KTestName,EFragmentStore);
	}

/**
	@SYMTestCaseID
	GRAPHICS-UI-BENCH-0142

	@SYMTestCaseDesc
	A pathological test case. It measures the time it takes to store and playback commands corresponding to 
	hundereds of overlapping segments, from RedrawStore

	@SYMTestActions
	A fullscreen window(RWindow) is created, segmented a few hundered times and drawn to storing the
	corresponding Redraw Commands. Finish() is called then to render the screen by playing back the
	commands from the RedrawStore. The time it takes to store and play back commands is logged and window
	is destroyed. 

	@SYMTestExpectedResults
	Test should pass and display average test time per iteration
*/	
void CTRedrawstorePerf::TestStoreAndPlaybackWithManyRectsL()
	{
	_LIT(KTestName, "TestStoreAndPlaybackWithManyRectsL");
	TestStoringAndPlayingbackL(KTestName,EFragmentStoreWithManyRects);
	}