Several of our structures include width and height fields that model a size while we have a Size class for that purpose. Use the Size class through libcamera, and give it a toString() method like other geometry and format classes. Signed-off-by: Laurent Pinchart <laurent.pinchart@ideasonboard.com> Reviewed-by: Niklas Söderlund <niklas.soderlund@ragnatech.se>
89 lines
1.9 KiB
C++
89 lines
1.9 KiB
C++
/* 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()
|
|
{
|
|
CameraConfiguration conf =
|
|
camera_->streamConfiguration({ Stream::VideoRecording() });
|
|
StreamConfiguration *sconf = &conf[conf.front()];
|
|
|
|
if (!conf.isValid()) {
|
|
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->size.width *= 2;
|
|
sconf->size.height *= 2;
|
|
if (camera_->configureStreams(conf)) {
|
|
cout << "Failed to set modified configuration" << endl;
|
|
return TestFail;
|
|
}
|
|
|
|
/*
|
|
* Test that setting an invalid configuration fails.
|
|
*/
|
|
sconf->size = { 0, 0 };
|
|
if (!camera_->configureStreams(conf)) {
|
|
cout << "Invalid configuration incorrectly accepted" << endl;
|
|
return TestFail;
|
|
}
|
|
|
|
return TestPass;
|
|
}
|
|
};
|
|
|
|
} /* namespace */
|
|
|
|
TEST_REGISTER(ConfigurationSet);
|