windowing/windowserver/test/tauto/THeartBeat.CPP
author hgs
Tue, 22 Jun 2010 15:21:29 +0300
changeset 103 2717213c588a
permissions -rw-r--r--
201024
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
103
hgs
parents:
diff changeset
     1
// Copyright (c) 2007-2009 Nokia Corporation and/or its subsidiary(-ies).
hgs
parents:
diff changeset
     2
// All rights reserved.
hgs
parents:
diff changeset
     3
// This component and the accompanying materials are made available
hgs
parents:
diff changeset
     4
// under the terms of "Eclipse Public License v1.0"
hgs
parents:
diff changeset
     5
// which accompanies this distribution, and is available
hgs
parents:
diff changeset
     6
// at the URL "http://www.eclipse.org/legal/epl-v10.html".
hgs
parents:
diff changeset
     7
//
hgs
parents:
diff changeset
     8
// Initial Contributors:
hgs
parents:
diff changeset
     9
// Nokia Corporation - initial contribution.
hgs
parents:
diff changeset
    10
//
hgs
parents:
diff changeset
    11
// Contributors:
hgs
parents:
diff changeset
    12
//
hgs
parents:
diff changeset
    13
// Description:
hgs
parents:
diff changeset
    14
// Test the Wserv heart beat switch on and off
hgs
parents:
diff changeset
    15
// 
hgs
parents:
diff changeset
    16
//
hgs
parents:
diff changeset
    17
hgs
parents:
diff changeset
    18
/**
hgs
parents:
diff changeset
    19
 @file
hgs
parents:
diff changeset
    20
 @test
hgs
parents:
diff changeset
    21
 @internalComponent - Internal Symbian test code
hgs
parents:
diff changeset
    22
*/
hgs
parents:
diff changeset
    23
hgs
parents:
diff changeset
    24
#include "THeartBeat.h"
hgs
parents:
diff changeset
    25
#include <w32debug.h>
hgs
parents:
diff changeset
    26
hgs
parents:
diff changeset
    27
CTHeartBeatTest::CTHeartBeatTest(CTestStep* aStep) :
hgs
parents:
diff changeset
    28
	CTWsGraphicsBase(aStep)
hgs
parents:
diff changeset
    29
	{
hgs
parents:
diff changeset
    30
	}
hgs
parents:
diff changeset
    31
hgs
parents:
diff changeset
    32
CTHeartBeatTest::~CTHeartBeatTest()
hgs
parents:
diff changeset
    33
	{
hgs
parents:
diff changeset
    34
	iAnimDll.Close();
hgs
parents:
diff changeset
    35
	delete iHbTestWin;
hgs
parents:
diff changeset
    36
	}
hgs
parents:
diff changeset
    37
hgs
parents:
diff changeset
    38
void CTHeartBeatTest::ConstructL()
hgs
parents:
diff changeset
    39
	{
hgs
parents:
diff changeset
    40
	TSize screenSize=TheClient->iGroup->Size();
hgs
parents:
diff changeset
    41
	TInt winWidth=(screenSize.iWidth/3)-10;
hgs
parents:
diff changeset
    42
	TInt winHeight=screenSize.iHeight-10;
hgs
parents:
diff changeset
    43
	iHbTestWin=new(ELeave) CAnimWindow(EFalse, CAnimWindow::ERedraw);
hgs
parents:
diff changeset
    44
	iHbTestWin->ConstructL(TPoint(screenSize.iWidth/3*2+5,5),TSize(winWidth,winHeight));
hgs
parents:
diff changeset
    45
	iAnimDll=RAnimDll(TheClient->iWs);
hgs
parents:
diff changeset
    46
	User::LeaveIfError(iAnimDll.Load(KAnimDLLName));
hgs
parents:
diff changeset
    47
	}
hgs
parents:
diff changeset
    48
hgs
parents:
diff changeset
    49
void CTHeartBeatTest::SetCursor(const TPoint& aPos,const TSize& aSize, TUint aFlags/*=0*/)
hgs
parents:
diff changeset
    50
	{ // Default aFlags=0 gives a flashing cursor
hgs
parents:
diff changeset
    51
	TTextCursor tc;
hgs
parents:
diff changeset
    52
	tc.iType=TTextCursor::ETypeRectangle;
hgs
parents:
diff changeset
    53
	tc.iHeight=aSize.iHeight;
hgs
parents:
diff changeset
    54
	tc.iAscent=aSize.iHeight*4/5;
hgs
parents:
diff changeset
    55
	tc.iWidth=aSize.iWidth;
hgs
parents:
diff changeset
    56
	tc.iFlags=aFlags;	
hgs
parents:
diff changeset
    57
	tc.iColor=KRgbGreen;
hgs
parents:
diff changeset
    58
	TheClient->iGroup->GroupWin()->SetTextCursor(*iHbTestWin->BaseWin(),TPoint(aPos.iX,aPos.iY+tc.iAscent),tc);
hgs
parents:
diff changeset
    59
	}
hgs
parents:
diff changeset
    60
hgs
parents:
diff changeset
    61
TBool CTHeartBeatTest::SetAutoHeartBeatPauseState(TBool aState) const
hgs
parents:
diff changeset
    62
	{
hgs
parents:
diff changeset
    63
	return(TheClient->iWs.DebugInfo(EWsDebugSetAutoHeartBeatPauseState,aState));
hgs
parents:
diff changeset
    64
	}
hgs
parents:
diff changeset
    65
hgs
parents:
diff changeset
    66
TBool CTHeartBeatTest::GetHeartBeatTimerState() const
hgs
parents:
diff changeset
    67
	{
hgs
parents:
diff changeset
    68
	return(TheClient->iWs.DebugInfo(EWsDebugHeartBeatState));
hgs
parents:
diff changeset
    69
	}
hgs
parents:
diff changeset
    70
hgs
parents:
diff changeset
    71
void CTHeartBeatTest::CancelTextCursor()
hgs
parents:
diff changeset
    72
	{
hgs
parents:
diff changeset
    73
	TheClient->iGroup->GroupWin()->CancelTextCursor();
hgs
parents:
diff changeset
    74
	}
hgs
parents:
diff changeset
    75
hgs
parents:
diff changeset
    76
