mirror of
https://github.com/swift-project/pilotclient.git
synced 2026-03-22 23:05:36 +08:00
146 lines
4.6 KiB
C++
146 lines
4.6 KiB
C++
/* Copyright (C) 2017
|
|
* 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. 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.
|
|
*/
|
|
|
|
//! \cond PRIVATE_TESTS
|
|
//! \file
|
|
//! \ingroup testblackcore
|
|
|
|
#include "blackcore/application.h"
|
|
#include "blackcore/db/networkwatchdog.h"
|
|
#include "blackcore/setupreader.h"
|
|
#include "blackmisc/applicationinfo.h"
|
|
#include "blackmisc/network/networkutils.h"
|
|
#include "blackmisc/statusmessagelist.h"
|
|
#include "test.h"
|
|
#include <QObject>
|
|
#include <QDateTime>
|
|
#include <QDebug>
|
|
#include <QTest>
|
|
#include <QString>
|
|
#include <QtDebug>
|
|
|
|
using namespace BlackCore;
|
|
using namespace BlackCore::Db;
|
|
using namespace BlackMisc;
|
|
using namespace BlackMisc::Network;
|
|
|
|
namespace BlackCoreTest
|
|
{
|
|
//! Test connectivity such as \c canConnect \c ping and BlackCore::Db::CNetworkWatchdog
|
|
class CTestConnectivity : public QObject
|
|
{
|
|
Q_OBJECT
|
|
|
|
private slots:
|
|
//! Init
|
|
void initTestCase();
|
|
|
|
//! Setup reader
|
|
void checkSetupReader();
|
|
|
|
//! Connecting test server
|
|
void connectServer();
|
|
|
|
//! Ping test server
|
|
void pingServer();
|
|
|
|
//! Test the watchdog BlackCore::Db::CNetworkWatchdog
|
|
void testNetworkWatchdog();
|
|
|
|
private:
|
|
int m_networkCheckCount = -1;
|
|
};
|
|
|
|
void CTestConnectivity::initTestCase()
|
|
{
|
|
QVERIFY2(sApp, "sApp not available");
|
|
QVERIFY2(sApp->getNetworkWatchdog(), "No network watchdog");
|
|
|
|
const int n = sApp->triggerNetworkWatchdogChecks();
|
|
QVERIFY2(n >= 0, "Cannot trigger setup reader");
|
|
m_networkCheckCount = n;
|
|
qDebug() << "Initial network check count:" << n;
|
|
}
|
|
|
|
void CTestConnectivity::checkSetupReader()
|
|
{
|
|
if (!sApp->hasSetupReader()) { QSKIP("Cannot load bootstrap file, skip unit test"); }
|
|
}
|
|
|
|
void CTestConnectivity::connectServer()
|
|
{
|
|
if (!sApp->hasSetupReader()) { QSKIP("Cannot load bootstrap file, skip unit test"); }
|
|
const CUrl url = sApp->getGlobalSetup().getDbHomePageUrl();
|
|
QElapsedTimer timer;
|
|
timer.start();
|
|
constexpr int max = 5;
|
|
for (int i = 0; i < max; i++)
|
|
{
|
|
bool ok = CNetworkUtils::canConnect(url, CNetworkUtils::getLongTimeoutMs());
|
|
if (!ok) { QSKIP(qPrintable("Cannot connect " + url.getFullUrl())); }
|
|
}
|
|
int elapsedMs = timer.elapsed();
|
|
qDebug() << "Completed" << max << "connection tests in" << elapsedMs << "ms to" << url.getFullUrl();
|
|
QVERIFY2(true, "connectServer");
|
|
}
|
|
|
|
void CTestConnectivity::pingServer()
|
|
{
|
|
if (!sApp->hasSetupReader()) { QSKIP("Cannot load bootstrap file, skip unit test"); }
|
|
const CUrl url = sApp->getGlobalSetup().getDbHomePageUrl();
|
|
const QString host(url.getHost());
|
|
QElapsedTimer timer;
|
|
timer.start();
|
|
constexpr int max = 5;
|
|
for (int i = 0; i < max; i++)
|
|
{
|
|
bool ok = canPing(host);
|
|
if (!ok) { QSKIP(qPrintable("Cannot ping " + url.getFullUrl())); }
|
|
}
|
|
int elapsedMs = timer.elapsed();
|
|
qDebug() << "Completed" << max << "ping tests in" << elapsedMs << "ms to" << url.getFullUrl();
|
|
QVERIFY2(true, "pingServer");
|
|
}
|
|
|
|
void CTestConnectivity::testNetworkWatchdog()
|
|
{
|
|
QVERIFY2(sApp->getNetworkWatchdog(), "No network watchdog");
|
|
const CUrl dbUrl = CNetworkWatchdog::dbTestUrl();
|
|
qDebug() << "Using DB test URL: " << dbUrl.toQString();
|
|
const bool ok = canPing(dbUrl);
|
|
if (!ok) { QSKIP(qPrintable("Cannot ping " + dbUrl.getFullUrl())); }
|
|
|
|
// only if URL is reachable
|
|
QTRY_VERIFY2_WITH_TIMEOUT(sApp->isSwiftDbAccessible(), "Watchdog cannot connect db", 20000);
|
|
QTRY_VERIFY2_WITH_TIMEOUT(sApp->getNetworkWatchdog()->getCheckCount() >= m_networkCheckCount + 1, "Timeout of network check", 30000);
|
|
qDebug() << "Current network check count:" << sApp->getNetworkWatchdog()->getCheckCount();
|
|
}
|
|
} // ns
|
|
|
|
//! main
|
|
int main(int argc, char *argv[])
|
|
{
|
|
QCoreApplication app(argc, argv);
|
|
BLACKTEST_INIT(BlackCoreTest::CTestConnectivity)
|
|
CApplication a(CApplicationInfo::UnitTest);
|
|
a.addVatlibOptions();
|
|
const bool setup = a.parseAndSynchronizeSetup();
|
|
if (!setup) { qWarning() << "No setup loaded"; }
|
|
int r = EXIT_FAILURE;
|
|
if (a.start())
|
|
{
|
|
r = QTest::qExec(&to, args);
|
|
}
|
|
a.gracefulShutdown();
|
|
return r;
|
|
}
|
|
|
|
#include "testconnectivity.moc"
|
|
|
|
//! \endcond
|