/* SPDX-License-Identifier: GPL-2.0-or-later */ /* * Copyright (C) 2019, Google Inc. * * event-dispatcher.cpp - Event dispatcher test */ #include #include #include #include #include #include #include #include "test.h" using namespace std; using namespace libcamera; static EventDispatcher *dispatcher; static bool interrupt; class EventDispatcherTest : public Test { protected: static void sigAlarmHandler(int) { cout << "SIGALARM received" << endl; if (interrupt) dispatcher->interrupt(); } int init() { dispatcher = Thread::current()->eventDispatcher(); struct sigaction sa = {}; sa.sa_handler = &sigAlarmHandler; sigaction(SIGALRM, &sa, nullptr); return 0; } int run() { Timer timer; /* Event processing interruption by signal. */ std::chrono::steady_clock::time_point start = std::chrono::steady_clock::now(); timer.start(1000); struct itimerval itimer = {}; itimer.it_value.tv_usec = 500000; interrupt = false; setitimer(ITIMER_REAL, &itimer, nullptr); dispatcher->processEvents(); std::chrono::steady_clock::time_point stop = std::chrono::steady_clock::now(); std::chrono::steady_clock::duration duration = stop - start; int msecs = std::chrono::duration_cast(duration).count(); if (abs(msecs - 1000) > 50) { cout << "Event processing restart test failed" << endl; return TestFail; } /* Event processing interruption. */ timer.start(1000); dispatcher->interrupt(); dispatcher->processEvents(); if (!timer.isRunning()) { cout << "Event processing immediate interruption failed" << endl; return TestFail; } timer.start(1000); itimer.it_value.tv_usec = 500000; interrupt = true; setitimer(ITIMER_REAL, &itimer, nullptr); dispatcher->processEvents(); if (!timer.isRunning()) { cout << "Event processing delayed interruption failed" << endl; return TestFail; } return TestPass; } void cleanup() { } }; TEST_REGISTER(EventDispatcherTest) 77e122008f1c06d1712a5e869d355a57067d9'/>
blob: 0f364f833ed1c1bdb8c242d6f9a6185eb2c76b65 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
/* SPDX-License-Identifier: GPL-2.0-or-later */
/*
 * Copyright (C) 2020, Kaaira Gupta
 * libcamera pixel format handling test
 */

#include <iostream>
#include <vector>

#include <libcamera/formats.h>
#include <libcamera/pixel_format.h>

#include <libcamera/base/utils.h>

#include "test.h"

using namespace std;
using namespace libcamera;

class PixelFormatTest : public Test
{
protected:
	int run()
	{
		std::vector<std::pair<PixelFormat, const char *>> formatsMap{
			{ formats::R8, "R8" },
			{ formats::SRGGB10_CSI2P, "SRGGB10_CSI2P" },
			{ PixelFormat(0, 0), "<INVALID>" },
			{ PixelFormat(0x20203843), "<C8  >" }
		};

		for (const auto &format : formatsMap) {
			if ((format.first).toString() != format.second) {
				cerr << "Failed to convert PixelFormat "
				     << utils::hex(format.first.fourcc()) << " to string"
				     << endl;
				return TestFail;
			}
		}

		if (PixelFormat().toString() != "<INVALID>") {
			cerr << "Failed to convert default PixelFormat to string"
			     << endl;
			return TestFail;
		}

		return TestPass;
	}
};

TEST_REGISTER(PixelFormatTest)