graphicscomposition/openwftest/src/openwftest.cpp
author hgs
Fri, 17 Sep 2010 17:25:01 +0300
changeset 179 b50de33648a3
parent 121 d72fc2aace31
permissions -rw-r--r--
201037_1
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
121
d72fc2aace31 201027_1
hgs
parents:
diff changeset
     1
// Copyright (c) 2010 Nokia Corporation and/or its subsidiary(-ies).
d72fc2aace31 201027_1
hgs
parents:
diff changeset
     2
// All rights reserved.
d72fc2aace31 201027_1
hgs
parents:
diff changeset
     3
// This component and the accompanying materials are made available
d72fc2aace31 201027_1
hgs
parents:
diff changeset
     4
// under the terms of "Eclipse Public License v1.0"
d72fc2aace31 201027_1
hgs
parents:
diff changeset
     5
// which accompanies this distribution, and is available
d72fc2aace31 201027_1
hgs
parents:
diff changeset
     6
// at the URL "http://www.eclipse.org/legal/epl-v10.html".
d72fc2aace31 201027_1
hgs
parents:
diff changeset
     7
//
d72fc2aace31 201027_1
hgs
parents:
diff changeset
     8
// Initial Contributors:
d72fc2aace31 201027_1
hgs
parents:
diff changeset
     9
// Nokia Corporation - initial contribution.
d72fc2aace31 201027_1
hgs
parents:
diff changeset
    10
//
d72fc2aace31 201027_1
hgs
parents:
diff changeset
    11
// Contributors:
d72fc2aace31 201027_1
hgs
parents:
diff changeset
    12
//
d72fc2aace31 201027_1
hgs
parents:
diff changeset
    13
// Description:
d72fc2aace31 201027_1
hgs
parents:
diff changeset
    14
// OpenWF tests
d72fc2aace31 201027_1
hgs
parents:
diff changeset
    15
//
d72fc2aace31 201027_1
hgs
parents:
diff changeset
    16
#include <test/extendtef.h>
d72fc2aace31 201027_1
hgs
parents:
diff changeset
    17
#include <hal.h>
d72fc2aace31 201027_1
hgs
parents:
diff changeset
    18
#include "openwftest.h"
d72fc2aace31 201027_1
hgs
parents:
diff changeset
    19
d72fc2aace31 201027_1
hgs
parents:
diff changeset
    20
#define KCompositorVersion	0x01023456
d72fc2aace31 201027_1
hgs
parents:
diff changeset
    21
#define KGrowCleanupStack	12
d72fc2aace31 201027_1
hgs
parents:
diff changeset
    22
#define KMaxNotificationDelay   5000000 //5 seconds
d72fc2aace31 201027_1
hgs
parents:
diff changeset
    23
#define KNotificationWarning    100000  //100 ms
d72fc2aace31 201027_1
hgs
parents:
diff changeset
    24
d72fc2aace31 201027_1
hgs
parents:
diff changeset
    25
_LIT(KTestSectionName, "TestInfo");
d72fc2aace31 201027_1
hgs
parents:
diff changeset
    26
_LIT(KImageSectionName, "ImageInfo");
d72fc2aace31 201027_1
hgs
parents:
diff changeset
    27
_LIT(KContiguousFlag, "ContiguousFlag");
d72fc2aace31 201027_1
hgs
parents:
diff changeset
    28
_LIT(KTolerance, "Tolerance");
d72fc2aace31 201027_1
hgs
parents:
diff changeset
    29
_LIT(KTestMode, "TestMode");
d72fc2aace31 201027_1
hgs
parents:
diff changeset
    30
_LIT(KSaveImage, "SaveImage");
d72fc2aace31 201027_1
hgs
parents:
diff changeset
    31
_LIT(KDir, "Dir");
d72fc2aace31 201027_1
hgs
parents:
diff changeset
    32
_LIT(KDefaultDir, "c:\\openwftest\\img\\");
d72fc2aace31 201027_1
hgs
parents:
diff changeset
    33
_LIT(KCompositionPause, "CompositionPause");
d72fc2aace31 201027_1
hgs
parents:
diff changeset
    34
_LIT(KManualPause, "ManualPause");
d72fc2aace31 201027_1
hgs
parents:
diff changeset
    35
d72fc2aace31 201027_1
hgs
parents:
diff changeset
    36
//Uncomment this and rebuild if you wish to test if fastpath is enabled using breakpoints
d72fc2aace31 201027_1
hgs
parents:
diff changeset
    37
//#define BREAKPOINT_FASTPATH
d72fc2aace31 201027_1
hgs
parents:
diff changeset
    38
d72fc2aace31 201027_1
hgs
parents:
diff changeset
    39
/*
d72fc2aace31 201027_1
hgs
parents:
diff changeset
    40
 * COpenwfTest implementation
d72fc2aace31 201027_1
hgs
parents:
diff changeset
    41
 */
d72fc2aace31 201027_1
hgs
parents:
diff changeset
    42
COpenwfTest::COpenwfTest()
d72fc2aace31 201027_1
hgs
parents:
diff changeset
    43
:iFastpathablePixelFormat(EUidPixelFormatXRGB_8888),
d72fc2aace31 201027_1
hgs
parents:
diff changeset
    44
 iNonFastpathablePixelFormat(EUidPixelFormatRGB_565),
d72fc2aace31 201027_1
hgs
parents:
diff changeset
    45
 iMappable(ETrue),
d72fc2aace31 201027_1
hgs
parents:
diff changeset
    46
 iMaxBuffers(2),
d72fc2aace31 201027_1
hgs
parents:
diff changeset
    47
 iMinBuffers(1),
d72fc2aace31 201027_1
hgs
parents:
diff changeset
    48
 iCacheAttrib(ECacheNotlisted),
d72fc2aace31 201027_1
hgs
parents:
diff changeset
    49
 iDeviceId(WFC_INVALID_HANDLE),
d72fc2aace31 201027_1
hgs
parents:
diff changeset
    50
 iSync(EGL_NO_SYNC_KHR),
d72fc2aace31 201027_1
hgs
parents:
diff changeset
    51
 iDevice(WFC_INVALID_HANDLE),
d72fc2aace31 201027_1
hgs
parents:
diff changeset
    52
 iContext(WFC_INVALID_HANDLE)
d72fc2aace31 201027_1
hgs
parents:
diff changeset
    53
	{
d72fc2aace31 201027_1
hgs
parents:
diff changeset
    54
	}
d72fc2aace31 201027_1
hgs
parents:
diff changeset
    55
d72fc2aace31 201027_1
hgs
parents:
diff changeset
    56
COpenwfTest::~COpenwfTest()
d72fc2aace31 201027_1
hgs
parents:
diff changeset
    57
	{
d72fc2aace31 201027_1
hgs
parents:
diff changeset
    58
    TearDown();
d72fc2aace31 201027_1
hgs
parents:
diff changeset
    59
	}
d72fc2aace31 201027_1
hgs
parents:
diff changeset
    60
d72fc2aace31 201027_1
hgs
parents:
diff changeset
    61