void CTHeartBeatTest::TestTextCursorTimerL()
hgs
parents:
diff changeset
    77
	{
hgs
parents:
diff changeset
    78
	TEST(!GetHeartBeatTimerState());
hgs
parents:
diff changeset
    79
	SetCursor(TPoint(0,0),TSize(10,10));
hgs
parents:
diff changeset
    80
	TEST(GetHeartBeatTimerState());
hgs
parents:
diff changeset
    81
	CancelTextCursor();
hgs
parents:
diff changeset
    82
	TEST(!GetHeartBeatTimerState());
hgs
parents:
diff changeset
    83
//
hgs
parents:
diff changeset
    84
	TPoint testCursorPos;
hgs
parents:
diff changeset
    85
	TSize testCursorSize(10,10);
hgs
parents:
diff changeset
    86
	SetCursor(testCursorPos,testCursorSize);
hgs
parents:
diff changeset
    87
	TEST(GetHeartBeatTimerState());
hgs
parents:
diff changeset
    88
	iHbTestWin->BaseWin()->SetVisible(EFalse);
hgs
parents:
diff changeset
    89
	TEST(!GetHeartBeatTimerState());
hgs
parents:
diff changeset
    90
	iHbTestWin->BaseWin()->SetVisible(ETrue);
hgs
parents:
diff changeset
    91
	TEST(GetHeartBeatTimerState());
hgs
parents:
diff changeset
    92
//
hgs
parents:
diff changeset
    93
// Cover the cursor and check heartbeat disabled
hgs
parents:
diff changeset
    94
	RWindow coverCursor(TheClient->iWs);
hgs
parents:
diff changeset
    95
	CleanupClosePushL(coverCursor);
hgs
parents:
diff changeset
    96
	User::LeaveIfError(coverCursor.Construct(*iHbTestWin->BaseWin(), 0xBADBAD));
hgs
parents:
diff changeset
    97
	coverCursor.SetExtent(testCursorPos,testCursorSize);
hgs
parents:
diff changeset
    98
	coverCursor.Activate();
hgs
parents:
diff changeset
    99
	TEST(!GetHeartBeatTimerState());
hgs
parents:
diff changeset
   100
// Now fractionally expose the cursor and check heartbeat re-enabled
hgs
parents:
diff changeset
   101
	coverCursor.SetExtent(testCursorPos+TPoint(1,1),testCursorSize);
hgs
parents:
diff changeset
   102
	TEST(GetHeartBeatTimerState());
hgs
parents:
diff changeset
   103
// Re-cover it
hgs
parents:
diff changeset
   104
	coverCursor.SetExtent(testCursorPos,testCursorSize);
hgs
parents:
diff changeset
   105
	TEST(!GetHeartBeatTimerState());
hgs
parents:
diff changeset
   106
// Enlarge cursor to expose itself then check heartbeat
hgs
parents:
diff changeset
   107
	SetCursor(testCursorPos,TSize(testCursorSize.iWidth+1,testCursorSize.iHeight));
hgs
parents:
diff changeset
   108
	TEST(GetHeartBeatTimerState());
hgs
parents:
diff changeset
   109
// Shrink cursor then check heartbeat
hgs
parents:
diff changeset
   110
	SetCursor(testCursorPos,testCursorSize);
hgs
parents:
diff changeset
   111
	TEST(!GetHeartBeatTimerState());
hgs
parents:
diff changeset
   112
// Turn off auto heart beat pausing, should turn timer back on
hgs
parents:
diff changeset
   113
	SetAutoHeartBeatPauseState(EFalse);
hgs
parents:
diff changeset
   114
	TEST(GetHeartBeatTimerState());
hgs
parents:
diff changeset
   115
// With auto pausing enabled covering/uncovering the cursor should have no effect,
hgs
parents:
diff changeset
   116
// timer will always be on
hgs
parents:
diff changeset
   117
	coverCursor.SetVisible(EFalse);
hgs
parents:
diff changeset
   118
	TEST(GetHeartBeatTimerState());
hgs
parents:
diff changeset
   119
	coverCursor.SetVisible(ETrue);
hgs
parents:
diff changeset
   120
	TEST(GetHeartBeatTimerState());
hgs
parents:
diff changeset
   121
// Re-enable auto-pause should turn timer back off
hgs
parents:
diff changeset
   122
	SetAutoHeartBeatPauseState(ETrue);
hgs
parents:
diff changeset
   123
	TEST(!GetHeartBeatTimerState());
hgs
parents:
diff changeset
   124
// Destroy covering window and check heartbeat re-enabled
hgs
parents:
diff changeset
   125
	CleanupStack::PopAndDestroy(&coverCursor);
hgs
parents:
diff changeset
   126
	TEST(GetHeartBeatTimerState());
hgs
parents:
diff changeset
   127
// Check using no flash flag turns timer off
hgs
parents:
diff changeset
   128
	SetCursor(testCursorPos,testCursorSize,TTextCursor::EFlagNoFlash);
hgs
parents:
diff changeset
   129
	TEST(!GetHeartBeatTimerState());
hgs
parents:
diff changeset
   130
// and turning no flash flag off turns timer back on
hgs
parents:
diff changeset
   131
	SetCursor(testCursorPos,testCursorSize);
hgs
parents:
diff changeset
   132
	TEST(GetHeartBeatTimerState());
hgs
parents:
diff changeset
   133
// Preparing for switch off should disable the heartbeat until another event is received
hgs
parents:
diff changeset
   134
	TheClient->iWs.PrepareForSwitchOff();
hgs
parents:
diff changeset
   135
	TEST(!GetHeartBeatTimerState());
hgs
parents:
diff changeset
   136
// Any event should wake the hearbeat back up again
hgs
parents:
diff changeset
   137
	TRawEvent rawEvent;
hgs
parents:
diff changeset
   138
	rawEvent.Set(TRawEvent::EPointerMove,0,0);
hgs
parents:
diff changeset
   139
	TheClient->iWs.SimulateRawEvent(rawEvent);
hgs
parents:
diff changeset
   140
	TEST(GetHeartBeatTimerState());
hgs
parents:
diff changeset
   141
//
hgs
parents:
diff changeset
   142
	CancelTextCursor();
hgs
parents:
diff changeset
   143
	TEST(!GetHeartBeatTimerState());
hgs
parents:
diff changeset
   144
// Check heartbeat still off as expected
hgs
parents:
diff changeset
   145
	TheClient->iWs.PrepareForSwitchOff();
hgs
parents:
diff changeset
   146
	TEST(!GetHeartBeatTimerState());
hgs
parents:
diff changeset
   147
// Check when hearbeat not required that it's not turned back when coming out of PrepareForSwitchOff() mode.
hgs
parents:
diff changeset
   148
	TheClient->iWs.SimulateRawEvent(rawEvent);
hgs
parents:
diff changeset
   149
	TheClient->Flush();
hgs
parents:
diff changeset
   150
	TEST(!GetHeartBeatTimerState());
hgs
parents:
diff changeset
   151
	}
hgs
parents:
diff changeset
   152
hgs
parents:
diff changeset
   153
void CTHeartBeatTest::doTestActiveInactiveEvents(TBool aCursorOn, TBool aAutoPauseOn)
hgs
parents:
diff changeset
   154
	{
hgs
parents:
diff changeset
   155
	SetAutoHeartBeatPauseState(aAutoPauseOn);
hgs
parents:
diff changeset
   156
	if (aCursorOn)
hgs
parents:
diff changeset
   157
		SetCursor(TPoint(0,0),TSize(10,10));
hgs
parents:
diff changeset
   158
// Should disable timer, regardless of other states
hgs
parents:
diff changeset
   159
	TRawEvent event;
hgs
parents:
diff changeset
   160
	event.Set(TRawEvent::EInactive);
hgs
parents:
diff changeset
   161
	UserSvr::AddEvent(event);
hgs
parents:
diff changeset
   162
	TEST(!GetHeartBeatTimerState());
hgs
parents:
diff changeset
   163
// ...and switch it back on
hgs
parents:
diff changeset
   164
	event.Set(TRawEvent::EActive);
hgs
parents:
diff changeset
   165
	UserSvr::AddEvent(event);
hgs
parents:
diff changeset
   166
	TBool testResult1=EFalse;
hgs
parents:
diff changeset
   167
	if (aAutoPauseOn)
hgs
parents:
diff changeset
   168
		testResult1=aCursorOn; // Only on if cursor is on without auto pause enabled
hgs
parents:
diff changeset
   169
	else
hgs
parents:
diff changeset
   170
		testResult1=ETrue; // Always on if auto pause disabled
hgs
parents:
diff changeset
   171
	TBool hbState=GetHeartBeatTimerState();
hgs
parents:
diff changeset
   172
	if ((!hbState)!=(!testResult1))
hgs
parents:
diff changeset
   173
		{
hgs
parents:
diff changeset
   174
		_LIT(KLog,"Fail in TestActiveInactiveEvents(%d.%d)  HBState=%d result=%d");
hgs
parents:
diff changeset
   175
		LOG_MESSAGE5(KLog,aCursorOn,aAutoPauseOn,hbState,testResult1);
hgs
parents:
diff changeset
   176
		}
hgs
parents:
diff changeset
   177
	TEST((!GetHeartBeatTimerState())==(!testResult1));		//Works with any positive value for True
hgs
parents:
diff changeset
   178
//
hgs
parents:
diff changeset
   179
	if (aCursorOn)
hgs
parents:
diff changeset
   180
		CancelTextCursor();
hgs
parents:
diff changeset
   181
	}
