libcamera/test/libtest/camera_test.cpp
Umang Jain cfa43199d3 libtest: camera_test: Plumb constructor to set LIBCAMERA_IPA_FORCE_ISOLATION
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>
2021-08-19 12:54:03 +05:30

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_;
}