os/graphics/egl/egltest/endpointtestsuite/automated/tsrc/egltest_endpointstreamingtests_local.cpp
Update contrib.
2 * Copyright (c) 2009 Nokia Corporation and/or its subsidiary(-ies).
4 * This component and the accompanying materials are made available
5 * under the terms of "Eclipse Public License v1.0"
6 * which accompanies this distribution, and is available
7 * at the URL "http://www.eclipse.org/legal/epl-v10.html".
9 * Initial Contributors:
10 * Nokia Corporation - initial contribution.
22 @internalComponent - Internal Symbian test code
26 #include "egltest_endpointstreamingtests.h"
27 #include "egltest_surface.h"
30 static const TTestCase KStreamingTestCases[] =
34 CASETITLE("Functional: Streaming: aStatusDisplayed behaves properly within streaming block"),
35 SurfaceTypes2(ESurfTypeRaw, ESurfTypeRawSingleBuffered),
37 { EInitializeCase, 0, EGL_SUCCESS },
38 { ECreateSurfaceCase, 0, EGL_SUCCESS, 0, EStandardSurface },
39 { ECreateEndpointCase, 0, EGL_SUCCESS },
40 { ESetAttribCase, 0, EGL_SUCCESS, 0, 0, EGL_DELAY_NOK, 50000 },
41 { EContentUpdateCase, 0, EGL_SUCCESS },
42 { EBeginStreamingCase, 0, EGL_SUCCESS },
43 { ETimeStampCase, 0, KErrNone },
44 { ENotifyWhenCase, 0, KErrNone, 0, ENotifyWhenDisplayed },
45 { EContentUpdateCase, ENoWait, EGL_SUCCESS },
46 { EWaitForCase, 0, KErrNone, 0, ENotifyWhenDisplayed, 55000, 50000 },
47 { ESetAttribCase, 0, EGL_SUCCESS, 0, 0, EGL_DELAY_NOK, 100000 },
48 { ETimeStampCase, 0, KErrNone },
49 { ENotifyWhenCase, 0, KErrNone, 0, ENotifyWhenDisplayed },
50 { EContentUpdateCase, ENoWait, EGL_SUCCESS },
51 { EWaitForCase, 0, KErrNone, 0, ENotifyWhenDisplayed, 110000, 100000 },
52 { EEndStreamingCase, 0, EGL_SUCCESS },
53 { EDestroyEndpointCase, 0, EGL_SUCCESS },
54 { ETerminateCase, 0, EGL_SUCCESS },
60 CASETITLE("Functional: Streaming: aStatusDisplayed behaves properly outside of streaming block"),
61 SurfaceTypes2(ESurfTypeRaw, ESurfTypeRawSingleBuffered),
63 { EInitializeCase, 0, EGL_SUCCESS },
64 { ECreateSurfaceCase, 0, EGL_SUCCESS, 0, EStandardSurface },
65 { ECreateEndpointCase, 0, EGL_SUCCESS },
66 { ESetAttribCase, 0, EGL_SUCCESS, 0, 0, EGL_DELAY_NOK, 50000 },
67 { ENotifyWhenCase, 0, KErrNone, 0, ENotifyWhenDisplayed },
68 { EContentUpdateCase, ENoWait, EGL_SUCCESS },
69 { EWaitForCase, 0, KErrNotVisible, 0, ENotifyWhenDisplayed, 55000 },
70 { ENotifyWhenCase, 0, KErrNone, 0, ENotifyWhenDisplayed },
71 { EContentUpdateCase, ENoWait, EGL_SUCCESS },
72 { EWaitForCase, 0, KErrNotVisible, 0, ENotifyWhenDisplayed, 5000 },
73 { EEndStreamingCase, 0, EGL_SUCCESS },
74 { EDestroyEndpointCase, 0, EGL_SUCCESS },
75 { ETerminateCase, 0, EGL_SUCCESS },
81 CASETITLE("Functional: Streaming: aStatusDisplayedXTimes behaves properly outside streaming block"),
82 SurfaceTypes2(ESurfTypeRaw, ESurfTypeRawSingleBuffered),
84 { EInitializeCase, 0, EGL_SUCCESS },
85 { ECreateSurfaceCase, 0, EGL_SUCCESS, 0, EStandardSurface },
86 { ECreateEndpointCase, 0, EGL_SUCCESS },
87 { ESetAttribCase, 0, EGL_SUCCESS, 0, 0, EGL_DELAY_NOK, 50000 },
88 { ENotifyWhenCase, 0, KErrNone, 0, ENotifyWhenDispXTimes, 2 },
89 { EContentUpdateCase, ENoWait, EGL_SUCCESS },
90 { EWaitForCase, 0, KErrNotVisible, 0, ENotifyWhenDispXTimes, 5000 },
91 { ENotifyWhenCase, 0, KErrNone, 0, ENotifyWhenDispXTimes, 10 },
92 { EContentUpdateCase, ENoWait, EGL_SUCCESS },
93 { EWaitForCase, 0, KErrNotVisible, 0, ENotifyWhenDispXTimes, 5000 },
94 { EEndStreamingCase, 0, EGL_SUCCESS },
95 { EDestroyEndpointCase, 0, EGL_SUCCESS },
96 { ETerminateCase, 0, EGL_SUCCESS },
102 CASETITLE("Functional: Streaming: Additional SubmitUpdate issued before aStatusDisplayed is notified results in error KErrOverflow"),
103 SurfaceTypes2(ESurfTypeRaw, ESurfTypeRawSingleBuffered),
105 { EInitializeCase, 0, EGL_SUCCESS },
106 { ECreateSurfaceCase, 0, EGL_SUCCESS, 0, EStandardSurface },
107 { ECreateEndpointCase, 0, EGL_SUCCESS },
108 { ESetAttribCase, 0, EGL_SUCCESS, 0, 0, EGL_DELAY_NOK, 20000 },
109 { EContentUpdateCase, 0, EGL_SUCCESS },
110 { EBeginStreamingCase, 0, EGL_SUCCESS },
111 { ENotifyWhenCase, 0, KErrNone, 0, ENotifyWhenDisplayed },
112 { EContentUpdateCase, ENoWait, EGL_SUCCESS },
113 { EContentUpdateCase, ENoWait, EGL_SUCCESS },
114 { EWaitForCase, 0, KErrOverflow, 0, ENotifyWhenDisplayed, 10000 },
115 { EEndStreamingCase, 0, EGL_SUCCESS },
116 { EDestroyEndpointCase, 0, EGL_SUCCESS },
117 { ETerminateCase, 0, EGL_SUCCESS },
123 CASETITLE("Functional: Streaming: aStatusDisplayed behaves properly on transition out of streaming block (variant 1)"),
124 SurfaceTypes2(ESurfTypeRaw, ESurfTypeRawSingleBuffered),
126 { EInitializeCase, 0, EGL_SUCCESS },
127 { ECreateSurfaceCase, 0, EGL_SUCCESS, 0, EStandardSurface },
128 { ECreateEndpointCase, 0, EGL_SUCCESS },
129 { ESetAttribCase, 0, EGL_SUCCESS, 0, 0, EGL_DELAY_NOK, 20000 },
130 { EContentUpdateCase, 0, EGL_SUCCESS },
131 { EBeginStreamingCase, 0, EGL_SUCCESS },
132 { ENotifyWhenCase, 0, KErrNone, 0, ENotifyWhenDisplayed },
133 { EContentUpdateCase, ENoWait, EGL_SUCCESS },
134 { EWaitForCase, 0, KErrNone, 0, ENotifyWhenDisplayed, 25000 },
135 { EEndStreamingCase, 0, EGL_SUCCESS },
136 { ENotifyWhenCase, 0, KErrNone, 0, ENotifyWhenDisplayed },
137 { EContentUpdateCase, ENoWait, EGL_SUCCESS },
138 { EWaitForCase, 0, KErrNotVisible, 0, ENotifyWhenDisplayed, 25000 },
139 { EDestroyEndpointCase, 0, EGL_SUCCESS },
140 { ETerminateCase, 0, EGL_SUCCESS },
146 CASETITLE("Functional: Streaming: aStatusDisplayed behaves properly on transition out of streaming block (variant 2)"),
147 SurfaceTypes2(ESurfTypeRaw, ESurfTypeRawSingleBuffered),
149 { EInitializeCase, 0, EGL_SUCCESS },
150 { ECreateSurfaceCase, 0, EGL_SUCCESS, 0, EStandardSurface },
151 { ECreateEndpointCase, 0, EGL_SUCCESS },
152 { ESetAttribCase, 0, EGL_SUCCESS, 0, 0, EGL_DELAY_NOK, 20000 },
153 { EContentUpdateCase, 0, EGL_SUCCESS },
154 { EBeginStreamingCase, 0, EGL_SUCCESS },
155 { ENotifyWhenCase, 0, KErrNone, 0, ENotifyWhenDisplayed },
156 { EContentUpdateCase, ENoWait, EGL_SUCCESS },
157 { EWaitForCase, 0, KErrNone, 0, ENotifyWhenDisplayed, 25000 },
158 { EDestroyEndpointCase, 0, EGL_SUCCESS },
159 { ENotifyWhenCase, 0, KErrNone, 0, ENotifyWhenDisplayed },
160 { EContentUpdateCase, ENoWait, EGL_SUCCESS },
161 { EWaitForCase, 0, KErrSurfaceNotRegistered, 0, ENotifyWhenDisplayed, 25000 },
162 { ETerminateCase, 0, EGL_SUCCESS },
169 static const TTestCases KTestCases[] =
171 TestCase(KStreamingTestCases),
174 const TInt KNumberTestCases = sizeof(KTestCases) / sizeof(KTestCases[0]);
177 CEglTest_LocalTestStep_EndpointStreamingTests::CEglTest_LocalTestStep_EndpointStreamingTests():
178 CEgltest_Local_Engine(KTestCases, KNumberTestCases)
183 //------------------------------------------------------
184 // GRAPHICS-EGL-583 can only be implemented with code...
185 //------------------------------------------------------
188 CEglTest_LocalTestStep_EndpointStreamingDispXTimesInStream::CEglTest_LocalTestStep_EndpointStreamingDispXTimesInStream()
189 : CLocalTestStepBase(ETestUidEndpointEngine) // We use the engine to do the remote side functionality.
193 void CEglTest_LocalTestStep_EndpointStreamingDispXTimesInStream::DoPreambleL()
197 void CEglTest_LocalTestStep_EndpointStreamingDispXTimesInStream::DoPostambleL()
201 CEglTest_LocalTestStep_EndpointStreamingDispXTimesInStream::~CEglTest_LocalTestStep_EndpointStreamingDispXTimesInStream()
205 void CEglTest_LocalTestStep_EndpointStreamingDispXTimesInStream::RunScript(const TEngineTestCase *aTestCases, TRemoteTestParams ¶ms)
207 for(TInt i = 0; aTestCases[i].iCase != EFinishedCase; i++)
209 params.iEndpointEngine.iEngineTestCase = aTestCases[i];
210 RunRemoteTestCase(aTestCases[i].iCase, params);
214 TUint CEglTest_LocalTestStep_EndpointStreamingDispXTimesInStream::TicksForDisplayXTimesL(CSurface* aSurface, TInt aNumTimes)
216 //Calculate timeout by assuming low framerate of 10 fps,
217 //multiplying period by number of times and an extra factor of 3.
218 //This should be plenty. Measured in microseconds.
219 TInt timeout = 3 * aNumTimes * TInt(1000000.0f / 10.0f);
221 TRequestStatus dispXTimesRs;
222 User::LeaveIfError(aSurface->Notify(ENotifyWhenDispXTimes, dispXTimesRs, aNumTimes));
224 TUint startTickCount = User::TickCount();
225 User::LeaveIfError(aSurface->SubmitContent(EFalse));
227 TUint32 dummyTimeStamp;
228 TInt err = aSurface->WaitFor(ENotifyWhenDispXTimes, dispXTimesRs, timeout, dummyTimeStamp);
231 ERR_PRINTF3(_L("Waiting for ENotifyWhenDispXTimes returned %d when we expected %d."), err, KErrNone);
235 return User::TickCount() - startTickCount;
238 void CEglTest_LocalTestStep_EndpointStreamingDispXTimesInStream::DispXTimesInStreamTestL(TSurfaceType aSurfaceType)
240 //Local: Create surface and save the id for the remote side.
241 CSurface* surface = CSurface::SurfaceFactoryL(aSurfaceType);
242 CleanupStack::PushL(surface);
243 surface->CreateL(EStandardSurface);
244 surface->GetSurfaceParamsL(iParams.iEndpointEngine.iSurfaceParams);
246 //Remote: Init remote side and create an endpoint from the surface. (tidy up ops are on cleanup stack)
247 static const TEngineTestCase createEndpointSteps[] =
249 { EInitializeCase, 0, EGL_SUCCESS },
250 { ECreateEndpointCase, 0, EGL_SUCCESS },
251 { EFinishedCase, 0, EGL_SUCCESS },
253 RunScript(createEndpointSteps, iParams);
254 CleanupStack::PushL(TCleanupItem(CleanupRemoteTestStep, this));
256 //Local: Submit update for the surface so that the endpoint enters the ready state.
257 User::LeaveIfError(surface->SubmitContent(ETrue));
259 //Remote: Set the EGL_DELAY_NOK value and begin streaming on the endpoint.
260 static const TEngineTestCase setDelayAndBeginStreamingSteps[] =
262 { ESetAttribCase, 0, EGL_SUCCESS, 0, 0, EGL_DELAY_NOK, 5000 },
263 { EBeginStreamingCase, 0, EGL_SUCCESS },
264 { EFinishedCase, 0, EGL_SUCCESS },
266 RunScript(setDelayAndBeginStreamingSteps, iParams);
268 //Local: Get number of ticks between submitting content and X frames being displayed.
269 TUint ticksForDisp20Times = TicksForDisplayXTimesL(surface, 20);
270 INFO_PRINTF2(_L("ticksForDisp20Times = %d"), ticksForDisp20Times);
271 TUint ticksForDisp200Times = TicksForDisplayXTimesL(surface, 200);
272 INFO_PRINTF2(_L("ticksForDisp200Times = %d"), ticksForDisp200Times);
274 //check to see if ticksForDisp200Times = 10 * ticksForDisp20Times (with some fuzz).
275 if( (ticksForDisp200Times < 5*ticksForDisp20Times) || (ticksForDisp200Times > 15*ticksForDisp20Times) )
277 ERR_PRINTF1(_L("Ratio between time for display 20 times and display 200 times not within limits."));
282 INFO_PRINTF1(_L("Ratio between time for display 20 times and display 200 times is within limits."));
285 CleanupStack::PopAndDestroy(2, surface);
288 TVerdict CEglTest_LocalTestStep_EndpointStreamingDispXTimesInStream::doTestStepL()
290 static const TRemoteTestParams nullParams = {};
291 StartRemoteTestStep(nullParams);
293 DispXTimesInStreamTestL(ESurfTypeRaw);
294 DispXTimesInStreamTestL(ESurfTypeRawSingleBuffered);
296 EndRemoteTestStep(nullParams);
297 INFO_PRINTF1(_L("EndpointStreamingDispXTimesInStream test finished"));
298 return TestStepResult();
301 void CEglTest_LocalTestStep_EndpointStreamingDispXTimesInStream::CleanupRemoteTestStep(TAny* aStreamingDispXTimesInStream)
303 CEglTest_LocalTestStep_EndpointStreamingDispXTimesInStream* self =
304 static_cast<CEglTest_LocalTestStep_EndpointStreamingDispXTimesInStream*>(aStreamingDispXTimesInStream);
306 //Remote: Destroy the endpoint and terminate EGL.
307 static const TEngineTestCase destroyEndpointSteps[] =
309 { EDestroyEndpointCase, 0, EGL_SUCCESS },
310 { ETerminateCase, 0, EGL_SUCCESS },
313 self->RunScript(destroyEndpointSteps, self->iParams);