Some tests might require to have LIBCAMERA_IPA_FORCE_ISOLATION set to ensure they can test the IPA running in isolated mode. These tests are likely to leverage CameraTest. The environment variable should be set before CameraManager::start() call which happens in CameraTest's constructor. Hence, plumb the constructor with a flag so that the LIBCAMERA_IPA_FORCE_ISOLATION can be set before CameraManager::start(). Signed-off-by: Umang Jain <umang.jain@ideasonboard.com> Reviewed-by: Kieran Bingham <kieran.bingham@ideasonboard.com> Reviewed-by: Paul Elder <paul.elder@ideasonboard.com> Reviewed-by: Laurent Pinchart <laurent.pinchart@ideasonboard.com>
55 lines
941 B
C++
55 lines
941 B
C++
/* SPDX-License-Identifier: GPL-2.0-or-later */
|
|
/*
|
|
* Copyright (C) 2019, Google Inc.
|
|
*
|
|
* libcamera Camera API tests
|
|
*/
|
|
|
|
#include <iostream>
|
|
|
|
#include "camera_test.h"
|
|
#include "test.h"
|
|
|
|
using namespace libcamera;
|
|
using namespace std;
|
|
|
|
CameraTest::CameraTest(const char *name, bool isolate)
|
|
{
|
|
cm_ = new CameraManager();
|
|
|
|
if (isolate)
|
|
setenv("LIBCAMERA_IPA_FORCE_ISOLATION", "1", 1);
|
|
|
|
if (cm_->start()) {
|
|
cerr << "Failed to start camera manager" << endl;
|
|
status_ = TestFail;
|
|
return;
|
|
}
|
|
|
|
camera_ = cm_->get(name);
|
|
if (!camera_) {
|
|
cerr << "Can not find '" << name << "' camera" << endl;
|
|
status_ = TestSkip;
|
|
return;
|
|
}
|
|
|
|
/* Sanity check that the camera has streams. */
|
|
if (camera_->streams().empty()) {
|
|
cerr << "Camera has no stream" << endl;
|
|
status_ = TestFail;
|
|
return;
|
|
}
|
|
|
|
status_ = TestPass;
|
|
}
|
|
|
|
CameraTest::~CameraTest()
|
|
{
|
|
if (camera_) {
|
|
camera_->release();
|
|
camera_.reset();
|
|
}
|
|
|
|
cm_->stop();
|
|
delete cm_;
|
|
}
|