/**************************************************************************** ** ** Copyright (C) 2016 The Qt Company Ltd. ** Contact: https://www.qt.io/licensing/ ** ** This file is part of Qt Creator. ** ** Commercial License Usage ** Licensees holding valid commercial Qt licenses may use this file in ** accordance with the commercial license agreement provided with the ** Software or, alternatively, in accordance with the terms contained in ** a written agreement between you and The Qt Company. For licensing terms ** and conditions see https://www.qt.io/terms-conditions. For further ** information use the contact form at https://www.qt.io/contact-us. ** ** GNU General Public License Usage ** Alternatively, this file may be used under the terms of the GNU ** General Public License version 3 as published by the Free Software ** Foundation with exceptions as appearing in the file LICENSE.GPL3-EXCEPT ** included in the packaging of this file. Please review the following ** information to ensure the GNU General Public License requirements will ** be met: https://www.gnu.org/licenses/gpl-3.0.html. ** ****************************************************************************/ #include "testframeworkmanager.h" #include "autotestconstants.h" #include "itestframework.h" #include "itestparser.h" #include "testrunner.h" #include "testsettings.h" #include "testtreeitem.h" #include "testtreemodel.h" #include #include #include static Q_LOGGING_CATEGORY(LOG, "qtc.autotest.frameworkmanager") namespace Autotest { namespace Internal { TestFrameworkManager *s_instance = 0; TestFrameworkManager::TestFrameworkManager() { m_testTreeModel = TestTreeModel::instance(); m_testRunner = TestRunner::instance(); s_instance = this; } TestFrameworkManager *TestFrameworkManager::instance() { if (!s_instance) return new TestFrameworkManager; return s_instance; } TestFrameworkManager::~TestFrameworkManager() { delete m_testRunner; delete m_testTreeModel; for (ITestFramework *framework : m_registeredFrameworks.values()) delete framework; } bool TestFrameworkManager::registerTestFramework(ITestFramework *framework) { QTC_ASSERT(framework, return false); Core::Id id = Core::Id(Constants::FRAMEWORK_PREFIX).withSuffix(framework->name()); QTC_ASSERT(!m_registeredFrameworks.contains(id), delete framework; return false); // TODO check for unique priority before registering qCDebug(LOG) << "Registering" << id; m_registeredFrameworks.insert(id, framework); return true; } void TestFrameworkManager::activateFrameworksFromSettings(QSharedPointer settings) { FrameworkIterator it = m_registeredFrameworks.begin(); FrameworkIterator end = m_registeredFrameworks.end(); for ( ; it != end; ++it) it.value()->setActive(settings->frameworks.value(it.key(), false)); } QString TestFrameworkManager::frameworkNameForId(const Core::Id &id) const { ITestFramework *framework = m_registeredFrameworks.value(id, 0); return framework ? QString::fromLatin1(framework->name()) : QString(); } QList TestFrameworkManager::registeredFrameworkIds() const { return m_registeredFrameworks.keys(); } QList TestFrameworkManager::sortedRegisteredFrameworkIds() const { QList registered = m_registeredFrameworks.keys(); Utils::sort(registered, [this] (const Core::Id &lhs, const Core::Id &rhs) { return m_registeredFrameworks[lhs]->priority() < m_registeredFrameworks[rhs]->priority(); }); qCDebug(LOG) << "Registered frameworks sorted by priority" << registered; return registered; } QVector TestFrameworkManager::activeFrameworkIds() const { QVector active; FrameworkIterator it = m_registeredFrameworks.begin(); FrameworkIterator end = m_registeredFrameworks.end(); for ( ; it != end; ++it) { if (it.value()->active()) active.append(it.key()); } return active; } QVector TestFrameworkManager::sortedActiveFrameworkIds() const { QVector active = activeFrameworkIds(); Utils::sort(active, [this] (const Core::Id &lhs, const Core::Id &rhs) { return m_registeredFrameworks[lhs]->priority() < m_registeredFrameworks[rhs]->priority(); }); qCDebug(LOG) << "Active frameworks sorted by priority" << active; return active; } TestTreeItem *TestFrameworkManager::rootNodeForTestFramework(const Core::Id &frameworkId) const { ITestFramework *framework = m_registeredFrameworks.value(frameworkId, 0); return framework ? framework->rootNode() : 0; } ITestParser *TestFrameworkManager::testParserForTestFramework(const Core::Id &frameworkId) const { ITestFramework *framework = m_registeredFrameworks.value(frameworkId, 0); if (!framework) return 0; ITestParser *testParser = framework->testParser(); qCDebug(LOG) << "Setting" << frameworkId << "as Id for test parser"; testParser->setId(frameworkId); return testParser; } bool TestFrameworkManager::isActive(const Core::Id &frameworkId) const { ITestFramework *framework = m_registeredFrameworks.value(frameworkId); return framework ? framework->active() : false; } bool TestFrameworkManager::hasActiveFrameworks() const { for (ITestFramework *framework : m_registeredFrameworks.values()) { if (framework->active()) return true; } return false; } } // namespace Internal } // namespace Autotest