test: v4l2_device: Provide asynchronous capture test
Utilise the event_dispatcher to create a default event loop, and process asynchronous buffer receive events. If no frames are captured in 5 seconds, the test will fail. It will also fail if less than 30 frames have been captured in the same timeout period. Signed-off-by: Kieran Bingham <kieran.bingham@ideasonboard.com> Signed-off-by: Jacopo Mondi <jacopo@jmondi.org> Signed-off-by: Laurent Pinchart <laurent.pinchart@ideasonboard.com> Signed-off-by: Niklas Söderlund <niklas.soderlund@ragnatech.se>
This commit is contained in:
parent
d2046d863b
commit
ba4dfa7471
2 changed files with 87 additions and 0 deletions
86
test/v4l2_device/capture_async.cpp
Normal file
86
test/v4l2_device/capture_async.cpp
Normal file
|
@ -0,0 +1,86 @@
|
||||||
|
/* SPDX-License-Identifier: GPL-2.0-or-later */
|
||||||
|
/*
|
||||||
|
* Copyright (C) 2019, Google Inc.
|
||||||
|
*
|
||||||
|
* libcamera V4L2 API tests
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include <libcamera/buffer.h>
|
||||||
|
#include <libcamera/camera_manager.h>
|
||||||
|
#include <libcamera/event_dispatcher.h>
|
||||||
|
#include <libcamera/timer.h>
|
||||||
|
|
||||||
|
#include <iostream>
|
||||||
|
|
||||||
|
#include "v4l2_device_test.h"
|
||||||
|
|
||||||
|
class CaptureAsyncTest : public V4L2DeviceTest
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
CaptureAsyncTest()
|
||||||
|
: frames(0){};
|
||||||
|
|
||||||
|
void receiveBuffer(Buffer *buffer)
|
||||||
|
{
|
||||||
|
std::cout << "Received buffer " << buffer->index() << std::endl;
|
||||||
|
frames++;
|
||||||
|
|
||||||
|
/* Requeue the buffer for further use. */
|
||||||
|
dev_->queueBuffer(buffer);
|
||||||
|
}
|
||||||
|
|
||||||
|
protected:
|
||||||
|
int run()
|
||||||
|
{
|
||||||
|
const unsigned int bufferCount = 8;
|
||||||
|
|
||||||
|
EventDispatcher *dispatcher = CameraManager::instance()->eventDispatcher();
|
||||||
|
Timer timeout;
|
||||||
|
int ret;
|
||||||
|
|
||||||
|
createBuffers(bufferCount);
|
||||||
|
|
||||||
|
ret = dev_->exportBuffers(bufferCount, &pool_);
|
||||||
|
if (ret)
|
||||||
|
return TestFail;
|
||||||
|
|
||||||
|
dev_->bufferReady.connect(this, &CaptureAsyncTest::receiveBuffer);
|
||||||
|
|
||||||
|
/* Queue all the buffers to the device. */
|
||||||
|
for (Buffer &b : pool_.buffers()) {
|
||||||
|
if (dev_->queueBuffer(&b))
|
||||||
|
return TestFail;
|
||||||
|
}
|
||||||
|
|
||||||
|
ret = dev_->streamOn();
|
||||||
|
if (ret)
|
||||||
|
return TestFail;
|
||||||
|
|
||||||
|
timeout.start(5000);
|
||||||
|
while (timeout.isRunning())
|
||||||
|
dispatcher->processEvents();
|
||||||
|
|
||||||
|
if (frames < 1) {
|
||||||
|
std::cout << "Failed to capture any frames within timeout." << std::endl;
|
||||||
|
return TestFail;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (frames < 30) {
|
||||||
|
std::cout << "Failed to capture 30 frames within timeout." << std::endl;
|
||||||
|
return TestFail;
|
||||||
|
}
|
||||||
|
|
||||||
|
std::cout << "Processed " << frames << " frames" << std::endl;
|
||||||
|
|
||||||
|
ret = dev_->streamOff();
|
||||||
|
if (ret)
|
||||||
|
return TestFail;
|
||||||
|
|
||||||
|
return TestPass;
|
||||||
|
}
|
||||||
|
|
||||||
|
private:
|
||||||
|
unsigned int frames;
|
||||||
|
};
|
||||||
|
|
||||||
|
TEST_REGISTER(CaptureAsyncTest);
|
|
@ -4,6 +4,7 @@ v4l2_device_tests = [
|
||||||
[ 'double_open', 'double_open.cpp' ],
|
[ 'double_open', 'double_open.cpp' ],
|
||||||
[ 'request_buffers', 'request_buffers.cpp' ],
|
[ 'request_buffers', 'request_buffers.cpp' ],
|
||||||
[ 'stream_on_off', 'stream_on_off.cpp' ],
|
[ 'stream_on_off', 'stream_on_off.cpp' ],
|
||||||
|
[ 'capture_async', 'capture_async.cpp' ],
|
||||||
]
|
]
|
||||||
|
|
||||||
foreach t : v4l2_device_tests
|
foreach t : v4l2_device_tests
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue