Configure additional xml output for each unit test via a BlackMisc utility class

refs #682
This commit is contained in:
Mathew Sutcliffe
2016-06-20 16:39:41 +02:00
committed by Roland Winklmeier
parent fbad0977fd
commit fdfc5256eb
5 changed files with 150 additions and 17 deletions

33
src/blackmisc/test.cpp Normal file
View File

@@ -0,0 +1,33 @@
/* Copyright (C) 2016
* swift project Community / Contributors
*
* This file is part of swift project. It is subject to the license terms in the LICENSE file found in the top-level
* directory of this distribution and at http://www.swift-project.org/license.html. No part of swift project,
* including this file, may be copied, modified, propagated, or distributed except according to the terms
* contained in the LICENSE file.
*/
#include "blackmisc/test.h"
namespace BlackMisc
{
CTestBase::CTestBase(int argc, const char *const *argv)
{
for (int i = 0; i < argc; ++i)
{
m_arguments.append(argv[i]);
}
// Output to stdout
m_arguments.append({ "-o", "-,txt" });
}
CTestBase::~CTestBase()
{}
int CTestBase::exec(QObject *test, const QString &name)
{
auto additionalArguments = QStringList { "-o", name + "_testresults.xml,xml" };
return this->qExec(test, m_arguments + additionalArguments);
}
}

66
src/blackmisc/test.h Normal file
View File

@@ -0,0 +1,66 @@
/* Copyright (C) 2016
* swift project Community / Contributors
*
* This file is part of swift project. It is subject to the license terms in the LICENSE file found in the top-level
* directory of this distribution and at http://www.swift-project.org/license.html. No part of swift project,
* including this file, may be copied, modified, propagated, or distributed except according to the terms
* contained in the LICENSE file.
*/
//! \file
#ifndef BLACKMISC_TEST_H
#define BLACKMISC_TEST_H
#include "blackmisc/blackmiscexport.h"
#include <QStringList>
#ifdef QT_TESTLIB_LIB
#include <QtTest>
#endif
class QObject;
namespace BlackMisc
{
/*!
* Helper base class for executing unit tests.
* Contains the parts that do not depend upon QtTest library, and pure
* virtual functions for derived class to implement the parts that do.
*/
class BLACKMISC_EXPORT CTestBase
{
public:
//! Constructor expects command line arguments.
CTestBase(int argc, const char *const *argv);
//! Destructor.
virtual ~CTestBase();
//! Execute the given test case.
int exec(QObject *test, const QString &name);
private:
virtual int qExec(QObject *test, const QStringList &args) = 0;
QStringList m_arguments;
};
#ifdef QT_TESTLIB_LIB
/*!
* Helper derived class for executing unit tests.
* Defined inline and only when building with QT += testlib so blackmisc
* doesn't need to link against QtTest library.
*/
class CTest : public CTestBase
{
public:
using CTestBase::CTestBase;
private:
virtual int qExec(QObject *test, const QStringList &args) override { return QTest::qExec(test, args); }
};
#endif
}
#endif

View File

@@ -18,25 +18,29 @@
#include "testinterpolator.h"
#include "testnetwork.h"
#include "testreaders.h"
#include "blackmisc/test.h"
#include <QStringList>
#include <QtTest>
namespace BlackCoreTest
{
int CBlackCoreTestMain::unitMain(int argc, char *argv[])
{
BlackMisc::CTest test(argc, argv);
int status = 0;
{
CTestInterpolator interpolatorTests;
status |= QTest::qExec(&interpolatorTests, argc, argv);
status |= test.exec(&interpolatorTests, "blackcore_interpolator");
}
{
CTestReaders readersTests;
status |= QTest::qExec(&readersTests, argc, argv);
status |= test.exec(&readersTests, "blackcore_readers");
}
{
CTestNetwork networkTests;
status |= QTest::qExec(&networkTests, argc, argv);
status |= test.exec(&networkTests, "blackcore_network");
}
return status;
}

View File

@@ -16,7 +16,9 @@
#include "testblackguimain.h"
#include "testutils.h"
#include "blackmisc/test.h"
#include <QStringList>
#include <QtTest>
namespace BlackGuiTest
@@ -26,10 +28,12 @@ namespace BlackGuiTest
*/
int CBlackGuiTestMain::unitMain(int argc, char *argv[])
{
BlackMisc::CTest test(argc, argv);
int status = 0;
{
CTestGuiUtilities utilityTests;
status |= QTest::qExec(&utilityTests, argc, argv);
status |= test.exec(&utilityTests, "blackgui_guiutilities");
}
return status;
}

View File

@@ -27,7 +27,9 @@
#include "testvaluecache.h"
#include "testvariantandmap.h"
#include "testweather.h"
#include "blackmisc/test.h"
#include <QStringList>
#include <QTest>
namespace BlackMiscTest
@@ -37,32 +39,56 @@ namespace BlackMiscTest
*/
int CBlackMiscTestMain::unitMain(int argc, char *argv[])
{
BlackMisc::CTest test(argc, argv);
int status = 0;
{
CTestPhysicalQuantities pqBaseTests ;
CTestPhysicalQuantities pqBaseTests;
status |= test.exec(&pqBaseTests, "blackmisc_physicalQuantities");
}
{
CTestAviation avBaseTests;
status |= test.exec(&avBaseTests, "blackmisc_aviation");
}
{
CTestGeo geoTests;
status |= test.exec(&geoTests, "blackmisc_geo");
}
{
CTestContainers containerTests;
status |= test.exec(&containerTests, "blackmisc_containers");
}
{
CTestVariantAndMap variantAndMap;
status |= test.exec(&variantAndMap, "blackmisc_variantandmap");
}
{
CTestInput inputTests;
status |= test.exec(&inputTests, "blackmisc_input");
}
{
CTestIdentifier identifierTests;
status |= test.exec(&identifierTests, "blackmisc_identifier");
}
{
CTestSlot slotTests;
status |= test.exec(&slotTests, "blackmisc_slot");
}
{
CTestValueCache valueCacheTests;
status |= test.exec(&valueCacheTests, "blackmisc_valuecache");
}
{
CTestWeather weatherTests;
status |= test.exec(&weatherTests, "blackmisc_weather");
}
{
CTestMath mathTests;
status |= test.exec(&mathTests, "blackmisc_math");
}
{
CTestLibraryPath libraryPathTests;
status |= QTest::qExec(&pqBaseTests, argc, argv);
status |= QTest::qExec(&avBaseTests, argc, argv);
status |= QTest::qExec(&geoTests, argc, argv);
status |= QTest::qExec(&identifierTests, argc, argv);
status |= QTest::qExec(&containerTests, argc, argv);
status |= QTest::qExec(&variantAndMap, argc, argv);
status |= QTest::qExec(&inputTests, argc, argv);
status |= QTest::qExec(&slotTests, argc, argv);
status |= QTest::qExec(&valueCacheTests, argc, argv);
status |= QTest::qExec(&weatherTests, argc, argv);
status |= QTest::qExec(&mathTests, argc, argv);
status |= QTest::qExec(&libraryPathTests, argc, argv);
status |= test.exec(&libraryPathTests, "blackmisc_librarypath");
}
return status;
}