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:
Laurent Pinchart 2019-08-11 18:51:48 +03:00
parent 92b4af98cd
commit 4d9f1a0efc
2 changed files with 79 additions and 0 deletions

View file

@ -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
View 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)