[libcamera-devel] [PATCH v5 8/9] test: v4l2_subdevice: Add ListFormat test
Laurent Pinchart
laurent.pinchart at ideasonboard.com
Thu Feb 28 23:16:57 CET 2019
Hi Jacopo,
Thank you for the patch.
On Thu, Feb 28, 2019 at 09:01:50PM +0100, Jacopo Mondi wrote:
> Add test to list formats on a v4l2 subdevice.
>
> Reviewed-by: Laurent Pinchart <laurent.pinchart at ideasonboard.com>
> Signed-off-by: Jacopo Mondi <jacopo at jmondi.org>
> ---
> test/v4l2_subdevice/list_formats.cpp | 85 ++++++++++++++++++++++++++++
> test/v4l2_subdevice/meson.build | 1 +
> 2 files changed, 86 insertions(+)
> create mode 100644 test/v4l2_subdevice/list_formats.cpp
>
> diff --git a/test/v4l2_subdevice/list_formats.cpp b/test/v4l2_subdevice/list_formats.cpp
> new file mode 100644
> index 000000000000..b902a198b17e
> --- /dev/null
> +++ b/test/v4l2_subdevice/list_formats.cpp
> @@ -0,0 +1,85 @@
> +/* SPDX-License-Identifier: GPL-2.0-or-later */
> +/*
> + * Copyright (C) 2019, Google Inc.
> + *
> + * libcamera V4L2 Subdevice format handling test
> + */
> +
> +#include <iostream>
> +#include <vector>
> +
> +#include "geometry.h"
> +#include "v4l2_subdevice.h"
> +#include "v4l2_subdevice_test.h"
> +
> +using namespace std;
> +using namespace libcamera;
> +
> +/* List image formats on the "Scaler" subdevice of vimc media device. */
> +
> +class ListFormatsTest : public V4L2SubdeviceTest
> +{
> +protected:
> + int run() override;
> +
> +private:
> + void printFormats(unsigned int pad, unsigned code,
> + std::vector<SizeRange> &formats);
> +};
> +
> +void ListFormatsTest::printFormats(unsigned int pad,
> + unsigned int code,
> + std::vector<SizeRange> &sizes)
> +{
> + cout << "Enumerate formats on pad " << pad << endl;
> + for (SizeRange &size : sizes) {
> + cout << " Mbus code: 0x" << hex << code << endl;
I'd write "media bus code" in full, or if you want to abbreviate, "mbus
code".
Should you ensure that at least 4 characters get printed ?
> + cout << " min Width: " << dec << size.minWidth << endl;
> + cout << " min Height: " << dec << size.minHeight << endl;
> + cout << " max Width: " << dec << size.maxWidth << endl;
> + cout << " max Height: " << dec << size.maxHeight << endl;
s/Width/width/ and s/Height/height/ ?
> + }
> +}
> +
> +int ListFormatsTest::run()
> +{
> + /* List all formats available on existing "Scaler" pads. */
> + std::map<unsigned int, std::vector<SizeRange>> formats;
> +
> + formats = scaler_->formats(0);
> + if (formats.size() == 0) {
> + cerr << "Failed to list formats on pad 0 of subdevice "
> + << scaler_->deviceName() << endl;
> + return TestFail;
> + }
> + auto it = formats.begin();
> + while (it != formats.end()) {
> + printFormats(0, it->first, it->second);
> + ++it;
> + }
How about
for (auto it = formats.begin(); it != formats.end(); ++it)
printFormats(0, it->first, it->second);
> +
> + formats = scaler_->formats(1);
> + if (formats.size() == 0) {
> + cerr << "Failed to list formats on pad 1 of subdevice "
> + << scaler_->deviceName() << endl;
> + return TestFail;
> + }
> + it = formats.begin();
> + while (it != formats.end()) {
> + printFormats(1, it->first, it->second);
> + ++it;
> + }
Same here.
> +
> + /* List format on a non-existing pad, format vector shall be empty. */
> + formats = scaler_->formats(2);
> + if (formats.size() != 0) {
Maybe
if (!formats.empty()) {
> + cerr << "Listing formats on non-existing pad 2 of subdevice "
> + << scaler_->deviceName()
> + << " should return an empty format list" << endl;
> + return TestFail;
> + }
> +
> + return TestPass;
> +}
> +
> +TEST_REGISTER(ListFormatsTest);
> diff --git a/test/v4l2_subdevice/meson.build b/test/v4l2_subdevice/meson.build
> index f45dca0d23d7..80cfbbbf9413 100644
> --- a/test/v4l2_subdevice/meson.build
> +++ b/test/v4l2_subdevice/meson.build
> @@ -1,4 +1,5 @@
> v4l2_subdevice_tests = [
> + [ 'list_formats', 'list_formats.cpp'],
> [ 'test_formats', 'test_formats.cpp'],
> ]
>
--
Regards,
Laurent Pinchart
More information about the libcamera-devel
mailing list