@@ -3,6 +3,7 @@ subdir('libtest')
subdir('media_device')
subdir('pipeline')
subdir('v4l2_device')
+subdir('v4l2_subdevice')
public_tests = [
['event', 'event.cpp'],
new file mode 100644
@@ -0,0 +1,10 @@
+v4l2_subdevice_tests = [
+ [ 'test_formats', 'test_formats.cpp'],
+]
+
+foreach t : v4l2_subdevice_tests
+ exe = executable(t[0], [t[1], 'v4l2_subdevice_test.cpp'],
+ link_with : test_libraries,
+ include_directories : test_includes_internal)
+ test(t[0], exe, suite: 'v4l2_subdevice', is_parallel: false)
+endforeach
new file mode 100644
@@ -0,0 +1,79 @@
+/* SPDX-License-Identifier: GPL-2.0-or-later */
+/*
+ * Copyright (C) 2019, Google Inc.
+ *
+ * libcamera V4L2 Subdevice format handling test
+ */
+
+#include <climits>
+#include <iostream>
+
+#include "v4l2_subdevice.h"
+
+#include "v4l2_subdevice_test.h"
+
+using namespace std;
+using namespace libcamera;
+
+/* Test format handling on the "Scaler" subdevice of vimc media device. */
+
+class FormatHandlingTest : public V4L2SubdeviceTest
+{
+protected:
+ int run();
+};
+
+int FormatHandlingTest::run()
+{
+ V4L2SubdeviceFormat format = {};
+
+ /*
+ * Get format on a non-existing Scaler pad: expect failure.
+ */
+ int ret = scaler_->getFormat(2, &format);
+ if (!ret) {
+ cerr << "Get format on a non existing pad should fail" << endl;
+ return TestFail;
+ }
+
+ ret = scaler_->getFormat(0, &format);
+ if (ret) {
+ cerr << "Failed to get format" << endl;
+ return TestFail;
+ }
+
+ /*
+ * Set unrealistic image resolutions and make sure it gets updated.
+ */
+ format.width = UINT_MAX;
+ format.height = UINT_MAX;
+ ret = scaler_->setFormat(0, &format);
+ if (ret) {
+ cerr << "Failed to set format: image resolution is wrong, but "
+ << "setFormat() should not fail." << endl;
+ return TestFail;
+ }
+
+ if (format.width == UINT_MAX || format.height == UINT_MAX) {
+ cerr << "Failed to update image format" << endl;
+ return TestFail;
+ }
+
+ format.width = 0;
+ format.height = 0;
+ ret = scaler_->setFormat(0, &format);
+ if (ret) {
+ cerr << "Failed to set format: image resolution is wrong, but "
+ << "setFormat() should not fail." << endl;
+ return TestFail;
+ }
+
+ if (format.width == 0 || format.height == 0) {
+ cerr << "Failed to update image format" << endl;
+ return TestFail;
+ }
+
+ return TestPass;
+}
+
+TEST_REGISTER(FormatHandlingTest);
new file mode 100644
@@ -0,0 +1,90 @@
+/* SPDX-License-Identifier: GPL-2.0-or-later */
+/*
+ * Copyright (C) 2019, Google Inc.
+ *
+ * v4l2_subdevice_test.cpp - V4L2 subdevice test
+ */
+
+#include <iostream>
+#include <string.h>
+#include <sys/stat.h>
+
+#include "device_enumerator.h"
+#include "media_device.h"
+#include "v4l2_subdevice.h"
+
+#include "v4l2_subdevice_test.h"
+
+using namespace std;
+using namespace libcamera;
+
+/*
+ * This test runs on vimc media device. For a description of vimc, in the
+ * context of libcamera testingrefer to
+ * 'test/media_device/media_device_link_test.cpp' file.
+ *
+ * If the vimc module is not loaded, the test gets skipped.
+ */
+
+int V4L2SubdeviceTest::init()
+{
+ enumerator_ = DeviceEnumerator::create();
+ if (!enumerator_) {
+ cerr << "Failed to create device enumerator" << endl;
+ return TestFail;
+ }
+
+ if (enumerator_->enumerate()) {
+ cerr << "Failed to enumerate media devices" << endl;
+ return TestFail;
+ }
+
+ DeviceMatch dm("vimc");
+ media_ = std::move(enumerator_->search(dm));
+ if (!media_) {
+ cerr << "Unable to find \'vimc\' media device node" << endl;
+ return TestSkip;
+ }
+
+ media_->acquire();
+
+ int ret = media_->open();
+ if (ret) {
+ cerr << "Unable to open media device: " << media_->deviceNode()
+ << ": " << strerror(ret) << endl;
+ media_->release();
+ return TestSkip;
+ }
+
+ MediaEntity *videoEntity = media_->getEntityByName("Scaler");
+ if (!videoEntity) {
+ cerr << "Unable to find media entity 'Scaler'" << endl;
+ media_->release();
+ return TestSkip;
+ }
+
+ scaler_ = new V4L2Subdevice(videoEntity);
+ if (!scaler_) {
+ cerr << "Unable to create media device from media entity: "
+ << videoEntity->deviceNode();
+ media_->release();
+ return TestSkip;
+ }
+
+ ret = scaler_->open();
+ if (ret) {
+ cerr << "Unable to open video subdevice "
+ << scaler_->deviceNode() << endl;
+ media_->release();
+ return TestSkip;
+ }
+
+ return 0;
+}
+
+void V4L2SubdeviceTest::cleanup()
+{
+ media_->release();
+
+ delete scaler_;
+}
new file mode 100644
@@ -0,0 +1,36 @@
+/* SPDX-License-Identifier: GPL-2.0-or-later */
+/*
+ * Copyright (C) 2019, Google Inc.
+ *
+ * v4l2_subdevice_test.h - V4L2 subdevice test
+ */
+
+#ifndef __LIBCAMERA_V4L2_SUBDEVICE_TEST_H_
+#define __LIBCAMERA_V4L2_SUBDEVICE_TEST_H_
+
+#include <libcamera/buffer.h>
+
+#include "device_enumerator.h"
+#include "media_device.h"
+#include "test.h"
+#include "v4l2_subdevice.h"
+
+using namespace libcamera;
+
+class V4L2SubdeviceTest : public Test
+{
+public:
+ V4L2SubdeviceTest()
+ : scaler_(nullptr){};
+
+protected:
+ int init();
+ virtual int run() = 0;
+ void cleanup();
+
+ std::unique_ptr<DeviceEnumerator> enumerator_;
+ std::shared_ptr<MediaDevice> media_;
+ V4L2Subdevice *scaler_;
+};
+
+#endif /* __LIBCAMERA_V4L2_SUBDEVICE_TEST_H_ */
Add test for video format get and set operations on V4L2Subdevice class. Signed-off-by: Jacopo Mondi <jacopo@jmondi.org> --- test/meson.build | 1 + test/v4l2_subdevice/meson.build | 10 +++ test/v4l2_subdevice/test_formats.cpp | 79 ++++++++++++++++++ test/v4l2_subdevice/v4l2_subdevice_test.cpp | 90 +++++++++++++++++++++ test/v4l2_subdevice/v4l2_subdevice_test.h | 36 +++++++++ 5 files changed, 216 insertions(+) create mode 100644 test/v4l2_subdevice/meson.build create mode 100644 test/v4l2_subdevice/test_formats.cpp create mode 100644 test/v4l2_subdevice/v4l2_subdevice_test.cpp create mode 100644 test/v4l2_subdevice/v4l2_subdevice_test.h