hgs
parents:
diff changeset
   182
hgs
parents:
diff changeset
   183
void CTHeartBeatTest::TestActiveInactiveEvents()
hgs
parents:
diff changeset
   184
	{
hgs
parents:
diff changeset
   185
	doTestActiveInactiveEvents(EFalse,EFalse);
hgs
parents:
diff changeset
   186
	doTestActiveInactiveEvents(ETrue,EFalse);
hgs
parents:
diff changeset
   187
	doTestActiveInactiveEvents(EFalse,ETrue);
hgs
parents:
diff changeset
   188
	doTestActiveInactiveEvents(ETrue,ETrue);
hgs
parents:
diff changeset
   189
	}
hgs
parents:
diff changeset
   190
hgs
parents:
diff changeset
   191
void CTHeartBeatTest::FailCursorHbTest(const TDesC& aErrorBase, const TDesC* aExtraText, TBool aHbState, TBool aHbCheckState)
hgs
parents:
diff changeset
   192
	{
hgs
parents:
diff changeset
   193
	TBuf<256> error(aErrorBase);
hgs
parents:
diff changeset
   194
	if (aExtraText)
hgs
parents:
diff changeset
   195
		{
hgs
parents:
diff changeset
   196
		error.Append(*aExtraText);
hgs
parents:
diff changeset
   197
		}
hgs
parents:
diff changeset
   198
	_LIT(KHbErrorAppendFmt," HB=%d (Testing for %d)");
hgs
parents:
diff changeset
   199
	error.AppendFormat(KHbErrorAppendFmt,aHbState,aHbCheckState);
hgs
parents:
diff changeset
   200
	LOG_MESSAGE(error);
hgs
parents:
diff changeset
   201
	TEST(EFalse);
hgs
parents:
diff changeset
   202
	}
hgs
parents:
diff changeset
   203
hgs
parents:
diff changeset
   204
TBool CTHeartBeatTest::ChangeTransAndCheckHeartBeat(TInt aTestMode, RWindow& aTransWin, const TRect& aGraphicRect, TInt aExtraWinTestMode, const TDesC* aErrorMsg, TBool aSetVisibleAfterTransUpdate)
hgs
parents:
diff changeset
   205
	{
hgs
parents:
diff changeset
   206
	TRect cursorRect(aGraphicRect);
hgs
parents:
diff changeset
   207
	cursorRect.Move(iHbTestWin->BaseWin()->InquireOffset(aTransWin));
hgs
parents:
diff changeset
   208
	TRect winRect(aTransWin.Size());
hgs
parents:
diff changeset
   209
	__ASSERT_ALWAYS(winRect.Contains(cursorRect.iTl) && winRect.Contains(cursorRect.iBr),AutoPanic(EAutoPanicHeartBeatCursorRect));
hgs
parents:
diff changeset
   210
//
hgs
parents:
diff changeset
   211
	TRegionFix<8> transRegion;
hgs
parents:
diff changeset
   212
	TBool heartBeatCheck=EFalse;
hgs
parents:
diff changeset
   213
	switch(aTestMode)
hgs
parents:
diff changeset
   214
		{
hgs
parents:
diff changeset
   215
		case ECursorTransWinTestModeFullTrans:
hgs
parents:
diff changeset
   216
			transRegion.AddRect(winRect);
hgs
parents:
diff changeset
   217
			heartBeatCheck=ETrue;
hgs
parents:
diff changeset
   218
			break;
hgs
parents:
diff changeset
   219
		case ECursorTransWinTestNoTrans:
hgs
parents:
diff changeset
   220
			break;
hgs
parents:
diff changeset
   221
		case ECursorTransWinTestPartialTransCoveringCursor:
hgs
parents:
diff changeset
   222
			transRegion.AddRect(winRect);
hgs
parents:
diff changeset
   223
			transRegion.SubRect(cursorRect);
hgs
parents:
diff changeset
   224
			break;
hgs
parents:
diff changeset
   225
		case ECursorTransWinTestPartialTransExposingCursor:
hgs
parents:
diff changeset
   226
			transRegion.AddRect(cursorRect);
hgs
parents:
diff changeset
   227
			heartBeatCheck=ETrue;
hgs
parents:
diff changeset
   228
			break;
hgs
parents:
diff changeset
   229
		default:
hgs
parents:
diff changeset
   230
			ASSERT(EFalse);
hgs
parents:
diff changeset
   231
		}
hgs
parents:
diff changeset
   232
	TBool invisHeartBeatCheck=ETrue;
hgs
parents:
diff changeset
   233
	switch(aExtraWinTestMode)
hgs
parents:
diff changeset
   234
		{
hgs
parents:
diff changeset
   235
		case ECursorTransWinTestNoTrans:
hgs
parents:
diff changeset
   236
		case ECursorTransWinTestPartialTransCoveringCursor:
hgs
parents:
diff changeset
   237
			heartBeatCheck=EFalse;
hgs
parents:
diff changeset
   238
			invisHeartBeatCheck=EFalse;
hgs
parents:
diff changeset
   239
			break;
hgs
parents:
diff changeset
   240
		default:
hgs
parents:
diff changeset
   241
			break;
hgs
parents:
diff changeset
   242
		}
hgs
parents:
diff changeset
   243
//
hgs
parents:
diff changeset
   244
	ASSERT(!transRegion.CheckError());
hgs
parents:
diff changeset
   245
	if (aSetVisibleAfterTransUpdate)
hgs
parents:
diff changeset
   246
		aTransWin.SetVisible(EFalse);
hgs
parents:
diff changeset
   247
	aTransWin.SetTransparentRegion(transRegion);
hgs
parents:
diff changeset
   248
	if (aSetVisibleAfterTransUpdate)
hgs
parents:
diff changeset
   249
		aTransWin.SetVisible(ETrue);
hgs
parents:
diff changeset
   250
//
hgs
parents:
diff changeset
   251
	TBool testSuccess=ETrue;
hgs
parents:
diff changeset
   252
	TBool heartBeatState=GetHeartBeatTimerState();
hgs
parents:
diff changeset
   253
	TBool failed1stTest=EFalse;
hgs
parents:
diff changeset
   254
	if ((!heartBeatState)!=(!heartBeatCheck))		//Works with any positive value for True
hgs
parents:
diff changeset
   255
		{
hgs
parents:
diff changeset
   256
		failed1stTest=ETrue;
hgs
parents:
diff changeset
   257
		_LIT(KFailedHbTest,"Failed ");
hgs
parents:
diff changeset
   258
		FailCursorHbTest(KFailedHbTest,aErrorMsg,heartBeatState,heartBeatCheck);
hgs
parents:
diff changeset
   259
		testSuccess=EFalse;
hgs
parents:
diff changeset
   260
		}
hgs
parents:
diff changeset
   261
//
hgs
parents:
diff changeset
   262
	aTransWin.SetVisible(EFalse);
hgs
parents:
diff changeset
   263
	heartBeatState=GetHeartBeatTimerState();
hgs
parents:
diff changeset
   264
	_LIT(KGoingInvisAfterTestAppend," after %S");
hgs
parents:
diff changeset
   265
	TBuf<256> errorExtra;
hgs
parents:
diff changeset
   266
	if (aErrorMsg)
hgs
parents:
diff changeset
   267
		{
hgs
parents:
diff changeset
   268
		errorExtra.Format(KGoingInvisAfterTestAppend,aErrorMsg);
hgs
parents:
diff changeset
   269
		}
hgs
parents:
diff changeset
   270
	if ((!heartBeatState)!=(!invisHeartBeatCheck))		//Works with any positive value for True
hgs
parents:
diff changeset
   271
		{
hgs
parents:
diff changeset
   272
		_LIT(KFailedGoingInvis,"Failed setting trans win invisible");
hgs
parents:
diff changeset
   273
		FailCursorHbTest(KFailedGoingInvis,&errorExtra,heartBeatState,invisHeartBeatCheck);
hgs
parents:
diff changeset
   274
		testSuccess=EFalse;
hgs
parents:
diff changeset
   275
		}
hgs
parents:
diff changeset
   276
//
hgs
parents:
diff changeset
   277
	aTransWin.SetVisible(ETrue);
hgs
parents:
diff changeset
   278
	heartBeatState=GetHeartBeatTimerState();
hgs
parents:
diff changeset
   279
	if (!failed1stTest && (!heartBeatState)!=(!heartBeatCheck))		//Works with any positive value for True
hgs
parents:
diff changeset
   280
		{
hgs
parents:
diff changeset
   281
		_LIT(KFailedResettingVis,"Failed re-setting trans win visible");
hgs
parents:
diff changeset
   282
		FailCursorHbTest(KFailedResettingVis,&errorExtra,heartBeatState,heartBeatCheck);
hgs
parents:
diff changeset
   283
		testSuccess=EFalse;
hgs
parents:
diff changeset
   284
		}
hgs
parents:
diff changeset
   285
	return(testSuccess);
hgs
parents:
diff changeset
   286
	}
