test: Add timer test
The test covers timer start, timeout, restart after completion, restart before completion and multiple timers. Signed-off-by: Laurent Pinchart <laurent.pinchart@ideasonboard.com> Reviewed-by: Niklas Söderlund <niklas.soderlund@ragnatech.se>
This commit is contained in:
parent
f151895c3f
commit
034ea86802
2 changed files with 150 additions and 0 deletions
|
@ -5,6 +5,7 @@ subdir('media_device')
|
||||||
public_tests = [
|
public_tests = [
|
||||||
['list-cameras', 'list-cameras.cpp'],
|
['list-cameras', 'list-cameras.cpp'],
|
||||||
['signal', 'signal.cpp'],
|
['signal', 'signal.cpp'],
|
||||||
|
['timer', 'timer.cpp'],
|
||||||
]
|
]
|
||||||
|
|
||||||
internal_tests = [
|
internal_tests = [
|
||||||
|
|
149
test/timer.cpp
Normal file
149
test/timer.cpp
Normal file
|
@ -0,0 +1,149 @@
|
||||||
|
/* SPDX-License-Identifier: GPL-2.0-or-later */
|
||||||
|
/*
|
||||||
|
* Copyright (C) 2019, Google Inc.
|
||||||
|
*
|
||||||
|
* timer.cpp - Timer test
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include <iostream>
|
||||||
|
|
||||||
|
#include <libcamera/camera_manager.h>
|
||||||
|
#include <libcamera/event_dispatcher.h>
|
||||||
|
#include <libcamera/timer.h>
|
||||||
|
|
||||||
|
#include "test.h"
|
||||||
|
|
||||||
|
using namespace std;
|
||||||
|
using namespace libcamera;
|
||||||
|
|
||||||
|
class ManagedTimer : public Timer
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
ManagedTimer() : Timer()
|
||||||
|
{
|
||||||
|
timeout.connect(this, &ManagedTimer::timeoutHandler);
|
||||||
|
}
|
||||||
|
|
||||||
|
void start(int msec)
|
||||||
|
{
|
||||||
|
interval_ = msec;
|
||||||
|
clock_gettime(CLOCK_MONOTONIC, &start_);
|
||||||
|
expiration_ = { 0, 0 };
|
||||||
|
|
||||||
|
Timer::start(msec);
|
||||||
|
}
|
||||||
|
|
||||||
|
int jitter()
|
||||||
|
{
|
||||||
|
int duration = (expiration_.tv_sec - start_.tv_sec) * 1000;
|
||||||
|
duration += (expiration_.tv_nsec - start_.tv_nsec) / 1000000;
|
||||||
|
return abs(duration - interval_);
|
||||||
|
}
|
||||||
|
|
||||||
|
private:
|
||||||
|
void timeoutHandler(Timer *timer)
|
||||||
|
{
|
||||||
|
clock_gettime(CLOCK_MONOTONIC, &expiration_);
|
||||||
|
}
|
||||||
|
|
||||||
|
int interval_;
|
||||||
|
struct timespec start_;
|
||||||
|
struct timespec expiration_;
|
||||||
|
};
|
||||||
|
|
||||||
|
class TimerTest : public Test
|
||||||
|
{
|
||||||
|
protected:
|
||||||
|
int init()
|
||||||
|
{
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
int run()
|
||||||
|
{
|
||||||
|
EventDispatcher *dispatcher = CameraManager::instance()->eventDispatcher();
|
||||||
|
ManagedTimer timer;
|
||||||
|
ManagedTimer timer2;
|
||||||
|
|
||||||
|
/* Timer expiration. */
|
||||||
|
timer.start(1000);
|
||||||
|
|
||||||
|
if (!timer.isRunning()) {
|
||||||
|
cout << "Timer expiration test failed" << endl;
|
||||||
|
return TestFail;
|
||||||
|
}
|
||||||
|
|
||||||
|
dispatcher->processEvents();
|
||||||
|
|
||||||
|
if (timer.isRunning() || timer.jitter() > 50) {
|
||||||
|
cout << "Timer expiration test failed" << endl;
|
||||||
|
return TestFail;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Timer restart. */
|
||||||
|
timer.start(500);
|
||||||
|
|
||||||
|
if (!timer.isRunning()) {
|
||||||
|
cout << "Timer restart test failed" << endl;
|
||||||
|
return TestFail;
|
||||||
|
}
|
||||||
|
|
||||||
|
dispatcher->processEvents();
|
||||||
|
|
||||||
|
if (timer.isRunning() || timer.jitter() > 50) {
|
||||||
|
cout << "Timer restart test failed" << endl;
|
||||||
|
return TestFail;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Two timers. */
|
||||||
|
timer.start(1000);
|
||||||
|
timer2.start(300);
|
||||||
|
|
||||||
|
dispatcher->processEvents();
|
||||||
|
|
||||||
|
if (!timer.isRunning()) {
|
||||||
|
cout << "Two timers test failed" << endl;
|
||||||
|
return TestFail;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (timer2.jitter() > 50) {
|
||||||
|
cout << "Two timers test failed" << endl;
|
||||||
|
return TestFail;
|
||||||
|
}
|
||||||
|
|
||||||
|
dispatcher->processEvents();
|
||||||
|
|
||||||
|
if (timer.jitter() > 50) {
|
||||||
|
cout << "Two timers test failed" << endl;
|
||||||
|
return TestFail;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Restart timer before expiration. */
|
||||||
|
timer.start(1000);
|
||||||
|
timer2.start(300);
|
||||||
|
|
||||||
|
dispatcher->processEvents();
|
||||||
|
|
||||||
|
if (timer2.jitter() > 50) {
|
||||||
|
cout << "Two timers test failed" << endl;
|
||||||
|
return TestFail;
|
||||||
|
}
|
||||||
|
|
||||||
|
timer.start(1000);
|
||||||
|
|
||||||
|
dispatcher->processEvents();
|
||||||
|
|
||||||
|
if (timer.jitter() > 50) {
|
||||||
|
cout << "Two timers test failed" << endl;
|
||||||
|
return TestFail;
|
||||||
|
}
|
||||||
|
|
||||||
|
return TestPass;
|
||||||
|
}
|
||||||
|
|
||||||
|
void cleanup()
|
||||||
|
{
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
TEST_REGISTER(TimerTest)
|
Loading…
Add table
Add a link
Reference in a new issue