| /*------------------------------------------------------------------------- |
| * drawElements Quality Program EGL Module |
| * --------------------------------------- |
| * |
| * Copyright 2015 The Android Open Source Project |
| * |
| * Licensed under the Apache License, Version 2.0 (the "License"); |
| * you may not use this file except in compliance with the License. |
| * You may obtain a copy of the License at |
| * |
| * http://www.apache.org/licenses/LICENSE-2.0 |
| * |
| * Unless required by applicable law or agreed to in writing, software |
| * distributed under the License is distributed on an "AS IS" BASIS, |
| * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
| * See the License for the specific language governing permissions and |
| * limitations under the License. |
| * |
| *//*! |
| * \file |
| * \brief Test negative use case of KHR_partial_update |
| *//*--------------------------------------------------------------------*/ |
| |
| #include "teglNegativePartialUpdateTests.hpp" |
| |
| #include "tcuTestLog.hpp" |
| #include "tcuSurface.hpp" |
| |
| #include "egluCallLogWrapper.hpp" |
| #include "egluConfigFilter.hpp" |
| #include "egluNativeWindow.hpp" |
| #include "egluStrUtil.hpp" |
| #include "egluUnique.hpp" |
| #include "egluUtil.hpp" |
| |
| #include "eglwLibrary.hpp" |
| #include "eglwEnums.hpp" |
| |
| using namespace eglu; |
| using namespace eglw; |
| using tcu::TestLog; |
| |
| namespace deqp |
| { |
| namespace egl |
| { |
| namespace |
| { |
| |
| class NegativePartialUpdateTest : public TestCase |
| { |
| public: |
| enum SurfaceType // used as a bit field when selecting a suitable EGL config |
| { |
| SURFACETYPE_WINDOW = 1 << 0, |
| SURFACETYPE_PBUFFER = 1 << 1 |
| }; |
| |
| NegativePartialUpdateTest (EglTestContext& eglTestCtx, bool preserveBuffer, SurfaceType surfaceType, const char* name, const char* description); |
| ~NegativePartialUpdateTest (void); |
| void init (void); |
| void deinit (void); |
| virtual IterateResult iterate (void) = 0; |
| |
| protected: |
| void expectError (eglw::EGLenum error); |
| void expectBoolean (EGLBoolean expected, EGLBoolean got); |
| inline void expectTrue (eglw::EGLBoolean got) { expectBoolean(EGL_TRUE, got); } |
| inline void expectFalse (eglw::EGLBoolean got) { expectBoolean(EGL_FALSE, got); } |
| |
| const bool m_preserveBuffer; |
| SurfaceType m_surfaceType; |
| EGLDisplay m_eglDisplay; |
| EGLConfig m_eglConfig; |
| NativeWindow* m_window; |
| EGLSurface m_eglSurface; |
| EGLContext m_eglContext; |
| }; |
| |
| bool isWindow (const CandidateConfig& c) |
| { |
| return (c.surfaceType() & EGL_WINDOW_BIT) == EGL_WINDOW_BIT; |
| } |
| |
| bool isPbuffer (const CandidateConfig& c) |
| { |
| return (c.surfaceType() & EGL_PBUFFER_BIT) == EGL_PBUFFER_BIT; |
| } |
| |
| bool isES2Renderable (const CandidateConfig& c) |
| { |
| return (c.get(EGL_RENDERABLE_TYPE) & EGL_OPENGL_ES2_BIT) == EGL_OPENGL_ES2_BIT; |
| } |
| |
| bool hasPreserveSwap (const CandidateConfig& c) |
| { |
| return (c.surfaceType() & EGL_SWAP_BEHAVIOR_PRESERVED_BIT) == EGL_SWAP_BEHAVIOR_PRESERVED_BIT; |
| } |
| |
| EGLConfig getEGLConfig (const Library& egl, EGLDisplay eglDisplay, unsigned surfaceTypes, bool preserveBuffer) |
| { |
| FilterList filters; |
| if ((surfaceTypes & NegativePartialUpdateTest::SURFACETYPE_WINDOW) != 0) |
| filters << isWindow; |
| if ((surfaceTypes & NegativePartialUpdateTest::SURFACETYPE_PBUFFER) != 0) |
| filters << isPbuffer; |
| if (((surfaceTypes & NegativePartialUpdateTest::SURFACETYPE_WINDOW) == 0) && |
| ((surfaceTypes & NegativePartialUpdateTest::SURFACETYPE_PBUFFER) == 0)) |
| DE_FATAL("Invalid surfaceType"); |
| |
| filters << isES2Renderable; |
| |
| if (preserveBuffer) |
| filters << hasPreserveSwap; |
| |
| return chooseSingleConfig(egl, eglDisplay, filters); |
| } |
| |
| EGLContext initAndMakeCurrentEGLContext (const Library& egl, EGLDisplay eglDisplay, EGLSurface eglSurface, EGLConfig eglConfig, const EGLint* attribList) |
| { |
| EGLContext eglContext = EGL_NO_CONTEXT; |
| |
| egl.bindAPI(EGL_OPENGL_ES_API); |
| eglContext = egl.createContext(eglDisplay, eglConfig, EGL_NO_CONTEXT, attribList); |
| EGLU_CHECK_MSG(egl, "eglCreateContext"); |
| TCU_CHECK(eglSurface != EGL_NO_SURFACE); |
| egl.makeCurrent(eglDisplay, eglSurface, eglSurface, eglContext); |
| EGLU_CHECK_MSG(egl, "eglMakeCurrent"); |
| |
| return eglContext; |
| } |
| |
| NegativePartialUpdateTest::NegativePartialUpdateTest (EglTestContext& eglTestCtx, bool preserveBuffer, SurfaceType surfaceType, const char* name, const char* description) |
| : TestCase (eglTestCtx, name, description) |
| , m_preserveBuffer (preserveBuffer) |
| , m_surfaceType (surfaceType) |
| , m_eglDisplay (EGL_NO_DISPLAY) |
| , m_window (DE_NULL) |
| , m_eglSurface (EGL_NO_SURFACE) |
| , m_eglContext (EGL_NO_CONTEXT) |
| { |
| } |
| |
| NegativePartialUpdateTest::~NegativePartialUpdateTest (void) |
| { |
| deinit(); |
| } |
| |
| void NegativePartialUpdateTest::init (void) |
| { |
| const Library& egl = m_eglTestCtx.getLibrary(); |
| static const EGLint contextAttribList[] = { EGL_CONTEXT_CLIENT_VERSION, 2, EGL_NONE }; |
| const int width = 480; |
| const int height = 480; |
| |
| m_eglDisplay = getAndInitDisplay(m_eglTestCtx.getNativeDisplay()); |
| |
| if (!hasExtension(egl, m_eglDisplay, "EGL_KHR_partial_update")) |
| TCU_THROW(NotSupportedError, "EGL_KHR_partial_update is not supported"); |
| |
| if (m_surfaceType == SURFACETYPE_PBUFFER) |
| { |
| m_eglConfig = getEGLConfig(egl, m_eglDisplay, SURFACETYPE_PBUFFER, m_preserveBuffer); |
| const EGLint pbufferAttribList[] = { EGL_WIDTH, width, EGL_HEIGHT, height, EGL_NONE }; |
| m_eglSurface = egl.createPbufferSurface(m_eglDisplay, m_eglConfig, pbufferAttribList); |
| } |
| else |
| { |
| m_eglConfig = getEGLConfig(egl, m_eglDisplay, SURFACETYPE_WINDOW | SURFACETYPE_PBUFFER, m_preserveBuffer); |
| const NativeWindowFactory& factory = selectNativeWindowFactory(m_eglTestCtx.getNativeDisplayFactory(), m_testCtx.getCommandLine()); |
| m_window = factory.createWindow(&m_eglTestCtx.getNativeDisplay(), m_eglDisplay, m_eglConfig, DE_NULL, |
| WindowParams(width, height, parseWindowVisibility(m_testCtx.getCommandLine()))); |
| m_eglSurface = createWindowSurface(m_eglTestCtx.getNativeDisplay(), *m_window, m_eglDisplay, m_eglConfig, DE_NULL); |
| } |
| m_eglContext = initAndMakeCurrentEGLContext(egl, m_eglDisplay, m_eglSurface, m_eglConfig, contextAttribList); |
| } |
| |
| void NegativePartialUpdateTest::deinit (void) |
| { |
| const Library& egl = m_eglTestCtx.getLibrary(); |
| |
| if (m_eglContext != EGL_NO_CONTEXT) |
| { |
| EGLU_CHECK_CALL(egl, makeCurrent(m_eglDisplay, EGL_NO_SURFACE, EGL_NO_SURFACE, EGL_NO_CONTEXT)); |
| EGLU_CHECK_CALL(egl, destroyContext(m_eglDisplay, m_eglContext)); |
| m_eglContext = EGL_NO_CONTEXT; |
| } |
| |
| if (m_eglSurface != EGL_NO_SURFACE) |
| { |
| EGLU_CHECK_CALL(egl, destroySurface(m_eglDisplay, m_eglSurface)); |
| m_eglSurface = EGL_NO_SURFACE; |
| } |
| |
| if (m_eglDisplay != EGL_NO_DISPLAY) |
| { |
| EGLU_CHECK_CALL(egl, terminate(m_eglDisplay)); |
| m_eglDisplay = EGL_NO_DISPLAY; |
| } |
| |
| delete m_window; |
| m_window = DE_NULL; |
| } |
| |
| void NegativePartialUpdateTest::expectError (EGLenum expected) |
| { |
| const EGLenum err = m_eglTestCtx.getLibrary().getError(); |
| |
| if (err != expected) |
| { |
| m_testCtx.getLog() << TestLog::Message << "// ERROR expected: " << eglu::getErrorStr(expected) << ", Got: " << eglu::getErrorStr(err) << TestLog::EndMessage; |
| if (m_testCtx.getTestResult() == QP_TEST_RESULT_PASS) |
| m_testCtx.setTestResult(QP_TEST_RESULT_FAIL, "Got invalid error"); |
| } |
| } |
| |
| void NegativePartialUpdateTest::expectBoolean (EGLBoolean expected, EGLBoolean got) |
| { |
| if (expected != got) |
| { |
| m_testCtx.getLog() << TestLog::Message << "// ERROR expected: " << eglu::getBooleanStr(expected) << ", Got: " << eglu::getBooleanStr(got) << TestLog::EndMessage; |
| if (m_testCtx.getTestResult() == QP_TEST_RESULT_PASS) |
| m_testCtx.setTestResult(QP_TEST_RESULT_FAIL, "Got invalid value"); |
| } |
| } |
| |
| class NotPostableTest : public NegativePartialUpdateTest |
| { |
| public: |
| NotPostableTest (EglTestContext& context); |
| TestCase::IterateResult iterate (void); |
| }; |
| |
| NotPostableTest::NotPostableTest (EglTestContext& context) |
| : NegativePartialUpdateTest (context, false, SURFACETYPE_PBUFFER, "not_postable_surface", "Call setDamageRegion() on pbuffer") |
| { |
| } |
| |
| TestCase::IterateResult NotPostableTest::iterate (void) |
| { |
| const Library& egl = m_eglTestCtx.getLibrary(); |
| TestLog& log = m_testCtx.getLog(); |
| CallLogWrapper wrapper (egl, log); |
| EGLint damageRegion[] = { 10, 10, 10, 10 }; |
| int bufferAge = -1; |
| |
| wrapper.enableLogging(true); |
| m_testCtx.setTestResult(QP_TEST_RESULT_PASS, "Pass"); |
| { |
| tcu::ScopedLogSection(log, "Test1", "If the surface is pbuffer (not postable) --> EGL_BAD_MATCH"); |
| EGLU_CHECK_CALL(egl, surfaceAttrib(m_eglDisplay, m_eglSurface, EGL_SWAP_BEHAVIOR, EGL_BUFFER_DESTROYED)); |
| EGLU_CHECK_CALL(egl, querySurface(m_eglDisplay, m_eglSurface, EGL_BUFFER_AGE_KHR, &bufferAge)); |
| expectFalse(wrapper.eglSetDamageRegionKHR(m_eglDisplay, m_eglSurface, damageRegion, DE_LENGTH_OF_ARRAY(damageRegion)/4)); |
| expectError(EGL_BAD_MATCH); |
| } |
| |
| return STOP; |
| } |
| |
| class NotCurrentSurfaceTest : public NegativePartialUpdateTest |
| { |
| public: |
| NotCurrentSurfaceTest (EglTestContext& context); |
| TestCase::IterateResult iterate (void); |
| }; |
| |
| NotCurrentSurfaceTest::NotCurrentSurfaceTest (EglTestContext& context) |
| : NegativePartialUpdateTest (context, false, SURFACETYPE_WINDOW, "not_current_surface", "Call setDamageRegion() on pbuffer") |
| { |
| } |
| |
| TestCase::IterateResult NotCurrentSurfaceTest::iterate (void) |
| { |
| const int impossibleBufferAge = -26084; |
| const Library& egl = m_eglTestCtx.getLibrary(); |
| const EGLint attribList[] = |
| { |
| EGL_WIDTH, 64, |
| EGL_HEIGHT, 64, |
| EGL_NONE |
| }; |
| const eglu::UniqueSurface unusedPbuffer (egl, m_eglDisplay, egl.createPbufferSurface(m_eglDisplay, m_eglConfig, attribList)); |
| TestLog& log = m_testCtx.getLog(); |
| CallLogWrapper wrapper (egl, log); |
| EGLint damageRegion[] = { 10, 10, 10, 10 }; |
| int bufferAge = impossibleBufferAge; |
| |
| wrapper.enableLogging(true); |
| m_testCtx.setTestResult(QP_TEST_RESULT_PASS, "Pass"); |
| EGLU_CHECK_CALL(egl, makeCurrent(m_eglDisplay, *unusedPbuffer, *unusedPbuffer, m_eglContext)); |
| { |
| tcu::ScopedLogSection(log, "Test2.1", "If query buffer age on a surface that is not the current draw surface --> EGL_BAD_SURFACE"); |
| EGLU_CHECK_CALL(egl, surfaceAttrib(m_eglDisplay, m_eglSurface, EGL_SWAP_BEHAVIOR, EGL_BUFFER_DESTROYED)); |
| expectFalse(wrapper.eglQuerySurface(m_eglDisplay, m_eglSurface, EGL_BUFFER_AGE_KHR, &bufferAge)); |
| expectError(EGL_BAD_SURFACE); |
| |
| if (bufferAge != impossibleBufferAge) |
| { |
| log << tcu::TestLog::Message << "On failure, eglQuerySurface shouldn't change buffer age but buffer age has been changed to " << bufferAge << tcu::TestLog::EndMessage; |
| m_testCtx.setTestResult(QP_TEST_RESULT_FAIL, "Fail, bufferAge shouldn't be changed"); |
| } |
| } |
| { |
| tcu::ScopedLogSection(log, "Test2.2", "If call setDamageRegion() on a surface that is not the current draw surface --> EGL_BAD_MATCH"); |
| expectFalse(wrapper.eglSetDamageRegionKHR(m_eglDisplay, m_eglSurface, damageRegion, 1)); |
| expectError(EGL_BAD_MATCH); |
| } |
| |
| EGLU_CHECK_CALL(egl, makeCurrent(m_eglDisplay, EGL_NO_SURFACE, EGL_NO_SURFACE, EGL_NO_CONTEXT)); |
| { |
| tcu::ScopedLogSection(log, "Test3.1", "If query buffer age on a surface that is not the current draw surface --> EGL_BAD_SURFACE"); |
| EGLU_CHECK_CALL(egl, surfaceAttrib(m_eglDisplay, m_eglSurface, EGL_SWAP_BEHAVIOR, EGL_BUFFER_DESTROYED)); |
| expectFalse(wrapper.eglQuerySurface(m_eglDisplay, m_eglSurface, EGL_BUFFER_AGE_KHR, &bufferAge)); |
| expectError(EGL_BAD_SURFACE); |
| |
| if (bufferAge != impossibleBufferAge) |
| { |
| log << tcu::TestLog::Message << "On failure, eglQuerySurface shouldn't change buffer age but buffer age has been changed to " << bufferAge << tcu::TestLog::EndMessage; |
| m_testCtx.setTestResult(QP_TEST_RESULT_FAIL, "Fail, bufferAge shouldn't be changed"); |
| } |
| } |
| { |
| tcu::ScopedLogSection(log, "Test3.2", "If call setDamageRegion() on a surface that is not the current draw surface --> EGL_BAD_MATCH"); |
| expectFalse(wrapper.eglSetDamageRegionKHR(m_eglDisplay, m_eglSurface, damageRegion, 1)); |
| expectError(EGL_BAD_MATCH); |
| } |
| |
| if (hasExtension(egl, m_eglDisplay, "EGL_KHR_surfaceless_context")) |
| { |
| EGLU_CHECK_CALL(egl, makeCurrent(m_eglDisplay, EGL_NO_SURFACE, EGL_NO_SURFACE, m_eglContext)); |
| { |
| tcu::ScopedLogSection(log, "Test4.1", "If query buffer age on a surface that is not the current draw surface --> EGL_BAD_SURFACE"); |
| EGLU_CHECK_CALL(egl, surfaceAttrib(m_eglDisplay, m_eglSurface, EGL_SWAP_BEHAVIOR, EGL_BUFFER_DESTROYED)); |
| expectFalse(wrapper.eglQuerySurface(m_eglDisplay, m_eglSurface, EGL_BUFFER_AGE_KHR, &bufferAge)); |
| expectError(EGL_BAD_SURFACE); |
| |
| if (bufferAge != impossibleBufferAge) |
| { |
| log << tcu::TestLog::Message << "On failure, eglQuerySurface shouldn't change buffer age but buffer age has been changed to " << bufferAge << tcu::TestLog::EndMessage; |
| m_testCtx.setTestResult(QP_TEST_RESULT_FAIL, "Fail, bufferAge shouldn't be changed"); |
| } |
| } |
| { |
| tcu::ScopedLogSection(log, "Test4.2", "If call setDamageRegion() on a surface that is not the current draw surface --> EGL_BAD_MATCH"); |
| expectFalse(wrapper.eglSetDamageRegionKHR(m_eglDisplay, m_eglSurface, damageRegion, 1)); |
| expectError(EGL_BAD_MATCH); |
| } |
| } |
| |
| return STOP; |
| } |
| |
| class BufferPreservedTest : public NegativePartialUpdateTest |
| { |
| public: |
| BufferPreservedTest (EglTestContext& context); |
| TestCase::IterateResult iterate (void); |
| }; |
| |
| BufferPreservedTest::BufferPreservedTest (EglTestContext& context) |
| : NegativePartialUpdateTest (context, true, SURFACETYPE_WINDOW, "buffer_preserved", "Call setDamageRegion() on pbuffer") |
| { |
| } |
| |
| TestCase::IterateResult BufferPreservedTest::iterate (void) |
| { |
| const Library& egl = m_eglTestCtx.getLibrary(); |
| TestLog& log = m_testCtx.getLog(); |
| CallLogWrapper wrapper (egl, log); |
| EGLint damageRegion[] = { 10, 10, 10, 10 }; |
| int bufferAge = -1; |
| |
| wrapper.enableLogging(true); |
| m_testCtx.setTestResult(QP_TEST_RESULT_PASS, "Pass"); |
| { |
| tcu::ScopedLogSection(log, "Test3", "If buffer_preserved --> EGL_BAD_MATCH"); |
| EGLU_CHECK_CALL(egl, surfaceAttrib(m_eglDisplay, m_eglSurface, EGL_SWAP_BEHAVIOR, EGL_BUFFER_PRESERVED)); |
| EGLU_CHECK_CALL(egl, querySurface(m_eglDisplay, m_eglSurface, EGL_BUFFER_AGE_KHR, &bufferAge)); |
| expectFalse(wrapper.eglSetDamageRegionKHR(m_eglDisplay, m_eglSurface, damageRegion, DE_LENGTH_OF_ARRAY(damageRegion)/4)); |
| expectError(EGL_BAD_MATCH); |
| } |
| |
| return STOP; |
| } |
| |
| class SetTwiceTest : public NegativePartialUpdateTest |
| { |
| public: |
| SetTwiceTest (EglTestContext& context); |
| TestCase::IterateResult iterate (void); |
| }; |
| |
| SetTwiceTest::SetTwiceTest (EglTestContext& context) |
| : NegativePartialUpdateTest (context, false, SURFACETYPE_WINDOW, "set_damage_region_twice", "Call setDamageRegion() twice") |
| { |
| } |
| |
| TestCase::IterateResult SetTwiceTest::iterate (void) |
| { |
| const Library& egl = m_eglTestCtx.getLibrary(); |
| TestLog& log = m_testCtx.getLog(); |
| CallLogWrapper wrapper (egl, log); |
| EGLint damageRegion[] = { 10, 10, 10, 10 }; |
| int bufferAge = -1; |
| |
| wrapper.enableLogging(true); |
| m_testCtx.setTestResult(QP_TEST_RESULT_PASS, "Pass"); |
| { |
| tcu::ScopedLogSection(log, "Test4", "If call setDamageRegion() twice --> EGL_BAD_ACCESS"); |
| EGLU_CHECK_CALL(egl, surfaceAttrib(m_eglDisplay, m_eglSurface, EGL_SWAP_BEHAVIOR, EGL_BUFFER_DESTROYED)); |
| EGLU_CHECK_CALL(egl, querySurface(m_eglDisplay, m_eglSurface, EGL_BUFFER_AGE_KHR, &bufferAge)); |
| expectTrue(wrapper.eglSetDamageRegionKHR(m_eglDisplay, m_eglSurface, damageRegion, DE_LENGTH_OF_ARRAY(damageRegion)/4)); |
| expectFalse(wrapper.eglSetDamageRegionKHR(m_eglDisplay, m_eglSurface, damageRegion, DE_LENGTH_OF_ARRAY(damageRegion)/4)); |
| expectError(EGL_BAD_ACCESS); |
| } |
| |
| return STOP; |
| } |
| |
| |
| class NoAgeTest : public NegativePartialUpdateTest |
| { |
| public: |
| NoAgeTest (EglTestContext& context); |
| TestCase::IterateResult iterate (void); |
| }; |
| |
| NoAgeTest::NoAgeTest (EglTestContext& context) |
| : NegativePartialUpdateTest (context, false, SURFACETYPE_WINDOW, "set_damage_region_before_query_age", "Call setDamageRegion() without querying buffer age") |
| { |
| } |
| |
| TestCase::IterateResult NoAgeTest::iterate (void) |
| { |
| const Library& egl = m_eglTestCtx.getLibrary(); |
| TestLog& log = m_testCtx.getLog(); |
| CallLogWrapper wrapper (egl, log); |
| EGLint damageRegion[] = { 10, 10, 10, 10 }; |
| |
| wrapper.enableLogging(true); |
| m_testCtx.setTestResult(QP_TEST_RESULT_PASS, "Pass"); |
| { |
| tcu::ScopedLogSection(log, "Test5", "If buffer age is not queried --> EGL_BAD_ACCESS"); |
| EGLU_CHECK_CALL(egl, surfaceAttrib(m_eglDisplay, m_eglSurface, EGL_SWAP_BEHAVIOR, EGL_BUFFER_DESTROYED)); |
| expectFalse(wrapper.eglSetDamageRegionKHR(m_eglDisplay, m_eglSurface, damageRegion, DE_LENGTH_OF_ARRAY(damageRegion)/4)); |
| expectError(EGL_BAD_ACCESS); |
| } |
| |
| return STOP; |
| } |
| |
| class PassNullTest : public NegativePartialUpdateTest |
| { |
| public: |
| PassNullTest (EglTestContext& context); |
| TestCase::IterateResult iterate (void); |
| }; |
| |
| PassNullTest::PassNullTest (EglTestContext& context) |
| : NegativePartialUpdateTest (context, false, SURFACETYPE_WINDOW, "pass_null_0_as_params", "Call setDamageRegion() with (NULL, 0)") |
| { |
| } |
| |
| TestCase::IterateResult PassNullTest::iterate (void) |
| { |
| const Library& egl = m_eglTestCtx.getLibrary(); |
| TestLog& log = m_testCtx.getLog(); |
| CallLogWrapper wrapper (egl, log); |
| int bufferAge = -1; |
| |
| wrapper.enableLogging(true); |
| m_testCtx.setTestResult(QP_TEST_RESULT_PASS, "Pass"); |
| { |
| tcu::ScopedLogSection(log, "Test6", "If pass (null, 0) to setDamageRegion(), no error"); |
| EGLU_CHECK_CALL(egl, surfaceAttrib(m_eglDisplay, m_eglSurface, EGL_SWAP_BEHAVIOR, EGL_BUFFER_DESTROYED)); |
| EGLU_CHECK_CALL(egl, querySurface(m_eglDisplay, m_eglSurface, EGL_BUFFER_AGE_KHR, &bufferAge)); |
| expectTrue(wrapper.eglSetDamageRegionKHR(m_eglDisplay, m_eglSurface, DE_NULL, 0)); |
| expectError(EGL_SUCCESS); |
| } |
| |
| return STOP; |
| } |
| |
| class NotCurrentSurfaceTest2 : public NegativePartialUpdateTest |
| { |
| public: |
| NotCurrentSurfaceTest2 (EglTestContext& context); |
| TestCase::IterateResult iterate (void); |
| }; |
| |
| NotCurrentSurfaceTest2::NotCurrentSurfaceTest2 (EglTestContext& context) |
| : NegativePartialUpdateTest (context, false, SURFACETYPE_WINDOW, "not_current_surface2", "Call setDamageRegion() on pbuffer") |
| { |
| } |
| |
| TestCase::IterateResult NotCurrentSurfaceTest2::iterate (void) |
| { |
| const Library& egl = m_eglTestCtx.getLibrary(); |
| const EGLint attribList[] = |
| { |
| EGL_WIDTH, 64, |
| EGL_HEIGHT, 64, |
| EGL_NONE |
| }; |
| const eglu::UniqueSurface unusedPbuffer (egl, m_eglDisplay, egl.createPbufferSurface(m_eglDisplay, m_eglConfig, attribList)); |
| TestLog& log = m_testCtx.getLog(); |
| CallLogWrapper wrapper (egl, log); |
| EGLint damageRegion[] = { 10, 10, 10, 10 }; |
| int bufferAge = -1; |
| |
| wrapper.enableLogging(true); |
| m_testCtx.setTestResult(QP_TEST_RESULT_PASS, "Pass"); |
| |
| EGLU_CHECK_CALL(egl, surfaceAttrib(m_eglDisplay, m_eglSurface, EGL_SWAP_BEHAVIOR, EGL_BUFFER_DESTROYED)); |
| EGLU_CHECK_CALL(egl, querySurface(m_eglDisplay, m_eglSurface, EGL_BUFFER_AGE_KHR, &bufferAge)); |
| |
| { |
| tcu::ScopedLogSection(log, "Test7", "If call setDamageRegion() on a surface that is not the current draw surface --> EGL_BAD_MATCH"); |
| EGLU_CHECK_CALL(egl, makeCurrent(m_eglDisplay, *unusedPbuffer, *unusedPbuffer, m_eglContext)); |
| expectFalse(wrapper.eglSetDamageRegionKHR(m_eglDisplay, m_eglSurface, damageRegion, 1)); |
| expectError(EGL_BAD_MATCH); |
| } |
| { |
| tcu::ScopedLogSection(log, "Test8", "If call setDamageRegion() on a surface that is not the current draw surface --> EGL_BAD_MATCH"); |
| EGLU_CHECK_CALL(egl, makeCurrent(m_eglDisplay, EGL_NO_SURFACE, EGL_NO_SURFACE, EGL_NO_CONTEXT)); |
| expectFalse(wrapper.eglSetDamageRegionKHR(m_eglDisplay, m_eglSurface, damageRegion, 1)); |
| expectError(EGL_BAD_MATCH); |
| } |
| if (hasExtension(egl, m_eglDisplay, "EGL_KHR_surfaceless_context")) |
| { |
| tcu::ScopedLogSection(log, "Test9", "If call setDamageRegion() on a surface that is not the current draw surface --> EGL_BAD_MATCH"); |
| EGLU_CHECK_CALL(egl, makeCurrent(m_eglDisplay, EGL_NO_SURFACE, EGL_NO_SURFACE, m_eglContext)); |
| expectFalse(wrapper.eglSetDamageRegionKHR(m_eglDisplay, m_eglSurface, damageRegion, 1)); |
| expectError(EGL_BAD_MATCH); |
| } |
| |
| return STOP; |
| } |
| |
| } // anonymous |
| |
| NegativePartialUpdateTests::NegativePartialUpdateTests (EglTestContext& eglTestCtx) |
| : TestCaseGroup(eglTestCtx, "negative_partial_update", "Negative partial update tests") |
| { |
| } |
| |
| void NegativePartialUpdateTests::init (void) |
| { |
| addChild(new NotPostableTest(m_eglTestCtx)); |
| addChild(new NotCurrentSurfaceTest(m_eglTestCtx)); |
| addChild(new BufferPreservedTest(m_eglTestCtx)); |
| addChild(new SetTwiceTest(m_eglTestCtx)); |
| addChild(new NoAgeTest(m_eglTestCtx)); |
| addChild(new PassNullTest(m_eglTestCtx)); |
| addChild(new NotCurrentSurfaceTest2(m_eglTestCtx)); |
| } |
| |
| } // egl |
| } // deqp |