2 * Copyright (c) 2014 Samsung Electronics Co., Ltd.
4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
8 * http://www.apache.org/licenses/LICENSE-2.0
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
18 #include "test-gl-sync-abstraction.h"
22 TestSyncObject::TestSyncObject(TraceCallStack& trace)
28 TestSyncObject::~TestSyncObject()
32 bool TestSyncObject::IsSynced()
34 mTrace.PushCall("SyncObject::IsSynced", ""); // Trace the method
38 TestGlSyncAbstraction::TestGlSyncAbstraction()
46 TestGlSyncAbstraction::~TestGlSyncAbstraction()
48 for(SyncIter iter = mSyncObjects.begin(), end = mSyncObjects.end(); iter != end; ++iter)
55 * Initialize the sync objects - clear down the map
57 void TestGlSyncAbstraction::Initialize()
63 * Create a sync object
64 * @return the sync object
66 Integration::GlSyncAbstraction::SyncObject* TestGlSyncAbstraction::CreateSyncObject()
68 mTrace.PushCall("CreateSyncObject", ""); // Trace the method
70 TestSyncObject* syncObject = new TestSyncObject(mTrace);
71 mSyncObjects.push_back(syncObject);
76 * Destroy a sync object
77 * @param[in] syncObject The object to destroy
79 void TestGlSyncAbstraction::DestroySyncObject(Integration::GlSyncAbstraction::SyncObject* syncObject)
81 std::stringstream out;
83 mTrace.PushCall("DestroySyncObject", out.str()); // Trace the method
85 for(SyncIter iter = mSyncObjects.begin(), end = mSyncObjects.end(); iter != end; ++iter)
87 if(*iter == syncObject)
90 mSyncObjects.erase(iter);
96 Integration::GlSyncAbstraction::SyncObject* TestGlSyncAbstraction::GetLastSyncObject()
98 if(!mSyncObjects.empty())
100 return mSyncObjects.back();
106 * Test method to trigger the object sync behaviour.
108 * @param[in] sync The sync value to set
110 void TestGlSyncAbstraction::SetObjectSynced(Integration::GlSyncAbstraction::SyncObject* syncObject, bool sync)
112 TestSyncObject* testSyncObject = static_cast<TestSyncObject*>(syncObject);
113 testSyncObject->synced = sync;
119 void TestGlSyncAbstraction::EnableTrace(bool enable)
121 mTrace.Enable(enable);
125 * Reset the trace callstack
127 void TestGlSyncAbstraction::ResetTrace()
133 * Get the trace object (allows test case to find methods on it)
135 TraceCallStack& TestGlSyncAbstraction::GetTrace()
140 int32_t TestGlSyncAbstraction::GetNumberOfSyncObjects()
142 return static_cast<int32_t>(mSyncObjects.size());