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:
parent
8638076aa1
commit
71e73bb6f8
@ -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();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user