hgs
parents:
diff changeset
   287
hgs
parents:
diff changeset
   288
void CTHeartBeatTest::LoopThroughTransWinTestModes(RWindow& aTransWin, const TRect& aGraphicRect, TInt aExtraWinTestMode)
hgs
parents:
diff changeset
   289
	{
hgs
parents:
diff changeset
   290
	TBuf<256> error;
hgs
parents:
diff changeset
   291
	for(TInt setVisMode=0;setVisMode<2;setVisMode++)
hgs
parents:
diff changeset
   292
		{
hgs
parents:
diff changeset
   293
		if (setVisMode==0)
hgs
parents:
diff changeset
   294
			continue;	// zzz setinvis/makevis needed to flush out changes it seems
hgs
parents:
diff changeset
   295
		const TBool setVisibleAfterTransUpdate=setVisMode>0;
hgs
parents:
diff changeset
   296
		for(TInt startTestMode=0;startTestMode<ENumCursorTransWinTestModes;startTestMode++)
hgs
parents:
diff changeset
   297
			{
hgs
parents:
diff changeset
   298
			if (startTestMode==ECursorTransWinTestNoTrans)
hgs
parents:
diff changeset
   299
				continue;// zzz bugged trans win problem
hgs
parents:
diff changeset
   300
			_LIT(KTcHbModeSetFail,"setting test mode %d (vis mode %d)");
hgs
parents:
diff changeset
   301
			error.Format(KTcHbModeSetFail,startTestMode,setVisibleAfterTransUpdate);
hgs
parents:
diff changeset
   302
			for(TInt switchToTestMode=0;switchToTestMode<ENumCursorTransWinTestModes;switchToTestMode++)
hgs
parents:
diff changeset
   303
				{
hgs
parents:
diff changeset
   304
				if (switchToTestMode==ECursorTransWinTestNoTrans)
hgs
parents:
diff changeset
   305
					continue;// zzz bugged trans win problem
hgs
parents:
diff changeset
   306
				if (startTestMode==switchToTestMode)
hgs
parents:
diff changeset
   307
					continue;
hgs
parents:
diff changeset
   308
				if (ChangeTransAndCheckHeartBeat(startTestMode, aTransWin, aGraphicRect, aExtraWinTestMode, &error, setVisibleAfterTransUpdate))
hgs
parents:
diff changeset
   309
					{
hgs
parents:
diff changeset
   310
					_LIT(KTcHbModeSwitchFail,"switching from test mode %d to %d (vis mode %d)");
hgs
parents:
diff changeset
   311
					error.Format(KTcHbModeSwitchFail, startTestMode, switchToTestMode, setVisibleAfterTransUpdate);
hgs
parents:
diff changeset
   312
					ChangeTransAndCheckHeartBeat(switchToTestMode, aTransWin, aGraphicRect, aExtraWinTestMode, &error, setVisibleAfterTransUpdate);
hgs
parents:
diff changeset
   313
					}
hgs
parents:
diff changeset
   314
				}
hgs
parents:
diff changeset
   315
			}
hgs
parents:
diff changeset
   316
		ChangeTransAndCheckHeartBeat(0, aTransWin, aGraphicRect, aExtraWinTestMode, NULL, setVisibleAfterTransUpdate);
hgs
parents:
diff changeset
   317
		}
hgs
parents:
diff changeset
   318
	}
hgs
parents:
diff changeset
   319
hgs
parents:
diff changeset
   320
void CTHeartBeatTest::RunTransWinTestsL(const TRect& aGraphicRect)
hgs
parents:
diff changeset
   321
	{
hgs
parents:
diff changeset
   322
// Test a variety of patterns of changing the layout of transparent windows over the cursor
hgs
parents:
diff changeset
   323
// cause the heartbeat state to be modified accordingly.
hgs
parents:
diff changeset
   324
//
hgs
parents:
diff changeset
   325
// Each transparent window has four specific states to test:
hgs
parents:
diff changeset
   326
// i) Transparency area is the whole window
hgs
parents:
diff changeset
   327
// ii) Partial transparency that exposes the cursor
hgs
parents:
diff changeset
   328
// iii) Partial transparency that covers the cursor
hgs
parents:
diff changeset
   329
// iv) Empty transparent region, i.e. totally opaque
hgs
parents:
diff changeset
   330
//
hgs
parents:
diff changeset
   331
// We need to test various transitions between these states, first on a single window, then
hgs
parents:
diff changeset
   332
// in a various layouts with transparent windows layered over each other.
hgs
parents:
diff changeset
   333
//
hgs
parents:
diff changeset
   334
	RWindow transWin1(TheClient->iWs);
hgs
parents:
diff changeset
   335
	User::LeaveIfError(transWin1.Construct(*TheClient->iGroup->GroupWin(),0xDEADBAD1));
hgs
parents:
diff changeset
   336
	CleanupClosePushL(transWin1);
hgs
parents:
diff changeset
   337
	if (transWin1.SetTransparencyFactor(TRgb::Gray256(128))!=KErrNone)
hgs
parents:
diff changeset
   338
		{	// Transparency not enabled, skip tests
hgs
parents:
diff changeset
   339
		CleanupStack::PopAndDestroy(&transWin1);
hgs
parents:
diff changeset
   340
		return;
hgs
parents:
diff changeset
   341
		}
hgs
parents:
diff changeset
   342
	transWin1.Activate();
hgs
parents:
diff changeset
   343
	TEST(GetHeartBeatTimerState());
hgs
parents:
diff changeset
   344
// First simply check activating default full screen transparent window doesn't disable the heartbeat
hgs
parents:
diff changeset
   345
	_LIT(KBasicTransCursorTests,"Running basic transparent window cursor heartbeat tests");
hgs
parents:
diff changeset
   346
	LOG_MESSAGE(KBasicTransCursorTests);
hgs
parents:
diff changeset
   347
	LoopThroughTransWinTestModes(transWin1, aGraphicRect, ECursorTransWinTestNA);
hgs
parents:
diff changeset
   348
//
hgs
parents:
diff changeset
   349
//  Lots of test code disabled due to bugs in handling of transparent window regions
hgs
parents:
diff changeset
   350
// See DEF110677, hopefully when the issues in there are addressed the rest of the
hgs
parents:
diff changeset
   351
// test code here can be enabled
hgs
parents:
diff changeset
   352
//  See sections marked with zzz for places where certain tests are disabled, once DEF110677
hgs
parents:
diff changeset
   353
// is marked as fixed these sections should be re-enabled and if problems still occur they
hgs
parents:
diff changeset
   354
// need to be investigated.
hgs
parents:
diff changeset
   355
//
hgs
parents:
diff changeset
   356
//
hgs
parents:
diff changeset
   357
// Now check more complex modes with two transparent windows over the test window
hgs
parents:
diff changeset
   358
	RWindow transWin2(TheClient->iWs);
hgs
parents:
diff changeset
   359
	User::LeaveIfError(transWin2.Construct(*TheClient->iGroup->GroupWin(),0xDEADBAD2));
hgs
parents:
diff changeset
   360
	CleanupClosePushL(transWin2);
hgs
parents:
diff changeset
   361
	User::LeaveIfError(transWin2.SetTransparencyFactor(TRgb::Gray256(128)));
hgs
parents:
diff changeset
   362
	TSize screenSize=TheClient->iGroup->Size();
hgs
parents:
diff changeset
   363
	screenSize.iWidth-=10;
hgs
parents:
diff changeset
   364
	transWin1.SetExtent(TPoint(0,0),screenSize);
hgs
parents:
diff changeset
   365
	transWin2.SetExtent(TPoint(10,0),screenSize);
hgs
parents:
diff changeset
   366
	transWin2.Activate();
hgs
parents:
diff changeset
   367
	for(TInt win1OrdPos=0;win1OrdPos<2;win1OrdPos++)
hgs
parents:
diff changeset
   368
		{
hgs
parents:
diff changeset
   369
		transWin1.SetOrdinalPosition(win1OrdPos);
hgs
parents:
diff changeset
   370
		_LIT(KOrdinalTransCursorTests,"Running tests with transwin1 ordinal pos=%d");
hgs
parents:
diff changeset
   371
		LOG_MESSAGE2(KOrdinalTransCursorTests,win1OrdPos);
hgs
parents:
diff changeset
   372
		for(TInt topWinTestMode=0;topWinTestMode<ENumCursorTransWinTestModes;topWinTestMode++)
hgs
parents:
diff changeset
   373
			{
hgs
parents:
diff changeset
   374
			if (topWinTestMode==ECursorTransWinTestNoTrans)
hgs
parents:
diff changeset
   375
				continue;// zzz bugged transparent window problem
hgs
parents:
diff changeset
   376
			if (topWinTestMode==ECursorTransWinTestPartialTransCoveringCursor)
hgs
parents:
diff changeset
   377
				continue;// zzz bugged transparent window problem
hgs
parents:
diff changeset
   378
			_LIT(KTopTransWinCursorTest,"Setting top trans win mode %d");
hgs
parents:
diff changeset
   379
			TBuf<256> msg;
hgs
parents:
diff changeset
   380
			msg.Format(KTopTransWinCursorTest,topWinTestMode);
hgs
parents:
diff changeset
   381
			LOG_MESSAGE(msg);
hgs
parents:
diff changeset
   382
			ChangeTransAndCheckHeartBeat(0, transWin2, aGraphicRect, topWinTestMode, NULL, ETrue);
hgs
parents:
diff changeset
   383
			LoopThroughTransWinTestModes(transWin1, aGraphicRect, topWinTestMode);
hgs
parents:
diff changeset
   384
			}
hgs
parents:
diff changeset
   385
		}
hgs
parents:
diff changeset
   386
	ChangeTransAndCheckHeartBeat(0, transWin2, aGraphicRect, 0, NULL, ETrue);
hgs
parents:
diff changeset
   387
	CleanupStack::PopAndDestroy(&transWin2);
hgs
parents:
diff changeset
   388
	TEST(GetHeartBeatTimerState());
hgs
parents:
diff changeset
   389
//
hgs
parents:
diff changeset
   390
	CleanupStack::PopAndDestroy(&transWin1);
hgs
parents:
diff changeset
   391
	TEST(GetHeartBeatTimerState());
hgs
parents:
diff changeset
   392
	}
hgs
parents:
diff changeset
   393
hgs
parents:
diff changeset
   394
void CTHeartBeatTest::TestTextCursorTimerTransL()
hgs
parents:
diff changeset
   395
	{
hgs
parents:
diff changeset
   396
	TSize testWinSize(iHbTestWin->BaseWin()->Size());
hgs
parents:
diff changeset
   397
	TRect cursorRect(testWinSize.iWidth/4,testWinSize.iHeight/3,testWinSize.iWidth*3/4,testWinSize.iHeight*2/3);
hgs
parents:
diff changeset
   398
	TEST(!GetHeartBeatTimerState());
hgs
parents:
diff changeset
   399
	SetCursor(cursorRect.iTl,cursorRect.Size());
hgs
parents:
diff changeset
   400
	TEST(GetHeartBeatTimerState());
hgs
parents:
diff changeset
   401
	RunTransWinTestsL(cursorRect);
hgs
parents:
diff changeset
   402
	CancelTextCursor();
hgs
parents:
diff changeset
   403
	TEST(!GetHeartBeatTimerState());
hgs
parents:
diff changeset
   404
	}
hgs
parents:
diff changeset
   405
hgs
parents:
diff changeset
   406
void CTHeartBeatTest::TestHeartBeatStopStart(TBool aHeartbeatStateOff,TBool aHeartbeatStateOn,const TDesC& aOffText,const TDesC& aOnText)
hgs
parents:
diff changeset
   407
	{
hgs
parents:
diff changeset
   408
	TEST(!aHeartbeatStateOff);
hgs
parents:
diff changeset
   409
	if (aHeartbeatStateOff)
hgs
parents:
diff changeset
   410
		LOG_MESSAGE2(_L("%S failed to disable heartbeat timer"),&aOffText);
hgs
parents:
diff changeset
   411
	TEST(aHeartbeatStateOn);
hgs
parents:
diff changeset
   412
	if (!aHeartbeatStateOn)
hgs
parents:
diff changeset
   413
		LOG_MESSAGE2(_L("%S failed to re-enable heartbeat timer"),&aOnText);
hgs
parents:
diff changeset
   414
	}
hgs
parents:
diff changeset
   415
hgs
parents:
diff changeset
   416
