Files
qt-creator/src/plugins/autotest/testframeworkmanager.cpp
Kai Köhne 56baf8c058 Remove GPL-3.0+ from license identifiers
Since we also license under GPL-3.0 WITH Qt-GPL-exception-1.0,
this applies only to a hypothetical newer version of GPL, that doesn't
exist yet. If such a version emerges, we can still decide to relicense...

While at it, replace (deprecated) GPL-3.0 with more explicit GPL-3.0-only

Change was done by running

  find . -type f -exec perl -pi -e "s/LicenseRef-Qt-Commercial OR GPL-3.0\+ OR GPL-3.0 WITH Qt-GPL-exception-1.0/LicenseRef-Qt-Commercial OR GPL-3.0-only WITH Qt-GPL-exception-1.0/g" {} \;

Change-Id: I5097e6ce8d10233993ee30d7e25120e2659eb10b
Reviewed-by: Eike Ziller <eike.ziller@qt.io>
2023-01-06 11:15:13 +00:00

113 lines
3.4 KiB
C++

// Copyright (C) 2016 The Qt Company Ltd.
// SPDX-License-Identifier: LicenseRef-Qt-Commercial OR GPL-3.0-only WITH Qt-GPL-exception-1.0
#include "testframeworkmanager.h"
#include "autotestplugin.h"
#include "testsettings.h"
#include <utils/aspects.h>
#include <utils/algorithm.h>
#include <utils/qtcassert.h>
#include <QSettings>
using namespace Utils;
namespace Autotest {
static TestFrameworkManager *s_instance = nullptr;
TestFrameworkManager::TestFrameworkManager()
{
s_instance = this;
}
TestFrameworkManager::~TestFrameworkManager()
{
qDeleteAll(m_registeredFrameworks);
qDeleteAll(m_registeredTestTools);
s_instance = nullptr;
}
bool TestFrameworkManager::registerTestFramework(ITestFramework *framework)
{
QTC_ASSERT(framework, return false);
QTC_ASSERT(!m_registeredFrameworks.contains(framework), return false);
// TODO check for unique priority before registering
m_registeredFrameworks.append(framework);
Utils::sort(m_registeredFrameworks, &ITestFramework::priority);
return true;
}
bool TestFrameworkManager::registerTestTool(ITestTool *testTool)
{
QTC_ASSERT(testTool, return false);
QTC_ASSERT(!m_registeredTestTools.contains(testTool), return false);
m_registeredTestTools.append(testTool);
return true;
}
void TestFrameworkManager::activateFrameworksAndToolsFromSettings(
const Internal::TestSettings *settings)
{
for (ITestFramework *framework : std::as_const(s_instance->m_registeredFrameworks)) {
framework->setActive(settings->frameworks.value(framework->id(), false));
framework->setGrouping(settings->frameworksGrouping.value(framework->id(), false));
}
for (ITestTool *testTool : std::as_const(s_instance->m_registeredTestTools))
testTool->setActive(settings->tools.value(testTool->id(), false));
}
const TestFrameworks TestFrameworkManager::registeredFrameworks()
{
return s_instance->m_registeredFrameworks;
}
const TestTools TestFrameworkManager::registeredTestTools()
{
return s_instance->m_registeredTestTools;
}
ITestFramework *TestFrameworkManager::frameworkForId(Id frameworkId)
{
return Utils::findOrDefault(s_instance->m_registeredFrameworks,
[frameworkId](ITestFramework *framework) {
return framework->id() == frameworkId;
});
}
ITestTool *TestFrameworkManager::testToolForId(Id testToolId)
{
return Utils::findOrDefault(s_instance->m_registeredTestTools,
[testToolId](ITestTool *testTool) {
return testTool->id() == testToolId;
});
}
ITestTool *TestFrameworkManager::testToolForBuildSystemId(Id buildSystemId)
{
if (!buildSystemId.isValid())
return nullptr;
return Utils::findOrDefault(s_instance->m_registeredTestTools,
[&buildSystemId](ITestTool *testTool) {
return testTool->buildSystemId() == buildSystemId;
});
}
void TestFrameworkManager::synchronizeSettings(QSettings *s)
{
Internal::AutotestPlugin::settings()->fromSettings(s);
for (ITestFramework *framework : std::as_const(m_registeredFrameworks)) {
if (ITestSettings *fSettings = framework->testSettings())
fSettings->readSettings(s);
}
for (ITestTool *testTool : std::as_const(m_registeredTestTools)) {
if (ITestSettings *tSettings = testTool->testSettings())
tSettings->readSettings(s);
}
}
} // namespace Autotest