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
|
/*
SPDX-FileCopyrightText: 2016 Milian Wolff <mail@milianw.de>
SPDX-License-Identifier: GPL-2.0-only OR GPL-3.0-only OR LicenseRef-KDE-Accepted-GPL
*/
#include "bench_duchain.h"
#include <QLoggingCategory>
#include <QTest>
#include <tests/autotestshell.h>
#include <tests/testcore.h>
#include <tests/testfile.h>
#include <language/duchain/duchainlock.h>
#include <language/duchain/duchain.h>
using namespace KDevelop;
BenchDUChain::BenchDUChain()
{
}
BenchDUChain::~BenchDUChain()
{
}
void BenchDUChain::initTestCase()
{
QLoggingCategory::setFilterRules(QStringLiteral("*.debug=false\ndefault.debug=true\nkdevelop.plugins.clang.debug=true\n"));
QVERIFY(qputenv("KDEV_CLANG_DISPLAY_DIAGS", "1"));
AutoTestShell::init({QStringLiteral("kdevclangsupport")});
TestCore::initialize(Core::NoUi);
}
void BenchDUChain::cleanupTestCase()
{
TestCore::shutdown();
}
void BenchDUChain::benchDUChainBuilder()
{
QBENCHMARK_ONCE {
TestFile file(
"#include <vector>\n"
"#include <map>\n"
"#include <set>\n"
"#include <algorithm>\n"
"#include <functional>\n"
"#include <limits>\n"
"#include <bitset>\n"
"#include <iostream>\n"
"#include <string>\n"
"#include <mutex>\n", QStringLiteral("cpp"));
file.parse(TopDUContext::AllDeclarationsContextsAndUses);
QVERIFY(file.waitForParsed(60000));
DUChainReadLocker lock;
auto top = file.topContext();
QVERIFY(top);
}
}
QTEST_MAIN(BenchDUChain)
#include "moc_bench_duchain.cpp"
|