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.
|
||||
camera_tests = [
|
||||
[ 'configuration_default', 'configuration_default.cpp' ],
|
||||
[ 'configuration_set', 'configuration_set.cpp' ],
|
||||
]
|
||||
|
||||
foreach t : camera_tests
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue