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
|
/*
SPDX-FileCopyrightText: 2010 Milian Wolff <mail@milianw.de>
SPDX-License-Identifier: GPL-2.0-or-later
*/
#include "test_foregroundlock.h"
#include <QTest>
#include <QStandardPaths>
#include <QThread>
#include <QRandomGenerator>
#include <memory>
#include <vector>
#include "../foregroundlock.h"
QTEST_MAIN(KDevelop::TestForegroundLock)
using namespace KDevelop;
//BEGIN Helper Threads
class TryLockThread : public QThread
{
Q_OBJECT
public:
void run() override
{
ForegroundLock lock(false);
auto* randomGenerator = QRandomGenerator::global();
for (int i = 0; i < 1000; ++i) {
if (lock.tryLock()) {
lock.unlock();
}
QThread::usleep(randomGenerator->bounded(20));
}
}
};
void TestForegroundLock::initTestCase()
{
QStandardPaths::setTestModeEnabled(true);
}
void TestForegroundLock::testTryLock_data()
{
QTest::addColumn<int>("numThreads");
for (int i = 1; i <= 10; ++i) {
QTest::newRow(qPrintable(QString::number(i))) << i;
}
}
void TestForegroundLock::testTryLock()
{
QFETCH(int, numThreads);
std::vector<std::unique_ptr<TryLockThread>> threads;
threads.reserve(numThreads);
for (int i = 0; i < numThreads; ++i) {
threads.push_back(std::make_unique<TryLockThread>());
}
ForegroundLock lock(true);
for (auto& thread : threads) {
thread->start();
}
lock.unlock();
while (true) {
const bool running
= std::any_of(threads.cbegin(), threads.cend(), [](const auto& thread) { return thread->isRunning(); });
if (!running) {
break;
}
lock.relock();
QThread::usleep(10);
lock.unlock();
}
}
#include "moc_test_foregroundlock.cpp"
#include "test_foregroundlock.moc"
|