blob: e90c2c2426dadf122c4376cc3b061e62ef3f8cd2 (
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
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
|
/* 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() override;
};
int FormatHandlingTest::run()
{
V4L2SubdeviceFormat format = {};
/*
* Get format on a non-existing Scaler pad: expect failure.
*/
int ret = scaler_->getFormat(2, &format);
if (!ret) {
cerr << "Getting 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.size = { UINT_MAX, 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.size.width == UINT_MAX ||
format.size.height == UINT_MAX) {
cerr << "Failed to update image format" << endl;
return TestFail;
}
format.size = { 0, 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.size.width == 0 || format.size.height == 0) {
cerr << "Failed to update image format" << endl;
return TestFail;
}
return TestPass;
}
TEST_REGISTER(FormatHandlingTest);
|