void CTHeartBeatTest::TestAnimDllL(TBool aSpriteMode, TUint aSpriteFlags)
hgs
parents:
diff changeset
   417
	{
hgs
parents:
diff changeset
   418
	RTestAnim anim(iAnimDll);
hgs
parents:
diff changeset
   419
	TEST(!GetHeartBeatTimerState());
hgs
parents:
diff changeset
   420
	TSize testWinSize(iHbTestWin->BaseWin()->Size());
hgs
parents:
diff changeset
   421
	TRect animRect(1,1,testWinSize.iWidth/3,testWinSize.iWidth/5);
hgs
parents:
diff changeset
   422
	TPckgC<TRect> rectPckg(animRect);
hgs
parents:
diff changeset
   423
	RWsSprite sprite(TheClient->iWs);
hgs
parents:
diff changeset
   424
	CleanupClosePushL(sprite);
hgs
parents:
diff changeset
   425
	if (aSpriteMode)
hgs
parents:
diff changeset
   426
		{
hgs
parents:
diff changeset
   427
		sprite.Construct(*iHbTestWin->BaseWin(),TPoint(),aSpriteFlags);
hgs
parents:
diff changeset
   428
		CFbsBitmap* bitmap1=new(ELeave) CFbsBitmap();
hgs
parents:
diff changeset
   429
		CleanupStack::PushL(bitmap1);
hgs
parents:
diff changeset
   430
		CFbsBitmap* bitmap2=new(ELeave) CFbsBitmap();
hgs
parents:
diff changeset
   431
		CleanupStack::PushL(bitmap2);
hgs
parents:
diff changeset
   432
		CFbsBitmap* bitmap3=new(ELeave) CFbsBitmap();
hgs
parents:
diff changeset
   433
		CleanupStack::PushL(bitmap3);
hgs
parents:
diff changeset
   434
		TSize animSize(animRect.Size());
hgs
parents:
diff changeset
   435
		User::LeaveIfError(bitmap1->Create(TSize(animSize.iWidth/2,animSize.iHeight/2),EGray4));
hgs
parents:
diff changeset
   436
		User::LeaveIfError(bitmap2->Create(TSize(animSize.iWidth,animSize.iHeight/3),EGray4));
hgs
parents:
diff changeset
   437
		User::LeaveIfError(bitmap3->Create(TSize(animSize.iWidth/3,animSize.iHeight),EGray4));
hgs
parents:
diff changeset
   438
//
hgs
parents:
diff changeset
   439
		TSpriteMember member1;
hgs
parents:
diff changeset
   440
		member1.iMaskBitmap=NULL;
hgs
parents:
diff changeset
   441
		member1.iInvertMask=EFalse;
hgs
parents:
diff changeset
   442
		member1.iDrawMode=CGraphicsContext::EDrawModePEN;
hgs
parents:
diff changeset
   443
		member1.iOffset=TPoint();
hgs
parents:
diff changeset
   444
		member1.iInterval=TTimeIntervalMicroSeconds32(1);
hgs
parents:
diff changeset
   445
		member1.iBitmap=bitmap1;
hgs
parents:
diff changeset
   446
		member1.iMaskBitmap=bitmap1;
hgs
parents:
diff changeset
   447
		sprite.AppendMember(member1);
hgs
parents:
diff changeset
   448
//
hgs
parents:
diff changeset
   449
		TSpriteMember member2;
hgs
parents:
diff changeset
   450
		member2.iInvertMask=EFalse;
hgs
parents:
diff changeset
   451
		member2.iDrawMode=CGraphicsContext::EDrawModeXOR;
hgs
parents:
diff changeset
   452
		member2.iOffset=TPoint(1,2);
hgs
parents:
diff changeset
   453
		member2.iInterval=TTimeIntervalMicroSeconds32(2);
hgs
parents:
diff changeset
   454
		member2.iBitmap=bitmap2;
hgs
parents:
diff changeset
   455
		member2.iMaskBitmap=bitmap2;
hgs
parents:
diff changeset
   456
		sprite.AppendMember(member2);
hgs
parents:
diff changeset
   457
//
hgs
parents:
diff changeset
   458
		TSpriteMember member3;
hgs
parents:
diff changeset
   459
		member3.iInvertMask=ETrue;
hgs
parents:
diff changeset
   460
		member3.iDrawMode=CGraphicsContext::EDrawModeOR;
hgs
parents:
diff changeset
   461
		member3.iOffset=TPoint(3,4);
hgs
parents:
diff changeset
   462
		member3.iInterval=TTimeIntervalMicroSeconds32(3);
hgs
parents:
diff changeset
   463
		member3.iBitmap=bitmap3;
hgs
parents:
diff changeset
   464
		member3.iMaskBitmap=bitmap3;
hgs
parents:
diff changeset
   465
		sprite.AppendMember(member3);
hgs
parents:
diff changeset
   466
//
hgs
parents:
diff changeset
   467
		User::LeaveIfError(anim.Construct(sprite,EAnimTypeSprite,rectPckg));
hgs
parents:
diff changeset
   468
		CleanupStack::PopAndDestroy(3,bitmap1);
hgs
parents:
diff changeset
   469
		}
hgs
parents:
diff changeset
   470
	else
hgs
parents:
diff changeset
   471
		{
hgs
parents:
diff changeset
   472
		User::LeaveIfError(anim.Construct(*iHbTestWin->BaseWin(),EAnimTypeTest3,rectPckg));
hgs
parents:
diff changeset
   473
		}
hgs
parents:
diff changeset
   474
	CleanupClosePushL(anim);
hgs
parents:
diff changeset
   475
	TEST(GetHeartBeatTimerState());
hgs
parents:
diff changeset
   476
hgs
parents:
diff changeset
   477
	// Cover up the window with the animation and check this disables the heartbeat timer.
hgs
parents:
diff changeset
   478
	RBlankWindow blankwin1(TheClient->iWs);
hgs
parents:
diff changeset
   479
	User::LeaveIfError(blankwin1.Construct(*TheClient->iGroup->GroupWin(),123));
hgs
parents:
diff changeset
   480
	TPoint winOffset(iHbTestWin->BaseWin()->InquireOffset(*TheClient->iGroup->GroupWin()));
hgs
parents:
diff changeset
   481
	if (aSpriteMode)
hgs
parents:
diff changeset
   482
		blankwin1.SetExtent(winOffset,testWinSize);
hgs
parents:
diff changeset
   483
	else
hgs
parents:
diff changeset
   484
		blankwin1.SetExtent(winOffset+animRect.iTl,animRect.Size());
hgs
parents:
diff changeset
   485
	blankwin1.Activate();
hgs
parents:
diff changeset
   486
	TBool heartbeatStateOff=GetHeartBeatTimerState();
hgs
parents:
diff changeset
   487
	TEST(!heartbeatStateOff);
hgs
parents:
diff changeset
   488
	if (heartbeatStateOff)
hgs
parents:
diff changeset
   489
		{
hgs
parents:
diff changeset
   490
		LOG_MESSAGE(_L("Covering window failed to disable heartbeat timer"));
hgs
parents:
diff changeset
   491
		}
hgs
parents:
diff changeset
   492
	TBool heartbeatStateOn;
hgs
parents:
diff changeset
   493
	if (!aSpriteMode)
hgs
parents:
diff changeset
   494
		{
hgs
parents:
diff changeset
   495
		// Resize the anim so it becomes visible, then shrink back down again
hgs
parents:
diff changeset
   496
		animRect.iBr.iX++;
hgs
parents:
diff changeset
   497
		anim.Command(EADllSetRect,rectPckg);
hgs
parents:
diff changeset
   498
		heartbeatStateOn=GetHeartBeatTimerState();
hgs
parents:
diff changeset
   499
		animRect.iBr.iX--;
hgs
parents:
diff changeset
   500
		anim.Command(EADllSetRect,rectPckg);
hgs
parents:
diff changeset
   501
		heartbeatStateOff=GetHeartBeatTimerState();
hgs
parents:
diff changeset
   502
		TestHeartBeatStopStart(heartbeatStateOff,heartbeatStateOn,_L("Shrinking anim"),_L("Growing anim"));
hgs
parents:
diff changeset
   503
		}
hgs
parents:
diff changeset
   504
//
hgs
parents:
diff changeset
   505
	blankwin1.Close();
hgs
parents:
diff changeset
   506
	heartbeatStateOn=GetHeartBeatTimerState();
hgs
parents:
diff changeset
   507
	TEST(heartbeatStateOn);
hgs
parents:
diff changeset
   508
	if (!heartbeatStateOn)
hgs
parents:
diff changeset
   509
		{
hgs
parents:
diff changeset
   510
		LOG_MESSAGE(_L("Un-covering window failed to disable heartbeat timer"));
hgs
parents:
diff changeset
   511
		}
hgs
parents:
diff changeset
   512
hgs
parents:
diff changeset
   513
	// Put a transparent window over the animation and check the heartbeat timer is not disabled
hgs
parents:
diff changeset
   514
	RWindow transWin(TheClient->iWs);
hgs
parents:
diff changeset
   515
	User::LeaveIfError(transWin.Construct(*TheClient->iGroup->GroupWin(),123));
hgs
parents:
diff changeset
   516
	if (transWin.SetTransparencyFactor(TRgb::Gray256(128))==KErrNone)
hgs
parents:
diff changeset
   517
		{
hgs
parents:
diff changeset
   518
		transWin.Activate();
hgs
parents:
diff changeset
   519
		heartbeatStateOn=GetHeartBeatTimerState();
hgs
parents:
diff changeset
   520
		TEST(heartbeatStateOn);
hgs
parents:
diff changeset
   521
		if (!heartbeatStateOn)
hgs
parents:
diff changeset
   522
			LOG_MESSAGE(_L("Transparent window caused heartbeat timer to be disabled"));
hgs
parents:
diff changeset
   523
		TRegionFix<1> emptyRegion;
hgs
parents:
diff changeset
   524
		transWin.SetTransparentRegion(emptyRegion);
hgs
parents:
diff changeset
   525
		heartbeatStateOff=GetHeartBeatTimerState();
hgs
parents:
diff changeset
   526
		TRegionFix<1> fullRegion(transWin.Size());
hgs
parents:
diff changeset
   527
		transWin.SetTransparentRegion(fullRegion);
hgs
parents:
diff changeset
   528
		heartbeatStateOn=GetHeartBeatTimerState();
hgs
parents:
diff changeset
   529
		TestHeartBeatStopStart(heartbeatStateOff,heartbeatStateOn,_L("Making covering window opaque"),_L("Making covering window transparent"));
hgs
parents:
diff changeset
   530
		if (aSpriteMode)
hgs
parents:
diff changeset
   531
			{
hgs
parents:
diff changeset
   532
			RBlankWindow blankwin2(TheClient->iWs);
hgs
parents:
diff changeset
   533
			User::LeaveIfError(blankwin2.Construct(*iHbTestWin->BaseWin(),1234));
hgs
parents:
diff changeset
   534
			blankwin2.Activate();
hgs
parents:
diff changeset
   535
			heartbeatStateOn=GetHeartBeatTimerState();
hgs
parents:
diff changeset
   536
			// With ESpriteNoChildClip the heartbeat should still be on as the sprite will still be visible
hgs
parents:
diff changeset
   537
			// Without it blankwin2 will cover up the sprite and cancel the heartbeat
hgs
parents:
diff changeset
   538
			TBool heartBeatCheck=aSpriteFlags&ESpriteNoChildClip;
hgs
parents:
diff changeset
   539
			TEST((!heartbeatStateOn)==(!heartBeatCheck));		//Works with any positive value for True
hgs
parents:
diff changeset
   540
			blankwin2.Close();
hgs
parents:
diff changeset
   541
			}
hgs
parents:
diff changeset
   542
		transWin.SetTransparentRegion(emptyRegion);
hgs
parents:
diff changeset
   543
		heartbeatStateOff=GetHeartBeatTimerState();
hgs
parents:
diff changeset
   544
		transWin.Close();
hgs
parents:
diff changeset
   545
		heartbeatStateOn=GetHeartBeatTimerState();
hgs
parents:
diff changeset
   546
		TestHeartBeatStopStart(heartbeatStateOff,heartbeatStateOn,_L("Making covering window opaque"),_L("Un-covering window"));
hgs
parents:
diff changeset
   547
		}
hgs
parents:
diff changeset
   548
	else
hgs
parents:
diff changeset
   549
		transWin.Close();
hgs
parents:
diff changeset
   550
hgs
parents:
diff changeset
   551
	// Make the window with the animation invisible and check this disables the heartbeat timer.
hgs
parents:
diff changeset
   552
	iHbTestWin->BaseWin()->SetVisible(EFalse);
hgs
parents:
diff changeset
   553
	heartbeatStateOff=GetHeartBeatTimerState();
hgs
parents:
diff changeset
   554
	iHbTestWin->BaseWin()->SetVisible(ETrue);
hgs
parents:
diff changeset
   555
	heartbeatStateOn=GetHeartBeatTimerState();
hgs
parents:
diff changeset
   556
	TestHeartBeatStopStart(heartbeatStateOff,heartbeatStateOn,_L("Making window invisible"),_L("Making window visible"));
hgs
parents:
diff changeset
   557
hgs
parents:
diff changeset
   558
	// Move the window with the animation off screen and check this disables the heartbeat timer.
hgs
parents:
diff changeset
   559
	TSize screenSize=TheClient->iGroup->Size();
hgs
parents:
diff changeset
   560
	TPoint oldPos(iHbTestWin->BaseWin()->Position());
hgs
parents:
diff changeset
   561
	iHbTestWin->BaseWin()->SetPosition(screenSize.AsPoint());
hgs
parents:
diff changeset
   562
	heartbeatStateOff=GetHeartBeatTimerState();
hgs
parents:
diff changeset
   563
	iHbTestWin->BaseWin()->SetPosition(oldPos);
hgs
parents:
diff changeset
   564
	heartbeatStateOn=GetHeartBeatTimerState();
hgs
parents:
diff changeset
   565
	TestHeartBeatStopStart(heartbeatStateOff,heartbeatStateOn,_L("Moving window offscreen"),_L("Moving window back onscreen"));
hgs
parents:
diff changeset
   566
	TEST(GetHeartBeatTimerState());
hgs
parents:
diff changeset
   567
	CleanupStack::PopAndDestroy(&anim);
hgs
parents:
diff changeset
   568
	TEST(!GetHeartBeatTimerState());
hgs
parents:
diff changeset
   569
	CleanupStack::PopAndDestroy(&sprite);
hgs
parents:
diff changeset
   570
	}
hgs
parents:
diff changeset
   571
hgs
parents:
diff changeset
   572
void CTHeartBeatTest::TestAnimDllTransL()
hgs
parents:
diff changeset
   573
	{
hgs
parents:
diff changeset
   574
	RTestAnim anim(iAnimDll);
hgs
parents:
diff changeset
   575
	TSize testWinSize(iHbTestWin->BaseWin()->Size());
hgs
parents:
diff changeset
   576
	TRect animRect(testWinSize.iWidth/4,testWinSize.iHeight/3,testWinSize.iWidth*3/4,testWinSize.iHeight*2/3);
hgs
parents:
diff changeset
   577
	TPckgBuf<TRect> rectPckg;
hgs
parents:
diff changeset
   578
	rectPckg()=animRect;
hgs
parents:
diff changeset
   579
	TEST(!GetHeartBeatTimerState());
hgs
parents:
diff changeset
   580
	User::LeaveIfError(anim.Construct(*iHbTestWin->BaseWin(),EAnimTypeTest3,rectPckg));
hgs
parents:
diff changeset
   581
	CleanupClosePushL(anim);
hgs
parents:
diff changeset
   582
	TEST(GetHeartBeatTimerState());
hgs
parents:
diff changeset
   583
//
hgs
parents:
diff changeset
   584
	RunTransWinTestsL(animRect);
hgs
parents:
diff changeset
   585
//
hgs
parents:
diff changeset
   586
	CleanupStack::PopAndDestroy(&anim);
hgs
parents:
diff changeset
   587
	TEST(!GetHeartBeatTimerState());
hgs
parents:
diff changeset
   588
	}
