test: Add Timer thread move test
The test verifies correct behaviour of a running timer moved to a different thread. Signed-off-by: Laurent Pinchart <laurent.pinchart@ideasonboard.com> Reviewed-by: Jacopo Mondi <jacopo@jmondi.org> Reviewed-by: Niklas Söderlund <niklas.soderlund@ragnatech.se>
This commit is contained in:
parent
92b4af98cd
commit
4d9f1a0efc
2 changed files with 79 additions and 0 deletions
|
@ -29,6 +29,7 @@ internal_tests = [
|
|||
['object-invoke', 'object-invoke.cpp'],
|
||||
['signal-threads', 'signal-threads.cpp'],
|
||||
['threads', 'threads.cpp'],
|
||||
['timer-thread', 'timer-thread.cpp'],
|
||||
]
|
||||
|
||||
foreach t : public_tests
|
||||
|
|
78
test/timer-thread.cpp
Normal file
78
test/timer-thread.cpp
Normal file
|
@ -0,0 +1,78 @@
|
|||
/* SPDX-License-Identifier: GPL-2.0-or-later */
|
||||
/*
|
||||
* Copyright (C) 2019, Google Inc.
|
||||
*
|
||||
* timer-thread.cpp - Threaded timer test
|
||||
*/
|
||||
|
||||
#include <chrono>
|
||||
#include <iostream>
|
||||
|
||||
#include <libcamera/timer.h>
|
||||
|
||||
#include "test.h"
|
||||
#include "thread.h"
|
||||
|
||||
using namespace std;
|
||||
using namespace libcamera;
|
||||
|
||||
class TimeoutHandler : public Object
|
||||
{
|
||||
public:
|
||||
TimeoutHandler()
|
||||
: timeout_(false)
|
||||
{
|
||||
timer_.timeout.connect(this, &TimeoutHandler::timeoutHandler);
|
||||
timer_.start(100);
|
||||
}
|
||||
|
||||
bool timeout() const
|
||||
{
|
||||
return timeout_;
|
||||
}
|
||||
|
||||
void moveToThread(Thread *thread)
|
||||
{
|
||||
Object::moveToThread(thread);
|
||||
timer_.moveToThread(thread);
|
||||
}
|
||||
|
||||
private:
|
||||
void timeoutHandler(Timer *timer)
|
||||
{
|
||||
timeout_ = true;
|
||||
}
|
||||
|
||||
Timer timer_;
|
||||
bool timeout_;
|
||||
};
|
||||
|
||||
class TimerThreadTest : public Test
|
||||
{
|
||||
protected:
|
||||
int run()
|
||||
{
|
||||
Thread thread;
|
||||
thread.start();
|
||||
|
||||
TimeoutHandler timeout;
|
||||
timeout.moveToThread(&thread);
|
||||
|
||||
this_thread::sleep_for(chrono::milliseconds(100));
|
||||
|
||||
/* Must stop thread before destroying timeout. */
|
||||
thread.exit(0);
|
||||
thread.wait();
|
||||
|
||||
if (!timeout.timeout()) {
|
||||
cout << "Timer expiration test failed" << endl;
|
||||
return TestFail;
|
||||
}
|
||||
|
||||
return TestPass;
|
||||
}
|
||||
|
||||
private:
|
||||
};
|
||||
|
||||
TEST_REGISTER(TimerThreadTest)
|
Loading…
Add table
Add a link
Reference in a new issue