1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103
|
/* KDevelop CMake Support
*
* Copyright 2017 Aleix Pol Gonzalez <aleixpol@kde.org>
*
* This program is free software; you can redistribute it and/or
* modify it under the terms of the GNU General Public License
* as published by the Free Software Foundation; either version 2
* of the License, or (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program; if not, write to the Free Software
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
* 02110-1301, USA.
*/
#include <cmakeserver.h>
#include <tests/autotestshell.h>
#include <tests/testproject.h>
#include <tests/testcore.h>
#include "testhelpers.h"
#include <cmakeutils.h>
#include <QTest>
#include <QJsonObject>
#include <QLoggingCategory>
#include <QVersionNumber>
using namespace KDevelop;
class CMakeServerTest : public QObject
{
Q_OBJECT
public:
CMakeServerTest()
{
QLoggingCategory::setFilterRules(QStringLiteral("default.debug=true\nkdevelop.projectmanagers.cmake.debug=true\n"));
AutoTestShell::init();
TestCore::initialize();
}
private Q_SLOTS:
void initTestCase()
{
const auto exe = CMake::findExecutable();
QVERIFY(!exe.isEmpty());
const auto versionStr = CMake::cmakeExecutableVersion(exe);
QVERIFY(!versionStr.isEmpty());
const auto version = QVersionNumber::fromString(versionStr);
QVERIFY(!version.isNull());
const bool versionWithServer = version >= QVersionNumber(3, 8);
if (!versionWithServer)
QSKIP("cmake server not supported");
}
void testRun()
{
CMakeServer server(nullptr);
QSignalSpy spyConnected(&server, &CMakeServer::connected);
QVERIFY(server.isServerAvailable() || spyConnected.wait());
QSignalSpy spy(&server, &CMakeServer::response);
QJsonObject codeModel;
int errors = 0;
connect(&server, &CMakeServer::response, this, [&errors, &codeModel, &server](const QJsonObject &response) {
if (response.value(QStringLiteral("type")) == QLatin1String("reply")) {
if (response.value(QStringLiteral("inReplyTo")) == QLatin1String("configure"))
server.compute();
else if (response.value(QStringLiteral("inReplyTo")) == QLatin1String("compute"))
server.codemodel();
else if(response.value(QStringLiteral("inReplyTo")) == QLatin1String("codemodel"))
codeModel = response;
} else if(response.value(QStringLiteral("type")) == QLatin1String("error")) {
++errors;
}
});
const QString name = QStringLiteral("single_subdirectory");
const auto paths = projectPaths(name);
const QString builddir = QStringLiteral(CMAKE_TESTS_BINARY_DIR "/cmake-server-test-builddir/") + name;
QVERIFY(QDir(builddir).removeRecursively());
QVERIFY(QDir(builddir).mkpath(builddir));
QVERIFY(spy.wait());
server.handshake(paths.sourceDir, Path(builddir));
QVERIFY(spy.wait());
server.configure({});
while(codeModel.isEmpty())
QVERIFY(spy.wait());
QCOMPARE(errors, 0);
QVERIFY(!codeModel.isEmpty());
qDebug() << "codemodel" << codeModel;
}
};
QTEST_MAIN( CMakeServerTest )
#include "test_cmakeserver.moc"
|