hgs
parents:
diff changeset
   589
hgs
parents:
diff changeset
   590
void CTHeartBeatTest::RunTestCaseL(TInt /*aCurTestCase*/)
hgs
parents:
diff changeset
   591
	{
hgs
parents:
diff changeset
   592
	
hgs
parents:
diff changeset
   593
	switch(++iTest->iState)
hgs
parents:
diff changeset
   594
		{
hgs
parents:
diff changeset
   595
		case 1:
hgs
parents:
diff changeset
   596
/**
hgs
parents:
diff changeset
   597
@SYMTestCaseID		GRAPHICS-WSERV-0568
hgs
parents:
diff changeset
   598
*/
hgs
parents:
diff changeset
   599
			((CTHeartBeatTestStep*)iStep)->SetTestStepID(_L("GRAPHICS-WSERV-0568"));
hgs
parents:
diff changeset
   600
			_LIT(KTestTextCursorTimer,"Basic heartbeat timer test");
hgs
parents:
diff changeset
   601
			iTest->LogSubTest(KTestTextCursorTimer);
hgs
parents:
diff changeset
   602
			TestTextCursorTimerL();
hgs
parents:
diff changeset
   603
			break;
hgs
parents:
diff changeset
   604
		case 2:
hgs
parents:
diff changeset
   605
/**
hgs
parents:
diff changeset
   606
@SYMTestCaseID		GRAPHICS-WSERV-0569
hgs
parents:
diff changeset
   607
*/
hgs
parents:
diff changeset
   608
			((CTHeartBeatTestStep*)iStep)->SetTestStepID(_L("GRAPHICS-WSERV-0569"));
hgs
parents:
diff changeset
   609
			_LIT(KTestTextCursorTimerTrans,"Heartbeat timer test with transparent windows");
hgs
parents:
diff changeset
   610
			iTest->LogSubTest(KTestTextCursorTimerTrans);
hgs
parents:
diff changeset
   611
			TestTextCursorTimerTransL();
hgs
parents:
diff changeset
   612
			break;
hgs
parents:
diff changeset
   613
		case 3:
hgs
parents:
diff changeset
   614
/**
hgs
parents:
diff changeset
   615
@SYMTestCaseID		GRAPHICS-WSERV-0570
hgs
parents:
diff changeset
   616
*/
hgs
parents:
diff changeset
   617
			((CTHeartBeatTestStep*)iStep)->SetTestStepID(_L("GRAPHICS-WSERV-0570"));
hgs
parents:
diff changeset
   618
			_LIT(KTestAnimDll1,"Anim DLL Heartbeat check (Win)");
hgs
parents:
diff changeset
   619
			iTest->LogSubTest(KTestAnimDll1);
hgs
parents:
diff changeset
   620
			TestAnimDllL(EFalse,0);
hgs
parents:
diff changeset
   621
			break;
hgs
parents:
diff changeset
   622
		case 4:
hgs
parents:
diff changeset
   623
/**
hgs
parents:
diff changeset
   624
@SYMTestCaseID		GRAPHICS-WSERV-0571
hgs
parents:
diff changeset
   625
*/
hgs
parents:
diff changeset
   626
			((CTHeartBeatTestStep*)iStep)->SetTestStepID(_L("GRAPHICS-WSERV-0571"));
hgs
parents:
diff changeset
   627
			_LIT(KTestAnimDll2,"Anim DLL Heartbeat check (Sprite)");
hgs
parents:
diff changeset
   628
			iTest->LogSubTest(KTestAnimDll2);
hgs
parents:
diff changeset
   629
			TestAnimDllL(ETrue,0);
hgs
parents:
diff changeset
   630
			TestAnimDllL(ETrue,ESpriteNoChildClip);
hgs
parents:
diff changeset
   631
			break;
hgs
parents:
diff changeset
   632
		case 5:
hgs
parents:
diff changeset
   633
/**
hgs
parents:
diff changeset
   634
@SYMTestCaseID		GRAPHICS-WSERV-0572
hgs
parents:
diff changeset
   635
*/
hgs
parents:
diff changeset
   636
			((CTHeartBeatTestStep*)iStep)->SetTestStepID(_L("GRAPHICS-WSERV-0572"));
hgs
parents:
diff changeset
   637
			_LIT(KTestAnimDllTrans,"Anim DLL Heartbeat check with transparent windows");
hgs
parents:
diff changeset
   638
			iTest->LogSubTest(KTestAnimDllTrans);
hgs
parents:
diff changeset
   639
			TestAnimDllTransL();
hgs
parents:
diff changeset
   640
			break;
hgs
parents:
diff changeset
   641
		case 6:
hgs
parents:
diff changeset
   642
/**
hgs
parents:
diff changeset
   643
@SYMTestCaseID		GRAPHICS-WSERV-0573
hgs
parents:
diff changeset
   644
*/
hgs
parents:
diff changeset
   645
			((CTHeartBeatTestStep*)iStep)->SetTestStepID(_L("GRAPHICS-WSERV-0573"));
hgs
parents:
diff changeset
   646
			_LIT(KTestActiveInactiveEvents,"Handling of TRawEvent::EInactive and EActive");
hgs
parents:
diff changeset
   647
			iTest->LogSubTest(KTestActiveInactiveEvents);
hgs
parents:
diff changeset
   648
			TestActiveInactiveEvents();
hgs
parents:
diff changeset
   649
			break;
hgs
parents:
diff changeset
   650
		default:
hgs
parents:
diff changeset
   651
			((CTHeartBeatTestStep*)iStep)->SetTestStepID(KNotATestSYMTestCaseIDName);
hgs
parents:
diff changeset
   652
			((CTHeartBeatTestStep*)iStep)->CloseTMSGraphicsStep();
hgs
parents:
diff changeset
   653
			TestComplete();
hgs
parents:
diff changeset
   654
			break;
hgs
parents:
diff changeset
   655
		}
hgs
parents:
diff changeset
   656
	((CTHeartBeatTestStep*)iStep)->RecordTestResultL();
hgs
parents:
diff changeset
   657
	}
hgs
parents:
diff changeset
   658
hgs
parents:
diff changeset
   659
__WS_CONSTRUCT_STEP__(HeartBeatTest)