os/graphics/graphicstest/uibench/s60/src/tests_flowwindow/tflowwindowstest.cpp
author sl@SLION-WIN7.fritz.box
Fri, 15 Jun 2012 03:10:57 +0200
changeset 0 bde4ae8d615e
permissions -rw-r--r--
First public contribution.
sl@0
     1
// Copyright (c) 2009 Nokia Corporation and/or its subsidiary(-ies).
sl@0
     2
// All rights reserved.
sl@0
     3
// This component and the accompanying materials are made available
sl@0
     4
// under the terms of "Eclipse Public License v1.0"
sl@0
     5
// which accompanies this distribution, and is available
sl@0
     6
// at the URL "http://www.eclipse.org/legal/epl-v10.html".
sl@0
     7
//
sl@0
     8
// Initial Contributors:
sl@0
     9
// Nokia Corporation - initial contribution.
sl@0
    10
//
sl@0
    11
// Contributors:
sl@0
    12
//
sl@0
    13
// Description:
sl@0
    14
//
sl@0
    15
sl@0
    16
/**
sl@0
    17
 @file
sl@0
    18
 @test
sl@0
    19
 @internalComponent - Internal Symbian test code 
sl@0
    20
*/
sl@0
    21
sl@0
    22
sl@0
    23
#include "tflowwindowstest.h"
sl@0
    24
#include "tsmallwindowraster.h"
sl@0
    25
sl@0
    26
sl@0
    27
_LIT(KTestStep0006, "GRAPHICS-UI-BENCH-S60-0006");
sl@0
    28
_LIT(KSectNameFlowsTest, "FlowTests");
sl@0
    29
_LIT(KKeyNamePreload, "Preload");
sl@0
    30
_LIT(KKeyNameFiles, "Files");
sl@0
    31
_LIT(KKeyNameWindowWidth, "WindowWidth");
sl@0
    32
_LIT(KKeyNameWindowHeight, "WindowHeight");
sl@0
    33
sl@0
    34
CTFlowWindowsTest::CTFlowWindowsTest()
sl@0
    35
	{
sl@0
    36
	SetTestStepName(KTFlowWindows);
sl@0
    37
	}
sl@0
    38
sl@0
    39
CTFlowWindowsTest::~CTFlowWindowsTest()
sl@0
    40
	{	
sl@0
    41
	iFileNames.Close();
sl@0
    42
	delete iFlowWindowsController;
sl@0
    43
	}
sl@0
    44
sl@0
    45
TVerdict CTFlowWindowsTest::doTestStepPreambleL()
sl@0
    46
	{
sl@0
    47
  	CTe_graphicsperformanceSuiteStepBase::doTestStepPreambleL();
sl@0
    48
	
sl@0
    49
	iPreload = EFalse; // default behaviour
sl@0
    50
	GetBoolFromConfig(KSectNameFlowsTest, KKeyNamePreload, iPreload);
sl@0
    51
sl@0
    52
	TPtrC fileNameList;
sl@0
    53
	TEST(GetStringFromConfig(KSectNameFlowsTest,KKeyNameFiles, fileNameList));
sl@0
    54
	ExtractListL(fileNameList, iFileNames);	
sl@0
    55
	
sl@0
    56
	TSize windowSize = CTWindow::GetDisplaySizeInPixels();
sl@0
    57
	INFO_PRINTF2(_L("Window-width: %d"), windowSize.iWidth);
sl@0
    58
	INFO_PRINTF2(_L("Window-height: %d"), windowSize.iHeight);
sl@0
    59
	GetIntFromConfig(KSectNameFlowsTest, KKeyNameWindowWidth, windowSize.iWidth);
sl@0
    60
	GetIntFromConfig(KSectNameFlowsTest, KKeyNameWindowHeight, windowSize.iHeight);
sl@0
    61
	
sl@0
    62
	RArray<TPoint> initialPositions;
sl@0
    63
	RArray<pTWindowCreatorFunction> windowCreatorFunctions;
sl@0
    64
	CleanupClosePushL(initialPositions);
sl@0
    65
	CleanupClosePushL(windowCreatorFunctions);
sl@0
    66
	TInt numberOfWindows = iFileNames.Count();
sl@0
    67
	TPoint initialPosition(0, 0);
sl@0
    68
	for (TInt i = 0; i < numberOfWindows; ++i)
sl@0
    69
		{
sl@0
    70
		windowCreatorFunctions.AppendL(CTSmallWindowRaster::NewL);
sl@0
    71
		initialPositions.AppendL(initialPosition);
sl@0
    72
		initialPosition.iX += windowSize.iWidth;
sl@0
    73
		}
sl@0
    74
	// run the test enough frames to see all the windows go by
sl@0
    75
	iIterationsToTest = windowSize.iWidth * numberOfWindows;
sl@0
    76
    iFlowWindowsController = CTFlowWindowsController::NewL(iPreload, iFileNames, windowSize, windowCreatorFunctions, initialPositions, EFalse);
sl@0
    77
	
sl@0
    78
	CleanupStack::PopAndDestroy(2, &initialPositions);
sl@0
    79
	return TestStepResult();
sl@0
    80
	}
sl@0
    81
sl@0
    82
/**
sl@0
    83
    Override of base class pure virtual
sl@0
    84
    Our implementation only gets called if the base class doTestStepPreambleL() did
sl@0
    85
    not leave.
sl@0
    86
    
sl@0
    87
    @return - TVerdict code
sl@0
    88
*/
sl@0
    89
TVerdict CTFlowWindowsTest::doTestStepL()
sl@0
    90
    {
sl@0
    91
    SetTestStepID(KTestStep0006);
sl@0
    92
    TRAPD(err, FlowWindowsL());
sl@0
    93
    if (err != KErrNone)
sl@0
    94
        {
sl@0
    95
        SetTestStepResult(EAbort);
sl@0
    96
        }
sl@0
    97
    return TestStepResult();
sl@0
    98
    }
sl@0
    99
sl@0
   100
/**
sl@0
   101
@SYMTestCaseID
sl@0
   102
GRAPHICS-UI-BENCH-S60-0006
sl@0
   103
sl@0
   104
@SYMTestCaseDesc
sl@0
   105
Tests how long it takes to moves windows over the screen.
sl@0
   106
sl@0
   107
@SYMTestActions
sl@0
   108
Creates windows which draw bitmaps and moves them over the screen.
sl@0
   109
sl@0
   110
@SYMTestExpectedResults
sl@0
   111
Test should pass and write the average framerate of the test to a log file.
sl@0
   112
*/
sl@0
   113
void CTFlowWindowsTest::FlowWindowsL()
sl@0
   114
    {
sl@0
   115
    iIterationsToTest = 50;
sl@0
   116
    iProfiler->InitResults();
sl@0
   117
    for (TInt i = 0; i < iIterationsToTest; ++i)
sl@0
   118
        {
sl@0
   119
        iFlowWindowsController->MoveL();
sl@0
   120
        }
sl@0
   121
    iProfiler->MarkResultSetL();
sl@0
   122
    TSize windowSize = CTWindow::GetDisplaySizeInPixels();   
sl@0
   123
    iProfiler->ResultsAnalysisFrameRate(KTestStep0006, 0, 0, 0, iIterationsToTest, windowSize.iWidth * windowSize.iHeight);    
sl@0
   124
    }