void COpenwfTest::SetupL()
d72fc2aace31 201027_1
hgs
parents:
diff changeset
    62
    {    
d72fc2aace31 201027_1
hgs
parents:
diff changeset
    63
    iScheduler = new(ELeave) CActiveScheduler;
d72fc2aace31 201027_1
hgs
parents:
diff changeset
    64
    CActiveScheduler::Install(iScheduler);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
    65
d72fc2aace31 201027_1
hgs
parents:
diff changeset
    66
    ReadIniData();
d72fc2aace31 201027_1
hgs
parents:
diff changeset
    67
    
d72fc2aace31 201027_1
hgs
parents:
diff changeset
    68
    iEGLDisplay = eglGetDisplay(EGL_DEFAULT_DISPLAY);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
    69
    ASSERT_FALSE(iEGLDisplay == EGL_NO_DISPLAY);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
    70
    ASSERT_FALSE(iEGLDisplay == EGL_BAD_ALLOC);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
    71
    ASSERT_EQUALS(eglGetError(),EGL_SUCCESS);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
    72
    eglInitialize(iEGLDisplay, NULL, NULL);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
    73
    ASSERT_EQUALS(eglGetError(),EGL_SUCCESS);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
    74
    
d72fc2aace31 201027_1
hgs
parents:
diff changeset
    75
    WFCint filterList[] = { WFC_DEVICE_FILTER_SCREEN_NUMBER, WFC_DEFAULT_SCREEN_NUMBER, WFC_NONE};
d72fc2aace31 201027_1
hgs
parents:
diff changeset
    76
    ASSERT_TRUE(wfcEnumerateDevices(&iDeviceId, 1, filterList) == 1);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
    77
    ASSERT_TRUE(iDeviceId != WFC_INVALID_HANDLE);    
d72fc2aace31 201027_1
hgs
parents:
diff changeset
    78
d72fc2aace31 201027_1
hgs
parents:
diff changeset
    79
    iDevice = wfcCreateDevice(iDeviceId, NULL);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
    80
    ASSERT_TRUE(iDevice != WFC_INVALID_HANDLE);  
d72fc2aace31 201027_1
hgs
parents:
diff changeset
    81
    ASSERT_EQUALS(wfcGetError(iDevice),WFC_ERROR_NONE);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
    82
    iContext = wfcCreateOnScreenContext(iDevice, WFC_DEFAULT_SCREEN_NUMBER, NULL);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
    83
    ASSERT_TRUE(iContext != WFC_INVALID_HANDLE);  
d72fc2aace31 201027_1
hgs
parents:
diff changeset
    84
    ASSERT_EQUALS(wfcGetError(iDevice),WFC_ERROR_NONE);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
    85
d72fc2aace31 201027_1
hgs
parents:
diff changeset
    86
    iFastpathableHeight = wfcGetContextAttribi(iDevice, iContext, WFC_CONTEXT_TARGET_HEIGHT);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
    87
    iFastpathableWidth = wfcGetContextAttribi(iDevice, iContext, WFC_CONTEXT_TARGET_WIDTH);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
    88
    iStride = iFastpathableWidth * 4;
d72fc2aace31 201027_1
hgs
parents:
diff changeset
    89
d72fc2aace31 201027_1
hgs
parents:
diff changeset
    90
    iFullScreenTRect = TRect(0,0,iFastpathableWidth,iFastpathableHeight);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
    91
    iFullScreenRect[0] = 0;
d72fc2aace31 201027_1
hgs
parents:
diff changeset
    92
    iFullScreenRect[1] = 0;
d72fc2aace31 201027_1
hgs
parents:
diff changeset
    93
    iFullScreenRect[2] = iFullScreenTRect.Width();
d72fc2aace31 201027_1
hgs
parents:
diff changeset
    94
    iFullScreenRect[3] = iFullScreenTRect.Height();
d72fc2aace31 201027_1
hgs
parents:
diff changeset
    95
    
d72fc2aace31 201027_1
hgs
parents:
diff changeset
    96
    iCenterTRect = TRect(iFastpathableWidth/4,iFastpathableHeight/4,
d72fc2aace31 201027_1
hgs
parents:
diff changeset
    97
            3*iFastpathableWidth/4,3*iFastpathableHeight/4);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
    98
    iCenterRect[0] = iCenterTRect.iTl.iX;
d72fc2aace31 201027_1
hgs
parents:
diff changeset
    99
    iCenterRect[1] = iCenterTRect.iTl.iY;
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   100
    iCenterRect[2] = iCenterTRect.Width();
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   101
    iCenterRect[3] = iCenterTRect.Height();
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   102
    
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   103
    iHalfSizeRect[0] = 0;
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   104
    iHalfSizeRect[1] = 0;
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   105
    iHalfSizeRect[2] = iFastpathableWidth/2;
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   106
    iHalfSizeRect[3] = iFastpathableHeight/2;
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   107
    
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   108
    iUtility = CSurfaceUtility::NewL();
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   109
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   110
    if((iTestMode == EAutomatic) || iSaveImage)
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   111
        {
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   112
        // Need to initialise the on screen stream before composition
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   113
        // to ensure the content is available later 
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   114
        iUtility->GetOnScreenStream(iDevice, iContext);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   115
        }
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   116
    if (iSaveImage)
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   117
        {   // Create a directory to save images
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   118
        iUtility->CreateImagePath(iImageDirectory);                
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   119
        }
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   120
    iAllowManualPause = ETrue; //tests can stop it (eg dispXtimes tests) 
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   121
    
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   122
    EGLint attrib_list[1] = {EGL_NONE};
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   123
    iSync = eglCreateSyncKHR(iEGLDisplay,EGL_SYNC_REUSABLE_KHR, attrib_list);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   124
    ASSERT_NOT_EQUALS(iSync,EGL_NO_SYNC_KHR);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   125
    ASSERT_EQUALS(eglGetError(),EGL_SUCCESS);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   126
    }
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   127
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   128
/**
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   129
 * test Suite furniture 
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   130
 **/
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   131
void COpenwfTest::TearDownL()
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   132
    {
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   133
    // Nothing leaves in this function, 
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   134
    // but TearDownL() is needed for the CTestFixture (TEF) interface
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   135
    TearDown();
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   136
    }
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   137
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   138
void COpenwfTest::TearDown()
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   139
    {
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   140
    WFCErrorCode wfcError;
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   141
    if (iDevice != WFC_INVALID_HANDLE)
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   142
        {
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   143
        wfcError = wfcGetError(iDevice);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   144
        if (wfcError != WFC_ERROR_NONE)
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   145
            {
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   146
            INFO_PRINTF2(_L("TearDown: There was a failure in the test. error=%d"),wfcError);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   147
            }
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   148
        }
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   149
    if (iOnScreenStream != WFC_INVALID_HANDLE)
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   150
        {
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   151
        (void)SymbianStreamReleaseReadBuffer(iOnScreenStream, iOnScreenBuffer); //ignore the error
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   152
        iOnScreenStream = WFC_INVALID_HANDLE;
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   153
        }
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   154
    delete iUtility;
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   155
    iUtility = NULL;
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   156
    if (iContext != WFC_INVALID_HANDLE)
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   157
        {
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   158
        wfcDestroyContext(iDevice, iContext);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   159
        iContext = WFC_INVALID_HANDLE;
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   160
        WFCErrorCode wfcError = wfcGetError(iDevice);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   161
        if (wfcError != WFC_ERROR_NONE)
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   162
            {
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   163
            INFO_PRINTF2(_L("TearDown: wfcDestroyContext error=%d"),wfcError);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   164
            }
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   165
        }
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   166
    if (iDevice != WFC_INVALID_HANDLE)
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   167
        {
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   168
        WFCErrorCode deviceError = wfcDestroyDevice(iDevice);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   169
        iDevice = WFC_INVALID_HANDLE;
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   170
        if (deviceError != WFC_ERROR_NONE)
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   171
            {
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   172
            INFO_PRINTF2(_L("TearDown: wfcDestroyDevice error=%d"),deviceError);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   173
            }
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   174
        }
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   175
    if (iSync != EGL_NO_SYNC_KHR)
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   176
        {
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   177
        EGLBoolean eglSyncError = eglDestroySyncKHR(iEGLDisplay, iSync);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   178
        iSync = EGL_NO_SYNC_KHR;
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   179
        if (eglSyncError != EGL_TRUE)
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   180
            {
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   181
            INFO_PRINTF2(_L("TearDown: eglSyncError line %d"),__LINE__);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   182
            }
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   183
        }
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   184
    if (iEGLDisplay != EGL_NO_DISPLAY)
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   185
        {
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   186
        EGLBoolean eglTerminateError = eglTerminate(iEGLDisplay);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   187
        iEGLDisplay = EGL_NO_DISPLAY;
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   188
        if (eglTerminateError != EGL_TRUE)
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   189
            {
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   190
            INFO_PRINTF2(_L("TearDown: eglTerminateError line %d"),__LINE__);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   191
            }
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   192
        }
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   193
    delete iScheduler;
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   194
    iScheduler = NULL;
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   195
    }
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   196
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   197
/**
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   198
 * To be called at the beginning of tests
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   199
 * aActivate default is ON
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   200
 */
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   201
void COpenwfTest::SetupEmptySceneL(TBool aActivate)
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   202
    {
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   203
#ifdef BREAKPOINT_FASTPATH
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   204
    __BREAKPOINT();
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   205
#endif
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   206
    wfcSetContextAttribi(iDevice, iContext, WFC_CONTEXT_ROTATION, WFC_ROTATION_0);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   207
    wfcSetContextAttribi(iDevice, iContext, WFC_CONTEXT_BG_COLOR, 0xFFFFFFFF);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   208
    if (aActivate)
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   209
        {
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   210
        LOG(("OpenWFTest: Running in autonomous composition mode"));
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   211
        wfcActivate(iDevice,iContext);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   212
        }
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   213
    else
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   214
        {
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   215
        LOG(("OpenWFTest: Running in non autonomous composition mode"));
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   216
        wfcDeactivate(iDevice,iContext);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   217
        }
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   218
    LOG(("OpenWFTest: Expecting COMPOSITION after next commit"));
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   219
    wfcCommit(iDevice, iContext, WFC_TRUE);   // Compose the scene
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   220
    wfcFence(iDevice, iContext, iEGLDisplay, iSync);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   221
    ASSERT_EQUALS(eglClientWaitSyncKHR(iEGLDisplay,iSync,0,(EGLTimeKHR)EGL_FOREVER_KHR),EGL_CONDITION_SATISFIED_KHR);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   222
    ASSERT_EQUALS(wfcGetError(iDevice),WFC_ERROR_NONE);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   223
    LOG(("OpenWFTest: Fastpath - setting up scene - fastpath now off"));
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   224
    }
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   225
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   226
void COpenwfTest::ReadIniData()
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   227
    {
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   228
	//test mode
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   229
    TBool returnValue = iConfig.GetInt(KTestSectionName, KTestMode, iTestMode);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   230
    ASSERT_TRUE(returnValue);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   231
    
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   232
    //save images
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   233
	iSaveImage=EFalse;
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   234
    if (iTestMode == EAutomatic)
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   235
        {
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   236
        returnValue = iConfig.GetBool(KTestSectionName, KSaveImage, iSaveImage);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   237
        }
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   238
    
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   239
    // Get path for the images to be saved to
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   240
    TPtrC dir;
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   241
    returnValue = iConfig.GetString(KTestSectionName, KDir, dir);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   242
    if (returnValue)
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   243
        {
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   244
		iImageDirectory.Set(dir);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   245
        }
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   246
    else
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   247
        {
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   248
		iImageDirectory.Set(KDefaultDir);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   249
        }
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   250
    
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   251
    // Composition pause in microseconds
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   252
    TInt compositionPause;
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   253
    returnValue = iConfig.GetInt(KTestSectionName, KCompositionPause, compositionPause);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   254
    ASSERT_TRUE(returnValue);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   255
    iCompositionPause = compositionPause;
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   256
    
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   257
    // Manual pause in microseconds
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   258
    iManualPause = 0;
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   259
    if (iTestMode != EAutomatic)
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   260
        {
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   261
		TInt manualPause;
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   262
		returnValue = iConfig.GetInt(KTestSectionName, KManualPause, manualPause);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   263
		ASSERT_TRUE(returnValue);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   264
		iManualPause = manualPause;
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   265
        }
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   266
    
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   267
    // Force contiguous
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   268
    TBool contiguousFlag;
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   269
    returnValue = iConfig.GetBool(KImageSectionName, KContiguousFlag, contiguousFlag);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   270
    if (returnValue && contiguousFlag)
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   271
        {
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   272
        iContiguous = EContiguous;
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   273
        }
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   274
    
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   275
    // Test tolerance
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   276
    TInt tolerance;
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   277
    returnValue = iConfig.GetInt(KImageSectionName, KTolerance, tolerance);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   278
    if (returnValue)
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   279
        {
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   280
        iTolerance = tolerance;
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   281
        }
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   282
    }
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   283
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   284
/**
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   285
 * Acquires the on screen stream and buffer number
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   286
 * NOTE: this function should be paired with a ReleaseOnScreenStream call
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   287
 * Returns ETrue on success
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   288
 */
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   289
TBool COpenwfTest::AcquireOnScreenStream()
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   290
	{
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   291
	TInt error = KErrNone;
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   292
	ASSERT_TRUE(iOnScreenStream == WFC_INVALID_HANDLE);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   293
    if(iTestMode == EAutomatic)
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   294
    	{	//need to get the on screen stream
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   295
		iOnScreenStream = iUtility->GetOnScreenStream(iDevice, iContext);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   296
		if(iOnScreenStream == WFC_INVALID_HANDLE)
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   297
			{
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   298
			INFO_PRINTF1(_L("Failed getting on screen stream"));
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   299
			LOG(("OpenWFTest: *** Failed getting on screen stream"));
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   300
			return EFalse;
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   301
			}
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   302
		error = SymbianStreamAcquireReadBuffer(iOnScreenStream, &iOnScreenBuffer);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   303
		if (error != KErrNone)
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   304
			{
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   305
			LOG(("OpenWFTest: *** Unable to acquire read buffer. error = %d",error));
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   306
			INFO_PRINTF2(_L("Unable to acquire read buffer. error = %d"),error);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   307
			}
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   308
		return (error == KErrNone);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   309
    	}
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   310
	else
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   311
		{
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   312
		INFO_PRINTF1(_L("No need to get the on screen stream, probably manual checking mode"));
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   313
		LOG(("OpenWFTest: *** No need to get the on screen stream, probably manual checking mode"));
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   314
		return ETrue;
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   315
		}
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   316
	}
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   317
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   318
/**
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   319
 * Releases the on screen stream
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   320
 */
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   321
void COpenwfTest::ReleaseOnScreenStream()
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   322
	{
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   323
	if (iOnScreenStream != WFC_INVALID_HANDLE)
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   324
		{
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   325
		(void)SymbianStreamReleaseReadBuffer(iOnScreenStream, iOnScreenBuffer);	//ignore the error
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   326
		iOnScreenStream = WFC_INVALID_HANDLE;
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   327
		}
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   328
	if(iTestMode != EAutomatic && iAllowManualPause)
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   329
		{
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   330
		INFO_PRINTF1(_L("Performing manual wait"));
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   331
		LOG(("OpenWFTest: *** Performing manual wait"));
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   332
		TRAP_IGNORE(WaitL(iManualPause));
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   333
		}
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   334
	if(iTestMode != EAutomatic && !iAllowManualPause)
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   335
	    {
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   336
        INFO_PRINTF1(_L("Test not allowing a manual wait"));
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   337
        LOG(("OpenWFTest: *** Test not allowing a manual wait"));
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   338
	    }
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   339
	}
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   340
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   341
/**
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   342
 * Checks the rect of the on screen stream
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   343
 * Returns ETrue on success
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   344
 */
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   345
TBool COpenwfTest::CheckOnScreenStreamRect(TRect aRect, const TRgb& aExpectedColor, TInt aTolerance)
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   346
	{
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   347
    if(iTestMode == EAutomatic)
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   348
    	{
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   349
		if (iOnScreenStream == WFC_INVALID_HANDLE)
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   350
			{
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   351
			LOG(("OpenWFTest: *** We don't have access to the on screen stream"));
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   352
			INFO_PRINTF1(_L("We don't have access to the on screen stream"));
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   353
			return EFalse;
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   354
			}
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   355
		const TSurfaceId* surfaceId = NULL;
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   356
		long bufferIndex;
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   357
		TInt error = SymbianStreamGetBufferId(iOnScreenStream,iOnScreenBuffer,&bufferIndex,&surfaceId);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   358
		if (error == KErrNone)
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   359
			{
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   360
			return CheckRect(*surfaceId,bufferIndex,aRect,aExpectedColor,aTolerance);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   361
			}
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   362
		else
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   363
			{
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   364
			LOG(("OpenWFTest: *** Unable to get stream buffer id. error = %d",error));
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   365
			INFO_PRINTF2(_L("Unable to get stream buffer id. error = %d"),error);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   366
			return EFalse;
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   367
			}
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   368
    	}
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   369
    else
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   370
    	{	//print out what we're hoping to see for manual testing
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   371
		LOG(("OpenWFTest: For rect %d %d %d %d",aRect.iTl.iX,aRect.iTl.iY,aRect.iBr.iX,aRect.iBr.iY));
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   372
		LOG(("OpenWFTest: The expected color is r=%d g=%d b=%d",aExpectedColor.Red(),aExpectedColor.Green(),
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   373
				aExpectedColor.Blue()));
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   374
		INFO_PRINTF5(_L("For rect %d %d %d %d"),aRect.iTl.iX,aRect.iTl.iY,aRect.iBr.iX,aRect.iBr.iY);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   375
		INFO_PRINTF4(_L("The expected color is r=%d g=%d b=%d"),aExpectedColor.Red(),aExpectedColor.Green(),
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   376
				aExpectedColor.Blue());
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   377
		return ETrue;
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   378
    	}
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   379
	}
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   380
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   381
/**
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   382
 * checks the color within the given rectangle of the given surface
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   383
 * returns ETrue on success
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   384
 */
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   385
TBool COpenwfTest::CheckRect(const TSurfaceId& aSurface, TInt aBuffer,  TRect aRect,
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   386
		const TRgb& aExpectedColor, TInt aTolerance)
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   387
	{
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   388
	INFO_PRINTF1(_L("Starting pixel checking"));
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   389
	LOG(("OpenWFTest: *** Starting pixel checking"));
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   390
	// Check pixel data
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   391
	
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   392
	TBool success = iUtility->CheckRectColor(aSurface, aRect, aBuffer, aExpectedColor, aTolerance);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   393
	if (success)
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   394
		{
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   395
		INFO_PRINTF1(_L("Finished pixel checking - pass"));
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   396
		LOG(("OpenWFTest: *** Finished pixel checking - pass"));
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   397
		}
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   398
	else
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   399
		{
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   400
		INFO_PRINTF1(_L("Finished pixel checking - fail"));
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   401
		LOG(("OpenWFTest: *** Finished pixel checking - fail"));
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   402
		}
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   403
    return success;
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   404
	}
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   405
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   406
/**
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   407
 * If in automatic mode it will save a TGA image of the on screen stream.
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   408
 * It will also print the name of the reference image.
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   409
 * Returns ETrue on success
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   410
 */
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   411
TBool COpenwfTest::CheckOnScreenReferenceImage()
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   412
	{
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   413
	TInt error = KErrNone;
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   414
	//Create image file name
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   415
	_LIT(KSeparator, "_");
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   416
	_LIT(KTGAImgFormat, ".tga");
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   417
	iImageAddress.Zero();
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   418
	iImageAddress.Append(iTestName);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   419
	iImageAddress.Append(KSeparator);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   420
	iImageAddress.AppendNum(iImageCounter);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   421
	iImageAddress.Append(KTGAImgFormat);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   422
    
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   423
	LOGL((_L("Reference Image:%S"),&iImageAddress));
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   424
	INFO_PRINTF2(_L("Reference Image:%S"),&iImageAddress);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   425
	//Add file path
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   426
	iImageAddress.Insert(0,iImageDirectory);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   427
	iImageCounter++;
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   428
	
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   429
    if(iTestMode == EAutomatic && iSaveImage)
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   430
    	{
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   431
		if (iOnScreenStream == WFC_INVALID_HANDLE)
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   432
			{
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   433
			LOG(("OpenWFTest: *** We don't have access to the on screen stream",error));
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   434
			INFO_PRINTF1(_L("We don't have access to the on screen stream"));
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   435
			return EFalse;
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   436
			}
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   437
		const TSurfaceId* surfaceId = NULL;
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   438
		long bufferIndex;
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   439
		error = SymbianStreamGetBufferId(iOnScreenStream,iOnScreenBuffer,&bufferIndex,&surfaceId);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   440
		if (error == KErrNone)
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   441
			{
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   442
			return SaveImage(*surfaceId,bufferIndex);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   443
			}
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   444
		else
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   445
			{
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   446
			LOG(("OpenWFTest: *** Unable to get stream buffer id. error = %d",error));
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   447
			INFO_PRINTF2(_L("Unable to get stream buffer id. error = %d"),error);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   448
			return EFalse;
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   449
			}
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   450
    	}
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   451
    return ETrue;
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   452
	}
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   453
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   454
/**
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   455
 *  helper function for saving images to files
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   456
 *  returns ETrue on success
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   457
 */
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   458
TBool COpenwfTest::SaveImage(const TSurfaceId& aSurface, TInt aNumOfBuffer)
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   459
    {
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   460
	if(iTestMode == EAutomatic && iSaveImage)
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   461
		{
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   462
		INFO_PRINTF1(_L("Start to save image"));
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   463
		LOG(("OpenWFTest: *** Start to save image"));
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   464
		TBool success = EFalse;
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   465
		TRAPD(error, success = iUtility->SaveResultImageTGAL(aSurface, aNumOfBuffer, iImageAddress));
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   466
		if(error != KErrNone || !success)
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   467
			{
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   468
			INFO_PRINTF1(_L("Failed saving image"));
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   469
			LOG(("OpenWFTest: *** Failed saving image"));
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   470
			return EFalse;
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   471
			}
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   472
		INFO_PRINTF1(_L("Saved image"));
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   473
		LOG(("OpenWFTest: *** Saved image"));
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   474
		}
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   475
    return ETrue;
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   476
    }
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   477
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   478
/**
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   479
 * Basic wait function call. Return amount of other active objects that stopped the scheduler
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   480
*/
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   481
TInt COpenwfTest::WaitL(TTimeIntervalMicroSeconds32 aDelay)	//aDelay in microseconds
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   482
	{
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   483
	CActiveWaiter* waiter = NULL;
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   484
	waiter = CActiveWaiter::NewL();
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   485
    TInt counter = waiter->Wait(aDelay);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   486
	delete waiter;
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   487
	return counter;
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   488
	}
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   489
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   490
/**
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   491
 * aMaxDelay    The maximum time we are willing to wait in microseconds
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   492
 * aNotifications   The amount of notifications we expect to complete, must be >0
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   493
 * Returns ETrue on success
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   494
*/
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   495
TBool COpenwfTest::WaitForNotifications(TTimeIntervalMicroSeconds32 aMaxDelay,TInt aNotificatons)
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   496
    {
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   497
    if (aNotificatons == 0)
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   498
        {   //use WaitL if no notifications are expected
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   499
        return EFalse;
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   500
        }
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   501
    TTime before;
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   502
    TTime after;
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   503
    before.UniversalTime();
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   504
    TTimeIntervalMicroSeconds diff;
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   505
    TInt counter = aNotificatons;
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   506
    CActiveWaiter* waiter = NULL;
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   507
    TRAP_IGNORE(waiter = CActiveWaiter::NewL());
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   508
    if (!waiter)
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   509
        {
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   510
        INFO_PRINTF1(_L("Failed creating CActiveWaiter"));
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   511
        LOG(("OpenWFTest: *** Failed creating CActiveWaiter"));
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   512
        return EFalse;
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   513
        }
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   514
    waiter->StartWait(aMaxDelay);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   515
    CActiveScheduler::Start();
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   516
    while(!waiter->iRun)
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   517
        {
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   518
        after.UniversalTime();
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   519
        diff = after.MicroSecondsFrom(before);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   520
        if (diff > KNotificationWarning)
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   521
            {
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   522
            INFO_PRINTF2(_L("note: Notification took a long time to complete: %ld microseconds"),diff.Int64());
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   523
            LOG(("OpenWFTest: *** note: Notification took a long time to complete: %ld microseconds",diff.Int64()));
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   524
            }
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   525
        counter--;
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   526
        if (counter == 0)
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   527
            {   //all expected notifications were completed
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   528
            delete waiter;
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   529
            return ETrue;
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   530
            }
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   531
        CActiveScheduler::Start();
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   532
        }
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   533
    INFO_PRINTF2(_L("Not all notifications completed, counter=%d"),counter);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   534
    LOG(("OpenWFTest: *** Not all notifications completed, counter=%d",counter));
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   535
    delete waiter;
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   536
    //the notifications didn't complete in time
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   537
    return EFalse;
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   538
    }
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   539
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   540
// Create a suite of all the tests
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   541
CTestSuite* COpenwfTest::CreateSuiteL(const TDesC& aName)
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   542
	{
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   543
	SUB_SUITE_OPT(COpenwfTest,NULL);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   544
		//positive fastpath tests
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   545
		ADD_THIS_TEST_STEP(GRAPHICS_OPENWFC_FASTPATH_0000L);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   546
		ADD_THIS_TEST_STEP(GRAPHICS_OPENWFC_FASTPATH_0001L);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   547
		ADD_THIS_TEST_STEP(GRAPHICS_OPENWFC_FASTPATH_0002L);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   548
		ADD_THIS_TEST_STEP(GRAPHICS_OPENWFC_FASTPATH_0003L);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   549
        ADD_THIS_TEST_STEP(GRAPHICS_OPENWFC_FASTPATH_0004L);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   550
        ADD_THIS_TEST_STEP(GRAPHICS_OPENWFC_FASTPATH_0005L);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   551
        ADD_THIS_TEST_STEP(GRAPHICS_OPENWFC_FASTPATH_0006L);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   552
        ADD_THIS_TEST_STEP(GRAPHICS_OPENWFC_FASTPATH_0007L);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   553
        //fastpath with notification tests
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   554
        ADD_THIS_TEST_STEP(GRAPHICS_OPENWFC_FASTPATH_0010L);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   555
        ADD_THIS_TEST_STEP(GRAPHICS_OPENWFC_FASTPATH_0011L);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   556
        ADD_THIS_TEST_STEP(GRAPHICS_OPENWFC_FASTPATH_0012L);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   557
        ADD_THIS_TEST_STEP(GRAPHICS_OPENWFC_FASTPATH_0013L);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   558
        //negative fastpath tests
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   559
        ADD_THIS_TEST_STEP(GRAPHICS_OPENWFC_FASTPATH_0020L);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   560
        ADD_THIS_TEST_STEP(GRAPHICS_OPENWFC_FASTPATH_0021L);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   561
        ADD_THIS_TEST_STEP(GRAPHICS_OPENWFC_FASTPATH_0022L);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   562
        ADD_THIS_TEST_STEP(GRAPHICS_OPENWFC_FASTPATH_0023L);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   563
        ADD_THIS_TEST_STEP(GRAPHICS_OPENWFC_FASTPATH_0024L);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   564
        ADD_THIS_TEST_STEP(GRAPHICS_OPENWFC_FASTPATH_0025L);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   565
        ADD_THIS_TEST_STEP(GRAPHICS_OPENWFC_FASTPATH_0026L);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   566
        ADD_THIS_TEST_STEP(GRAPHICS_OPENWFC_FASTPATH_0027L);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   567
		
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   568
	END_SUITE;
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   569
	}
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   570
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   571
void TefUnitFailLeaveL()
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   572
	{
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   573
	User::Leave(KErrTEFUnitFail);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   574
	}
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   575
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   576
CActiveNotification* CActiveNotification::NewL(RSurfaceUpdateSession& aSurfaceUpdateSession,TBool aActivate)
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   577
	{
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   578
	CActiveNotification* self = new (ELeave) CActiveNotification;
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   579
	CleanupStack::PushL(self);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   580
	self->ConstructL(aSurfaceUpdateSession);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   581
	CleanupStack::Pop(self);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   582
	if (aActivate)
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   583
		{
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   584
		self->SetActive();
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   585
		}
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   586
	return self;
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   587
	}
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   588
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   589
void CActiveNotification::ConstructL(RSurfaceUpdateSession& aSurfaceUpdateSession)
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   590
	{
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   591
	CActiveScheduler::Add(this);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   592
	iSurfaceUpdateSession = aSurfaceUpdateSession;
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   593
	}
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   594
	
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   595
CActiveNotification::CActiveNotification() : CActive(EPriorityNormal)
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   596
	{}
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   597
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   598
CActiveNotification::~CActiveNotification()
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   599
	{
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   600
	Cancel();
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   601
	}
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   602
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   603
void CActiveNotification::DoCancel()
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   604
	{  //we need to cancel all notifications - this will impact other notifications in this sus session!
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   605
    iSurfaceUpdateSession.CancelAllUpdateNotifications();
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   606
	}
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   607
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   608
void CActiveNotification::RunL()
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   609
	{
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   610
	CActiveScheduler::Stop();
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   611
	}
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   612
	
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   613
TInt CActiveNotification::RunError(TInt aError)
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   614
	{
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   615
	return aError; // exists so a break point can be placed on it.
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   616
	}
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   617
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   618
void CActiveNotification::Activate()
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   619
	{
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   620
	SetActive();
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   621
	}
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   622
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   623
CActiveWaiter* CActiveWaiter::NewL()
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   624
    {
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   625
	CActiveWaiter* self = new (ELeave) CActiveWaiter;
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   626
    CleanupStack::PushL(self);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   627
    self->ConstructL();
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   628
    CleanupStack::Pop(self);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   629
    return self;
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   630
    }
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   631
    
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   632
void CActiveWaiter::ConstructL()
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   633
    {
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   634
    User::LeaveIfError(iTimer.CreateLocal());
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   635
    CActiveScheduler::Add(this);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   636
    }
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   637
    
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   638
CActiveWaiter::CActiveWaiter() : CActive(CActive::EPriorityStandard)
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   639
    {}
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   640
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   641
CActiveWaiter::~CActiveWaiter()
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   642
    {
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   643
    Cancel();
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   644
    iTimer.Close();
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   645
    }
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   646
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   647
void CActiveWaiter::DoCancel()
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   648
    {
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   649
    iTimer.Cancel();
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   650
    }
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   651
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   652
void CActiveWaiter::RunL()
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   653
    {
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   654
	iRun = ETrue;
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   655
    CActiveScheduler::Stop();
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   656
    }
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   657
    
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   658
TInt CActiveWaiter::RunError(TInt aError)
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   659
    {
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   660
    return aError; // exists so a break point can be placed on it.
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   661
    }
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   662
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   663
/**
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   664
 * Waits the set amount of time. Returns the amount of times the active scheduler 
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   665
 * was stopped (not including its own active scheduler stop)
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   666
 */
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   667
TInt CActiveWaiter::Wait(TTimeIntervalMicroSeconds32 aDelay)   //microseconds
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   668
    {
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   669
	TInt counter = 0;
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   670
    SetActive();
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   671
    iTimer.After(iStatus, aDelay);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   672
    iRun = EFalse;
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   673
    CActiveScheduler::Start();
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   674
    while (!iRun)
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   675
    	{//may be another object that stops the scheduler running in these tests.
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   676
		counter++;
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   677
		CActiveScheduler::Start();
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   678
    	}
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   679
    return counter;
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   680
    }
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   681
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   682
/**
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   683
 * Starts an AO with the given delay. Remember the RunL will stop the active scheduler.
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   684
 */
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   685
void CActiveWaiter::StartWait(TTimeIntervalMicroSeconds32 aDelay)   //microseconds
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   686
    {
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   687
    SetActive();
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   688
    iTimer.After(iStatus, aDelay);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   689
    }
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   690
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   691
/*
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   692
@SYMTestCaseID          GRAPHICS-OPENWFC-FASTPATH-0000
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   693
@SYMTestCaseDesc        Positive testing - Fastpath one-element scene
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   694
@SYMREQ                 
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   695
@SYMPREQ                PREQ417-54885
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   696
@SYMTestType            Unit Test
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   697
@SYMTestPriority        High
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   698
@SYMTestPurpose         Check a scene meeting fastpath criteria can be fastpathed
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   699
@SYMTestActions         
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   700
    All compositions are autonomous:
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   701
    Compose an empty scene
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   702
    Create a scene containing a screen sized element with no scaling, no alpha, no mask, no rotation
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   703
    Compose the scene
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   704
@SYMTestExpectedResults
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   705
    The final scene should be fastpathed    
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   706
*/
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   707
void COpenwfTest::GRAPHICS_OPENWFC_FASTPATH_0000L()
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   708
	{
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   709
    iTestName = _L("FASTPATH_0000");
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   710
    INFO_PRINTF2(_L("GRAPHICS_OPENWFC_%SL()"),&iTestName);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   711
    LOGL((_L("OpenWFTest: GRAPHICS_OPENWFC_%SL()"),&iTestName));
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   712
    SetupEmptySceneL();
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   713
    
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   714
    TSurfaceId surface=iUtility->CreateSurfaceL(TSize(iFastpathableWidth,iFastpathableHeight),
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   715
                                                iFastpathablePixelFormat,
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   716
                                                iStride, iContiguous, iMaxBuffers);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   717
    ASSERT_FALSE(surface.IsNull());
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   718
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   719
    WFCSource fpSource = wfcCreateSourceFromStream(iDevice, iContext,reinterpret_cast<WFCNativeStreamType>(&surface), NULL);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   720
    TInt err = iUtility->SubmitUpdate(surface, 0, NULL);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   721
    ASSERT_EQUALS(err,KErrNone);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   722
    WFCElement fpElement = wfcCreateElement(iDevice, iContext, NULL);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   723
    wfcSetElementAttribi(iDevice, fpElement, WFC_ELEMENT_SOURCE, fpSource);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   724
    
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   725
    wfcSetElementAttribiv(iDevice, fpElement, WFC_ELEMENT_SOURCE_RECTANGLE, 4, iFullScreenRect);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   726
    wfcSetElementAttribiv(iDevice, fpElement, WFC_ELEMENT_DESTINATION_RECTANGLE, 4, iFullScreenRect);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   727
    
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   728
#ifdef BREAKPOINT_FASTPATH
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   729
    __BREAKPOINT();
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   730
#endif
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   731
    wfcInsertElement(iDevice, fpElement, WFC_INVALID_HANDLE);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   732
    LOG(("OpenWFTest: Expecting FASTPATH after next commit"));
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   733
    wfcCommit(iDevice, iContext, WFC_TRUE);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   734
    wfcFence(iDevice, iContext, iEGLDisplay, iSync);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   735
    ASSERT_EQUALS(eglClientWaitSyncKHR(iEGLDisplay,iSync,0,(EGLTimeKHR)EGL_FOREVER_KHR),EGL_CONDITION_SATISFIED_KHR);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   736
    LOG(("OpenWFTest: Fastpath - Now ON"));
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   737
    
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   738
    iUtility->FillSurfaceL(surface, 0, KGreen);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   739
    err = iUtility->SubmitUpdate(surface, 0, NULL);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   740
    ASSERT_EQUALS(err,KErrNone);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   741
    WaitL(iCompositionPause);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   742
    
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   743
    ASSERT_TRUE(AcquireOnScreenStream());
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   744
    ASSERT_TRUE(CheckOnScreenReferenceImage());
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   745
    ASSERT_TRUE(CheckOnScreenStreamRect(iFullScreenTRect,KGreen,iTolerance));
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   746
    ReleaseOnScreenStream();
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   747
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   748
    ASSERT_EQUALS(wfcGetError(iDevice),WFC_ERROR_NONE);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   749
    wfcDestroySource(iDevice, fpSource);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   750
	}
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   751
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   752
/*
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   753
@SYMTestCaseID			GRAPHICS-OPENWFC-FASTPATH-0001
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   754
@SYMTestCaseDesc		Positive testing - Fastpath one-element scene  
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   755
@SYMREQ					
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   756
@SYMPREQ						PREQ417-54885
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   757
@SYMTestType				Unit Test
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   758
@SYMTestPriority		High	
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   759
@SYMTestPurpose			Check a scene including a full screen element with global alpha at opaque level 
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   760
										can be fastpathed
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   761
@SYMTestActions			
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   762
	All compositions are autonomous:
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   763
	Compose an empty scene
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   764
	Create a scene containing a screen sized element with 2 buffers
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   765
	Enable WFC_TRANPARENCY_GLOBAL_ALPHA 
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   766
	Set WFC_ELEMENT_GLOBAL_ALPHA to be 255 (opaque)
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   767
	Compose the scene
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   768
@SYMTestExpectedResults
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   769
	The final scene should be fastpathed
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   770
*/
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   771
void COpenwfTest::GRAPHICS_OPENWFC_FASTPATH_0001L()
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   772
	{
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   773
    iTestName = _L("FASTPATH_0001");
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   774
    INFO_PRINTF2(_L("GRAPHICS_OPENWFC_%SL()"),&iTestName);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   775
    LOGL((_L("OpenWFTest: GRAPHICS_OPENWFC_%SL()"),&iTestName));
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   776
    SetupEmptySceneL();
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   777
    
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   778
    TSurfaceId surface=iUtility->CreateSurfaceL(TSize(iFastpathableWidth,iFastpathableHeight),
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   779
                                                iFastpathablePixelFormat,
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   780
                                                iStride, iContiguous, iMaxBuffers);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   781
    ASSERT_FALSE(surface.IsNull());
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   782
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   783
    WFCSource fpSource = wfcCreateSourceFromStream(iDevice, iContext,reinterpret_cast<WFCNativeStreamType>(&surface), NULL);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   784
    TInt err = iUtility->SubmitUpdate(surface, 0, NULL);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   785
    ASSERT_EQUALS(err,KErrNone);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   786
    WFCElement fpElement = wfcCreateElement(iDevice, iContext, NULL);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   787
    wfcSetElementAttribi(iDevice, fpElement, WFC_ELEMENT_SOURCE, fpSource);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   788
    
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   789
    wfcSetElementAttribiv(iDevice, fpElement, WFC_ELEMENT_SOURCE_RECTANGLE, 4, iFullScreenRect);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   790
    wfcSetElementAttribiv(iDevice, fpElement, WFC_ELEMENT_DESTINATION_RECTANGLE, 4, iFullScreenRect);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   791
    //set element global alpha
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   792
    wfcSetElementAttribi(iDevice, fpElement, WFC_ELEMENT_TRANSPARENCY_TYPES, WFC_TRANSPARENCY_ELEMENT_GLOBAL_ALPHA);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   793
    wfcSetElementAttribf(iDevice, fpElement, WFC_ELEMENT_GLOBAL_ALPHA, 1.0f);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   794
    
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   795
#ifdef BREAKPOINT_FASTPATH
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   796
    __BREAKPOINT();
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   797
#endif
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   798
    wfcInsertElement(iDevice, fpElement, WFC_INVALID_HANDLE);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   799
    LOG(("OpenWFTest: Expecting FASTPATH after next commit - using element alpha"));
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   800
    wfcCommit(iDevice, iContext, WFC_TRUE);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   801
    wfcFence(iDevice, iContext, iEGLDisplay, iSync);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   802
    ASSERT_EQUALS(eglClientWaitSyncKHR(iEGLDisplay,iSync,0,(EGLTimeKHR)EGL_FOREVER_KHR),EGL_CONDITION_SATISFIED_KHR);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   803
    LOG(("OpenWFTest: Fastpath - now ON - using element alpha"));
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   804
    
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   805
    iUtility->FillSurfaceL(surface, 0, KGreen);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   806
    err = iUtility->SubmitUpdate(surface, 0, NULL);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   807
    ASSERT_EQUALS(err,KErrNone);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   808
    WaitL(iCompositionPause);	
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   809
 
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   810
    ASSERT_TRUE(AcquireOnScreenStream());
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   811
    ASSERT_TRUE(CheckOnScreenReferenceImage());
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   812
    ASSERT_TRUE(CheckOnScreenStreamRect(iFullScreenTRect,KGreen,iTolerance));
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   813
    ReleaseOnScreenStream();
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   814
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   815
    ASSERT_EQUALS(wfcGetError(iDevice),WFC_ERROR_NONE);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   816
    wfcDestroySource(iDevice, fpSource);  
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   817
	}
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   818
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   819
/*
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   820
@SYMTestCaseID			GRAPHICS-OPENWFC-FASTPATH-0002
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   821
@SYMTestCaseDesc		Positive testing - Fastpath one-element scene  
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   822
@SYMREQ					
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   823
@SYMPREQ						PREQ417-54885
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   824
@SYMTestType				Unit Test
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   825
@SYMTestPriority		High
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   826
@SYMTestPurpose			Check a scene including a full screen element with source alpha flagged but an 
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   827
										opaque data format can be fastpathed
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   828
@SYMTestActions			
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   829
	All compositions are autonomous:
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   830
	Compose an empty scene
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   831
	Create a scene containing a screen sized element 
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   832
	Enable WFC_TRANSPARENCY_SOURCE, but the source format has no alpha value 
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   833
	Compose the scene
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   834
@SYMTestExpectedResults
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   835
	The final scene should be fastpathed
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   836
*/	
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   837
void COpenwfTest::GRAPHICS_OPENWFC_FASTPATH_0002L()
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   838
	{
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   839
    iTestName = _L("FASTPATH_0002");
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   840
    INFO_PRINTF2(_L("GRAPHICS_OPENWFC_%SL()"),&iTestName);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   841
    LOGL((_L("OpenWFTest: GRAPHICS_OPENWFC_%SL()"),&iTestName));
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   842
    SetupEmptySceneL();
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   843
    
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   844
    TSurfaceId surface=iUtility->CreateSurfaceL(TSize(iFastpathableWidth,iFastpathableHeight),
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   845
												EUidPixelFormatXRGB_8888,
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   846
                                                iStride, iContiguous, iMaxBuffers);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   847
    ASSERT_FALSE(surface.IsNull());
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   848
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   849
    WFCSource fpSource = wfcCreateSourceFromStream(iDevice, iContext,reinterpret_cast<WFCNativeStreamType>(&surface), NULL);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   850
    TInt err = iUtility->SubmitUpdate(surface, 0, NULL);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   851
    ASSERT_EQUALS(err,KErrNone);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   852
    WFCElement fpElement = wfcCreateElement(iDevice, iContext, NULL);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   853
    wfcSetElementAttribi(iDevice, fpElement, WFC_ELEMENT_SOURCE, fpSource);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   854
    wfcSetElementAttribiv(iDevice, fpElement, WFC_ELEMENT_SOURCE_RECTANGLE, 4, iFullScreenRect);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   855
    wfcSetElementAttribiv(iDevice, fpElement, WFC_ELEMENT_DESTINATION_RECTANGLE, 4, iFullScreenRect);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   856
    //set pixel alpha on XRGB element
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   857
    wfcSetElementAttribi(iDevice, fpElement, WFC_ELEMENT_TRANSPARENCY_TYPES, WFC_TRANSPARENCY_SOURCE);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   858
    
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   859
#ifdef BREAKPOINT_FASTPATH
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   860
    __BREAKPOINT();
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   861
#endif
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   862
    wfcInsertElement(iDevice, fpElement, WFC_INVALID_HANDLE);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   863
    LOG(("OpenWFTest: Expecting FASTPATH after next commit - using pixel alpha"));
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   864
    wfcCommit(iDevice, iContext, WFC_TRUE);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   865
    wfcFence(iDevice, iContext, iEGLDisplay, iSync);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   866
    ASSERT_EQUALS(eglClientWaitSyncKHR(iEGLDisplay,iSync,0,(EGLTimeKHR)EGL_FOREVER_KHR),EGL_CONDITION_SATISFIED_KHR);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   867
    LOG(("OpenWFTest: Fastpath - now ON - using pixel alpha"));
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   868
    
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   869
    iUtility->FillSurfaceL(surface, 0, KGreen);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   870
    err = iUtility->SubmitUpdate(surface, 0, NULL);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   871
    ASSERT_EQUALS(err,KErrNone);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   872
    WaitL(iCompositionPause);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   873
 
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   874
    ASSERT_TRUE(AcquireOnScreenStream());
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   875
    ASSERT_TRUE(CheckOnScreenReferenceImage());
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   876
    ASSERT_TRUE(CheckOnScreenStreamRect(iFullScreenTRect,KGreen,iTolerance));
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   877
    ReleaseOnScreenStream();
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   878
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   879
    ASSERT_EQUALS(wfcGetError(iDevice),WFC_ERROR_NONE);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   880
    wfcDestroySource(iDevice, fpSource);  
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   881
	}
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   882
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   883
/*
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   884
@SYMTestCaseID			GRAPHICS-OPENWFC-FASTPATH-0003
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   885
@SYMTestCaseDesc		Positive testing - Fastpath scene with a double buffered element
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   886
@SYMREQ					
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   887
@SYMPREQ						PREQ417-54885
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   888
@SYMTestType				Unit Test
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   889
@SYMTestPriority		High
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   890
@SYMTestPurpose			Check if a scene is fastpathed using the second buffer
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   891
@SYMTestActions			
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   892
	All compositions are autonomous:
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   893
	Compose an empty scene
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   894
	A) Create a scene containing an element with 2 buffers
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   895
	Set the element screen size
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   896
	Set destination and source rectangle to screen size
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   897
	Compose the scene
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   898
	B) Send an update to buffer 1 with change of colour
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   899
	Wait for notification
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   900
@SYMTestExpectedResults
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   901
	The scene should be fastpathed for A and B
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   902
	Screen colour should change after B
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   903
*/
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   904
void COpenwfTest::GRAPHICS_OPENWFC_FASTPATH_0003L()
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   905
	{
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   906
    iTestName = _L("FASTPATH_0003");
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   907
    INFO_PRINTF2(_L("GRAPHICS_OPENWFC_%SL()"),&iTestName);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   908
    LOGL((_L("OpenWFTest: GRAPHICS_OPENWFC_%SL()"),&iTestName));
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   909
    SetupEmptySceneL();
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   910
    
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   911
    TSurfaceId surface=iUtility->CreateSurfaceL(TSize(iFastpathableWidth,iFastpathableHeight),
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   912
                                                iFastpathablePixelFormat,
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   913
                                                iStride, iContiguous, iMaxBuffers);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   914
    ASSERT_FALSE(surface.IsNull());
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   915
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   916
    WFCSource fpSource = wfcCreateSourceFromStream(iDevice, iContext,reinterpret_cast<WFCNativeStreamType>(&surface), NULL);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   917
    TInt err = iUtility->SubmitUpdate(surface, 0, NULL);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   918
    ASSERT_EQUALS(err,KErrNone);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   919
    WFCElement fpElement = wfcCreateElement(iDevice, iContext, NULL);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   920
    wfcSetElementAttribi(iDevice, fpElement, WFC_ELEMENT_SOURCE, fpSource);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   921
    
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   922
    wfcSetElementAttribiv(iDevice, fpElement, WFC_ELEMENT_SOURCE_RECTANGLE, 4, iFullScreenRect);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   923
    wfcSetElementAttribiv(iDevice, fpElement, WFC_ELEMENT_DESTINATION_RECTANGLE, 4, iFullScreenRect);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   924
    
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   925
#ifdef BREAKPOINT_FASTPATH
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   926
    __BREAKPOINT();
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   927
#endif
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   928
    wfcInsertElement(iDevice, fpElement, WFC_INVALID_HANDLE);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   929
    LOG(("OpenWFTest: Expecting FASTPATH after next commit"));
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   930
    wfcCommit(iDevice, iContext, WFC_TRUE);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   931
    wfcFence(iDevice, iContext, iEGLDisplay, iSync);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   932
    ASSERT_EQUALS(eglClientWaitSyncKHR(iEGLDisplay,iSync,0,(EGLTimeKHR)EGL_FOREVER_KHR),EGL_CONDITION_SATISFIED_KHR);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   933
    LOG(("OpenWFTest: Fastpath - now ON"));
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   934
    
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   935
    iUtility->FillSurfaceL(surface, 0, KGreen);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   936
    err = iUtility->SubmitUpdate(surface, 0, NULL);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   937
    ASSERT_EQUALS(err,KErrNone);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   938
    WaitL(iCompositionPause);	
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   939
 
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   940
    ASSERT_TRUE(AcquireOnScreenStream());
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   941
    ASSERT_TRUE(CheckOnScreenReferenceImage());
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   942
    ASSERT_TRUE(CheckOnScreenStreamRect(iFullScreenTRect,KGreen,iTolerance));
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   943
    ReleaseOnScreenStream();
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   944
    
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   945
    //Fill surface is blue
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   946
    iUtility->FillSurfaceL(surface, 1, KBlue);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   947
	//Do content update for surface buff1
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   948
    CActiveNotification* buff1disp = CActiveNotification::NewL(iUtility->Session(),ETrue);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   949
    CleanupStack::PushL(buff1disp);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   950
    TTimeStamp buff1time;
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   951
    iUtility->NotifyWhenDisplayed(buff1disp->iStatus,buff1time);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   952
    
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   953
    LOG(("OpenWFTest: Fastpath - staying ON..."));
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   954
    err = iUtility->SubmitUpdate(surface, 1, NULL);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   955
	ASSERT_EQUALS(err,KErrNone);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   956
    ASSERT_TRUE(WaitForNotifications(KMaxNotificationDelay,1));	//1 AO should have completed
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   957
    
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   958
    //create ref image/check on screen content
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   959
    ASSERT_TRUE(AcquireOnScreenStream());
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   960
    ASSERT_TRUE(CheckOnScreenReferenceImage());
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   961
    ASSERT_TRUE(CheckOnScreenStreamRect(iFullScreenTRect,KBlue,iTolerance));
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   962
    ReleaseOnScreenStream();
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   963
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   964
    ASSERT_EQUALS(wfcGetError(iDevice),WFC_ERROR_NONE);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   965
    wfcDestroySource(iDevice, fpSource);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   966
    CleanupStack::PopAndDestroy(buff1disp);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   967
	}
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   968
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   969
/*
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   970
@SYMTestCaseID			GRAPHICS-OPENWFC-FASTPATH-0004
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   971
@SYMTestCaseDesc		Positive testing - Fastpath two-element scene 
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   972
@SYMREQ					
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   973
@SYMPREQ						PREQ417-54885
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   974
@SYMTestType				Unit Test
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   975
@SYMTestPriority		Medium
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   976
@SYMTestPurpose			Check a scene including a full screen opaque element as the top layer can be 
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   977
										fastpathed
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   978
@SYMTestActions			
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   979
	All compositions are autonomous:
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   980
	Compose an empty scene
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   981
	A) Create a scene containing a screen sized element with WFC_TRANSPARENCY_NONE enabled
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   982
	Compose the scene
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   983
  B) Create a small rectangle behind the first element
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   984
	Compose the scene
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   985
*/
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   986
void COpenwfTest::GRAPHICS_OPENWFC_FASTPATH_0004L()
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   987
	{
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   988
    iTestName = _L("FASTPATH_0004");
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   989
    INFO_PRINTF2(_L("GRAPHICS_OPENWFC_%SL()"),&iTestName);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   990
    LOGL((_L("OpenWFTest: GRAPHICS_OPENWFC_%SL()"),&iTestName));
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   991
    SetupEmptySceneL();
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   992
	
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   993
	TSurfaceId surface=iUtility->CreateSurfaceL(TSize(iFastpathableWidth,iFastpathableHeight),
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   994
												iFastpathablePixelFormat,
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   995
												iStride, iContiguous, iMaxBuffers);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   996
	ASSERT_FALSE(surface.IsNull());
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   997
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   998
	WFCSource fpSource = wfcCreateSourceFromStream(iDevice, iContext,reinterpret_cast<WFCNativeStreamType>(&surface), NULL);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
   999
	TInt err = iUtility->SubmitUpdate(surface, 0, NULL);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1000
	ASSERT_EQUALS(err,KErrNone);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1001
	WFCElement fpElement = wfcCreateElement(iDevice, iContext, NULL);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1002
	wfcSetElementAttribi(iDevice, fpElement, WFC_ELEMENT_SOURCE, fpSource);	
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1003
	wfcSetElementAttribiv(iDevice, fpElement, WFC_ELEMENT_SOURCE_RECTANGLE, 4, iFullScreenRect);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1004
	wfcSetElementAttribiv(iDevice, fpElement, WFC_ELEMENT_DESTINATION_RECTANGLE, 4, iFullScreenRect);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1005
	
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1006
    TSurfaceId surfaceB = iUtility->CreateSurfaceL(TSize(iFastpathableWidth/2,iFastpathableHeight/2),
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1007
                                                iFastpathablePixelFormat,
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1008
                                                iStride, iContiguous, iMaxBuffers);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1009
    ASSERT_FALSE(surfaceB.IsNull());
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1010
    WFCSource sourceB = wfcCreateSourceFromStream(iDevice, iContext, reinterpret_cast<WFCNativeStreamType>(&surfaceB), NULL);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1011
    err = iUtility->SubmitUpdate(surfaceB, 0, NULL);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1012
    ASSERT_EQUALS(err,KErrNone);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1013
    WFCElement elementB = wfcCreateElement(iDevice, iContext, NULL);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1014
    wfcSetElementAttribi(iDevice, elementB, WFC_ELEMENT_SOURCE, sourceB);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1015
    wfcSetElementAttribiv(iDevice, elementB, WFC_ELEMENT_SOURCE_RECTANGLE, 4, iHalfSizeRect);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1016
    wfcSetElementAttribiv(iDevice, elementB, WFC_ELEMENT_DESTINATION_RECTANGLE, 4, iCenterRect);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1017
	
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1018
#ifdef BREAKPOINT_FASTPATH
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1019
    __BREAKPOINT();
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1020
#endif
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1021
	wfcInsertElement(iDevice, fpElement, WFC_INVALID_HANDLE);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1022
    LOG(("OpenWFTest: Expecting FASTPATH after next commit"));
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1023
	wfcCommit(iDevice, iContext, WFC_TRUE);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1024
	wfcFence(iDevice, iContext, iEGLDisplay, iSync);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1025
	ASSERT_EQUALS(eglClientWaitSyncKHR(iEGLDisplay,iSync,0,(EGLTimeKHR)EGL_FOREVER_KHR),EGL_CONDITION_SATISFIED_KHR);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1026
	LOG(("OpenWFTest: Fastpath - now ON"));
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1027
	
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1028
	iUtility->FillSurfaceL(surface, 0, KGreen);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1029
	err = iUtility->SubmitUpdate(surface, 0, NULL);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1030
	ASSERT_EQUALS(err,KErrNone);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1031
	WaitL(iCompositionPause);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1032
 
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1033
    ASSERT_TRUE(AcquireOnScreenStream());
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1034
    ASSERT_TRUE(CheckOnScreenReferenceImage());
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1035
    ASSERT_TRUE(CheckOnScreenStreamRect(iFullScreenTRect,KGreen,iTolerance));
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1036
    ReleaseOnScreenStream();
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1037
	
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1038
    LOG(("OpenWFTest: Fastpath - staying ON..."));
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1039
#ifdef BREAKPOINT_FASTPATH
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1040
    __BREAKPOINT();
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1041
#endif
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1042
	wfcInsertElement(iDevice, elementB, WFC_INVALID_HANDLE);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1043
    LOG(("OpenWFTest: Expecting FASTPATH after next commit"));
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1044
	wfcCommit(iDevice, iContext, WFC_TRUE);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1045
	wfcFence(iDevice, iContext, iEGLDisplay, iSync);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1046
	ASSERT_EQUALS(eglClientWaitSyncKHR(iEGLDisplay,iSync,0,(EGLTimeKHR)EGL_FOREVER_KHR),EGL_CONDITION_SATISFIED_KHR);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1047
	
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1048
	iUtility->FillSurfaceL(surfaceB, 0, KBlue);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1049
	err = iUtility->SubmitUpdate(surfaceB, 0, NULL);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1050
	ASSERT_EQUALS(err,KErrNone);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1051
	WaitL(iCompositionPause);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1052
 
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1053
    ASSERT_TRUE(AcquireOnScreenStream());
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1054
    ASSERT_TRUE(CheckOnScreenReferenceImage());
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1055
    ASSERT_TRUE(CheckOnScreenStreamRect(iFullScreenTRect,KGreen,iTolerance));
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1056
    ReleaseOnScreenStream();
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1057
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1058
    ASSERT_EQUALS(wfcGetError(iDevice),WFC_ERROR_NONE);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1059
	wfcDestroySource(iDevice, fpSource);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1060
	wfcDestroySource(iDevice, sourceB);  
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1061
	}
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1062
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1063
/*
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1064
@SYMTestCaseID			GRAPHICS-OPENWFC-FASTPATH-0005
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1065
@SYMTestCaseDesc		Positive testing - Fastpath two-element scene 
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1066
@SYMREQ					
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1067
@SYMPREQ						PREQ417-54885
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1068
@SYMTestType				Unit Test
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1069
@SYMTestPriority		Medium	
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1070
@SYMTestPurpose			Check a scene including a full screen element with global alpha as the top layer 
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1071
										can be fastpathed
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1072
@SYMTestActions			
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1073
	All compositions are autonomous:
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1074
	Compose an empty scene
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1075
	A) Create a scene containing a screen sized element 
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1076
	Enable WFC_TRANPARENCY_GLOBAL_ALPHA and set WFC_ELEMENT_GLOBAL_ALPHA to be 255 (opaque)
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1077
	Compose the scene
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1078
	B) Create a smaller element behind the first element
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1079
	Compose the scene
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1080
@SYMTestExpectedResults
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1081
	Both compositions should trigger fastpathing.
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1082
*/
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1083
void COpenwfTest::GRAPHICS_OPENWFC_FASTPATH_0005L()
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1084
	{
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1085
    iTestName = _L("FASTPATH_0005");
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1086
    INFO_PRINTF2(_L("GRAPHICS_OPENWFC_%SL()"),&iTestName);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1087
    LOGL((_L("OpenWFTest: GRAPHICS_OPENWFC_%SL()"),&iTestName));
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1088
    SetupEmptySceneL();
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1089
	
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1090
	TSurfaceId surface=iUtility->CreateSurfaceL(TSize(iFastpathableWidth,iFastpathableHeight),
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1091
												iFastpathablePixelFormat,
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1092
												iStride, iContiguous, iMaxBuffers);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1093
	ASSERT_FALSE(surface.IsNull());
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1094
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1095
	WFCSource fpSource = wfcCreateSourceFromStream(iDevice, iContext,reinterpret_cast<WFCNativeStreamType>(&surface), NULL);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1096
	TInt err = iUtility->SubmitUpdate(surface, 0, NULL);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1097
	ASSERT_EQUALS(err,KErrNone);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1098
	WFCElement fpElement = wfcCreateElement(iDevice, iContext, NULL);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1099
	wfcSetElementAttribi(iDevice, fpElement, WFC_ELEMENT_SOURCE, fpSource);	
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1100
	wfcSetElementAttribiv(iDevice, fpElement, WFC_ELEMENT_SOURCE_RECTANGLE, 4, iFullScreenRect);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1101
	wfcSetElementAttribiv(iDevice, fpElement, WFC_ELEMENT_DESTINATION_RECTANGLE, 4, iFullScreenRect);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1102
//set element global alpha
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1103
	wfcSetElementAttribf(iDevice, fpElement, WFC_ELEMENT_GLOBAL_ALPHA, 1.0f);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1104
	wfcSetElementAttribi(iDevice, fpElement, WFC_ELEMENT_TRANSPARENCY_TYPES, WFC_TRANSPARENCY_ELEMENT_GLOBAL_ALPHA);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1105
	
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1106
    TSurfaceId surfaceB = iUtility->CreateSurfaceL(TSize(iFastpathableWidth/2,iFastpathableHeight/2),
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1107
                                                iFastpathablePixelFormat,
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1108
                                                iStride, iContiguous, iMaxBuffers);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1109
    ASSERT_FALSE(surfaceB.IsNull());
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1110
    WFCSource sourceB = wfcCreateSourceFromStream(iDevice, iContext, reinterpret_cast<WFCNativeStreamType>(&surfaceB), NULL);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1111
    err = iUtility->SubmitUpdate(surfaceB, 0, NULL);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1112
    ASSERT_EQUALS(err,KErrNone);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1113
    WFCElement elementB = wfcCreateElement(iDevice, iContext, NULL);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1114
    wfcSetElementAttribi(iDevice, elementB, WFC_ELEMENT_SOURCE, sourceB);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1115
    wfcSetElementAttribiv(iDevice, elementB, WFC_ELEMENT_SOURCE_RECTANGLE, 4, iHalfSizeRect);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1116
    wfcSetElementAttribiv(iDevice, elementB, WFC_ELEMENT_DESTINATION_RECTANGLE, 4, iCenterRect);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1117
	
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1118
#ifdef BREAKPOINT_FASTPATH
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1119
    __BREAKPOINT();
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1120
#endif
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1121
	wfcInsertElement(iDevice, fpElement, WFC_INVALID_HANDLE);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1122
    LOG(("OpenWFTest: Expecting FASTPATH after next commit - using element global alpha"));
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1123
	wfcCommit(iDevice, iContext, WFC_TRUE);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1124
	wfcFence(iDevice, iContext, iEGLDisplay, iSync);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1125
	ASSERT_EQUALS(eglClientWaitSyncKHR(iEGLDisplay,iSync,0,(EGLTimeKHR)EGL_FOREVER_KHR),EGL_CONDITION_SATISFIED_KHR);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1126
	LOG(("OpenWFTest: Fastpath - now ON... - using element global alpha"));
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1127
	
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1128
	iUtility->FillSurfaceL(surface, 0, KGreen);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1129
	ASSERT_EQUALS(iUtility->SubmitUpdate(surface, 0, NULL),KErrNone);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1130
	WaitL(iCompositionPause);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1131
 
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1132
    ASSERT_TRUE(AcquireOnScreenStream());
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1133
    ASSERT_TRUE(CheckOnScreenReferenceImage());
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1134
    ASSERT_TRUE(CheckOnScreenStreamRect(iFullScreenTRect,KGreen,iTolerance));
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1135
    ReleaseOnScreenStream();
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1136
	
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1137
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1138
#ifdef BREAKPOINT_FASTPATH
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1139
    __BREAKPOINT();
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1140
#endif
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1141
	wfcInsertElement(iDevice, elementB, WFC_INVALID_HANDLE);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1142
    LOG(("OpenWFTest: Expecting FASTPATH after next commit - using element global alpha"));
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1143
	wfcCommit(iDevice, iContext, WFC_TRUE);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1144
	wfcFence(iDevice, iContext, iEGLDisplay, iSync);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1145
	ASSERT_EQUALS(eglClientWaitSyncKHR(iEGLDisplay,iSync,0,(EGLTimeKHR)EGL_FOREVER_KHR),EGL_CONDITION_SATISFIED_KHR);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1146
	
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1147
	iUtility->FillSurfaceL(surfaceB, 0, KBlue);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1148
	err = iUtility->SubmitUpdate(surfaceB, 0, NULL);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1149
	ASSERT_EQUALS(err,KErrNone);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1150
	WaitL(iCompositionPause);	
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1151
 
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1152
    ASSERT_TRUE(AcquireOnScreenStream());
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1153
    ASSERT_TRUE(CheckOnScreenReferenceImage());
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1154
    ASSERT_TRUE(CheckOnScreenStreamRect(iFullScreenTRect,KGreen,iTolerance));
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1155
    ReleaseOnScreenStream();
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1156
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1157
    ASSERT_EQUALS(wfcGetError(iDevice),WFC_ERROR_NONE);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1158
	wfcDestroySource(iDevice, fpSource);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1159
	wfcDestroySource(iDevice, sourceB);  
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1160
	}
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1161
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1162
/*
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1163
@SYMTestCaseID			GRAPHICS-OPENWFC-FASTPATH-0006
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1164
@SYMTestCaseDesc		Positive testing - Fastpath two-element scene 
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1165
@SYMREQ					
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1166
@SYMPREQ						PREQ417-54885
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1167
@SYMTestType				Unit Test
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1168
@SYMTestPriority		Low
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1169
@SYMTestPurpose			Check a scene including a full screen opaque element behind a transparent element 
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1170
										can be fastpathed
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1171
@SYMTestActions			
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1172
	All compositions are autonomous:
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1173
	Compose an empty scene
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1174
	A) Create a scene containing an element of any size 
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1175
	Enable WFC_TRANPARENCY_GLOBAL_ALPHA and set WFC_ELEMENT_GLOBAL_ALPHA to 0 (transparent)
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1176
	Compose the scene
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1177
	B) Create another screen sized opaque element behind the frist 
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1178
	Compose the scene
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1179
@SYMTestExpectedResults
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1180
	The final scene should fastpath for B), not for A)	
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1181
	(The current implementation does not support this fastpath behaviour. This test can be ignored at 
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1182
	the moment.)
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1183
*/
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1184
void COpenwfTest::GRAPHICS_OPENWFC_FASTPATH_0006L()
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1185
	{
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1186
    iTestName = _L("FASTPATH_0006");
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1187
    INFO_PRINTF2(_L("GRAPHICS_OPENWFC_%SL()"),&iTestName);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1188
    LOGL((_L("OpenWFTest: GRAPHICS_OPENWFC_%SL()"),&iTestName));
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1189
    SetupEmptySceneL();
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1190
	
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1191
	TSurfaceId surface=iUtility->CreateSurfaceL(TSize(iFastpathableWidth/2,iFastpathableHeight/2),
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1192
												iFastpathablePixelFormat,
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1193
												iStride, iContiguous, iMaxBuffers);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1194
	ASSERT_FALSE(surface.IsNull());
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1195
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1196
	WFCSource fpSource = wfcCreateSourceFromStream(iDevice, iContext,reinterpret_cast<WFCNativeStreamType>(&surface), NULL);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1197
	TInt err = iUtility->SubmitUpdate(surface, 0, NULL);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1198
	ASSERT_EQUALS(err,KErrNone);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1199
	WFCElement fpElement = wfcCreateElement(iDevice, iContext, NULL);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1200
	wfcSetElementAttribi(iDevice, fpElement, WFC_ELEMENT_SOURCE, fpSource);	
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1201
	wfcSetElementAttribiv(iDevice, fpElement, WFC_ELEMENT_SOURCE_RECTANGLE, 4, iHalfSizeRect);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1202
	wfcSetElementAttribiv(iDevice, fpElement, WFC_ELEMENT_DESTINATION_RECTANGLE, 4, iCenterRect);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1203
	//set element global alpha fully transparent
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1204
	wfcSetElementAttribf(iDevice, fpElement, WFC_ELEMENT_GLOBAL_ALPHA, 0.0f);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1205
	wfcSetElementAttribi(iDevice, fpElement, WFC_ELEMENT_TRANSPARENCY_TYPES, WFC_TRANSPARENCY_ELEMENT_GLOBAL_ALPHA);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1206
	
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1207
    TSurfaceId surfaceB = iUtility->CreateSurfaceL(TSize(iFastpathableWidth,iFastpathableHeight),
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1208
													iFastpathablePixelFormat,
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1209
													iStride, iContiguous, iMaxBuffers);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1210
    ASSERT_FALSE(surfaceB.IsNull());
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1211
    WFCSource sourceB = wfcCreateSourceFromStream(iDevice, iContext, reinterpret_cast<WFCNativeStreamType>(&surfaceB), NULL);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1212
    err = iUtility->SubmitUpdate(surfaceB, 0, NULL);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1213
    ASSERT_EQUALS(err,KErrNone);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1214
    WFCElement elementB = wfcCreateElement(iDevice, iContext, NULL);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1215
    wfcSetElementAttribi(iDevice, elementB, WFC_ELEMENT_SOURCE, sourceB);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1216
    wfcSetElementAttribiv(iDevice, elementB, WFC_ELEMENT_SOURCE_RECTANGLE, 4, iFullScreenRect);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1217
    wfcSetElementAttribiv(iDevice, elementB, WFC_ELEMENT_DESTINATION_RECTANGLE, 4, iFullScreenRect);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1218
	
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1219
#ifdef BREAKPOINT_FASTPATH
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1220
    __BREAKPOINT();
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1221
#endif
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1222
	wfcInsertElement(iDevice, fpElement, WFC_INVALID_HANDLE);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1223
    LOG(("OpenWFTest: Expecting COMPOSITION after next commit -single fully transparent element using global alpha"));
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1224
	wfcCommit(iDevice, iContext, WFC_TRUE);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1225
	wfcFence(iDevice, iContext, iEGLDisplay, iSync);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1226
	ASSERT_EQUALS(eglClientWaitSyncKHR(iEGLDisplay,iSync,0,(EGLTimeKHR)EGL_FOREVER_KHR),EGL_CONDITION_SATISFIED_KHR);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1227
	LOG(("OpenWFTest: Fastpath - now ON - single fully transparent element using global alpha"));
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1228
	
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1229
	iUtility->FillSurfaceL(surface, 0, KGreen);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1230
	err = iUtility->SubmitUpdate(surface, 0, NULL);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1231
	ASSERT_EQUALS(err,KErrNone);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1232
	WaitL(iCompositionPause);	
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1233
 
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1234
#ifdef BREAKPOINT_FASTPATH
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1235
    __BREAKPOINT();
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1236
#endif
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1237
	wfcInsertElement(iDevice, elementB, WFC_INVALID_HANDLE);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1238
    LOG(("OpenWFTest: Expecting FASTPATH after next commit -fullscreen opaque element behind fully transparent element"));
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1239
	wfcCommit(iDevice, iContext, WFC_TRUE);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1240
	wfcFence(iDevice, iContext, iEGLDisplay, iSync);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1241
	ASSERT_EQUALS(eglClientWaitSyncKHR(iEGLDisplay,iSync,0,(EGLTimeKHR)EGL_FOREVER_KHR),EGL_CONDITION_SATISFIED_KHR);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1242
	LOG(("OpenWFTest: Fastpath - now ON - fullscreen opaque element behind transparent element"));
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1243
	
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1244
	iUtility->FillSurfaceL(surfaceB, 0, KBlue);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1245
	err = iUtility->SubmitUpdate(surfaceB, 0, NULL);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1246
	ASSERT_EQUALS(err,KErrNone);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1247
	WaitL(iCompositionPause);	
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1248
 
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1249
    ASSERT_TRUE(AcquireOnScreenStream());
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1250
    ASSERT_TRUE(CheckOnScreenReferenceImage());
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1251
    ASSERT_TRUE(CheckOnScreenStreamRect(iFullScreenTRect,KBlue,iTolerance));
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1252
    ReleaseOnScreenStream();
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1253
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1254
    ASSERT_EQUALS(wfcGetError(iDevice),WFC_ERROR_NONE);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1255
	wfcDestroySource(iDevice, fpSource);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1256
	wfcDestroySource(iDevice, sourceB);  
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1257
	}
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1258
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1259
/*
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1260
@SYMTestCaseID			GRAPHICS-OPENWFC-FASTPATH-0007
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1261
@SYMTestCaseDesc		Positive testing - Fastpath one-element scene  
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1262
@SYMREQ					
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1263
@SYMPREQ						PREQ417-54885
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1264
@SYMTestType				Unit Test
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1265
@SYMTestPriority		High
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1266
@SYMTestPurpose			Check a scene including destination rectangle changes can trigger fastpath on and off
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1267
@SYMTestActions			
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1268
	All compositions are autonomous:
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1269
	Compose an empty scene
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1270
	Create a scene containing a screen sized element 
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1271
	Compose scene
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1272
	Set the destination rectangle smaller than screen size
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1273
	Compose the scene
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1274
	Set the destination rectangle back to screen size
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1275
	Compose the scene
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1276
@SYMTestExpectedResults
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1277
	The scenes with the element of full screen destination rectangle should be fastpathed	
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1278
	The scene with the element of smaller destination rectangle should not be fastpathed
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1279
*/
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1280
void COpenwfTest::GRAPHICS_OPENWFC_FASTPATH_0007L()
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1281
	{
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1282
    iTestName = _L("FASTPATH_0007");
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1283
    INFO_PRINTF2(_L("GRAPHICS_OPENWFC_%SL()"),&iTestName);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1284
    LOGL((_L("OpenWFTest: GRAPHICS_OPENWFC_%SL()"),&iTestName));
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1285
    SetupEmptySceneL();
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1286
	
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1287
	TSurfaceId surface=iUtility->CreateSurfaceL(TSize(iFastpathableWidth,iFastpathableHeight),
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1288
												iFastpathablePixelFormat,
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1289
												iStride, iContiguous, iMaxBuffers);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1290
	ASSERT_FALSE(surface.IsNull());
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1291
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1292
	WFCSource fpSource = wfcCreateSourceFromStream(iDevice, iContext,reinterpret_cast<WFCNativeStreamType>(&surface), NULL);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1293
	TInt err = iUtility->SubmitUpdate(surface, 0, NULL);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1294
	ASSERT_EQUALS(err,KErrNone);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1295
	WFCElement fpElement = wfcCreateElement(iDevice, iContext, NULL);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1296
	wfcSetElementAttribi(iDevice, fpElement, WFC_ELEMENT_SOURCE, fpSource);	
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1297
	wfcSetElementAttribiv(iDevice, fpElement, WFC_ELEMENT_SOURCE_RECTANGLE, 4, iFullScreenRect);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1298
	//NOT full screen destination
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1299
    wfcSetElementAttribiv(iDevice, fpElement, WFC_ELEMENT_DESTINATION_RECTANGLE, 4, iCenterRect);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1300
	
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1301
#ifdef BREAKPOINT_FASTPATH
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1302
    __BREAKPOINT();
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1303
#endif
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1304
	wfcInsertElement(iDevice, fpElement, WFC_INVALID_HANDLE);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1305
    LOG(("OpenWFTest: Expecting COMPOSITION after next commit"));
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1306
	wfcCommit(iDevice, iContext, WFC_TRUE);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1307
	wfcFence(iDevice, iContext, iEGLDisplay, iSync);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1308
	ASSERT_EQUALS(eglClientWaitSyncKHR(iEGLDisplay,iSync,0,(EGLTimeKHR)EGL_FOREVER_KHR),EGL_CONDITION_SATISFIED_KHR);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1309
	LOG(("OpenWFTest: Fastpath - still OFF"));
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1310
	
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1311
	iUtility->FillSurfaceL(surface, 0, KGreen);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1312
	err = iUtility->SubmitUpdate(surface, 0, NULL);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1313
	ASSERT_EQUALS(err,KErrNone);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1314
	WaitL(iCompositionPause);	
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1315
 
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1316
    ASSERT_TRUE(AcquireOnScreenStream());
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1317
    ASSERT_TRUE(CheckOnScreenReferenceImage());
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1318
    ASSERT_TRUE(CheckOnScreenStreamRect(iCenterTRect,KGreen,iTolerance));
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1319
    ReleaseOnScreenStream();
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1320
	
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1321
	//NOW set full screen
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1322
	wfcSetElementAttribiv(iDevice, fpElement, WFC_ELEMENT_DESTINATION_RECTANGLE, 4, iFullScreenRect);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1323
	
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1324
#ifdef BREAKPOINT_FASTPATH
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1325
    __BREAKPOINT();
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1326
#endif
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1327
    LOG(("OpenWFTest: Expecting FASTPATH after next commit"));
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1328
	wfcCommit(iDevice, iContext, WFC_TRUE);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1329
	wfcFence(iDevice, iContext, iEGLDisplay, iSync);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1330
	ASSERT_EQUALS(eglClientWaitSyncKHR(iEGLDisplay,iSync,0,(EGLTimeKHR)EGL_FOREVER_KHR),EGL_CONDITION_SATISFIED_KHR);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1331
	WaitL(iCompositionPause);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1332
 
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1333
    ASSERT_TRUE(AcquireOnScreenStream());
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1334
    ASSERT_TRUE(CheckOnScreenReferenceImage());
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1335
    ASSERT_TRUE(CheckOnScreenStreamRect(iFullScreenTRect,KGreen,iTolerance));
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1336
    ReleaseOnScreenStream();
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1337
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1338
    ASSERT_EQUALS(wfcGetError(iDevice),WFC_ERROR_NONE);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1339
	wfcDestroySource(iDevice, fpSource);  
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1340
	}
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1341
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1342
//NOTIFICATION TESTS
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1343
void COpenwfTest::FastpathNotificationsTestL(TBool aAutonomous)
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1344
	{
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1345
    SetupEmptySceneL(aAutonomous);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1346
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1347
    //Create 3 elements A+C fastpathable, B centered
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1348
    TSurfaceId surfaceA = iUtility->CreateSurfaceL(TSize(iFastpathableWidth,iFastpathableHeight),
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1349
                                                iFastpathablePixelFormat,
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1350
                                                iStride, iContiguous, iMaxBuffers);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1351
    ASSERT_FALSE(surfaceA.IsNull());
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1352
    WFCSource sourceA = wfcCreateSourceFromStream(iDevice, iContext, reinterpret_cast<WFCNativeStreamType>(&surfaceA), NULL);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1353
    TInt err = iUtility->SubmitUpdate(surfaceA, 0, NULL);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1354
    ASSERT_EQUALS(err,KErrNone);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1355
    WFCElement elementA = wfcCreateElement(iDevice, iContext, NULL);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1356
    wfcSetElementAttribi(iDevice, elementA, WFC_ELEMENT_SOURCE, sourceA);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1357
    wfcSetElementAttribiv(iDevice, elementA, WFC_ELEMENT_SOURCE_RECTANGLE, 4, iFullScreenRect);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1358
    wfcSetElementAttribiv(iDevice, elementA, WFC_ELEMENT_DESTINATION_RECTANGLE, 4, iFullScreenRect);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1359
    
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1360
    TSurfaceId surfaceB = iUtility->CreateSurfaceL(TSize(iFastpathableWidth/2,iFastpathableHeight/2),
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1361
                                                iFastpathablePixelFormat,
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1362
                                                iStride, iContiguous, iMaxBuffers);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1363
    ASSERT_FALSE(surfaceB.IsNull());
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1364
    WFCSource sourceB = wfcCreateSourceFromStream(iDevice, iContext, reinterpret_cast<WFCNativeStreamType>(&surfaceB), NULL);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1365
    err = iUtility->SubmitUpdate(surfaceB, 0, NULL);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1366
    ASSERT_EQUALS(err,KErrNone);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1367
    WFCElement elementB = wfcCreateElement(iDevice, iContext, NULL);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1368
    wfcSetElementAttribi(iDevice, elementB, WFC_ELEMENT_SOURCE, sourceB);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1369
    wfcSetElementAttribiv(iDevice, elementB, WFC_ELEMENT_SOURCE_RECTANGLE, 4, iHalfSizeRect);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1370
    wfcSetElementAttribiv(iDevice, elementB, WFC_ELEMENT_DESTINATION_RECTANGLE, 4, iCenterRect);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1371
    
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1372
    TSurfaceId surfaceC = iUtility->CreateSurfaceL(TSize(iFastpathableWidth,iFastpathableHeight),
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1373
                                                iFastpathablePixelFormat,
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1374
                                                iStride, iContiguous, iMaxBuffers);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1375
    ASSERT_FALSE(surfaceC.IsNull());
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1376
    WFCSource sourceC = wfcCreateSourceFromStream(iDevice, iContext, reinterpret_cast<WFCNativeStreamType>(&surfaceC), NULL);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1377
    err = iUtility->SubmitUpdate(surfaceC, 0, NULL);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1378
    ASSERT_EQUALS(err,KErrNone);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1379
    WFCElement elementC = wfcCreateElement(iDevice, iContext, NULL);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1380
    wfcSetElementAttribi(iDevice, elementC, WFC_ELEMENT_SOURCE, sourceC);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1381
    wfcSetElementAttribiv(iDevice, elementC, WFC_ELEMENT_SOURCE_RECTANGLE, 4, iFullScreenRect);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1382
    wfcSetElementAttribiv(iDevice, elementC, WFC_ELEMENT_DESTINATION_RECTANGLE, 4, iFullScreenRect);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1383
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1384
    //**********STARTING ACTUAL TEST!**********
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1385
    //**********SURFACE A FASTPATHABLE**********
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1386
	//Add A to scene
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1387
    wfcInsertElement(iDevice, elementA, WFC_INVALID_HANDLE);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1388
#ifdef BREAKPOINT_FASTPATH
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1389
    __BREAKPOINT();
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1390
#endif
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1391
    LOG(("OpenWFTest: Expecting FASTPATH after next commit"));
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1392
    wfcCommit(iDevice, iContext, WFC_TRUE);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1393
    wfcFence(iDevice, iContext, iEGLDisplay, iSync);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1394
    ASSERT_EQUALS(eglClientWaitSyncKHR(iEGLDisplay,iSync,0,(EGLTimeKHR)EGL_FOREVER_KHR),EGL_CONDITION_SATISFIED_KHR);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1395
    LOG(("OpenWFTest: Fastpath - now ON"));
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1396
	//Set A buffer0 red
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1397
    iUtility->FillSurfaceL(surfaceA, 0, KRed);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1398
	//Do content update Abuff0 idisp iavail
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1399
    CActiveNotification* surfAbuff0disp = CActiveNotification::NewL(iUtility->Session(),ETrue);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1400
    CleanupStack::PushL(surfAbuff0disp);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1401
    TTimeStamp surfAbuff0time;
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1402
    CActiveNotification* surfAbuff0avail = CActiveNotification::NewL(iUtility->Session(),ETrue);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1403
    CleanupStack::PushL(surfAbuff0avail);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1404
    //iUtility->NotifyWhenDisplayed(surfAbuff0disp,surfAbuff0time);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1405
    iUtility->NotifyWhenDisplayed(surfAbuff0disp->iStatus,surfAbuff0time);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1406
    iUtility->NotifyWhenAvailable(surfAbuff0avail->iStatus); 
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1407
    err = iUtility->SubmitUpdate(surfaceA, 0, NULL);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1408
	ASSERT_EQUALS(err,KErrNone);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1409
	
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1410
    if(!aAutonomous)
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1411
    	{
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1412
        WaitL(iCompositionPause);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1413
		//Check A buff0 iDisp doesnt complete
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1414
		ASSERT_EQUALS(surfAbuff0disp->iStatus.Int(),KRequestPending);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1415
		//Check A buff0 iAvail doesnt complete
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1416
		ASSERT_EQUALS(surfAbuff0avail->iStatus.Int(),KRequestPending);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1417
		wfcCompose(iDevice, iContext, WFC_TRUE);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1418
	    wfcFence(iDevice, iContext, iEGLDisplay, iSync);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1419
	    ASSERT_EQUALS(eglClientWaitSyncKHR(iEGLDisplay,iSync,0,(EGLTimeKHR)EGL_FOREVER_KHR),EGL_CONDITION_SATISFIED_KHR);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1420
    	}
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1421
    ASSERT_TRUE(WaitForNotifications(KMaxNotificationDelay,1));
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1422
	
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1423
	//Check A buff0 iDisp completes
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1424
    ASSERT_EQUALS(surfAbuff0disp->iStatus.Int(),KErrNone);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1425
	//Check A buff0 iAvail doesnt complete
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1426
    ASSERT_EQUALS(surfAbuff0avail->iStatus.Int(),KRequestPending);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1427
    
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1428
    ASSERT_TRUE(AcquireOnScreenStream());
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1429
    ASSERT_TRUE(CheckOnScreenReferenceImage());
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1430
    ASSERT_TRUE(CheckOnScreenStreamRect(iFullScreenTRect,KRed,iTolerance));
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1431
    ReleaseOnScreenStream();
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1432
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1433
	//Set A buffer1 Yellow
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1434
    iUtility->FillSurfaceL(surfaceA, 1, KYellow);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1435
	
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1436
	//Check A buff0 iavail doesnt complete
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1437
    ASSERT_EQUALS(surfAbuff0avail->iStatus.Int(),KRequestPending);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1438
    
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1439
    ASSERT_TRUE(AcquireOnScreenStream());
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1440
    ASSERT_TRUE(CheckOnScreenReferenceImage());
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1441
	ASSERT_TRUE(CheckOnScreenStreamRect(iFullScreenTRect,KRed,iTolerance));
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1442
	ReleaseOnScreenStream();
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1443
	
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1444
	//Do content update Abuff1 idisp iavail
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1445
    CActiveNotification* surfAbuff1disp = CActiveNotification::NewL(iUtility->Session(),ETrue);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1446
    CleanupStack::PushL(surfAbuff1disp);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1447
    TTimeStamp surfAbuff1time;
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1448
    CActiveNotification* surfAbuff1avail = CActiveNotification::NewL(iUtility->Session(),ETrue);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1449
    CleanupStack::PushL(surfAbuff1avail);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1450
    iUtility->NotifyWhenDisplayed(surfAbuff1disp->iStatus,surfAbuff1time);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1451
    iUtility->NotifyWhenAvailable(surfAbuff1avail->iStatus); 
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1452
    err = iUtility->SubmitUpdate(surfaceA, 1, NULL);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1453
    ASSERT_EQUALS(err,KErrNone);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1454
    
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1455
    if(!aAutonomous)
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1456
    	{
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1457
        WaitL(iCompositionPause);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1458
		//Check A buff1 iDisp doesnt complete
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1459
		ASSERT_EQUALS(surfAbuff1disp->iStatus.Int(),KRequestPending);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1460
		//Check A buff1 iAvail doesnt complete
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1461
		ASSERT_EQUALS(surfAbuff1avail->iStatus.Int(),KRequestPending);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1462
		//Check A buff0 iAvail doesnt complete
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1463
	    ASSERT_EQUALS(surfAbuff0avail->iStatus.Int(),KRequestPending);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1464
		wfcCompose(iDevice, iContext, WFC_TRUE);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1465
	    wfcFence(iDevice, iContext, iEGLDisplay, iSync);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1466
	    ASSERT_EQUALS(eglClientWaitSyncKHR(iEGLDisplay,iSync,0,(EGLTimeKHR)EGL_FOREVER_KHR),EGL_CONDITION_SATISFIED_KHR);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1467
    	}
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1468
    ASSERT_TRUE(WaitForNotifications(KMaxNotificationDelay,2));
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1469
	
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1470
	//Check A buff1 idisp completes
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1471
    ASSERT_EQUALS(surfAbuff1disp->iStatus.Int(),KErrNone);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1472
	//Check A buff0 iAvail completes
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1473
    ASSERT_EQUALS(surfAbuff0avail->iStatus.Int(),KErrNone);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1474
	//Check A buff1 iAvail doesnt complete
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1475
    ASSERT_EQUALS(surfAbuff1avail->iStatus.Int(),KRequestPending);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1476
    
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1477
    ASSERT_TRUE(AcquireOnScreenStream());
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1478
    ASSERT_TRUE(CheckOnScreenReferenceImage());
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1479
	ASSERT_TRUE(CheckOnScreenStreamRect(iFullScreenTRect,KYellow,iTolerance));
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1480
	ReleaseOnScreenStream();
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1481
	
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1482
	//**********SURFACE B NOT VISIBLE**********
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1483
	//Add surfaceB to scene behind surfaceA
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1484
    wfcInsertElement(iDevice, elementB, WFC_INVALID_HANDLE);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1485
#ifdef BREAKPOINT_FASTPATH
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1486
    __BREAKPOINT();
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1487
#endif
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1488
    LOG(("OpenWFTest: Expecting FASTPATH after next commit"));
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1489
	wfcCommit(iDevice, iContext, WFC_TRUE);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1490
    wfcFence(iDevice, iContext, iEGLDisplay, iSync);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1491
    ASSERT_EQUALS(eglClientWaitSyncKHR(iEGLDisplay,iSync,0,(EGLTimeKHR)EGL_FOREVER_KHR),EGL_CONDITION_SATISFIED_KHR);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1492
    LOG(("OpenWFTest: Fastpath - still ON"));
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1493
	//Set B buffer0 green
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1494
    iUtility->FillSurfaceL(surfaceB, 0, KGreen);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1495
	//Do content update idisp iavail
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1496
    CActiveNotification* surfBbuff0disp = CActiveNotification::NewL(iUtility->Session(),ETrue);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1497
    CleanupStack::PushL(surfBbuff0disp);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1498
    TTimeStamp surfBbuff0time;
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1499
    CActiveNotification* surfBbuff0avail = CActiveNotification::NewL(iUtility->Session(),ETrue);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1500
    CleanupStack::PushL(surfBbuff0avail);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1501
    iUtility->NotifyWhenDisplayed(surfBbuff0disp->iStatus,surfBbuff0time);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1502
    iUtility->NotifyWhenAvailable(surfBbuff0avail->iStatus); 
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1503
    err = iUtility->SubmitUpdate(surfaceB, 0, NULL);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1504
	ASSERT_EQUALS(err,KErrNone);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1505
	
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1506
    if(!aAutonomous)
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1507
    	{
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1508
        WaitL(iCompositionPause);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1509
		//Check B buff0 iAvail doesnt complete
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1510
		ASSERT_EQUALS(surfBbuff0avail->iStatus.Int(),KRequestPending);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1511
		//Check B buff0 iDisp doesnt complete
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1512
		ASSERT_EQUALS(surfBbuff0disp->iStatus.Int(),KRequestPending);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1513
		//Check A buff1 iAvail doesnt complete
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1514
		ASSERT_EQUALS(surfAbuff1avail->iStatus.Int(),KRequestPending);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1515
		wfcCompose(iDevice, iContext, WFC_TRUE);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1516
	    wfcFence(iDevice, iContext, iEGLDisplay, iSync);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1517
	    ASSERT_EQUALS(eglClientWaitSyncKHR(iEGLDisplay,iSync,0,(EGLTimeKHR)EGL_FOREVER_KHR),EGL_CONDITION_SATISFIED_KHR);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1518
    	}
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1519
    ASSERT_TRUE(WaitForNotifications(KMaxNotificationDelay,1));
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1520
    
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1521
	//Check B buff0 idisp completes - could be no error or not visible
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1522
    ASSERT_TRUE((surfBbuff0disp->iStatus.Int()==KErrNotVisible)||(surfBbuff0disp->iStatus.Int()==KErrNone));
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1523
	//Check B buff0 iavail doesnt complete
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1524
    ASSERT_EQUALS(surfBbuff0avail->iStatus.Int(),KRequestPending);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1525
	//Check A buff1 iavail doesnt complete
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1526
    ASSERT_EQUALS(surfAbuff1avail->iStatus.Int(),KRequestPending);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1527
	
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1528
	//Set B buffer1 blue
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1529
	iUtility->FillSurfaceL(surfaceB, 1, KBlue);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1530
	//Do content update idisp iavail
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1531
    CActiveNotification* surfBbuff1disp = CActiveNotification::NewL(iUtility->Session(),ETrue);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1532
    CleanupStack::PushL(surfBbuff1disp);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1533
    TTimeStamp surfBbuff1time;
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1534
    CActiveNotification* surfBbuff1avail = CActiveNotification::NewL(iUtility->Session(),ETrue);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1535
    CleanupStack::PushL(surfBbuff1avail);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1536
    iUtility->NotifyWhenDisplayed(surfBbuff1disp->iStatus,surfBbuff1time);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1537
    iUtility->NotifyWhenAvailable(surfBbuff1avail->iStatus); 
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1538
    err = iUtility->SubmitUpdate(surfaceB, 1, NULL);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1539
    ASSERT_EQUALS(err,KErrNone);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1540
    
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1541
    if(!aAutonomous)
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1542
    	{
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1543
        WaitL(iCompositionPause);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1544
		//Check B buff1 iAvail doesnt complete
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1545
		ASSERT_EQUALS(surfBbuff1avail->iStatus.Int(),KRequestPending);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1546
		//Check B buff1 iDisp doesnt complete
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1547
		ASSERT_EQUALS(surfBbuff1disp->iStatus.Int(),KRequestPending);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1548
		//Check B buff0 iAvail doesnt complete
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1549
		ASSERT_EQUALS(surfBbuff0avail->iStatus.Int(),KRequestPending);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1550
		//Check A buff1 iAvail doesnt complete
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1551
		ASSERT_EQUALS(surfAbuff1avail->iStatus.Int(),KRequestPending);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1552
		wfcCompose(iDevice, iContext, WFC_TRUE);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1553
	    wfcFence(iDevice, iContext, iEGLDisplay, iSync);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1554
	    ASSERT_EQUALS(eglClientWaitSyncKHR(iEGLDisplay,iSync,0,(EGLTimeKHR)EGL_FOREVER_KHR),EGL_CONDITION_SATISFIED_KHR);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1555
    	}
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1556
    ASSERT_TRUE(WaitForNotifications(KMaxNotificationDelay,2));
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1557
    
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1558
    //Check B buff1 idisp completes - could be no error or not visible
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1559
    ASSERT_TRUE((surfBbuff1disp->iStatus.Int()==KErrNotVisible)||(surfBbuff1disp->iStatus.Int()==KErrNone));
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1560
	//Check B buff1 iavail doesnt complete
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1561
    ASSERT_EQUALS(surfBbuff1avail->iStatus.Int(),KRequestPending);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1562
	//Check B buff0 iavail completes - could be no error or not visible
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1563
    ASSERT_TRUE((surfBbuff0avail->iStatus.Int()==KErrNotVisible)||(surfBbuff0avail->iStatus.Int()==KErrNone));
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1564
	//Check A buff1 iavail doesnt complete
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1565
    ASSERT_EQUALS(surfAbuff1avail->iStatus.Int(),KRequestPending);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1566
    
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1567
    ASSERT_TRUE(AcquireOnScreenStream());
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1568
    ASSERT_TRUE(CheckOnScreenReferenceImage());
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1569
	ASSERT_TRUE(CheckOnScreenStreamRect(iFullScreenTRect,KYellow,iTolerance));
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1570
	ReleaseOnScreenStream();
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1571
	
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1572
	//**********SURFACE C ALSO FASTPATHABLE**********
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1573
	//Add C to scene in front of surfaceA
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1574
    wfcInsertElement(iDevice, elementC, elementA);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1575
#ifdef BREAKPOINT_FASTPATH
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1576
    __BREAKPOINT();
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1577
#endif
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1578
    LOG(("OpenWFTest: Expecting FASTPATH after next commit"));
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1579
	wfcCommit(iDevice, iContext, WFC_TRUE);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1580
    wfcFence(iDevice, iContext, iEGLDisplay, iSync);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1581
    ASSERT_EQUALS(eglClientWaitSyncKHR(iEGLDisplay,iSync,0,(EGLTimeKHR)EGL_FOREVER_KHR),EGL_CONDITION_SATISFIED_KHR);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1582
    LOG(("OpenWFTest: Fastpath - still ON"));
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1583
	//Set C to brown
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1584
    iUtility->FillSurfaceL(surfaceC, 0, KBrown);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1585
	//Do content update Cbuff0 idisp iavail
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1586
    CActiveNotification* surfCbuff0disp = CActiveNotification::NewL(iUtility->Session(),ETrue);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1587
    CleanupStack::PushL(surfCbuff0disp);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1588
    TTimeStamp surfCbuff0time;
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1589
    CActiveNotification* surfCbuff0avail = CActiveNotification::NewL(iUtility->Session(),ETrue);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1590
    CleanupStack::PushL(surfCbuff0avail);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1591
    iUtility->NotifyWhenDisplayed(surfCbuff0disp->iStatus,surfCbuff0time);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1592
    iUtility->NotifyWhenAvailable(surfCbuff0avail->iStatus); 
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1593
    err = iUtility->SubmitUpdate(surfaceC, 0, NULL);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1594
	ASSERT_EQUALS(err,KErrNone);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1595
	
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1596
    if(!aAutonomous)
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1597
    	{
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1598
        WaitL(iCompositionPause);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1599
		//Check C buff0 iAvail doesnt complete
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1600
		ASSERT_EQUALS(surfCbuff0avail->iStatus.Int(),KRequestPending);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1601
		//Check C buff0 iDisp doesnt complete
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1602
		ASSERT_EQUALS(surfCbuff0disp->iStatus.Int(),KRequestPending);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1603
		//Check B buff1 iAvail doesnt complete
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1604
		ASSERT_EQUALS(surfBbuff1avail->iStatus.Int(),KRequestPending);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1605
		//Check A buff1 iAvail doesnt complete
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1606
		ASSERT_EQUALS(surfAbuff1avail->iStatus.Int(),KRequestPending);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1607
		wfcCompose(iDevice, iContext, WFC_TRUE);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1608
	    wfcFence(iDevice, iContext, iEGLDisplay, iSync);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1609
	    ASSERT_EQUALS(eglClientWaitSyncKHR(iEGLDisplay,iSync,0,(EGLTimeKHR)EGL_FOREVER_KHR),EGL_CONDITION_SATISFIED_KHR);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1610
    	}
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1611
    ASSERT_TRUE(WaitForNotifications(KMaxNotificationDelay,1));
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1612
    
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1613
	//Check C buff0 idisp completes
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1614
    ASSERT_EQUALS(surfCbuff0disp->iStatus.Int(),KErrNone);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1615
	//Check C buff0 iavail does not complete
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1616
    ASSERT_EQUALS(surfCbuff0avail->iStatus.Int(),KRequestPending);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1617
	//Check B buff1 iavail doesnt complete
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1618
    ASSERT_EQUALS(surfBbuff1avail->iStatus.Int(),KRequestPending);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1619
	//Check A buff1 iavail doesnt complete
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1620
    ASSERT_EQUALS(surfAbuff1avail->iStatus.Int(),KRequestPending);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1621
    
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1622
    ASSERT_TRUE(AcquireOnScreenStream());
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1623
    ASSERT_TRUE(CheckOnScreenReferenceImage());
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1624
	ASSERT_TRUE(CheckOnScreenStreamRect(iFullScreenTRect,KBrown,iTolerance));
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1625
	ReleaseOnScreenStream();
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1626
	
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1627
	//Set C buffer1 grey
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1628
    iUtility->FillSurfaceL(surfaceC, 1, KGray);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1629
	//Do content update Cbuff1 idisp iavail
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1630
    CActiveNotification* surfCbuff1disp = CActiveNotification::NewL(iUtility->Session(),ETrue);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1631
    CleanupStack::PushL(surfCbuff1disp);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1632
    TTimeStamp surfCbuff1time;
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1633
    CActiveNotification* surfCbuff1avail = CActiveNotification::NewL(iUtility->Session(),ETrue);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1634
    CleanupStack::PushL(surfCbuff1avail);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1635
    iUtility->NotifyWhenDisplayed(surfCbuff1disp->iStatus,surfCbuff1time);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1636
    iUtility->NotifyWhenAvailable(surfCbuff1avail->iStatus); 
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1637
    err = iUtility->SubmitUpdate(surfaceC, 1, NULL);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1638
    ASSERT_EQUALS(err,KErrNone);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1639
    
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1640
    if(!aAutonomous)
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1641
    	{
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1642
        WaitL(iCompositionPause);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1643
		//Check C buff1 iAvail doesnt complete
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1644
		ASSERT_EQUALS(surfCbuff1avail->iStatus.Int(),KRequestPending);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1645
		//Check C buff1 iDisp doesnt complete
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1646
		ASSERT_EQUALS(surfCbuff1disp->iStatus.Int(),KRequestPending);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1647
		//Check C buff0 iAvail doesnt complete
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1648
		ASSERT_EQUALS(surfCbuff0avail->iStatus.Int(),KRequestPending);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1649
		//Check B buff1 iAvail doesnt complete
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1650
		ASSERT_EQUALS(surfBbuff1avail->iStatus.Int(),KRequestPending);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1651
		//Check A buff1 iAvail doesnt complete
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1652
		ASSERT_EQUALS(surfAbuff1avail->iStatus.Int(),KRequestPending);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1653
		wfcCompose(iDevice, iContext, WFC_TRUE);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1654
	    wfcFence(iDevice, iContext, iEGLDisplay, iSync);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1655
	    ASSERT_EQUALS(eglClientWaitSyncKHR(iEGLDisplay,iSync,0,(EGLTimeKHR)EGL_FOREVER_KHR),EGL_CONDITION_SATISFIED_KHR);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1656
    	}
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1657
    ASSERT_TRUE(WaitForNotifications(KMaxNotificationDelay,2));
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1658
    
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1659
	//Check C buff1 idisp completes
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1660
    ASSERT_EQUALS(surfCbuff1disp->iStatus.Int(),KErrNone);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1661
	//Check C buff1 iavail does not complete
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1662
    ASSERT_EQUALS(surfCbuff1avail->iStatus.Int(),KRequestPending);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1663
	//Check C buff0 iavail completes
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1664
    ASSERT_EQUALS(surfCbuff0avail->iStatus.Int(),KErrNone);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1665
	//Check B buff1 iavail doesnt complete
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1666
    ASSERT_EQUALS(surfBbuff1avail->iStatus.Int(),KRequestPending);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1667
	//Check A buff1 iavail doesnt complete
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1668
    ASSERT_EQUALS(surfAbuff1avail->iStatus.Int(),KRequestPending);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1669
    
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1670
    ASSERT_TRUE(AcquireOnScreenStream());
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1671
    ASSERT_TRUE(CheckOnScreenReferenceImage());
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1672
	ASSERT_TRUE(CheckOnScreenStreamRect(iFullScreenTRect,KGray,iTolerance));
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1673
	ReleaseOnScreenStream();
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1674
	
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1675
    //**********SURFACE A BACK TO FRONT**********
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1676
	//Move A to the front
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1677
    wfcInsertElement(iDevice, elementA, elementC);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1678
#ifdef BREAKPOINT_FASTPATH
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1679
    __BREAKPOINT();
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1680
#endif
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1681
    LOG(("OpenWFTest: Expecting FASTPATH after next commit"));
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1682
	wfcCommit(iDevice, iContext, WFC_TRUE);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1683
    wfcFence(iDevice, iContext, iEGLDisplay, iSync);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1684
    ASSERT_EQUALS(eglClientWaitSyncKHR(iEGLDisplay,iSync,0,(EGLTimeKHR)EGL_FOREVER_KHR),EGL_CONDITION_SATISFIED_KHR);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1685
    LOG(("OpenWFTest: Fastpath - still ON"));
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1686
	//Set A buffer0 magenta
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1687
    iUtility->FillSurfaceL(surfaceA, 0, KMagenta);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1688
	//Do content update Abuff0 idisp iavail
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1689
    surfAbuff0disp->Activate();
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1690
    surfAbuff0avail->Activate();
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1691
    iUtility->NotifyWhenDisplayed(surfAbuff0disp->iStatus,surfAbuff0time);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1692
    iUtility->NotifyWhenAvailable(surfAbuff0avail->iStatus); 
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1693
    err = iUtility->SubmitUpdate(surfaceA, 0, NULL);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1694
	ASSERT_EQUALS(err,KErrNone);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1695
	
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1696
    if(!aAutonomous)
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1697
    	{
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1698
        WaitL(iCompositionPause);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1699
		//Check A buff0 iAvail doesnt complete
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1700
		ASSERT_EQUALS(surfAbuff0avail->iStatus.Int(),KRequestPending);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1701
		//Check A buff0 iDisp doesnt complete
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1702
		ASSERT_EQUALS(surfAbuff0disp->iStatus.Int(),KRequestPending);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1703
		//Check C buff1 iAvail doesnt complete
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1704
		ASSERT_EQUALS(surfCbuff1avail->iStatus.Int(),KRequestPending);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1705
		//Check B buff1 iAvail doesnt complete
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1706
		ASSERT_EQUALS(surfBbuff1avail->iStatus.Int(),KRequestPending);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1707
		//Check A buff1 iAvail doesnt complete
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1708
		ASSERT_EQUALS(surfAbuff1avail->iStatus.Int(),KRequestPending);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1709
		wfcCompose(iDevice, iContext, WFC_TRUE);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1710
	    wfcFence(iDevice, iContext, iEGLDisplay, iSync);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1711
	    ASSERT_EQUALS(eglClientWaitSyncKHR(iEGLDisplay,iSync,0,(EGLTimeKHR)EGL_FOREVER_KHR),EGL_CONDITION_SATISFIED_KHR);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1712
    	}
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1713
    ASSERT_TRUE(WaitForNotifications(KMaxNotificationDelay,2));
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1714
    
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1715
	//Check A buff0 idisp completes
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1716
    ASSERT_EQUALS(surfAbuff0disp->iStatus.Int(),KErrNone);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1717
	//Check A buff0 iavail does not complete
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1718
    ASSERT_EQUALS(surfAbuff0avail->iStatus.Int(),KRequestPending);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1719
	//Check A buff1 iavail does complete
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1720
    ASSERT_EQUALS(surfAbuff1avail->iStatus.Int(),KErrNone);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1721
	//Check C buff1 iavail does not complete
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1722
    ASSERT_EQUALS(surfCbuff1avail->iStatus.Int(),KRequestPending);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1723
	//Check B buff1 iavail doesnt complete
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1724
    ASSERT_EQUALS(surfBbuff1avail->iStatus.Int(),KRequestPending);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1725
    
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1726
    ASSERT_TRUE(AcquireOnScreenStream());
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1727
    ASSERT_TRUE(CheckOnScreenReferenceImage());
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1728
	ASSERT_TRUE(CheckOnScreenStreamRect(iFullScreenTRect,KMagenta,iTolerance));
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1729
	ReleaseOnScreenStream();
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1730
    
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1731
    //**********SURFACE B TO FRONT - STOPS FASTPATH HAPPENING**********
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1732
    //Move B to the front
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1733
	wfcInsertElement(iDevice, elementB, elementA);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1734
#ifdef BREAKPOINT_FASTPATH
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1735
    __BREAKPOINT();
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1736
#endif
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1737
    LOG(("OpenWFTest: Expecting COMPOSITION after next commit"));
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1738
	wfcCommit(iDevice, iContext, WFC_TRUE);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1739
    wfcFence(iDevice, iContext, iEGLDisplay, iSync);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1740
    ASSERT_EQUALS(eglClientWaitSyncKHR(iEGLDisplay,iSync,0,(EGLTimeKHR)EGL_FOREVER_KHR),EGL_CONDITION_SATISFIED_KHR);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1741
    LOG(("OpenWFTest: Fastpath - now OFF..."));
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1742
	//Set B buffer0 dark red
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1743
	iUtility->FillSurfaceL(surfaceB, 0, KDarkRed);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1744
	//Do content update Abuff0 idisp iavail
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1745
	surfBbuff0disp->Activate();
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1746
	surfBbuff0avail->Activate();
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1747
	iUtility->NotifyWhenDisplayed(surfBbuff0disp->iStatus,surfBbuff0time);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1748
	iUtility->NotifyWhenAvailable(surfBbuff0avail->iStatus); 
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1749
	err = iUtility->SubmitUpdate(surfaceB, 0, NULL);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1750
	ASSERT_EQUALS(err,KErrNone);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1751
	
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1752
    if(!aAutonomous)
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1753
    	{
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1754
        WaitL(iCompositionPause);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1755
		//Check B buff0 iAvail doesnt complete
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1756
		ASSERT_EQUALS(surfBbuff0avail->iStatus.Int(),KRequestPending);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1757
		//Check B buff0 iDisp doesnt complete
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1758
		ASSERT_EQUALS(surfBbuff0disp->iStatus.Int(),KRequestPending);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1759
		//Check A buff0 iAvail doesnt complete
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1760
		ASSERT_EQUALS(surfAbuff0avail->iStatus.Int(),KRequestPending);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1761
		//Check C buff1 iAvail doesnt complete
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1762
		ASSERT_EQUALS(surfCbuff1avail->iStatus.Int(),KRequestPending);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1763
		//Check B buff1 iAvail doesnt complete
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1764
		ASSERT_EQUALS(surfBbuff1avail->iStatus.Int(),KRequestPending);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1765
		wfcCompose(iDevice, iContext, WFC_TRUE);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1766
	    wfcFence(iDevice, iContext, iEGLDisplay, iSync);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1767
	    ASSERT_EQUALS(eglClientWaitSyncKHR(iEGLDisplay,iSync,0,(EGLTimeKHR)EGL_FOREVER_KHR),EGL_CONDITION_SATISFIED_KHR);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1768
    	}
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1769
    ASSERT_TRUE(WaitForNotifications(KMaxNotificationDelay,2));
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1770
	
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1771
	//Check B buff0 iAvail doesnt complete
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1772
	ASSERT_EQUALS(surfBbuff0avail->iStatus.Int(),KRequestPending);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1773
	//Check B buff0 iDisp completes
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1774
	ASSERT_EQUALS(surfBbuff0disp->iStatus.Int(),KErrNone);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1775
	//Check A buff0 iAvail doesnt complete
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1776
	ASSERT_EQUALS(surfAbuff0avail->iStatus.Int(),KRequestPending);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1777
	//Check C buff1 iAvail doesnt complete
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1778
	ASSERT_EQUALS(surfCbuff1avail->iStatus.Int(),KRequestPending);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1779
	//Check B buff1 iAvail completes
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1780
	ASSERT_EQUALS(surfBbuff1avail->iStatus.Int(),KErrNone);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1781
	
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1782
    ASSERT_TRUE(AcquireOnScreenStream());
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1783
    ASSERT_TRUE(CheckOnScreenReferenceImage());
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1784
	//Check dark red center of screen
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1785
	ASSERT_TRUE(CheckOnScreenStreamRect(iCenterTRect,KDarkRed,iTolerance));
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1786
	//Check magenta around the borders
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1787
	ASSERT_TRUE(CheckOnScreenStreamRect(TRect(0,0,iCenterTRect.iTl.iX,iCenterTRect.iTl.iY),KMagenta,iTolerance));
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1788
	ASSERT_TRUE(CheckOnScreenStreamRect(TRect(iCenterTRect.iBr.iX+1,iCenterTRect.iBr.iY+1,
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1789
			iFastpathableWidth,iFastpathableHeight),KMagenta,iTolerance));
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1790
	ReleaseOnScreenStream();
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1791
	
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1792
	ASSERT_EQUALS(wfcGetError(iDevice),WFC_ERROR_NONE);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1793
    
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1794
    wfcDestroySource(iDevice, sourceA);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1795
    wfcDestroySource(iDevice, sourceB);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1796
    wfcDestroySource(iDevice, sourceC);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1797
    
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1798
	CleanupStack::PopAndDestroy(12,surfAbuff0disp);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1799
	}
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1800
/*
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1801
@SYMTestCaseID			GRAPHICS-OPENWFC-FASTPATH-0010
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1802
@SYMTestCaseDesc		Positive testing - Fastpath with notification checking for autonomous composition
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1803
@SYMREQ					
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1804
@SYMPREQ						PREQ417-54885
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1805
@SYMTestType				Integration Test
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1806
@SYMTestPriority		High
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1807
@SYMTestPurpose			Check fastpath does not cause any problem to notifications
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1808
@SYMTestActions			
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1809
	Autonomous composition
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1810
	All elements created are double buffered and opaque:
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1811
	Compose an empty scene
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1812
	
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1813
	A) Create a scene containing a screen sized element A
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1814
	Fill buffer 0 of element A with red colour 
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1815
	Submit the scene
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1816
	Do content update of buffer 0 for available (iAvailable) and display time (iDisplayed)
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1817
	Compose the scene, iDisplayed for buffer 0 should complete
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1818
	
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1819
	Fill buffer 1 of element A with yellow colour
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1820
	Do content update of buffer 1 
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1821
	Compose the scene, iDisplayed for buffer 1 should complete
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1822
	Wait for iAvailable of buffer 0 to complete	
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1823
	(iAvailable of buffer 1 will not complete until further content update)	
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1824
	
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1825
	B) Add a new element B of smaller non fastpathable size behind element A
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1826
	Fill buffer 0 of element B with green colour
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1827
	Submit the scene
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1828
	Do content update of buffer 0 of element B 
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1829
	Compose the scene, iDisplayed for buffer 0 of element B should not complete
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1830
	iAvailable for buffer 1 of element A should not complete
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1831
		
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1832
	Fill buffer 1 of element B with blue colour
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1833
	Do content update of buffer 1 of element B 
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1834
	Wait for iDisplay to complete (possibly with KErrNotVisible)
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1835
	Wait for iAvailable for buffer 0 of element B to complete (possibly with KErrNotVisible)
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1836
	
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1837
	C) Add a new screen size element C in front of A and B
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1838
	Fill buffer 0 of element C to be brown
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1839
	Do content update of buffer 0 of element C 
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1840
	Compose the scene, iDisplayed of buffer 0 of element C should complete
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1841
	iAvailable of buffer 1 of element B should not complete
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1842
	
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1843
	Fill buffer 1 of element C with grey colour
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1844
	Do content update of buffer 1 of element C 
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1845
	Compose the scene, iDisplayed of buffer 1 of element C should complete
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1846
	Wait for iAvailable of buffer 0 of element C to complete
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1847
		
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1848
	D) Move element A to the front
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1849
	Fill buffer 0 of element A with magenta colour
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1850
	Do content update of buffer 0 of element A 
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1851
	Compose the scene, iDisplayed for buffer 0 of element A should complete
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1852
	Wait for iAvailable of buffer 1 of element A to complete
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1853
	iAvailable of buffer 1 of element C should not complete
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1854
	
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1855
	E) Move element B to the front *NOW NOT FASTPATHING*
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1856
	Fill buffer 0 of element B with dark red colour
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1857
	Do content update of buffer 0 of element B
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1858
	Compose the scene, iDisplayed for buffer 0 of element B should complete
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1859
	Wait for iAvailable of buffer 1 of element B to complete
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1860
	iAvailable of buffer 1 of element C should not complete
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1861
	iAvailable of buffer 0 of element A should not complete
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1862
		
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1863
@SYMTestExpectedResults
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1864
	All composition should trigger fastpath 
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1865
	Request status checks iAvailable and iDisplayed should be set to KErrNone every time.	
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1866
	Screen colour should change in the sequence of red, yellow, brown, grey, magenta
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1867
*/
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1868
void COpenwfTest::GRAPHICS_OPENWFC_FASTPATH_0010L()
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1869
	{
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1870
    iTestName = _L("FASTPATH_0010");
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1871
    INFO_PRINTF2(_L("GRAPHICS_OPENWFC_%SL()"),&iTestName);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1872
    LOGL((_L("OpenWFTest: GRAPHICS_OPENWFC_%SL()"),&iTestName));
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1873
    FastpathNotificationsTestL(ETrue);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1874
	}
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1875
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1876
/*
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1877
@SYMTestCaseID			GRAPHICS-OPENWFC-FASTPATH-0011
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1878
@SYMTestCaseDesc		Positive testing - Fastpath with notification checking for non-autonomous composition
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1879
@SYMREQ					
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1880
@SYMPREQ						PREQ417-54885
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1881
@SYMTestType				Integration Test
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1882
@SYMTestPriority		High
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1883
@SYMTestPurpose			Check fastpath does not cause any problem to notifications
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1884
@SYMTestActions			
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1885
	A repeat of GRAPHICS-OPENWFC-FASTPATH-0010 but with non autonomous composition
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1886
	
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1887
	Where possible TRequestStatuses are additionally checked after submit updates and before
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1888
	explicit wfcCompose calls are made.
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1889
	
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1890
@SYMTestExpectedResults
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1891
	Just commit should not trigger any changes to the scene or notifications to complete
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1892
	Just content updates should not trigger any changes to the scene or notifications to complete
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1893
	Only after Commit, Content update and Force compose should things happen.
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1894
	Request status checks iAvailable and iDisplayed should be completed.
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1895
	Screen colour should change in the sequence of red, yellow, green, blue, brown and grey
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1896
*/
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1897
void COpenwfTest::GRAPHICS_OPENWFC_FASTPATH_0011L()
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1898
	{
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1899
    iTestName = _L("FASTPATH_0011");
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1900
    INFO_PRINTF2(_L("GRAPHICS_OPENWFC_%SL()"),&iTestName);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1901
    LOGL((_L("OpenWFTest: GRAPHICS_OPENWFC_%SL()"),&iTestName));
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1902
    FastpathNotificationsTestL(EFalse);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1903
	}
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1904
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1905
//NOTIFICATION TESTS
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1906
void COpenwfTest::FastpathDispXNotificationsTestL(TBool aAutonomous)
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1907
	{
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1908
    SetupEmptySceneL(aAutonomous);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1909
    if (aAutonomous)
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1910
        {   //if we have manual pauses the test will complete early
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1911
        iAllowManualPause = EFalse;
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1912
        }
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1913
	
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1914
	//Create 2 fastpathable elements
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1915
    TSurfaceId surfaceA = iUtility->CreateSurfaceL(TSize(iFastpathableWidth,iFastpathableHeight),
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1916
                                                iFastpathablePixelFormat,
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1917
                                                iStride, iContiguous, iMaxBuffers);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1918
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1919
    ASSERT_FALSE(surfaceA.IsNull());
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1920
    WFCSource sourceA = wfcCreateSourceFromStream(iDevice, iContext, reinterpret_cast<WFCNativeStreamType>(&surfaceA), NULL);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1921
    TInt err = iUtility->SubmitUpdate(surfaceA, 0, NULL);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1922
    ASSERT_EQUALS(err,KErrNone);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1923
    WFCElement elementA = wfcCreateElement(iDevice, iContext, NULL);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1924
    wfcSetElementAttribi(iDevice, elementA, WFC_ELEMENT_SOURCE, sourceA);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1925
    wfcSetElementAttribiv(iDevice, elementA, WFC_ELEMENT_SOURCE_RECTANGLE, 4, iFullScreenRect);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1926
    wfcSetElementAttribiv(iDevice, elementA, WFC_ELEMENT_DESTINATION_RECTANGLE, 4, iFullScreenRect);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1927
    
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1928
    TSurfaceId surfaceB = iUtility->CreateSurfaceL(TSize(iFastpathableWidth/2,iFastpathableHeight/2),
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1929
                                                iFastpathablePixelFormat,
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1930
                                                iStride, iContiguous, iMaxBuffers);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1931
    ASSERT_FALSE(surfaceB.IsNull());
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1932
    WFCSource sourceB = wfcCreateSourceFromStream(iDevice, iContext, reinterpret_cast<WFCNativeStreamType>(&surfaceB), NULL);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1933
    err = iUtility->SubmitUpdate(surfaceB, 0, NULL);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1934
    ASSERT_EQUALS(err,KErrNone);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1935
    WFCElement elementB = wfcCreateElement(iDevice, iContext, NULL);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1936
    wfcSetElementAttribi(iDevice, elementB, WFC_ELEMENT_SOURCE, sourceB);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1937
    wfcSetElementAttribiv(iDevice, elementB, WFC_ELEMENT_SOURCE_RECTANGLE, 4, iHalfSizeRect);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1938
    wfcSetElementAttribiv(iDevice, elementB, WFC_ELEMENT_DESTINATION_RECTANGLE, 4, iCenterRect);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1939
	
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1940
	//**********STARTING ACTUAL TEST!**********
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1941
	//Add A to scene
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1942
	wfcInsertElement(iDevice, elementA, WFC_INVALID_HANDLE);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1943
#ifdef BREAKPOINT_FASTPATH
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1944
    __BREAKPOINT();
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1945
#endif
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1946
    LOG(("OpenWFTest: Expecting FASTPATH after next commit"));
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1947
	wfcCommit(iDevice, iContext, WFC_TRUE);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1948
    wfcFence(iDevice, iContext, iEGLDisplay, iSync);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1949
    ASSERT_EQUALS(eglClientWaitSyncKHR(iEGLDisplay,iSync,0,(EGLTimeKHR)EGL_FOREVER_KHR),EGL_CONDITION_SATISFIED_KHR);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1950
    LOG(("OpenWFTest: Fastpath - now ON"));
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1951
	//Set A buffer0 red
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1952
	iUtility->FillSurfaceL(surfaceA, 0, KRed);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1953
	err = iUtility->SubmitUpdate(surfaceA, 0, NULL);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1954
	ASSERT_EQUALS(err,KErrNone);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1955
    if(!aAutonomous)
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1956
    	{
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1957
		wfcCompose(iDevice, iContext, WFC_TRUE);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1958
	    wfcFence(iDevice, iContext, iEGLDisplay, iSync);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1959
	    ASSERT_EQUALS(eglClientWaitSyncKHR(iEGLDisplay,iSync,0,(EGLTimeKHR)EGL_FOREVER_KHR),EGL_CONDITION_SATISFIED_KHR);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1960
    	}
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1961
    WaitL(iCompositionPause);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1962
    
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1963
    ASSERT_TRUE(AcquireOnScreenStream());
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1964
    ASSERT_TRUE(CheckOnScreenReferenceImage());
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1965
	ASSERT_TRUE(CheckOnScreenStreamRect(iFullScreenTRect,KRed,iTolerance));
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1966
	ReleaseOnScreenStream();
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1967
	
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1968
	//Add surfaceB to scene infront of surfaceA
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1969
	wfcInsertElement(iDevice, elementB, elementA);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1970
#ifdef BREAKPOINT_FASTPATH
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1971
    __BREAKPOINT();
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1972
#endif
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1973
    LOG(("OpenWFTest: Expecting COMPOSITION after next commit"));
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1974
	wfcCommit(iDevice, iContext, WFC_TRUE);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1975
    wfcFence(iDevice, iContext, iEGLDisplay, iSync);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1976
    ASSERT_EQUALS(eglClientWaitSyncKHR(iEGLDisplay,iSync,0,(EGLTimeKHR)EGL_FOREVER_KHR),EGL_CONDITION_SATISFIED_KHR);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1977
    LOG(("OpenWFTest: Fastpath - now OFF"));
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1978
	//Set B buffer0 green
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1979
	iUtility->FillSurfaceL(surfaceB, 0, KBlue);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1980
	err = iUtility->SubmitUpdate(surfaceB, 0, NULL);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1981
	ASSERT_EQUALS(err,KErrNone);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1982
    if(!aAutonomous)
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1983
    	{
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1984
		wfcCompose(iDevice, iContext, WFC_TRUE);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1985
	    wfcFence(iDevice, iContext, iEGLDisplay, iSync);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1986
	    ASSERT_EQUALS(eglClientWaitSyncKHR(iEGLDisplay,iSync,0,(EGLTimeKHR)EGL_FOREVER_KHR),EGL_CONDITION_SATISFIED_KHR);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1987
    	}
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1988
    WaitL(iCompositionPause);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1989
    
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1990
    ASSERT_TRUE(AcquireOnScreenStream());
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1991
    ASSERT_TRUE(CheckOnScreenReferenceImage());
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1992
	//Check blue center of screen
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1993
    ASSERT_TRUE(CheckOnScreenStreamRect(iCenterTRect,KBlue,iTolerance));
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1994
	//Check red around the borders
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1995
	ASSERT_TRUE(CheckOnScreenStreamRect(TRect(0,0,iCenterTRect.iTl.iX,iCenterTRect.iTl.iY),KRed,iTolerance));
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1996
	ASSERT_TRUE(CheckOnScreenStreamRect(TRect(iCenterTRect.iBr.iX+1,iCenterTRect.iBr.iY+1,
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1997
			iFastpathableWidth,iFastpathableHeight),KRed,iTolerance));
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1998
	ReleaseOnScreenStream();
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  1999
	
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2000
	//Set A buffer1 yellow
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2001
	iUtility->FillSurfaceL(surfaceA, 1, KYellow);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2002
	//Set B buffer1 KGreen
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2003
	iUtility->FillSurfaceL(surfaceB, 1, KGreen);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2004
	
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2005
	//Do content updated surfaceA dispXtimes 10
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2006
	CActiveNotification* surfAbuff1dispX = CActiveNotification::NewL(iUtility->Session(),ETrue);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2007
	CleanupStack::PushL(surfAbuff1dispX);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2008
	iUtility->NotifyWhenDisplayedXTimes(10,surfAbuff1dispX->iStatus);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2009
	err = iUtility->SubmitUpdate(surfaceA, 1, NULL);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2010
	//Do content updated surfaceB dispXtimes 5
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2011
	CActiveNotification* surfBbuff1dispX = CActiveNotification::NewL(iUtility->Session(),ETrue);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2012
	CleanupStack::PushL(surfBbuff1dispX);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2013
	iUtility->NotifyWhenDisplayedXTimes(5,surfBbuff1dispX->iStatus);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2014
	err = iUtility->SubmitUpdate(surfaceB, 1, NULL);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2015
	
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2016
    if(!aAutonomous)
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2017
    	{
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2018
		for(TInt i=0;i<4;i++)
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2019
			{
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2020
			wfcCompose(iDevice, iContext, WFC_TRUE);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2021
		    wfcFence(iDevice, iContext, iEGLDisplay, iSync);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2022
		    ASSERT_EQUALS(eglClientWaitSyncKHR(iEGLDisplay,iSync,0,(EGLTimeKHR)EGL_FOREVER_KHR),EGL_CONDITION_SATISFIED_KHR);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2023
		    WaitL(iCompositionPause);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2024
			//Check A has not completed yet
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2025
			ASSERT_EQUALS(surfAbuff1dispX->iStatus.Int(),KRequestPending);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2026
			//Check B has not completed yet
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2027
			ASSERT_EQUALS(surfBbuff1dispX->iStatus.Int(),KRequestPending);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2028
			}
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2029
		wfcCompose(iDevice, iContext, WFC_TRUE);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2030
	    wfcFence(iDevice, iContext, iEGLDisplay, iSync);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2031
	    ASSERT_EQUALS(eglClientWaitSyncKHR(iEGLDisplay,iSync,0,(EGLTimeKHR)EGL_FOREVER_KHR),EGL_CONDITION_SATISFIED_KHR);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2032
    	}
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2033
	//surfBbuff1dispX should complete, and its RunL will stop the scheduler
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2034
    CActiveScheduler::Start();
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2035
	//Check B has completed
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2036
    ASSERT_EQUALS(surfBbuff1dispX->iStatus.Int(),KErrNone);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2037
	//Check A has not completed yet
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2038
	ASSERT_EQUALS(surfAbuff1dispX->iStatus.Int(),KRequestPending);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2039
	
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2040
    ASSERT_TRUE(AcquireOnScreenStream());
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2041
    ASSERT_TRUE(CheckOnScreenReferenceImage());
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2042
	//Check green center of screen
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2043
    ASSERT_TRUE(CheckOnScreenStreamRect(iCenterTRect,KGreen,iTolerance));
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2044
	//Check yellow around the borders
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2045
	ASSERT_TRUE(CheckOnScreenStreamRect(TRect(0,0,iCenterTRect.iTl.iX,iCenterTRect.iTl.iY),KYellow,iTolerance));
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2046
	ASSERT_TRUE(CheckOnScreenStreamRect(TRect(iCenterTRect.iBr.iX+1,iCenterTRect.iBr.iY+1,
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2047
			iFastpathableWidth,iFastpathableHeight),KYellow,iTolerance));
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2048
	ReleaseOnScreenStream();
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2049
	
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2050
    //check it hasn't completed unexpectedly early while using on screen stream
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2051
    ASSERT_EQUALS(surfAbuff1dispX->iStatus.Int(),KRequestPending);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2052
    
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2053
	//Remove surfaceB from the scene
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2054
	wfcRemoveElement(iDevice, elementB);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2055
#ifdef BREAKPOINT_FASTPATH
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2056
    __BREAKPOINT();
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2057
#endif
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2058
    LOG(("OpenWFTest: Expecting FASTPATH after next commit"));
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2059
	wfcCommit(iDevice, iContext, WFC_TRUE);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2060
    if(!aAutonomous)
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2061
    	{
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2062
		for(TInt i=0;i<4;i++)
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2063
			{
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2064
			wfcCompose(iDevice, iContext, WFC_TRUE);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2065
		    wfcFence(iDevice, iContext, iEGLDisplay, iSync);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2066
		    ASSERT_EQUALS(eglClientWaitSyncKHR(iEGLDisplay,iSync,0,(EGLTimeKHR)EGL_FOREVER_KHR),EGL_CONDITION_SATISFIED_KHR);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2067
		    LOG(("OpenWFTest: Fastpath - now ON"));
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2068
		    WaitL(iCompositionPause);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2069
			//Check A has not completed yet
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2070
			ASSERT_EQUALS(surfAbuff1dispX->iStatus.Int(),KRequestPending);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2071
			}
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2072
		wfcCompose(iDevice, iContext, WFC_TRUE);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2073
    	}
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2074
    wfcFence(iDevice, iContext, iEGLDisplay, iSync);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2075
    ASSERT_EQUALS(eglClientWaitSyncKHR(iEGLDisplay,iSync,0,(EGLTimeKHR)EGL_FOREVER_KHR),EGL_CONDITION_SATISFIED_KHR);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2076
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2077
	//surfAbuff1dispX should complete, and its RunL will stop the scheduler
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2078
    CActiveScheduler::Start();
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2079
    ASSERT_EQUALS(surfAbuff1dispX->iStatus.Int(),KErrNone);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2080
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2081
    ASSERT_TRUE(AcquireOnScreenStream());
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2082
    ASSERT_TRUE(CheckOnScreenReferenceImage());
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2083
	ASSERT_TRUE(CheckOnScreenStreamRect(iFullScreenTRect,KYellow,iTolerance));
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2084
	ReleaseOnScreenStream();
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2085
	
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2086
	ASSERT_EQUALS(wfcGetError(iDevice),WFC_ERROR_NONE);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2087
	//Shutdown
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2088
    wfcDestroySource(iDevice, sourceA);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2089
    wfcDestroySource(iDevice, sourceB);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2090
    
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2091
	CleanupStack::PopAndDestroy(2,surfAbuff1dispX);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2092
	}
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2093
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2094
/*
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2095
@SYMTestCaseID			GRAPHICS-OPENWFC-FASTPATH-0012
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2096
@SYMTestCaseDesc		Positive testing - Fastpath with notification checking DisplayXTime
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2097
@SYMREQ					
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2098
@SYMPREQ						PREQ417-54885
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2099
@SYMTestType				Integration Test
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2100
@SYMTestPriority		High
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2101
@SYMTestPurpose			Check fastpath does not cause any problem to notifications
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2102
@SYMTestActions			
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2103
	All compositions are autonomous:
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2104
	Compose an empty scene
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2105
	A) Create a scene containing a screen sized opaque element A
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2106
	Commit the scene
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2107
	Make a content update for available (iAvailable) and display time (aDisplayed)
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2108
	Wait for the request status objects to complete
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2109
	
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2110
	B) Add a small element B in front of A
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2111
	Compose the scene
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2112
	Content update for both A and B, set display 10 times to A, set display 5 times to B 
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2113
	Wait for the 5 times
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2114
	
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2115
	C) Remove element B
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2116
	Commit the scene
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2117
	Compose the scene
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2118
	Wait for the 10 times
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2119
@SYMTestExpectedResults
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2120
	Composition should fastpath in sections A and C
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2121
	Elements A's 10 times should not complete before element B's 5 times
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2122
*/
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2123
void COpenwfTest::GRAPHICS_OPENWFC_FASTPATH_0012L()
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2124
	{
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2125
    iTestName = _L("FASTPATH_0012");
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2126
    INFO_PRINTF2(_L("GRAPHICS_OPENWFC_%SL()"),&iTestName);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2127
    LOGL((_L("OpenWFTest: GRAPHICS_OPENWFC_%SL()"),&iTestName));
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2128
	FastpathDispXNotificationsTestL(ETrue);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2129
	}
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2130
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2131
/*
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2132
@SYMTestCaseID			GRAPHICS-OPENWFC-FASTPATH-0013
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2133
@SYMTestCaseDesc		Positive testing - Fastpath with notification checking DisplayXTime
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2134
@SYMREQ					
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2135
@SYMPREQ						PREQ417-54885
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2136
@SYMTestType				Integration Test
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2137
@SYMTestPriority		High
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2138
@SYMTestPurpose			Check fastpath does not cause any problem to notifications
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2139
@SYMTestActions			
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2140
	Repeats GRAPHICS-OPENWFC-FASTPATH-0013 in non autonomous mode.
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2141
	This allows gives the added benefit of accurate counting of wfcCompose calls, checking the displayXtimes
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2142
	notifications only complete after the correct number of composes.
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2143
@SYMTestExpectedResults
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2144
	Composition should fastpath in sections A and C
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2145
	Both should complete after their expect amount of compose calls with no errors
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2146
*/
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2147
void COpenwfTest::GRAPHICS_OPENWFC_FASTPATH_0013L()
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2148
	{
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2149
    iTestName = _L("FASTPATH_0013");
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2150
    INFO_PRINTF2(_L("GRAPHICS_OPENWFC_%SL()"),&iTestName);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2151
    LOGL((_L("OpenWFTest: GRAPHICS_OPENWFC_%SL()"),&iTestName));
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2152
    FastpathDispXNotificationsTestL(EFalse);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2153
	}
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2154
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2155
/*
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2156
 *	NEGATIVE TESTING
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2157
 * */
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2158
/*
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2159
@SYMTestCaseID			GRAPHICS-OPENWFC-FASTPATH-0020
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2160
@SYMTestCaseDesc		Negative testing - Fastpath one-element scene
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2161
@SYMREQ					
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2162
@SYMPREQ						PREQ417-54885
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2163
@SYMTestType				Unit Test
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2164
@SYMTestPriority		High
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2165
@SYMTestPurpose			Check a scene including a full screen element with source alpha cannot be fastpathed
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2166
@SYMTestActions			
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2167
	All compositions are autonomous:
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2168
	Create a scene containing a screen sized element 
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2169
	Enable WFC_TRANSPARENCY_SOURCE  
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2170
	Set the value of WFC_ELEMENT_SOURCE between 0 and 255 (non-inclusive).
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2171
	Compose the scene
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2172
@SYMTestExpectedResults
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2173
	The scene cannot be fastpathed.
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2174
*/
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2175
void COpenwfTest::GRAPHICS_OPENWFC_FASTPATH_0020L()
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2176
	{
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2177
    iTestName = _L("FASTPATH_0020");
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2178
    INFO_PRINTF2(_L("GRAPHICS_OPENWFC_%SL()"),&iTestName);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2179
    LOGL((_L("OpenWFTest: GRAPHICS_OPENWFC_%SL()"),&iTestName));
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2180
    SetupEmptySceneL();
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2181
    
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2182
    TSurfaceId surface=iUtility->CreateSurfaceL(TSize(iFastpathableWidth,iFastpathableHeight),
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2183
												EUidPixelFormatARGB_8888,
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2184
                                                iStride, iContiguous, iMaxBuffers);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2185
    ASSERT_FALSE(surface.IsNull());
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2186
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2187
    WFCSource fpSource = wfcCreateSourceFromStream(iDevice, iContext,reinterpret_cast<WFCNativeStreamType>(&surface), NULL);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2188
    TInt err = iUtility->SubmitUpdate(surface, 0, NULL);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2189
    ASSERT_EQUALS(err,KErrNone);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2190
    WFCElement fpElement = wfcCreateElement(iDevice, iContext, NULL);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2191
    wfcSetElementAttribi(iDevice, fpElement, WFC_ELEMENT_SOURCE, fpSource);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2192
    
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2193
    wfcSetElementAttribiv(iDevice, fpElement, WFC_ELEMENT_SOURCE_RECTANGLE, 4, iFullScreenRect);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2194
    wfcSetElementAttribiv(iDevice, fpElement, WFC_ELEMENT_DESTINATION_RECTANGLE, 4, iFullScreenRect);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2195
    //set per pixel alpha
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2196
    wfcSetElementAttribi(iDevice, fpElement, WFC_ELEMENT_TRANSPARENCY_TYPES, WFC_TRANSPARENCY_SOURCE);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2197
    
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2198
#ifdef BREAKPOINT_FASTPATH
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2199
    __BREAKPOINT();
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2200
#endif
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2201
    wfcInsertElement(iDevice, fpElement, WFC_INVALID_HANDLE);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2202
    LOG(("OpenWFTest: Expecting COMPOSITION after next commit - using source alpha"));
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2203
    wfcCommit(iDevice, iContext, WFC_TRUE);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2204
    wfcFence(iDevice, iContext, iEGLDisplay, iSync);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2205
    ASSERT_EQUALS(eglClientWaitSyncKHR(iEGLDisplay,iSync,0,(EGLTimeKHR)EGL_FOREVER_KHR),EGL_CONDITION_SATISFIED_KHR);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2206
    
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2207
    for (TInt i=0;i<=256;i+=64)
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2208
    	{
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2209
		i=(i==256)?255:i;
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2210
		iUtility->FillSurfaceL(surface, 0, TRgb(0,255,0,i));
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2211
		err = iUtility->SubmitUpdate(surface, 0, NULL);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2212
		ASSERT_EQUALS(err,KErrNone);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2213
		WaitL(iCompositionPause);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2214
    	}
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2215
    ASSERT_EQUALS(wfcGetError(iDevice),WFC_ERROR_NONE);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2216
    wfcDestroySource(iDevice, fpSource);  
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2217
	}
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2218
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2219
/*
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2220
@SYMTestCaseID			GRAPHICS-OPENWFC-FASTPATH-0021
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2221
@SYMTestCaseDesc		Negative testing - Fastpath one-element scene
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2222
@SYMREQ					
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2223
@SYMPREQ						PREQ417-54885
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2224
@SYMTestType				Unit Test
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2225
@SYMTestPriority		High	
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2226
@SYMTestPurpose			Check a scene including a full screen element with global alpha cannot be fastpathed
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2227
@SYMTestActions			
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2228
	All compositions are autonomous:
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2229
	Create a scene containing a screen sized element 
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2230
	Enable WFC_TRANSPARENCY_ELEMENT_GLOBAL_ALPHA
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2231
	Set the value of WFC_ELEMENT_GLOBAL_ALPHA between 0 and 255 (non-inclusive)
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2232
	Compose the scene
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2233
@SYMTestExpectedResults
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2234
	The scene cannot be fastpathed.
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2235
*/
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2236
void COpenwfTest::GRAPHICS_OPENWFC_FASTPATH_0021L()
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2237
	{
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2238
    iTestName = _L("FASTPATH_0021");
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2239
    INFO_PRINTF2(_L("GRAPHICS_OPENWFC_%SL()"),&iTestName);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2240
    LOGL((_L("OpenWFTest: GRAPHICS_OPENWFC_%SL()"),&iTestName));
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2241
    SetupEmptySceneL();
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2242
    
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2243
    TSurfaceId surface=iUtility->CreateSurfaceL(TSize(iFastpathableWidth,iFastpathableHeight),
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2244
												EUidPixelFormatXRGB_8888,
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2245
                                                iStride, iContiguous, iMaxBuffers);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2246
    ASSERT_FALSE(surface.IsNull());
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2247
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2248
    WFCSource fpSource = wfcCreateSourceFromStream(iDevice, iContext,reinterpret_cast<WFCNativeStreamType>(&surface), NULL);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2249
    TInt err = iUtility->SubmitUpdate(surface, 0, NULL);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2250
    ASSERT_EQUALS(err,KErrNone);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2251
    WFCElement fpElement = wfcCreateElement(iDevice, iContext, NULL);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2252
    wfcSetElementAttribi(iDevice, fpElement, WFC_ELEMENT_SOURCE, fpSource);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2253
    
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2254
    wfcSetElementAttribiv(iDevice, fpElement, WFC_ELEMENT_SOURCE_RECTANGLE, 4, iFullScreenRect);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2255
    wfcSetElementAttribiv(iDevice, fpElement, WFC_ELEMENT_DESTINATION_RECTANGLE, 4, iFullScreenRect);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2256
    //set element global alpha
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2257
	wfcSetElementAttribi(iDevice, fpElement, WFC_ELEMENT_TRANSPARENCY_TYPES, WFC_TRANSPARENCY_ELEMENT_GLOBAL_ALPHA);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2258
	wfcSetElementAttribf(iDevice, fpElement, WFC_ELEMENT_GLOBAL_ALPHA, 0.0f);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2259
	
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2260
#ifdef BREAKPOINT_FASTPATH
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2261
    __BREAKPOINT();
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2262
#endif
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2263
    wfcInsertElement(iDevice, fpElement, WFC_INVALID_HANDLE);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2264
	iUtility->FillSurfaceL(surface, 0, KGreen);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2265
	err = iUtility->SubmitUpdate(surface, 0, NULL);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2266
    LOG(("OpenWFTest: Expecting COMPOSITION after next commit - using element global alpha not fully opaque"));
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2267
    wfcCommit(iDevice, iContext, WFC_TRUE);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2268
    wfcFence(iDevice, iContext, iEGLDisplay, iSync);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2269
    ASSERT_EQUALS(eglClientWaitSyncKHR(iEGLDisplay,iSync,0,(EGLTimeKHR)EGL_FOREVER_KHR),EGL_CONDITION_SATISFIED_KHR);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2270
    
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2271
    for (TInt i=0;i<=256;i+=64)
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2272
    	{
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2273
		i=(i==256)?255:i;
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2274
		wfcSetElementAttribf(iDevice, fpElement, WFC_ELEMENT_GLOBAL_ALPHA, (TReal32)i/255);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2275
		if(i == 255)
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2276
			{
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2277
#ifdef BREAKPOINT_FASTPATH
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2278
			__BREAKPOINT();
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2279
#endif
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2280
			}
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2281
        if(i == 255)
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2282
            {
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2283
            LOG(("OpenWFTest: Expecting FASTPATH after next commit - using element global alpha fully opaque"));
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2284
            }
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2285
        else
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2286
            {
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2287
            LOG(("OpenWFTest: Expecting COMPOSITION after next commit - using element global alpha not fully opaque"));
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2288
            }
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2289
	    wfcCommit(iDevice, iContext, WFC_TRUE);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2290
	    wfcFence(iDevice, iContext, iEGLDisplay, iSync);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2291
	    ASSERT_EQUALS(eglClientWaitSyncKHR(iEGLDisplay,iSync,0,(EGLTimeKHR)EGL_FOREVER_KHR),EGL_CONDITION_SATISFIED_KHR);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2292
		WaitL(iCompositionPause);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2293
    	}
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2294
    ASSERT_EQUALS(wfcGetError(iDevice),WFC_ERROR_NONE);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2295
    wfcDestroySource(iDevice, fpSource);  
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2296
	}
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2297
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2298
/*
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2299
@SYMTestCaseID			GRAPHICS-OPENWFC-FASTPATH-0022
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2300
@SYMTestCaseDesc		Negative testing - Fastpath one-element scene
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2301
@SYMREQ					
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2302
@SYMPREQ						PREQ417-54885
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2303
@SYMTestType				Unit Test
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2304
@SYMTestPriority		High	
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2305
@SYMTestPurpose			Check a scene with RGB 565 format cannot be fastpathed
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2306
@SYMTestActions			
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2307
	Create a scene containing a screen sized element with an unsupported source format, such as 565
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2308
	Compose the scene
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2309
@SYMTestExpectedResults
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2310
	The scene cannot be fastpathed.	
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2311
*/
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2312
void COpenwfTest::GRAPHICS_OPENWFC_FASTPATH_0022L()
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2313
	{
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2314
    iTestName = _L("FASTPATH_0022");
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2315
    INFO_PRINTF2(_L("GRAPHICS_OPENWFC_%SL()"),&iTestName);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2316
    LOGL((_L("OpenWFTest: GRAPHICS_OPENWFC_%SL()"),&iTestName));
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2317
    SetupEmptySceneL();
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2318
    
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2319
    //NON fastpathable pixel format
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2320
    TSurfaceId surface=iUtility->CreateSurfaceL(TSize(iFastpathableWidth,iFastpathableHeight),
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2321
												iNonFastpathablePixelFormat,
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2322
                                                iStride, iContiguous, iMaxBuffers);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2323
    ASSERT_FALSE(surface.IsNull());
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2324
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2325
    WFCSource fpSource = wfcCreateSourceFromStream(iDevice, iContext,reinterpret_cast<WFCNativeStreamType>(&surface), NULL);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2326
    TInt err = iUtility->SubmitUpdate(surface, 0, NULL);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2327
    ASSERT_EQUALS(err,KErrNone);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2328
    WFCElement fpElement = wfcCreateElement(iDevice, iContext, NULL);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2329
    wfcSetElementAttribi(iDevice, fpElement, WFC_ELEMENT_SOURCE, fpSource);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2330
    wfcSetElementAttribiv(iDevice, fpElement, WFC_ELEMENT_SOURCE_RECTANGLE, 4, iFullScreenRect);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2331
    wfcSetElementAttribiv(iDevice, fpElement, WFC_ELEMENT_DESTINATION_RECTANGLE, 4, iFullScreenRect);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2332
    wfcInsertElement(iDevice, fpElement, WFC_INVALID_HANDLE);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2333
    
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2334
#ifdef BREAKPOINT_FASTPATH
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2335
    __BREAKPOINT();
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2336
#endif
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2337
    LOG(("OpenWFTest: Expecting COMPOSITION after next commit - using non fastpathable pixel format"));
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2338
    wfcCommit(iDevice, iContext, WFC_TRUE);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2339
    wfcFence(iDevice, iContext, iEGLDisplay, iSync);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2340
    ASSERT_EQUALS(eglClientWaitSyncKHR(iEGLDisplay,iSync,0,(EGLTimeKHR)EGL_FOREVER_KHR),EGL_CONDITION_SATISFIED_KHR);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2341
    
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2342
    iUtility->FillSurfaceL(surface, 0, KGreen);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2343
    err = iUtility->SubmitUpdate(surface, 0, NULL);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2344
    ASSERT_EQUALS(err,KErrNone);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2345
    WaitL(iCompositionPause);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2346
    
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2347
    ASSERT_TRUE(AcquireOnScreenStream());
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2348
    ASSERT_TRUE(CheckOnScreenReferenceImage());
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2349
	ASSERT_TRUE(CheckOnScreenStreamRect(iFullScreenTRect,KGreen,iTolerance));
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2350
	ReleaseOnScreenStream();
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2351
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2352
	ASSERT_EQUALS(wfcGetError(iDevice),WFC_ERROR_NONE);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2353
    wfcDestroySource(iDevice, fpSource);  
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2354
	}
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2355
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2356
/*
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2357
@SYMTestCaseID			GRAPHICS-OPENWFC-FASTPATH-0023
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2358
@SYMTestCaseDesc		Negative testing - Fastpath one-element scene
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2359
@SYMREQ					
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2360
@SYMPREQ						PREQ417-54885
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2361
@SYMTestType				Unit Test
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2362
@SYMTestPriority		High
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2363
@SYMTestPurpose			Check a scene with mask settings cannot be fastpathed
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2364
@SYMTestActions			
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2365
	All compositions are autonomous:
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2366
	Create a scene containing a screen sized element A
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2367
	Enable WFC_TRANSPARENCY_MASK
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2368
	Set a value to WFC_ELEMENT_MASK
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2369
	Create a mask element, set the size to be the same as element A's desitnation rectangle 
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2370
	Compose the scene
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2371
@SYMTestExpectedResults
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2372
	The scene cannot be fastpathed.
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2373
*/
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2374
void COpenwfTest::GRAPHICS_OPENWFC_FASTPATH_0023L()
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2375
	{
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2376
    iTestName = _L("FASTPATH_0023");
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2377
    INFO_PRINTF2(_L("GRAPHICS_OPENWFC_%SL()"),&iTestName);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2378
    LOGL((_L("OpenWFTest: GRAPHICS_OPENWFC_%SL()"),&iTestName));
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2379
    SetupEmptySceneL();
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2380
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2381
    TSurfaceId surface=iUtility->CreateSurfaceL(TSize(iFastpathableWidth,iFastpathableHeight),
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2382
												iFastpathablePixelFormat,
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2383
                                                iStride, iContiguous, iMaxBuffers);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2384
    ASSERT_FALSE(surface.IsNull());
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2385
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2386
    WFCSource fpSource = wfcCreateSourceFromStream(iDevice, iContext,reinterpret_cast<WFCNativeStreamType>(&surface), NULL);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2387
    TInt err = iUtility->SubmitUpdate(surface, 0, NULL);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2388
    ASSERT_EQUALS(err,KErrNone);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2389
    WFCElement fpElement = wfcCreateElement(iDevice, iContext, NULL);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2390
    wfcSetElementAttribi(iDevice, fpElement, WFC_ELEMENT_SOURCE, fpSource);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2391
    wfcSetElementAttribiv(iDevice, fpElement, WFC_ELEMENT_SOURCE_RECTANGLE, 4, iFullScreenRect);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2392
    wfcSetElementAttribiv(iDevice, fpElement, WFC_ELEMENT_DESTINATION_RECTANGLE, 4, iFullScreenRect);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2393
    
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2394
    TSurfaceId surfaceMask = iUtility->CreateSurfaceL(TSize(iFastpathableWidth,iFastpathableHeight),
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2395
                                                iFastpathablePixelFormat,
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2396
                                                iStride, iContiguous, iMaxBuffers);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2397
    ASSERT_FALSE(surfaceMask.IsNull());
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2398
    WFCMask mask = wfcCreateMaskFromStream(iDevice, iContext, reinterpret_cast<WFCNativeStreamType>(&surfaceMask), NULL);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2399
    err = iUtility->SubmitUpdate(surfaceMask, 0, NULL);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2400
    ASSERT_EQUALS(err,KErrNone);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2401
    
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2402
    //set the mask to fpElement
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2403
    wfcSetElementAttribi(iDevice, fpElement, WFC_ELEMENT_TRANSPARENCY_TYPES, WFC_TRANSPARENCY_MASK);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2404
    wfcSetElementAttribi(iDevice, fpElement, WFC_ELEMENT_MASK, mask);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2405
    ASSERT_EQUALS(wfcGetError(iDevice),WFC_ERROR_NONE);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2406
    
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2407
#ifdef BREAKPOINT_FASTPATH
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2408
    __BREAKPOINT();
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2409
#endif
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2410
    wfcInsertElement(iDevice, fpElement, WFC_INVALID_HANDLE);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2411
    LOG(("OpenWFTest: Expecting COMPOSITION after next commit - using a mask"));
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2412
    wfcCommit(iDevice, iContext, WFC_TRUE);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2413
    wfcFence(iDevice, iContext, iEGLDisplay, iSync);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2414
    ASSERT_EQUALS(eglClientWaitSyncKHR(iEGLDisplay,iSync,0,(EGLTimeKHR)EGL_FOREVER_KHR),EGL_CONDITION_SATISFIED_KHR);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2415
    LOG(("OpenWFTest:Fastpath - still off - using a mask"));
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2416
    
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2417
    iUtility->FillSurfaceL(surface, 0, KGreen);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2418
    err = iUtility->SubmitUpdate(surface, 0, NULL);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2419
    ASSERT_EQUALS(err,KErrNone);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2420
    iUtility->FillSurfaceL(surfaceMask, 0, KBlack);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2421
    err = iUtility->SubmitUpdate(surfaceMask, 0, NULL);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2422
    ASSERT_EQUALS(err,KErrNone);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2423
    WaitL(iCompositionPause);	
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2424
 
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2425
    ASSERT_EQUALS(wfcGetError(iDevice),WFC_ERROR_NONE);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2426
    wfcDestroySource(iDevice, fpSource);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2427
	}
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2428
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2429
/*
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2430
@SYMTestCaseID			GRAPHICS-OPENWFC-FASTPATH-0024
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2431
@SYMTestCaseDesc		Negative testing - Fastpath one-element scene
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2432
@SYMREQ					
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2433
@SYMPREQ						PREQ417-54885
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2434
@SYMTestType				Unit Test
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2435
@SYMTestPriority		High
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2436
@SYMTestPurpose			Check a scene with alpha and mask settings cannot be fastpathed
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2437
@SYMTestActions			
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2438
	All compositions are autonomous:
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2439
	Create a scene containing a screen sized element A
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2440
	Enable WFC_TRANSPARENCY_ELEMENT_GLOBAL_ALPHA
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2441
	Set the value of WFC_ELEMENT_GLOBAL_ALPHA to be 255 
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2442
	Enable WFC_TRANSPARENCY_MASK
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2443
	Set a value to WFC_ELEMENT_MASK 	
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2444
	Create a mask element, set it the same size of element A's destination rectangle
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2445
	Compose the scene
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2446
@SYMTestExpectedResults
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2447
	The scene cannot be fastpathed.
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2448
*/
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2449
void COpenwfTest::GRAPHICS_OPENWFC_FASTPATH_0024L()
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2450
	{
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2451
    iTestName = _L("FASTPATH_0024");
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2452
    INFO_PRINTF2(_L("GRAPHICS_OPENWFC_%SL()"),&iTestName);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2453
    LOGL((_L("OpenWFTest: GRAPHICS_OPENWFC_%SL()"),&iTestName));
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2454
    SetupEmptySceneL();
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2455
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2456
    TSurfaceId surface=iUtility->CreateSurfaceL(TSize(iFastpathableWidth,iFastpathableHeight),
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2457
												iFastpathablePixelFormat,
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2458
                                                iStride, iContiguous, iMaxBuffers);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2459
    ASSERT_FALSE(surface.IsNull());
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2460
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2461
    WFCSource fpSource = wfcCreateSourceFromStream(iDevice, iContext,reinterpret_cast<WFCNativeStreamType>(&surface), NULL);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2462
    TInt err = iUtility->SubmitUpdate(surface, 0, NULL);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2463
    ASSERT_EQUALS(err,KErrNone);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2464
    WFCElement fpElement = wfcCreateElement(iDevice, iContext, NULL);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2465
    wfcSetElementAttribi(iDevice, fpElement, WFC_ELEMENT_SOURCE, fpSource);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2466
    wfcSetElementAttribiv(iDevice, fpElement, WFC_ELEMENT_SOURCE_RECTANGLE, 4, iFullScreenRect);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2467
    wfcSetElementAttribiv(iDevice, fpElement, WFC_ELEMENT_DESTINATION_RECTANGLE, 4, iFullScreenRect);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2468
    
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2469
    TSurfaceId surfaceMask = iUtility->CreateSurfaceL(TSize(iFastpathableWidth,iFastpathableHeight),
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2470
                                                iFastpathablePixelFormat,
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2471
                                                iStride, iContiguous, iMaxBuffers);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2472
    ASSERT_FALSE(surfaceMask.IsNull());
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2473
    WFCMask mask = wfcCreateMaskFromStream(iDevice, iContext, reinterpret_cast<WFCNativeStreamType>(&surfaceMask), NULL);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2474
    err = iUtility->SubmitUpdate(surfaceMask, 0, NULL);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2475
    ASSERT_EQUALS(err,KErrNone);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2476
    
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2477
    //set the mask and global alpha for use with fpElement
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2478
    wfcSetElementAttribi(iDevice, fpElement, WFC_ELEMENT_MASK, mask);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2479
    wfcSetElementAttribi(iDevice, fpElement, WFC_ELEMENT_TRANSPARENCY_TYPES, 
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2480
    		WFC_TRANSPARENCY_ELEMENT_GLOBAL_ALPHA|WFC_TRANSPARENCY_MASK);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2481
    //set global alpha to fully opaque
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2482
    wfcSetElementAttribf(iDevice, fpElement, WFC_ELEMENT_GLOBAL_ALPHA, 1.0f);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2483
    
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2484
    wfcInsertElement(iDevice, fpElement, WFC_INVALID_HANDLE);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2485
#ifdef BREAKPOINT_FASTPATH
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2486
    __BREAKPOINT();
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2487
#endif
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2488
    LOG(("OpenWFTest: Expecting COMPOSITION after next commit - using a mask and global alpha"));
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2489
    wfcCommit(iDevice, iContext, WFC_TRUE);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2490
    wfcFence(iDevice, iContext, iEGLDisplay, iSync);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2491
    ASSERT_EQUALS(eglClientWaitSyncKHR(iEGLDisplay,iSync,0,(EGLTimeKHR)EGL_FOREVER_KHR),EGL_CONDITION_SATISFIED_KHR);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2492
    LOG(("OpenWFTest: Fastpath - still off - using a mask and global alpha"));
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2493
    
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2494
    iUtility->FillSurfaceL(surface, 0, KGreen);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2495
    err = iUtility->SubmitUpdate(surface, 0, NULL);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2496
    ASSERT_EQUALS(err,KErrNone);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2497
    iUtility->FillSurfaceL(surfaceMask, 0, KBlack);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2498
    err = iUtility->SubmitUpdate(surfaceMask, 0, NULL);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2499
    ASSERT_EQUALS(err,KErrNone);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2500
    WaitL(iCompositionPause);	
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2501
 
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2502
    ASSERT_EQUALS(wfcGetError(iDevice),WFC_ERROR_NONE);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2503
    wfcDestroySource(iDevice, fpSource);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2504
	}
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2505
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2506
/*
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2507
@SYMTestCaseID			GRAPHICS-OPENWFC-FASTPATH-0025
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2508
@SYMTestCaseDesc		Negative testing - Fastpath a scene with scaling element
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2509
@SYMREQ					
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2510
@SYMPREQ						PREQ417-54885
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2511
@SYMTestType				Unit Test
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2512
@SYMTestPriority		High	
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2513
@SYMTestPurpose			Check a scene with scaling cannot be fastpathed
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2514
@SYMTestActions			
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2515
	All compositions are autonomous:
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2516
	Create an element containing source size smaller than full screen destination size
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2517
	Add to scene and compose
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2518
@SYMTestExpectedResults
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2519
	The scene cannot be fastpathed.
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2520
*/
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2521
void COpenwfTest::GRAPHICS_OPENWFC_FASTPATH_0025L()
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2522
	{
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2523
    iTestName = _L("FASTPATH_0025");
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2524
    INFO_PRINTF2(_L("GRAPHICS_OPENWFC_%SL()"),&iTestName);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2525
    LOGL((_L("OpenWFTest: GRAPHICS_OPENWFC_%SL()"),&iTestName));
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2526
    SetupEmptySceneL();
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2527
	
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2528
	//create half screen size surface
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2529
	TSurfaceId surface=iUtility->CreateSurfaceL(TSize(iFastpathableWidth/2,iFastpathableHeight/2),
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2530
												iFastpathablePixelFormat,
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2531
												iStride, iContiguous, iMaxBuffers);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2532
	ASSERT_FALSE(surface.IsNull());
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2533
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2534
	WFCSource fpSource = wfcCreateSourceFromStream(iDevice, iContext,reinterpret_cast<WFCNativeStreamType>(&surface), NULL);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2535
	TInt err = iUtility->SubmitUpdate(surface, 0, NULL);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2536
	ASSERT_EQUALS(err,KErrNone);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2537
	WFCElement fpElement = wfcCreateElement(iDevice, iContext, NULL);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2538
	wfcSetElementAttribi(iDevice, fpElement, WFC_ELEMENT_SOURCE, fpSource);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2539
	
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2540
	//note the source is only half the size of the screen
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2541
	wfcSetElementAttribiv(iDevice, fpElement, WFC_ELEMENT_SOURCE_RECTANGLE, 4, iHalfSizeRect);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2542
	//set destination to fullscreen, causing it to stretch
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2543
	wfcSetElementAttribiv(iDevice, fpElement, WFC_ELEMENT_DESTINATION_RECTANGLE, 4, iFullScreenRect);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2544
    wfcInsertElement(iDevice, fpElement, WFC_INVALID_HANDLE);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2545
#ifdef BREAKPOINT_FASTPATH
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2546
    __BREAKPOINT();
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2547
#endif
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2548
    LOG(("OpenWFTest: Expecting COMPOSITION after next commit - using a mask and global alpha"));
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2549
	wfcCommit(iDevice, iContext, WFC_TRUE);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2550
	wfcFence(iDevice, iContext, iEGLDisplay, iSync);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2551
	ASSERT_EQUALS(eglClientWaitSyncKHR(iEGLDisplay,iSync,0,(EGLTimeKHR)EGL_FOREVER_KHR),EGL_CONDITION_SATISFIED_KHR);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2552
	LOG(("OpenWFTest: Fastpath - still off... - source not equal to destination"));
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2553
	
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2554
	iUtility->FillSurfaceL(surface, 0, KGreen);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2555
	err = iUtility->SubmitUpdate(surface, 0, NULL);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2556
	ASSERT_EQUALS(err,KErrNone);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2557
	WaitL(iCompositionPause);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2558
	
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2559
    ASSERT_TRUE(AcquireOnScreenStream());
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2560
    ASSERT_TRUE(CheckOnScreenReferenceImage());
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2561
	ASSERT_TRUE(CheckOnScreenStreamRect(iFullScreenTRect,KGreen,iTolerance));
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2562
	ReleaseOnScreenStream();
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2563
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2564
	ASSERT_EQUALS(wfcGetError(iDevice),WFC_ERROR_NONE);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2565
	wfcDestroySource(iDevice, fpSource);  
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2566
	}
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2567
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2568
/*
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2569
@SYMTestCaseID			GRAPHICS-OPENWFC-FASTPATH-0026
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2570
@SYMTestCaseDesc		Negative testing - Fastpath a scene with rotation
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2571
@SYMREQ					
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2572
@SYMPREQ						PREQ417-54885
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2573
@SYMTestType				Unit Test
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2574
@SYMTestPriority		High	
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2575
@SYMTestPurpose			Check a scene with rotation cannot be fastpathed
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2576
@SYMTestActions			
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2577
	All compositions are autonomous:
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2578
	Create a scene containing a screen size element 
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2579
	Compose the scene
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2580
	Rotate the element with 90, 180 and 270 degrees
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2581
	Compose the scene
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2582
@SYMTestExpectedResults
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2583
	The scene can be fastpathed only for the first scene commited composition.
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2584
*/
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2585
void COpenwfTest::GRAPHICS_OPENWFC_FASTPATH_0026L()
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2586
	{
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2587
    iTestName = _L("FASTPATH_0026");
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2588
    INFO_PRINTF2(_L("GRAPHICS_OPENWFC_%SL()"),&iTestName);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2589
    LOGL((_L("OpenWFTest: GRAPHICS_OPENWFC_%SL()"),&iTestName));
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2590
    SetupEmptySceneL();
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2591
    
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2592
    TSurfaceId surface=iUtility->CreateSurfaceL(TSize(iFastpathableWidth,iFastpathableHeight),
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2593
                                                iFastpathablePixelFormat,
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2594
                                                iStride, iContiguous, iMaxBuffers);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2595
    ASSERT_FALSE(surface.IsNull());
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2596
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2597
    WFCSource fpSource = wfcCreateSourceFromStream(iDevice, iContext,reinterpret_cast<WFCNativeStreamType>(&surface), NULL);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2598
    TInt err = iUtility->SubmitUpdate(surface, 0, NULL);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2599
    ASSERT_EQUALS(err,KErrNone);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2600
    WFCElement fpElement = wfcCreateElement(iDevice, iContext, NULL);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2601
    wfcSetElementAttribi(iDevice, fpElement, WFC_ELEMENT_SOURCE, fpSource);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2602
    wfcSetElementAttribiv(iDevice, fpElement, WFC_ELEMENT_SOURCE_RECTANGLE, 4, iFullScreenRect);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2603
    wfcSetElementAttribiv(iDevice, fpElement, WFC_ELEMENT_DESTINATION_RECTANGLE, 4, iFullScreenRect);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2604
    
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2605
    wfcInsertElement(iDevice, fpElement, WFC_INVALID_HANDLE);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2606
#ifdef BREAKPOINT_FASTPATH
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2607
    __BREAKPOINT();
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2608
#endif
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2609
    LOG(("OpenWFTest: Expecting FASTPATH after next commit"));
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2610
    wfcCommit(iDevice, iContext, WFC_TRUE);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2611
    wfcFence(iDevice, iContext, iEGLDisplay, iSync);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2612
    ASSERT_EQUALS(eglClientWaitSyncKHR(iEGLDisplay,iSync,0,(EGLTimeKHR)EGL_FOREVER_KHR),EGL_CONDITION_SATISFIED_KHR);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2613
    LOG(("OpenWFTest: Fastpath - now ON"));
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2614
    
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2615
    iUtility->FillSurfaceL(surface, 0, KGreen);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2616
    err = iUtility->SubmitUpdate(surface, 0, NULL);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2617
    ASSERT_EQUALS(err,KErrNone);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2618
    WaitL(iCompositionPause);	
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2619
 
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2620
    //Set 90 degree rotation
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2621
    wfcSetElementAttribi(iDevice, fpElement, WFC_ELEMENT_SOURCE_ROTATION, WFC_ROTATION_90);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2622
    
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2623
#ifdef BREAKPOINT_FASTPATH
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2624
    __BREAKPOINT();
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2625
#endif
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2626
    iUtility->FillSurfaceL(surface, 0, KBlue);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2627
    LOG(("OpenWFTest: Expecting COMPOSITION after next commit"));
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2628
    wfcCommit(iDevice, iContext, WFC_TRUE);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2629
    wfcFence(iDevice, iContext, iEGLDisplay, iSync);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2630
    ASSERT_EQUALS(eglClientWaitSyncKHR(iEGLDisplay,iSync,0,(EGLTimeKHR)EGL_FOREVER_KHR),EGL_CONDITION_SATISFIED_KHR);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2631
    LOG(("OpenWFTest: Fastpath - now OFF"));
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2632
    WaitL(iCompositionPause);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2633
    
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2634
    ASSERT_TRUE(AcquireOnScreenStream());
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2635
    ASSERT_TRUE(CheckOnScreenReferenceImage());
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2636
	ASSERT_TRUE(CheckOnScreenStreamRect(iFullScreenTRect,KBlue,iTolerance));
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2637
	ReleaseOnScreenStream();
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2638
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2639
	
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2640
    //Set 180 degree rotation
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2641
    wfcSetElementAttribi(iDevice, fpElement, WFC_ELEMENT_SOURCE_ROTATION, WFC_ROTATION_180);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2642
    
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2643
#ifdef BREAKPOINT_FASTPATH
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2644
    __BREAKPOINT();
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2645
#endif
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2646
    iUtility->FillSurfaceL(surface, 0, KMagenta);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2647
    LOG(("OpenWFTest: Expecting FASTPATH after next commit"));
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2648
    wfcCommit(iDevice, iContext, WFC_TRUE);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2649
    wfcFence(iDevice, iContext, iEGLDisplay, iSync);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2650
    ASSERT_EQUALS(eglClientWaitSyncKHR(iEGLDisplay,iSync,0,(EGLTimeKHR)EGL_FOREVER_KHR),EGL_CONDITION_SATISFIED_KHR);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2651
    LOG(("OpenWFTest: Fastpath - now OFF"));
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2652
    WaitL(iCompositionPause);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2653
    
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2654
    ASSERT_TRUE(AcquireOnScreenStream());
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2655
    ASSERT_TRUE(CheckOnScreenStreamRect(iFullScreenTRect,KMagenta,iTolerance));
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2656
    ASSERT_TRUE(CheckOnScreenReferenceImage());
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2657
    ReleaseOnScreenStream();
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2658
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2659
    //Set 270 degree rotation
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2660
    wfcSetElementAttribi(iDevice, fpElement, WFC_ELEMENT_SOURCE_ROTATION, WFC_ROTATION_270);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2661
    
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2662
#ifdef BREAKPOINT_FASTPATH
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2663
    __BREAKPOINT();
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2664
#endif
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2665
    iUtility->FillSurfaceL(surface, 0, KBrown);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2666
    LOG(("OpenWFTest: Expecting COMPOSITION after next commit"));
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2667
    wfcCommit(iDevice, iContext, WFC_TRUE);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2668
    wfcFence(iDevice, iContext, iEGLDisplay, iSync);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2669
    ASSERT_EQUALS(eglClientWaitSyncKHR(iEGLDisplay,iSync,0,(EGLTimeKHR)EGL_FOREVER_KHR),EGL_CONDITION_SATISFIED_KHR);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2670
    LOG(("OpenWFTest: Fastpath - now OFF"));
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2671
    WaitL(iCompositionPause);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2672
    
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2673
    ASSERT_TRUE(AcquireOnScreenStream());
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2674
    ASSERT_TRUE(CheckOnScreenStreamRect(iFullScreenTRect,KBrown,iTolerance));
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2675
    ASSERT_TRUE(CheckOnScreenReferenceImage());
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2676
    ReleaseOnScreenStream();
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2677
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2678
    ASSERT_EQUALS(wfcGetError(iDevice),WFC_ERROR_NONE);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2679
    wfcDestroySource(iDevice, fpSource);  
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2680
	}
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2681
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2682
/*
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2683
@SYMTestCaseID          GRAPHICS-OPENWFC-FASTPATH-0027
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2684
@SYMTestCaseDesc        Negative testing - Pass in bad parameter values 
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2685
@SYMREQ                 
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2686
@SYMPREQ                PREQ417-54885
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2687
@SYMTestType            Unit Test
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2688
@SYMTestPriority        High    
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2689
@SYMTestPurpose         Check invalid parameter values passed in OWF APIs
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2690
@SYMTestActions 
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2691
    Use invalid values to call OWF APIs
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2692
@SYMTestExpectedResults
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2693
    Test should pass without panic.
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2694
*/
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2695
void COpenwfTest::GRAPHICS_OPENWFC_FASTPATH_0027L()
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2696
    {
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2697
    iTestName = _L("FASTPATH_0027");
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2698
    INFO_PRINTF2(_L("GRAPHICS_OPENWFC_%SL()"),&iTestName);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2699
    LOGL((_L("OpenWFTest: GRAPHICS_OPENWFC_%SL()"),&iTestName));
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2700
    
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2701
    WFCint deviceId;
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2702
    WFCint filterList[] = { WFC_DEVICE_FILTER_SCREEN_NUMBER, WFC_DEFAULT_SCREEN_NUMBER, WFC_NONE};
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2703
    ASSERT_TRUE(wfcEnumerateDevices(&deviceId, 1, filterList) == 1);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2704
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2705
    WFCint attribList = 1;
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2706
    WFCDevice device = wfcCreateDevice(deviceId, &attribList);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2707
    WFCContext onScreenContext = wfcCreateOnScreenContext(NULL, WFC_DEFAULT_SCREEN_NUMBER, NULL);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2708
    WFCContext offScreenContext = wfcCreateOffScreenContext(NULL, WFC_DEFAULT_SCREEN_NUMBER, NULL);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2709
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2710
    WFCfloat value = 1.0;
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2711
    wfcGetContextAttribi(NULL, iContext, WFC_CONTEXT_TARGET_HEIGHT);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2712
    wfcSetContextAttribi(NULL, iContext, WFC_CONTEXT_ROTATION, WFC_ROTATION_0);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2713
    wfcGetContextAttribfv(NULL, iContext, WFC_CONTEXT_ROTATION, NULL, &value);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2714
    wfcSetContextAttribfv(NULL, iContext, WFC_CONTEXT_ROTATION, NULL, &value);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2715
    
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2716
    TSurfaceId surface=iUtility->CreateSurfaceL(TSize(iFastpathableWidth,iFastpathableHeight),
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2717
                                                iFastpathablePixelFormat,
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2718
                                                iStride, iContiguous, iMaxBuffers);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2719
    ASSERT_FALSE(surface.IsNull());
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2720
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2721
    WFCSource fpSource = wfcCreateSourceFromStream(NULL, iContext,reinterpret_cast<WFCNativeStreamType>(&surface), NULL);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2722
    wfcCreateMaskFromStream(NULL, iContext, reinterpret_cast<WFCNativeStreamType>(&surface), NULL);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2723
    WFCElement fpElement = wfcCreateElement(NULL, iContext, NULL);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2724
    wfcSetElementAttribi(NULL, fpElement, WFC_ELEMENT_SOURCE, fpSource);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2725
    wfcSetElementAttribf(NULL, fpElement, WFC_ELEMENT_SOURCE, NULL);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2726
    wfcSetElementAttribiv(NULL, fpElement, WFC_ELEMENT_SOURCE, NULL, NULL);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2727
    wfcSetElementAttribfv(NULL, fpElement, WFC_ELEMENT_SOURCE, NULL, NULL);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2728
    wfcSetElementAttribiv(iDevice, fpElement, WFC_ELEMENT_SOURCE, NULL, NULL);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2729
    wfcSetElementAttribfv(iDevice, fpElement, WFC_ELEMENT_SOURCE, NULL, NULL);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2730
    
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2731
    wfcGetElementAttribi(NULL, fpElement, WFC_ELEMENT_SOURCE);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2732
    wfcGetElementAttribf(NULL, fpElement, WFC_ELEMENT_SOURCE);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2733
    wfcGetElementAttribiv(NULL, fpElement, WFC_ELEMENT_SOURCE, NULL, NULL);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2734
    wfcGetElementAttribiv(iDevice, fpElement, WFC_ELEMENT_SOURCE, NULL, NULL);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2735
    wfcGetElementAttribfv(NULL, fpElement, WFC_ELEMENT_SOURCE, NULL, NULL);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2736
    wfcGetElementAttribfv(iDevice, fpElement, WFC_ELEMENT_SOURCE, NULL, NULL);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2737
    
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2738
    wfcInsertElement(NULL, fpElement, NULL);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2739
    wfcGetElementAbove(NULL, fpElement);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2740
    wfcGetElementBelow(NULL, fpElement);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2741
        
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2742
    WFCDeviceAttrib devAttrib = WFC_DEVICE_ID;
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2743
    wfcGetDeviceAttribi(NULL, devAttrib);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2744
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2745
    wfcActivate(NULL, iContext);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2746
    wfcActivate(iDevice, NULL);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2747
    wfcDeactivate(NULL, iContext);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2748
    wfcDeactivate(iDevice, NULL);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2749
    wfcCompose(NULL, iContext, WFC_TRUE);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2750
    wfcCompose(iDevice, NULL, WFC_TRUE);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2751
    wfcCommit(NULL, iContext, WFC_TRUE);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2752
    wfcCommit(iDevice, NULL, WFC_TRUE);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2753
    wfcFence(NULL, iContext, iEGLDisplay, iSync);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2754
    wfcFence(iDevice, NULL, iEGLDisplay, iSync);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2755
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2756
    WFCMask mask = WFC_INVALID_HANDLE;
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2757
    wfcDestroyMask(NULL, mask);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2758
    wfcRemoveElement(NULL, fpElement);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2759
    wfcDestroyElement(NULL, fpElement);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2760
    wfcDestroySource(NULL, fpSource);  
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2761
    wfcDestroyContext(NULL, onScreenContext);
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2762
    }
d72fc2aace31 201027_1
hgs
parents:
diff changeset
  2763