sl@0: /* sl@0: * Copyright (c) 2009 Nokia Corporation and/or its subsidiary(-ies). sl@0: * All rights reserved. sl@0: * This component and the accompanying materials are made available sl@0: * under the terms of "Eclipse Public License v1.0" sl@0: * which accompanies this distribution, and is available sl@0: * at the URL "http://www.eclipse.org/legal/epl-v10.html". sl@0: * sl@0: * Initial Contributors: sl@0: * Nokia Corporation - initial contribution. sl@0: * sl@0: * Contributors: sl@0: * sl@0: * Description: sl@0: * sl@0: */ sl@0: sl@0: sl@0: /** sl@0: @file sl@0: @test sl@0: @internalComponent - Internal Symbian test code sl@0: */ sl@0: sl@0: sl@0: #include "egltest_endpointstreamingtests.h" sl@0: #include "egltest_surface.h" sl@0: sl@0: sl@0: static const TTestCase KStreamingTestCases[] = sl@0: { sl@0: { sl@0: TESTIDS("582"), sl@0: CASETITLE("Functional: Streaming: aStatusDisplayed behaves properly within streaming block"), sl@0: SurfaceTypes2(ESurfTypeRaw, ESurfTypeRawSingleBuffered), sl@0: { sl@0: { EInitializeCase, 0, EGL_SUCCESS }, sl@0: { ECreateSurfaceCase, 0, EGL_SUCCESS, 0, EStandardSurface }, sl@0: { ECreateEndpointCase, 0, EGL_SUCCESS }, sl@0: { ESetAttribCase, 0, EGL_SUCCESS, 0, 0, EGL_DELAY_NOK, 50000 }, sl@0: { EContentUpdateCase, 0, EGL_SUCCESS }, sl@0: { EBeginStreamingCase, 0, EGL_SUCCESS }, sl@0: { ETimeStampCase, 0, KErrNone }, sl@0: { ENotifyWhenCase, 0, KErrNone, 0, ENotifyWhenDisplayed }, sl@0: { EContentUpdateCase, ENoWait, EGL_SUCCESS }, sl@0: { EWaitForCase, 0, KErrNone, 0, ENotifyWhenDisplayed, 55000, 50000 }, sl@0: { ESetAttribCase, 0, EGL_SUCCESS, 0, 0, EGL_DELAY_NOK, 100000 }, sl@0: { ETimeStampCase, 0, KErrNone }, sl@0: { ENotifyWhenCase, 0, KErrNone, 0, ENotifyWhenDisplayed }, sl@0: { EContentUpdateCase, ENoWait, EGL_SUCCESS }, sl@0: { EWaitForCase, 0, KErrNone, 0, ENotifyWhenDisplayed, 110000, 100000 }, sl@0: { EEndStreamingCase, 0, EGL_SUCCESS }, sl@0: { EDestroyEndpointCase, 0, EGL_SUCCESS }, sl@0: { ETerminateCase, 0, EGL_SUCCESS }, sl@0: { EFinishedCase } sl@0: }, sl@0: }, sl@0: { sl@0: TESTIDS("584"), sl@0: CASETITLE("Functional: Streaming: aStatusDisplayed behaves properly outside of streaming block"), sl@0: SurfaceTypes2(ESurfTypeRaw, ESurfTypeRawSingleBuffered), sl@0: { sl@0: { EInitializeCase, 0, EGL_SUCCESS }, sl@0: { ECreateSurfaceCase, 0, EGL_SUCCESS, 0, EStandardSurface }, sl@0: { ECreateEndpointCase, 0, EGL_SUCCESS }, sl@0: { ESetAttribCase, 0, EGL_SUCCESS, 0, 0, EGL_DELAY_NOK, 50000 }, sl@0: { ENotifyWhenCase, 0, KErrNone, 0, ENotifyWhenDisplayed }, sl@0: { EContentUpdateCase, ENoWait, EGL_SUCCESS }, sl@0: { EWaitForCase, 0, KErrNotVisible, 0, ENotifyWhenDisplayed, 55000 }, sl@0: { ENotifyWhenCase, 0, KErrNone, 0, ENotifyWhenDisplayed }, sl@0: { EContentUpdateCase, ENoWait, EGL_SUCCESS }, sl@0: { EWaitForCase, 0, KErrNotVisible, 0, ENotifyWhenDisplayed, 5000 }, sl@0: { EEndStreamingCase, 0, EGL_SUCCESS }, sl@0: { EDestroyEndpointCase, 0, EGL_SUCCESS }, sl@0: { ETerminateCase, 0, EGL_SUCCESS }, sl@0: { EFinishedCase } sl@0: }, sl@0: }, sl@0: { sl@0: TESTIDS("585"), sl@0: CASETITLE("Functional: Streaming: aStatusDisplayedXTimes behaves properly outside streaming block"), sl@0: SurfaceTypes2(ESurfTypeRaw, ESurfTypeRawSingleBuffered), sl@0: { sl@0: { EInitializeCase, 0, EGL_SUCCESS }, sl@0: { ECreateSurfaceCase, 0, EGL_SUCCESS, 0, EStandardSurface }, sl@0: { ECreateEndpointCase, 0, EGL_SUCCESS }, sl@0: { ESetAttribCase, 0, EGL_SUCCESS, 0, 0, EGL_DELAY_NOK, 50000 }, sl@0: { ENotifyWhenCase, 0, KErrNone, 0, ENotifyWhenDispXTimes, 2 }, sl@0: { EContentUpdateCase, ENoWait, EGL_SUCCESS }, sl@0: { EWaitForCase, 0, KErrNotVisible, 0, ENotifyWhenDispXTimes, 5000 }, sl@0: { ENotifyWhenCase, 0, KErrNone, 0, ENotifyWhenDispXTimes, 10 }, sl@0: { EContentUpdateCase, ENoWait, EGL_SUCCESS }, sl@0: { EWaitForCase, 0, KErrNotVisible, 0, ENotifyWhenDispXTimes, 5000 }, sl@0: { EEndStreamingCase, 0, EGL_SUCCESS }, sl@0: { EDestroyEndpointCase, 0, EGL_SUCCESS }, sl@0: { ETerminateCase, 0, EGL_SUCCESS }, sl@0: { EFinishedCase } sl@0: }, sl@0: }, sl@0: { sl@0: TESTIDS("586"), sl@0: CASETITLE("Functional: Streaming: Additional SubmitUpdate issued before aStatusDisplayed is notified results in error KErrOverflow"), sl@0: SurfaceTypes2(ESurfTypeRaw, ESurfTypeRawSingleBuffered), sl@0: { sl@0: { EInitializeCase, 0, EGL_SUCCESS }, sl@0: { ECreateSurfaceCase, 0, EGL_SUCCESS, 0, EStandardSurface }, sl@0: { ECreateEndpointCase, 0, EGL_SUCCESS }, sl@0: { ESetAttribCase, 0, EGL_SUCCESS, 0, 0, EGL_DELAY_NOK, 20000 }, sl@0: { EContentUpdateCase, 0, EGL_SUCCESS }, sl@0: { EBeginStreamingCase, 0, EGL_SUCCESS }, sl@0: { ENotifyWhenCase, 0, KErrNone, 0, ENotifyWhenDisplayed }, sl@0: { EContentUpdateCase, ENoWait, EGL_SUCCESS }, sl@0: { EContentUpdateCase, ENoWait, EGL_SUCCESS }, sl@0: { EWaitForCase, 0, KErrOverflow, 0, ENotifyWhenDisplayed, 10000 }, sl@0: { EEndStreamingCase, 0, EGL_SUCCESS }, sl@0: { EDestroyEndpointCase, 0, EGL_SUCCESS }, sl@0: { ETerminateCase, 0, EGL_SUCCESS }, sl@0: { EFinishedCase } sl@0: }, sl@0: }, sl@0: { sl@0: TESTIDS("587A"), sl@0: CASETITLE("Functional: Streaming: aStatusDisplayed behaves properly on transition out of streaming block (variant 1)"), sl@0: SurfaceTypes2(ESurfTypeRaw, ESurfTypeRawSingleBuffered), sl@0: { sl@0: { EInitializeCase, 0, EGL_SUCCESS }, sl@0: { ECreateSurfaceCase, 0, EGL_SUCCESS, 0, EStandardSurface }, sl@0: { ECreateEndpointCase, 0, EGL_SUCCESS }, sl@0: { ESetAttribCase, 0, EGL_SUCCESS, 0, 0, EGL_DELAY_NOK, 20000 }, sl@0: { EContentUpdateCase, 0, EGL_SUCCESS }, sl@0: { EBeginStreamingCase, 0, EGL_SUCCESS }, sl@0: { ENotifyWhenCase, 0, KErrNone, 0, ENotifyWhenDisplayed }, sl@0: { EContentUpdateCase, ENoWait, EGL_SUCCESS }, sl@0: { EWaitForCase, 0, KErrNone, 0, ENotifyWhenDisplayed, 25000 }, sl@0: { EEndStreamingCase, 0, EGL_SUCCESS }, sl@0: { ENotifyWhenCase, 0, KErrNone, 0, ENotifyWhenDisplayed }, sl@0: { EContentUpdateCase, ENoWait, EGL_SUCCESS }, sl@0: { EWaitForCase, 0, KErrNotVisible, 0, ENotifyWhenDisplayed, 25000 }, sl@0: { EDestroyEndpointCase, 0, EGL_SUCCESS }, sl@0: { ETerminateCase, 0, EGL_SUCCESS }, sl@0: { EFinishedCase } sl@0: }, sl@0: }, sl@0: { sl@0: TESTIDS("587B"), sl@0: CASETITLE("Functional: Streaming: aStatusDisplayed behaves properly on transition out of streaming block (variant 2)"), sl@0: SurfaceTypes2(ESurfTypeRaw, ESurfTypeRawSingleBuffered), sl@0: { sl@0: { EInitializeCase, 0, EGL_SUCCESS }, sl@0: { ECreateSurfaceCase, 0, EGL_SUCCESS, 0, EStandardSurface }, sl@0: { ECreateEndpointCase, 0, EGL_SUCCESS }, sl@0: { ESetAttribCase, 0, EGL_SUCCESS, 0, 0, EGL_DELAY_NOK, 20000 }, sl@0: { EContentUpdateCase, 0, EGL_SUCCESS }, sl@0: { EBeginStreamingCase, 0, EGL_SUCCESS }, sl@0: { ENotifyWhenCase, 0, KErrNone, 0, ENotifyWhenDisplayed }, sl@0: { EContentUpdateCase, ENoWait, EGL_SUCCESS }, sl@0: { EWaitForCase, 0, KErrNone, 0, ENotifyWhenDisplayed, 25000 }, sl@0: { EDestroyEndpointCase, 0, EGL_SUCCESS }, sl@0: { ENotifyWhenCase, 0, KErrNone, 0, ENotifyWhenDisplayed }, sl@0: { EContentUpdateCase, ENoWait, EGL_SUCCESS }, sl@0: { EWaitForCase, 0, KErrSurfaceNotRegistered, 0, ENotifyWhenDisplayed, 25000 }, sl@0: { ETerminateCase, 0, EGL_SUCCESS }, sl@0: { EFinishedCase } sl@0: }, sl@0: }, sl@0: }; sl@0: sl@0: sl@0: static const TTestCases KTestCases[] = sl@0: { sl@0: TestCase(KStreamingTestCases), sl@0: }; sl@0: sl@0: const TInt KNumberTestCases = sizeof(KTestCases) / sizeof(KTestCases[0]); sl@0: sl@0: sl@0: CEglTest_LocalTestStep_EndpointStreamingTests::CEglTest_LocalTestStep_EndpointStreamingTests(): sl@0: CEgltest_Local_Engine(KTestCases, KNumberTestCases) sl@0: { sl@0: } sl@0: sl@0: sl@0: //------------------------------------------------------ sl@0: // GRAPHICS-EGL-583 can only be implemented with code... sl@0: //------------------------------------------------------ sl@0: sl@0: sl@0: CEglTest_LocalTestStep_EndpointStreamingDispXTimesInStream::CEglTest_LocalTestStep_EndpointStreamingDispXTimesInStream() sl@0: : CLocalTestStepBase(ETestUidEndpointEngine) // We use the engine to do the remote side functionality. sl@0: { sl@0: } sl@0: sl@0: void CEglTest_LocalTestStep_EndpointStreamingDispXTimesInStream::DoPreambleL() sl@0: { sl@0: } sl@0: sl@0: void CEglTest_LocalTestStep_EndpointStreamingDispXTimesInStream::DoPostambleL() sl@0: { sl@0: } sl@0: sl@0: CEglTest_LocalTestStep_EndpointStreamingDispXTimesInStream::~CEglTest_LocalTestStep_EndpointStreamingDispXTimesInStream() sl@0: { sl@0: } sl@0: sl@0: void CEglTest_LocalTestStep_EndpointStreamingDispXTimesInStream::RunScript(const TEngineTestCase *aTestCases, TRemoteTestParams ¶ms) sl@0: { sl@0: for(TInt i = 0; aTestCases[i].iCase != EFinishedCase; i++) sl@0: { sl@0: params.iEndpointEngine.iEngineTestCase = aTestCases[i]; sl@0: RunRemoteTestCase(aTestCases[i].iCase, params); sl@0: } sl@0: } sl@0: sl@0: TUint CEglTest_LocalTestStep_EndpointStreamingDispXTimesInStream::TicksForDisplayXTimesL(CSurface* aSurface, TInt aNumTimes) sl@0: { sl@0: //Calculate timeout by assuming low framerate of 10 fps, sl@0: //multiplying period by number of times and an extra factor of 3. sl@0: //This should be plenty. Measured in microseconds. sl@0: TInt timeout = 3 * aNumTimes * TInt(1000000.0f / 10.0f); sl@0: sl@0: TRequestStatus dispXTimesRs; sl@0: User::LeaveIfError(aSurface->Notify(ENotifyWhenDispXTimes, dispXTimesRs, aNumTimes)); sl@0: sl@0: TUint startTickCount = User::TickCount(); sl@0: User::LeaveIfError(aSurface->SubmitContent(EFalse)); sl@0: sl@0: TUint32 dummyTimeStamp; sl@0: TInt err = aSurface->WaitFor(ENotifyWhenDispXTimes, dispXTimesRs, timeout, dummyTimeStamp); sl@0: if(err != KErrNone) sl@0: { sl@0: ERR_PRINTF3(_L("Waiting for ENotifyWhenDispXTimes returned %d when we expected %d."), err, KErrNone); sl@0: User::Leave(err); sl@0: } sl@0: sl@0: return User::TickCount() - startTickCount; sl@0: } sl@0: sl@0: void CEglTest_LocalTestStep_EndpointStreamingDispXTimesInStream::DispXTimesInStreamTestL(TSurfaceType aSurfaceType) sl@0: { sl@0: //Local: Create surface and save the id for the remote side. sl@0: CSurface* surface = CSurface::SurfaceFactoryL(aSurfaceType); sl@0: CleanupStack::PushL(surface); sl@0: surface->CreateL(EStandardSurface); sl@0: surface->GetSurfaceParamsL(iParams.iEndpointEngine.iSurfaceParams); sl@0: sl@0: //Remote: Init remote side and create an endpoint from the surface. (tidy up ops are on cleanup stack) sl@0: static const TEngineTestCase createEndpointSteps[] = sl@0: { sl@0: { EInitializeCase, 0, EGL_SUCCESS }, sl@0: { ECreateEndpointCase, 0, EGL_SUCCESS }, sl@0: { EFinishedCase, 0, EGL_SUCCESS }, sl@0: }; sl@0: RunScript(createEndpointSteps, iParams); sl@0: CleanupStack::PushL(TCleanupItem(CleanupRemoteTestStep, this)); sl@0: sl@0: //Local: Submit update for the surface so that the endpoint enters the ready state. sl@0: User::LeaveIfError(surface->SubmitContent(ETrue)); sl@0: sl@0: //Remote: Set the EGL_DELAY_NOK value and begin streaming on the endpoint. sl@0: static const TEngineTestCase setDelayAndBeginStreamingSteps[] = sl@0: { sl@0: { ESetAttribCase, 0, EGL_SUCCESS, 0, 0, EGL_DELAY_NOK, 5000 }, sl@0: { EBeginStreamingCase, 0, EGL_SUCCESS }, sl@0: { EFinishedCase, 0, EGL_SUCCESS }, sl@0: }; sl@0: RunScript(setDelayAndBeginStreamingSteps, iParams); sl@0: sl@0: //Local: Get number of ticks between submitting content and X frames being displayed. sl@0: TUint ticksForDisp20Times = TicksForDisplayXTimesL(surface, 20); sl@0: INFO_PRINTF2(_L("ticksForDisp20Times = %d"), ticksForDisp20Times); sl@0: TUint ticksForDisp200Times = TicksForDisplayXTimesL(surface, 200); sl@0: INFO_PRINTF2(_L("ticksForDisp200Times = %d"), ticksForDisp200Times); sl@0: sl@0: //check to see if ticksForDisp200Times = 10 * ticksForDisp20Times (with some fuzz). sl@0: if( (ticksForDisp200Times < 5*ticksForDisp20Times) || (ticksForDisp200Times > 15*ticksForDisp20Times) ) sl@0: { sl@0: ERR_PRINTF1(_L("Ratio between time for display 20 times and display 200 times not within limits.")); sl@0: User::Leave(EFail); sl@0: } sl@0: else sl@0: { sl@0: INFO_PRINTF1(_L("Ratio between time for display 20 times and display 200 times is within limits.")); sl@0: } sl@0: sl@0: CleanupStack::PopAndDestroy(2, surface); sl@0: } sl@0: sl@0: TVerdict CEglTest_LocalTestStep_EndpointStreamingDispXTimesInStream::doTestStepL() sl@0: { sl@0: static const TRemoteTestParams nullParams = {}; sl@0: StartRemoteTestStep(nullParams); sl@0: sl@0: DispXTimesInStreamTestL(ESurfTypeRaw); sl@0: DispXTimesInStreamTestL(ESurfTypeRawSingleBuffered); sl@0: sl@0: EndRemoteTestStep(nullParams); sl@0: INFO_PRINTF1(_L("EndpointStreamingDispXTimesInStream test finished")); sl@0: return TestStepResult(); sl@0: } sl@0: sl@0: void CEglTest_LocalTestStep_EndpointStreamingDispXTimesInStream::CleanupRemoteTestStep(TAny* aStreamingDispXTimesInStream) sl@0: { sl@0: CEglTest_LocalTestStep_EndpointStreamingDispXTimesInStream* self = sl@0: static_cast(aStreamingDispXTimesInStream); sl@0: sl@0: //Remote: Destroy the endpoint and terminate EGL. sl@0: static const TEngineTestCase destroyEndpointSteps[] = sl@0: { sl@0: { EDestroyEndpointCase, 0, EGL_SUCCESS }, sl@0: { ETerminateCase, 0, EGL_SUCCESS }, sl@0: { EFinishedCase }, sl@0: }; sl@0: self->RunScript(destroyEndpointSteps, self->iParams); sl@0: } sl@0: