test: camera: Add setting of configuration test
Try to set the default configuration, a modified valid configuration and an invalid configuration. Signed-off-by: Niklas Söderlund <niklas.soderlund@ragnatech.se> Reviewed-by: Laurent Pinchart <laurent.pinchart@ideasonboard.com> Reviewed-by: Kieran Bingham <kieran.bingham@ideasonboard.com>
This commit is contained in:
parent
86a1900657
commit
e44b63b377
2 changed files with 92 additions and 0 deletions
91
test/camera/configuration_set.cpp
Normal file
91
test/camera/configuration_set.cpp
Normal file
|
@ -0,0 +1,91 @@
|
||||||
|
/* SPDX-License-Identifier: GPL-2.0-or-later */
|
||||||
|
/*
|
||||||
|
* Copyright (C) 2019, Google Inc.
|
||||||
|
*
|
||||||
|
* libcamera Camera API tests
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include <iostream>
|
||||||
|
|
||||||
|
#include "camera_test.h"
|
||||||
|
|
||||||
|
using namespace std;
|
||||||
|
|
||||||
|
namespace {
|
||||||
|
|
||||||
|
class ConfigurationSet : public CameraTest
|
||||||
|
{
|
||||||
|
protected:
|
||||||
|
int run()
|
||||||
|
{
|
||||||
|
std::set<Stream *> streams = { *camera_->streams().begin() };
|
||||||
|
std::map<Stream *, StreamConfiguration> conf =
|
||||||
|
camera_->streamConfiguration(streams);
|
||||||
|
StreamConfiguration *sconf = &conf.begin()->second;
|
||||||
|
|
||||||
|
if (!configurationValid(streams, conf)) {
|
||||||
|
cout << "Failed to read default configuration" << endl;
|
||||||
|
return TestFail;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (camera_->acquire()) {
|
||||||
|
cout << "Failed to acquire the camera" << endl;
|
||||||
|
return TestFail;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Test that setting the default configuration works. */
|
||||||
|
if (camera_->configureStreams(conf)) {
|
||||||
|
cout << "Failed to set default configuration" << endl;
|
||||||
|
return TestFail;
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Test that configuring the camera fails if it is not
|
||||||
|
* acquired, this will also test release and reacquiring
|
||||||
|
* of the camera.
|
||||||
|
*/
|
||||||
|
if (camera_->release()) {
|
||||||
|
cout << "Failed to release the camera" << endl;
|
||||||
|
return TestFail;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!camera_->configureStreams(conf)) {
|
||||||
|
cout << "Setting configuration on a camera not acquired succeeded when it should have failed"
|
||||||
|
<< endl;
|
||||||
|
return TestFail;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (camera_->acquire()) {
|
||||||
|
cout << "Failed to acquire the camera" << endl;
|
||||||
|
return TestFail;
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Test that modifying the default configuration works. Doubling
|
||||||
|
* the default configuration of the VIMC camera is known to
|
||||||
|
* work.
|
||||||
|
*/
|
||||||
|
sconf->width *= 2;
|
||||||
|
sconf->height *= 2;
|
||||||
|
if (camera_->configureStreams(conf)) {
|
||||||
|
cout << "Failed to set modified configuration" << endl;
|
||||||
|
return TestFail;
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Test that setting an invalid configuration fails.
|
||||||
|
*/
|
||||||
|
sconf->width = 0;
|
||||||
|
sconf->height = 0;
|
||||||
|
if (!camera_->configureStreams(conf)) {
|
||||||
|
cout << "Invalid configuration incorrectly accepted" << endl;
|
||||||
|
return TestFail;
|
||||||
|
}
|
||||||
|
|
||||||
|
return TestPass;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
} /* namespace */
|
||||||
|
|
||||||
|
TEST_REGISTER(ConfigurationSet);
|
|
@ -2,6 +2,7 @@
|
||||||
# They are not alphabetically sorted.
|
# They are not alphabetically sorted.
|
||||||
camera_tests = [
|
camera_tests = [
|
||||||
[ 'configuration_default', 'configuration_default.cpp' ],
|
[ 'configuration_default', 'configuration_default.cpp' ],
|
||||||
|
[ 'configuration_set', 'configuration_set.cpp' ],
|
||||||
]
|
]
|
||||||
|
|
||||||
foreach t : camera_tests
|
foreach t : camera_tests
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue