summaryrefslogtreecommitdiff
path: root/src/qcam/assets/feathericons/minus-square.svg
blob: 4862832a8ebcb7e65d7288dd25d8a05cc2b20635 (plain)
1
<svg xmlns="http://www.w3.org/2000/svg" width="24" height="24" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round" class="feather feather-minus-square"><rect x="3" y="3" width="18" height="18" rx="2" ry="2"></rect><line x1="8" y1="12" x2="16" y2="12"></line></svg>
>28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 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);