fix(tests): linux big task memory leak.

- move big_task into function scope

Signed-off-by: Rachel Powers <508861+Ryex@users.noreply.github.com>
This commit is contained in:
Rachel Powers 2023-07-05 21:18:49 -07:00
parent 8638076aa1
commit 71e73bb6f8
No known key found for this signature in database
GPG Key ID: E10E321EB160949B

View File

@ -50,31 +50,34 @@ class BigConcurrentTask : public ConcurrentTask {
class BigConcurrentTaskThread : public QThread { class BigConcurrentTaskThread : public QThread {
Q_OBJECT Q_OBJECT
BigConcurrentTask big_task;
void run() override void run() override
{ {
QTimer deadline; QTimer deadline;
BigConcurrentTask big_task;
deadline.setInterval(10000); deadline.setInterval(10000);
connect(&deadline, &QTimer::timeout, this, [this] { passed_the_deadline = true; }); bool* pt_deadline = &passed_the_deadline;
QMetaObject::Connection conn = connect(&deadline, &QTimer::timeout, this, [pt_deadline] { *pt_deadline = true; });
deadline.start(); deadline.start();
// NOTE: Arbitrary value that manages to trigger a problem when there is one. // NOTE: Arbitrary value that manages to trigger a problem when there is one.
// Considering each tasks, in a problematic state, adds 1024 * 4 bytes to the stack, // Considering each tasks, in a problematic state, adds 1024 * 4 bytes to the stack,
// this number is enough to fill up 16 MiB of stack, more than enough to cause a problem. // this number is enough to fill up 16 MiB of stack, more than enough to cause a problem.
static const unsigned s_num_tasks = 1 << 12; static const unsigned s_num_tasks = 1 << 12;
{ for (unsigned i = 0; i < s_num_tasks; i++) {
auto sub_task = makeShared<BasicTask>(false);
big_task.addTask(sub_task);
}
for (unsigned i = 0; i < s_num_tasks; i++) { big_task.run();
auto sub_task = makeShared<BasicTask>(false);
big_task.addTask(sub_task);
}
big_task.run(); while (!big_task.isFinished() && !passed_the_deadline)
QCoreApplication::processEvents();
while (!big_task.isFinished() && !passed_the_deadline) // don't fire timer after this point
QCoreApplication::processEvents(); disconnect(conn);
} // drop before emit if (deadline.isActive())
deadline.stop();
// task finished
emit finished(); emit finished();
} }