/*-------------------------------------------------------------------------
* drawElements Quality Program Tester Core
* ----------------------------------------
*
* Copyright 2014 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 Base class for a test case.
*//*--------------------------------------------------------------------*/
#include "tcuTestPackage.hpp"
#include "tcuPlatform.hpp"
#include "deString.h"
using std::vector;
namespace tcu
{
// TestPackage
TestPackage::TestPackage (TestContext& testCtx, const char* name, const char* description)
: TestNode(testCtx, NODETYPE_PACKAGE, name, description)
{
}
TestPackage::~TestPackage (void)
{
}
TestNode::IterateResult TestPackage::iterate (void)
{
DE_ASSERT(DE_FALSE); // should never be here!
throw InternalError("TestPackage::iterate() called!", "", __FILE__, __LINE__);
}
// TestPackageRegistry
TestPackageRegistry::TestPackageRegistry (void)
{
}
TestPackageRegistry::~TestPackageRegistry (void)
{
for (int i = 0; i < (int)m_packageInfos.size(); i++)
delete m_packageInfos[i];
}
TestPackageRegistry* TestPackageRegistry::getSingleton (void)
{
return TestPackageRegistry::getOrDestroy(true);
}
void TestPackageRegistry::destroy (void)
{
TestPackageRegistry::getOrDestroy(false);
}
TestPackageRegistry* TestPackageRegistry::getOrDestroy (bool isCreate)
{
static TestPackageRegistry* s_ptr = DE_NULL;
if (isCreate)
{
if (!s_ptr)
s_ptr = new TestPackageRegistry();
return s_ptr;
}
else
{
if (s_ptr)
{
delete s_ptr;
s_ptr = DE_NULL;
}
return DE_NULL;
}
}
void TestPackageRegistry::registerPackage (const char* name, TestPackageCreateFunc createFunc)
{
m_packageInfos.push_back(new PackageInfo(name, createFunc));
}
const std::vector<TestPackageRegistry::PackageInfo*>& TestPackageRegistry::getPackageInfos (void) const
{
return m_packageInfos;
}
TestPackageRegistry::PackageInfo* TestPackageRegistry::getPackageInfoByName (const char* packageName) const
{
for (int i = 0; i < (int)m_packageInfos.size(); i++)
{
if (m_packageInfos[i]->name == packageName)
return m_packageInfos[i];
}
return DE_NULL;
}
TestPackage* TestPackageRegistry::createPackage (const char* name, TestContext& testCtx) const
{
PackageInfo* info = getPackageInfoByName(name);
return info ? info->createFunc(testCtx) : DE_NULL;
}
// TestPackageDescriptor
TestPackageDescriptor::TestPackageDescriptor (const char* name, TestPackageCreateFunc createFunc)
{
TestPackageRegistry::getSingleton()->registerPackage(name, createFunc);
}
TestPackageDescriptor::~TestPackageDescriptor (void)
{
TestPackageRegistry::destroy();
}
// TestPackageRoot
TestPackageRoot::TestPackageRoot (TestContext& testCtx)
: TestNode(testCtx, NODETYPE_ROOT, "", "")
{
}
TestPackageRoot::TestPackageRoot (TestContext& testCtx, const vector<TestNode*>& children)
: TestNode(testCtx, NODETYPE_ROOT, "", "", children)
{
}
TestPackageRoot::TestPackageRoot (TestContext& testCtx, const TestPackageRegistry* packageRegistry)
: TestNode(testCtx, NODETYPE_ROOT, "", "")
{
const vector<TestPackageRegistry::PackageInfo*>& packageInfos = packageRegistry->getPackageInfos();
for (int i = 0; i < (int)packageInfos.size(); i++)
addChild(packageInfos[i]->createFunc(testCtx));
}
TestPackageRoot::~TestPackageRoot (void)
{
}
TestCase::IterateResult TestPackageRoot::iterate (void)
{
DE_ASSERT(DE_FALSE); // should never be here!
throw InternalError("TestPackageRoot::iterate() called!", "", __FILE__, __LINE__);
}
} // tcu