blob: e9f69795735233a01e87f294ca699e212c189b57 [file] [log] [blame]
Eino-Ville Talvala2f09bac2016-12-13 11:29:54 -08001/*
2 * Copyright (C) 2016 The Android Open Source Project
3 *
4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
7 *
8 * http://www.apache.org/licenses/LICENSE-2.0
9 *
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
15 */
16
17#define LOG_NDEBUG 0
18#define LOG_TAG "CameraProviderManagerTest"
19
20#include "../common/CameraProviderManager.h"
21#include <android/hidl/manager/1.0/IServiceManager.h>
22#include <android/hidl/manager/1.0/IServiceNotification.h>
Emilian Peev71c73a22017-03-21 16:35:51 +000023#include <android/hardware/camera/device/3.2/ICameraDeviceCallback.h>
24#include <android/hardware/camera/device/3.2/ICameraDeviceSession.h>
25#include <camera_metadata_hidden.h>
Emilian Peevc93cac22020-08-17 16:00:10 -070026#include <hidl/HidlBinderSupport.h>
Eino-Ville Talvala2f09bac2016-12-13 11:29:54 -080027#include <gtest/gtest.h>
Emilian Peevc93cac22020-08-17 16:00:10 -070028#include <utility>
Eino-Ville Talvala2f09bac2016-12-13 11:29:54 -080029
30using namespace android;
31using namespace android::hardware::camera;
32using android::hardware::camera::common::V1_0::Status;
Emilian Peev71c73a22017-03-21 16:35:51 +000033using android::hardware::camera::common::V1_0::VendorTag;
34using android::hardware::camera::common::V1_0::VendorTagSection;
35using android::hardware::camera::common::V1_0::CameraMetadataType;
36using android::hardware::camera::device::V3_2::ICameraDeviceCallback;
37using android::hardware::camera::device::V3_2::ICameraDeviceSession;
Eino-Ville Talvala63f36112018-12-06 14:57:03 -080038using android::hardware::camera::provider::V2_5::DeviceState;
Emilian Peev71c73a22017-03-21 16:35:51 +000039
40/**
41 * Basic test implementation of a camera ver. 3.2 device interface
42 */
43struct TestDeviceInterface : public device::V3_2::ICameraDevice {
44 std::vector<hardware::hidl_string> mDeviceNames;
Emilian Peev2a245e12020-04-07 16:54:14 -070045 android::hardware::hidl_vec<uint8_t> mCharacteristics;
46
47 TestDeviceInterface(std::vector<hardware::hidl_string> deviceNames,
48 android::hardware::hidl_vec<uint8_t> chars) :
49 mDeviceNames(deviceNames), mCharacteristics(chars) {}
50
Emilian Peev71c73a22017-03-21 16:35:51 +000051 TestDeviceInterface(std::vector<hardware::hidl_string> deviceNames) :
52 mDeviceNames(deviceNames) {}
Emilian Peev2a245e12020-04-07 16:54:14 -070053
Emilian Peev71c73a22017-03-21 16:35:51 +000054 using getResourceCost_cb = std::function<void(
55 hardware::camera::common::V1_0::Status status,
56 const hardware::camera::common::V1_0::CameraResourceCost& resourceCost)>;
57 virtual ::android::hardware::Return<void> getResourceCost(
58 getResourceCost_cb _hidl_cb) override {
59 hardware::camera::common::V1_0::CameraResourceCost resourceCost = {100,
60 mDeviceNames};
61 _hidl_cb(Status::OK, resourceCost);
62 return hardware::Void();
63 }
64
65 using getCameraCharacteristics_cb = std::function<void(
66 hardware::camera::common::V1_0::Status status,
67 const hardware::hidl_vec<uint8_t>& cameraCharacteristics)>;
68 hardware::Return<void> getCameraCharacteristics(
69 getCameraCharacteristics_cb _hidl_cb) override {
Emilian Peev2a245e12020-04-07 16:54:14 -070070 _hidl_cb(Status::OK, mCharacteristics);
Emilian Peev71c73a22017-03-21 16:35:51 +000071 return hardware::Void();
72 }
73
74 hardware::Return<hardware::camera::common::V1_0::Status> setTorchMode(
75 ::android::hardware::camera::common::V1_0::TorchMode) override {
76 return Status::OK;
77 }
78
79 using open_cb = std::function<void(
80 ::android::hardware::camera::common::V1_0::Status status,
81 const ::android::sp<ICameraDeviceSession>& session)>;
82 hardware::Return<void> open(
83 const ::android::sp<ICameraDeviceCallback>&,
84 open_cb _hidl_cb) override {
85 sp<ICameraDeviceSession> deviceSession = nullptr;
86 _hidl_cb(Status::OK, deviceSession);
87 return hardware::Void();
88 }
89
90 hardware::Return<void> dumpState(
91 const ::android::hardware::hidl_handle&) override {
92 return hardware::Void();
93 }
94};
Eino-Ville Talvala2f09bac2016-12-13 11:29:54 -080095
96/**
97 * Basic test implementation of a camera provider
98 */
Eino-Ville Talvala63f36112018-12-06 14:57:03 -080099struct TestICameraProvider : virtual public provider::V2_5::ICameraProvider {
Emilian Peev71c73a22017-03-21 16:35:51 +0000100 sp<provider::V2_4::ICameraProviderCallback> mCallbacks;
Eino-Ville Talvala2f09bac2016-12-13 11:29:54 -0800101 std::vector<hardware::hidl_string> mDeviceNames;
Emilian Peev71c73a22017-03-21 16:35:51 +0000102 sp<device::V3_2::ICameraDevice> mDeviceInterface;
103 hardware::hidl_vec<common::V1_0::VendorTagSection> mVendorTagSections;
Eino-Ville Talvala2f09bac2016-12-13 11:29:54 -0800104
Emilian Peev71c73a22017-03-21 16:35:51 +0000105 TestICameraProvider(const std::vector<hardware::hidl_string> &devices,
106 const hardware::hidl_vec<common::V1_0::VendorTagSection> &vendorSection) :
107 mDeviceNames(devices),
108 mDeviceInterface(new TestDeviceInterface(devices)),
109 mVendorTagSections (vendorSection) {}
Eino-Ville Talvala2f09bac2016-12-13 11:29:54 -0800110
Emilian Peev2a245e12020-04-07 16:54:14 -0700111 TestICameraProvider(const std::vector<hardware::hidl_string> &devices,
112 const hardware::hidl_vec<common::V1_0::VendorTagSection> &vendorSection,
113 android::hardware::hidl_vec<uint8_t> chars) :
114 mDeviceNames(devices),
115 mDeviceInterface(new TestDeviceInterface(devices, chars)),
116 mVendorTagSections (vendorSection) {}
117
Emilian Peev71c73a22017-03-21 16:35:51 +0000118 virtual hardware::Return<Status> setCallback(
119 const sp<provider::V2_4::ICameraProviderCallback>& callbacks) override {
Eino-Ville Talvala63f36112018-12-06 14:57:03 -0800120 mCalledCounter[SET_CALLBACK]++;
Eino-Ville Talvala2f09bac2016-12-13 11:29:54 -0800121 mCallbacks = callbacks;
122 return hardware::Return<Status>(Status::OK);
123 }
124
125 using getVendorTags_cb = std::function<void(Status status,
126 const hardware::hidl_vec<common::V1_0::VendorTagSection>& sections)>;
Emilian Peev71c73a22017-03-21 16:35:51 +0000127 hardware::Return<void> getVendorTags(getVendorTags_cb _hidl_cb) override {
Eino-Ville Talvala63f36112018-12-06 14:57:03 -0800128 mCalledCounter[GET_VENDOR_TAGS]++;
Emilian Peev71c73a22017-03-21 16:35:51 +0000129 _hidl_cb(Status::OK, mVendorTagSections);
130 return hardware::Void();
131 }
132
133 using isSetTorchModeSupported_cb = std::function<void(
134 ::android::hardware::camera::common::V1_0::Status status,
135 bool support)>;
136 virtual ::hardware::Return<void> isSetTorchModeSupported(
137 isSetTorchModeSupported_cb _hidl_cb) override {
Eino-Ville Talvala63f36112018-12-06 14:57:03 -0800138 mCalledCounter[IS_SET_TORCH_MODE_SUPPORTED]++;
Emilian Peev71c73a22017-03-21 16:35:51 +0000139 _hidl_cb(Status::OK, false);
Eino-Ville Talvala2f09bac2016-12-13 11:29:54 -0800140 return hardware::Void();
141 }
142
143 using getCameraIdList_cb = std::function<void(Status status,
144 const hardware::hidl_vec<hardware::hidl_string>& cameraDeviceNames)>;
145 virtual hardware::Return<void> getCameraIdList(getCameraIdList_cb _hidl_cb) override {
Eino-Ville Talvala63f36112018-12-06 14:57:03 -0800146 mCalledCounter[GET_CAMERA_ID_LIST]++;
Eino-Ville Talvala2f09bac2016-12-13 11:29:54 -0800147 _hidl_cb(Status::OK, mDeviceNames);
148 return hardware::Void();
149 }
150
151 using getCameraDeviceInterface_V1_x_cb = std::function<void(Status status,
152 const sp<device::V1_0::ICameraDevice>& device)>;
153 virtual hardware::Return<void> getCameraDeviceInterface_V1_x(
154 const hardware::hidl_string& cameraDeviceName,
155 getCameraDeviceInterface_V1_x_cb _hidl_cb) override {
156 (void) cameraDeviceName;
Emilian Peev71c73a22017-03-21 16:35:51 +0000157 _hidl_cb(Status::OK, nullptr); //TODO: impl. of ver. 1.0 device interface
158 // otherwise enumeration will fail.
Eino-Ville Talvala2f09bac2016-12-13 11:29:54 -0800159 return hardware::Void();
160 }
161
162 using getCameraDeviceInterface_V3_x_cb = std::function<void(Status status,
163 const sp<device::V3_2::ICameraDevice>& device)>;
164 virtual hardware::Return<void> getCameraDeviceInterface_V3_x(
Emilian Peev71c73a22017-03-21 16:35:51 +0000165 const hardware::hidl_string&,
Eino-Ville Talvala2f09bac2016-12-13 11:29:54 -0800166 getCameraDeviceInterface_V3_x_cb _hidl_cb) override {
Emilian Peev71c73a22017-03-21 16:35:51 +0000167 _hidl_cb(Status::OK, mDeviceInterface);
Eino-Ville Talvala2f09bac2016-12-13 11:29:54 -0800168 return hardware::Void();
169 }
170
Eino-Ville Talvala63f36112018-12-06 14:57:03 -0800171 virtual hardware::Return<void> notifyDeviceStateChange(
172 hardware::hidl_bitfield<DeviceState> newState) override {
173 mCalledCounter[NOTIFY_DEVICE_STATE]++;
174 mCurrentState = newState;
175 return hardware::Void();
176 }
177
Emilian Peevc93cac22020-08-17 16:00:10 -0700178 virtual ::android::hardware::Return<bool> linkToDeath(
179 const ::android::sp<::android::hardware::hidl_death_recipient>& recipient,
180 uint64_t cookie) {
181 if (mInitialDeathRecipient.get() == nullptr) {
182 mInitialDeathRecipient =
183 std::make_unique<::android::hardware::hidl_binder_death_recipient>(recipient,
184 cookie, this);
185 }
186 return true;
187 }
188
189 void signalInitialBinderDeathRecipient() {
190 if (mInitialDeathRecipient.get() != nullptr) {
191 mInitialDeathRecipient->binderDied(nullptr /*who*/);
192 }
193 }
194
195 std::unique_ptr<::android::hardware::hidl_binder_death_recipient> mInitialDeathRecipient;
196
Eino-Ville Talvala63f36112018-12-06 14:57:03 -0800197 enum MethodNames {
198 SET_CALLBACK,
199 GET_VENDOR_TAGS,
200 IS_SET_TORCH_MODE_SUPPORTED,
201 NOTIFY_DEVICE_STATE,
202 GET_CAMERA_ID_LIST,
203
204 METHOD_NAME_COUNT
205 };
206 int mCalledCounter[METHOD_NAME_COUNT] {0};
207
208 hardware::hidl_bitfield<DeviceState> mCurrentState = 0xFFFFFFFF; // Unlikely to be a real state
Eino-Ville Talvala2f09bac2016-12-13 11:29:54 -0800209};
210
211/**
212 * Simple test version of the interaction proxy, to use to inject onRegistered calls to the
213 * CameraProviderManager
214 */
Jayant Chowdhary0bd38522021-11-05 17:49:27 -0700215struct TestInteractionProxy : public CameraProviderManager::HidlServiceInteractionProxy {
Eino-Ville Talvala2f09bac2016-12-13 11:29:54 -0800216 sp<hidl::manager::V1_0::IServiceNotification> mManagerNotificationInterface;
Emilian Peev71c73a22017-03-21 16:35:51 +0000217 sp<TestICameraProvider> mTestCameraProvider;
Eino-Ville Talvala2f09bac2016-12-13 11:29:54 -0800218
Emilian Peev71c73a22017-03-21 16:35:51 +0000219 TestInteractionProxy() {}
Eino-Ville Talvala998d1fe2019-10-23 10:34:53 -0700220
Emilian Peev71c73a22017-03-21 16:35:51 +0000221 void setProvider(sp<TestICameraProvider> provider) {
222 mTestCameraProvider = provider;
Eino-Ville Talvala2f09bac2016-12-13 11:29:54 -0800223 }
Emilian Peev71c73a22017-03-21 16:35:51 +0000224
Eino-Ville Talvalabb6e4142018-08-21 14:17:40 -0700225 std::vector<std::string> mLastRequestedServiceNames;
Eino-Ville Talvala2f09bac2016-12-13 11:29:54 -0800226
227 virtual ~TestInteractionProxy() {}
228
229 virtual bool registerForNotifications(
230 const std::string &serviceName,
231 const sp<hidl::manager::V1_0::IServiceNotification> &notification) override {
232 (void) serviceName;
233 mManagerNotificationInterface = notification;
234 return true;
235 }
236
Eino-Ville Talvalaec960602019-10-15 11:46:16 -0700237 virtual sp<hardware::camera::provider::V2_4::ICameraProvider> tryGetService(
238 const std::string &serviceName) override {
Eino-Ville Talvala998d1fe2019-10-23 10:34:53 -0700239 // If no provider has been given, act like the HAL isn't available and return null.
240 if (mTestCameraProvider == nullptr) return nullptr;
Eino-Ville Talvalaec960602019-10-15 11:46:16 -0700241 return getService(serviceName);
242 }
243
Eino-Ville Talvala2f09bac2016-12-13 11:29:54 -0800244 virtual sp<hardware::camera::provider::V2_4::ICameraProvider> getService(
245 const std::string &serviceName) override {
Eino-Ville Talvala998d1fe2019-10-23 10:34:53 -0700246 // If no provider has been given, fail; in reality, getService would
247 // block for HALs that don't start correctly, so we should never use
248 // getService when we don't have a valid HAL running
249 if (mTestCameraProvider == nullptr) {
250 ADD_FAILURE() << "getService called with no valid provider; would block indefinitely";
251 // Real getService would block, but that's bad in unit tests. So
252 // just record an error and return nullptr
253 return nullptr;
254 }
Eino-Ville Talvalabb6e4142018-08-21 14:17:40 -0700255 mLastRequestedServiceNames.push_back(serviceName);
Eino-Ville Talvala2f09bac2016-12-13 11:29:54 -0800256 return mTestCameraProvider;
257 }
258
Yin-Chia Yeh177b0c12019-06-25 10:53:03 -0700259 virtual hardware::hidl_vec<hardware::hidl_string> listServices() override {
Eino-Ville Talvala998d1fe2019-10-23 10:34:53 -0700260 // Always provide a list even if there's no actual provider yet, to
261 // simulate stuck HAL situations as well
Yin-Chia Yeh177b0c12019-06-25 10:53:03 -0700262 hardware::hidl_vec<hardware::hidl_string> ret = {"test/0"};
263 return ret;
264 }
265
Eino-Ville Talvala2f09bac2016-12-13 11:29:54 -0800266};
267
Emilian Peev71c73a22017-03-21 16:35:51 +0000268struct TestStatusListener : public CameraProviderManager::StatusListener {
269 ~TestStatusListener() {}
Eino-Ville Talvala2f09bac2016-12-13 11:29:54 -0800270
Emilian Peev71c73a22017-03-21 16:35:51 +0000271 void onDeviceStatusChanged(const String8 &,
Jayant Chowdhary0bd38522021-11-05 17:49:27 -0700272 CameraDeviceStatus) override {}
Shuzhen Wang43858162020-01-10 13:42:15 -0800273 void onDeviceStatusChanged(const String8 &, const String8 &,
Jayant Chowdhary0bd38522021-11-05 17:49:27 -0700274 CameraDeviceStatus) override {}
Emilian Peev71c73a22017-03-21 16:35:51 +0000275 void onTorchStatusChanged(const String8 &,
Jayant Chowdhary0bd38522021-11-05 17:49:27 -0700276 TorchModeStatus) override {}
Jayant Chowdhary46ef0f52021-10-05 14:36:13 -0700277 void onTorchStatusChanged(const String8 &,
Jayant Chowdhary0bd38522021-11-05 17:49:27 -0700278 TorchModeStatus, SystemCameraKind) override {}
Eino-Ville Talvala7cffc832018-06-03 17:32:53 -0700279 void onNewProviderRegistered() override {}
Emilian Peev71c73a22017-03-21 16:35:51 +0000280};
281
Emilian Peev2a245e12020-04-07 16:54:14 -0700282TEST(CameraProviderManagerTest, InitializeDynamicDepthTest) {
283 std::vector<hardware::hidl_string> deviceNames;
284 deviceNames.push_back("device@3.2/test/0");
285 hardware::hidl_vec<common::V1_0::VendorTagSection> vendorSection;
286 status_t res;
287 sp<CameraProviderManager> providerManager = new CameraProviderManager();
288 sp<TestStatusListener> statusListener = new TestStatusListener();
289 TestInteractionProxy serviceProxy;
290
291 android::hardware::hidl_vec<uint8_t> chars;
292 CameraMetadata meta;
293 int32_t charKeys[] = { ANDROID_DEPTH_DEPTH_IS_EXCLUSIVE,
294 ANDROID_DEPTH_AVAILABLE_DEPTH_STREAM_CONFIGURATIONS };
295 meta.update(ANDROID_REQUEST_AVAILABLE_CHARACTERISTICS_KEYS, charKeys,
296 sizeof(charKeys) / sizeof(charKeys[0]));
297 uint8_t depthIsExclusive = ANDROID_DEPTH_DEPTH_IS_EXCLUSIVE_FALSE;
298 meta.update(ANDROID_DEPTH_DEPTH_IS_EXCLUSIVE, &depthIsExclusive, 1);
299 int32_t sizes[] = { HAL_PIXEL_FORMAT_BLOB,
300 640, 480, ANDROID_SCALER_AVAILABLE_STREAM_CONFIGURATIONS_OUTPUT };
301 meta.update(ANDROID_SCALER_AVAILABLE_STREAM_CONFIGURATIONS, sizes,
302 sizeof(sizes) / sizeof(sizes[0]));
303 sizes[0] = HAL_PIXEL_FORMAT_Y16;
304 meta.update(ANDROID_DEPTH_AVAILABLE_DEPTH_STREAM_CONFIGURATIONS, sizes,
305 sizeof(sizes) / sizeof(sizes[0]));
306 int64_t durations[] = { HAL_PIXEL_FORMAT_BLOB, 640, 480, 0 };
307 meta.update(ANDROID_SCALER_AVAILABLE_MIN_FRAME_DURATIONS, durations,
308 sizeof(durations) / sizeof(durations[0]));
309 meta.update(ANDROID_SCALER_AVAILABLE_STALL_DURATIONS, durations,
310 sizeof(durations) / sizeof(durations[0]));
311 durations[0]= HAL_PIXEL_FORMAT_Y16;
312 meta.update(ANDROID_DEPTH_AVAILABLE_DEPTH_MIN_FRAME_DURATIONS, durations,
313 sizeof(durations) / sizeof(durations[0]));
314 meta.update(ANDROID_DEPTH_AVAILABLE_DEPTH_STALL_DURATIONS, durations,
315 sizeof(durations) / sizeof(durations[0]));
316 camera_metadata_t* metaBuffer = const_cast<camera_metadata_t*>(meta.getAndLock());
317 chars.setToExternal(reinterpret_cast<uint8_t*>(metaBuffer),
318 get_camera_metadata_size(metaBuffer));
319
320 sp<TestICameraProvider> provider = new TestICameraProvider(deviceNames,
321 vendorSection, chars);
322 serviceProxy.setProvider(provider);
323
324 res = providerManager->initialize(statusListener, &serviceProxy);
325 ASSERT_EQ(res, OK) << "Unable to initialize provider manager";
326}
327
Emilian Peev71c73a22017-03-21 16:35:51 +0000328TEST(CameraProviderManagerTest, InitializeTest) {
329 std::vector<hardware::hidl_string> deviceNames;
330 deviceNames.push_back("device@3.2/test/0");
331 deviceNames.push_back("device@1.0/test/0");
332 deviceNames.push_back("device@3.2/test/1");
333 hardware::hidl_vec<common::V1_0::VendorTagSection> vendorSection;
Eino-Ville Talvala2f09bac2016-12-13 11:29:54 -0800334 status_t res;
335 sp<CameraProviderManager> providerManager = new CameraProviderManager();
Emilian Peev71c73a22017-03-21 16:35:51 +0000336 sp<TestStatusListener> statusListener = new TestStatusListener();
337 TestInteractionProxy serviceProxy;
338 sp<TestICameraProvider> provider = new TestICameraProvider(deviceNames,
339 vendorSection);
340 serviceProxy.setProvider(provider);
Eino-Ville Talvala2f09bac2016-12-13 11:29:54 -0800341
Yin-Chia Yeh177b0c12019-06-25 10:53:03 -0700342 int numProviders = static_cast<int>(serviceProxy.listServices().size());
343
Emilian Peev71c73a22017-03-21 16:35:51 +0000344 res = providerManager->initialize(statusListener, &serviceProxy);
Eino-Ville Talvala2f09bac2016-12-13 11:29:54 -0800345 ASSERT_EQ(res, OK) << "Unable to initialize provider manager";
Eino-Ville Talvala63f36112018-12-06 14:57:03 -0800346 // Check that both "legacy" and "external" providers (really the same object) are called
347 // once for all the init methods
Yin-Chia Yeh177b0c12019-06-25 10:53:03 -0700348 EXPECT_EQ(provider->mCalledCounter[TestICameraProvider::SET_CALLBACK], numProviders) <<
Eino-Ville Talvala63f36112018-12-06 14:57:03 -0800349 "Only one call to setCallback per provider expected during init";
Yin-Chia Yeh177b0c12019-06-25 10:53:03 -0700350 EXPECT_EQ(provider->mCalledCounter[TestICameraProvider::GET_VENDOR_TAGS], numProviders) <<
Eino-Ville Talvala63f36112018-12-06 14:57:03 -0800351 "Only one call to getVendorTags per provider expected during init";
Yin-Chia Yeh177b0c12019-06-25 10:53:03 -0700352 EXPECT_EQ(provider->mCalledCounter[TestICameraProvider::IS_SET_TORCH_MODE_SUPPORTED],
353 numProviders) <<
Eino-Ville Talvala63f36112018-12-06 14:57:03 -0800354 "Only one call to isSetTorchModeSupported per provider expected during init";
Yin-Chia Yeh177b0c12019-06-25 10:53:03 -0700355 EXPECT_EQ(provider->mCalledCounter[TestICameraProvider::GET_CAMERA_ID_LIST], numProviders) <<
Eino-Ville Talvala63f36112018-12-06 14:57:03 -0800356 "Only one call to getCameraIdList per provider expected during init";
Yin-Chia Yeh177b0c12019-06-25 10:53:03 -0700357 EXPECT_EQ(provider->mCalledCounter[TestICameraProvider::NOTIFY_DEVICE_STATE], numProviders) <<
Eino-Ville Talvala63f36112018-12-06 14:57:03 -0800358 "Only one call to notifyDeviceState per provider expected during init";
Eino-Ville Talvala2f09bac2016-12-13 11:29:54 -0800359
Eino-Ville Talvala2f09bac2016-12-13 11:29:54 -0800360 hardware::hidl_string testProviderFqInterfaceName =
361 "android.hardware.camera.provider@2.4::ICameraProvider";
362 hardware::hidl_string testProviderInstanceName = "test/0";
363 serviceProxy.mManagerNotificationInterface->onRegistration(
364 testProviderFqInterfaceName,
365 testProviderInstanceName, false);
366
Eino-Ville Talvalabb6e4142018-08-21 14:17:40 -0700367 ASSERT_EQ(serviceProxy.mLastRequestedServiceNames.back(), testProviderInstanceName) <<
Eino-Ville Talvala2f09bac2016-12-13 11:29:54 -0800368 "Incorrect instance requested from service manager";
369}
Emilian Peev71c73a22017-03-21 16:35:51 +0000370
371TEST(CameraProviderManagerTest, MultipleVendorTagTest) {
372 hardware::hidl_string sectionName = "VendorTestSection";
373 hardware::hidl_string tagName = "VendorTestTag";
374 uint32_t tagId = VENDOR_SECTION << 16;
375 hardware::hidl_vec<common::V1_0::VendorTagSection> vendorSection;
376 CameraMetadataType tagType = CameraMetadataType::BYTE;
377 vendorSection.resize(1);
378 vendorSection[0].sectionName = sectionName;
379 vendorSection[0].tags.resize(1);
380 vendorSection[0].tags[0].tagId = tagId;
381 vendorSection[0].tags[0].tagName = tagName;
382 vendorSection[0].tags[0].tagType = tagType;
383 std::vector<hardware::hidl_string> deviceNames = {"device@3.2/test/0"};
384
385 sp<CameraProviderManager> providerManager = new CameraProviderManager();
386 sp<TestStatusListener> statusListener = new TestStatusListener();
387 TestInteractionProxy serviceProxy;
388
389 sp<TestICameraProvider> provider = new TestICameraProvider(deviceNames,
390 vendorSection);
391 serviceProxy.setProvider(provider);
392
393 auto res = providerManager->initialize(statusListener, &serviceProxy);
394 ASSERT_EQ(res, OK) << "Unable to initialize provider manager";
395
396 hardware::hidl_string testProviderInstanceName = "test/0";
397 hardware::hidl_string testProviderFqInterfaceName =
398 "android.hardware.camera.provider@2.4::ICameraProvider";
399 serviceProxy.mManagerNotificationInterface->onRegistration(
400 testProviderFqInterfaceName, testProviderInstanceName, false);
Eino-Ville Talvalabb6e4142018-08-21 14:17:40 -0700401 ASSERT_EQ(serviceProxy.mLastRequestedServiceNames.back(), testProviderInstanceName) <<
Emilian Peev71c73a22017-03-21 16:35:51 +0000402 "Incorrect instance requested from service manager";
403
404 hardware::hidl_string sectionNameSecond = "SecondVendorTestSection";
405 hardware::hidl_string secondTagName = "SecondVendorTestTag";
406 CameraMetadataType secondTagType = CameraMetadataType::DOUBLE;
407 vendorSection[0].sectionName = sectionNameSecond;
408 vendorSection[0].tags[0].tagId = tagId;
409 vendorSection[0].tags[0].tagName = secondTagName;
410 vendorSection[0].tags[0].tagType = secondTagType;
411 deviceNames = {"device@3.2/test2/1"};
412
413 sp<TestICameraProvider> secondProvider = new TestICameraProvider(
414 deviceNames, vendorSection);
415 serviceProxy.setProvider(secondProvider);
416 hardware::hidl_string testProviderSecondInstanceName = "test2/0";
417 serviceProxy.mManagerNotificationInterface->onRegistration(
418 testProviderFqInterfaceName, testProviderSecondInstanceName, false);
Eino-Ville Talvalabb6e4142018-08-21 14:17:40 -0700419 ASSERT_EQ(serviceProxy.mLastRequestedServiceNames.back(),
Emilian Peev71c73a22017-03-21 16:35:51 +0000420 testProviderSecondInstanceName) <<
421 "Incorrect instance requested from service manager";
422
423 ASSERT_EQ(NO_ERROR , providerManager->setUpVendorTags());
424 sp<VendorTagDescriptorCache> vendorCache =
425 VendorTagDescriptorCache::getGlobalVendorTagCache();
426 ASSERT_NE(nullptr, vendorCache.get());
427
428 metadata_vendor_id_t vendorId = std::hash<std::string> {} (
429 testProviderInstanceName.c_str());
430 metadata_vendor_id_t vendorIdSecond = std::hash<std::string> {} (
431 testProviderSecondInstanceName.c_str());
432
433 hardware::hidl_string resultTag = vendorCache->getTagName(tagId, vendorId);
434 ASSERT_EQ(resultTag, tagName);
435
436 resultTag = vendorCache->getTagName(tagId, vendorIdSecond);
437 ASSERT_EQ(resultTag, secondTagName);
438
439 // Check whether we can create two separate CameraMetadata instances
440 // using different tag vendor vendors.
441 camera_metadata *metaBuffer = allocate_camera_metadata(10, 20);
442 ASSERT_NE(nullptr, metaBuffer);
443 set_camera_metadata_vendor_id(metaBuffer, vendorId);
444 CameraMetadata metadata(metaBuffer);
445
446 uint8_t byteVal = 10;
447 ASSERT_TRUE(metadata.isEmpty());
448 ASSERT_EQ(OK, metadata.update(tagId, &byteVal, 1));
449 ASSERT_FALSE(metadata.isEmpty());
450 ASSERT_TRUE(metadata.exists(tagId));
451
452 metaBuffer = allocate_camera_metadata(10, 20);
453 ASSERT_NE(nullptr, metaBuffer);
454 set_camera_metadata_vendor_id(metaBuffer, vendorIdSecond);
455 CameraMetadata secondMetadata(metaBuffer);
456
457 ASSERT_TRUE(secondMetadata.isEmpty());
458 double doubleVal = 1.0f;
459 ASSERT_EQ(OK, secondMetadata.update(tagId, &doubleVal, 1));
460 ASSERT_FALSE(secondMetadata.isEmpty());
461 ASSERT_TRUE(secondMetadata.exists(tagId));
462
463 // Check whether CameraMetadata copying works as expected
464 CameraMetadata metadataCopy(metadata);
465 ASSERT_FALSE(metadataCopy.isEmpty());
466 ASSERT_TRUE(metadataCopy.exists(tagId));
467 ASSERT_EQ(OK, metadataCopy.update(tagId, &byteVal, 1));
468 ASSERT_TRUE(metadataCopy.exists(tagId));
469
470 // Check whether values are as expected
471 camera_metadata_entry_t entry = metadata.find(tagId);
472 ASSERT_EQ(1u, entry.count);
473 ASSERT_EQ(byteVal, entry.data.u8[0]);
474 entry = secondMetadata.find(tagId);
475 ASSERT_EQ(1u, entry.count);
476 ASSERT_EQ(doubleVal, entry.data.d[0]);
477
478 // Swap and erase
479 secondMetadata.swap(metadataCopy);
480 ASSERT_TRUE(metadataCopy.exists(tagId));
481 ASSERT_TRUE(secondMetadata.exists(tagId));
482 ASSERT_EQ(OK, secondMetadata.erase(tagId));
483 ASSERT_TRUE(secondMetadata.isEmpty());
484 doubleVal = 0.0f;
485 ASSERT_EQ(OK, metadataCopy.update(tagId, &doubleVal, 1));
486 entry = metadataCopy.find(tagId);
487 ASSERT_EQ(1u, entry.count);
488 ASSERT_EQ(doubleVal, entry.data.d[0]);
489
490 // Append
491 uint8_t sceneMode = ANDROID_CONTROL_SCENE_MODE_ACTION;
492 secondMetadata.update(ANDROID_CONTROL_SCENE_MODE, &sceneMode, 1);
493 // Append from two different vendor tag providers is not supported!
494 ASSERT_NE(OK, metadataCopy.append(secondMetadata));
495 ASSERT_EQ(OK, metadataCopy.erase(tagId));
496 metadataCopy.update(ANDROID_CONTROL_SCENE_MODE, &sceneMode, 1);
497 // However appending from same vendor tag provider should be fine
498 ASSERT_EQ(OK, metadata.append(secondMetadata));
Emilian Peev68dbd4e2017-04-11 11:44:29 +0100499 // Append from a metadata without vendor tag provider should be supported
Emilian Peev71c73a22017-03-21 16:35:51 +0000500 CameraMetadata regularMetadata(10, 20);
501 uint8_t controlMode = ANDROID_CONTROL_MODE_AUTO;
502 regularMetadata.update(ANDROID_CONTROL_MODE, &controlMode, 1);
Emilian Peev68dbd4e2017-04-11 11:44:29 +0100503 ASSERT_EQ(OK, secondMetadata.append(regularMetadata));
504 ASSERT_EQ(2u, secondMetadata.entryCount());
Emilian Peev71c73a22017-03-21 16:35:51 +0000505 ASSERT_EQ(2u, metadata.entryCount());
506
507 // Dump
508 metadata.dump(1, 2);
509 metadataCopy.dump(1, 2);
510 secondMetadata.dump(1, 2);
511}
Eino-Ville Talvala63f36112018-12-06 14:57:03 -0800512
513TEST(CameraProviderManagerTest, NotifyStateChangeTest) {
514 std::vector<hardware::hidl_string> deviceNames {
515 "device@3.2/test/0",
516 "device@1.0/test/0",
517 "device@3.2/test/1"};
518
519 hardware::hidl_vec<common::V1_0::VendorTagSection> vendorSection;
520 status_t res;
521 sp<CameraProviderManager> providerManager = new CameraProviderManager();
522 sp<TestStatusListener> statusListener = new TestStatusListener();
523 TestInteractionProxy serviceProxy;
524 sp<TestICameraProvider> provider = new TestICameraProvider(deviceNames,
525 vendorSection);
526 serviceProxy.setProvider(provider);
527
528 res = providerManager->initialize(statusListener, &serviceProxy);
529 ASSERT_EQ(res, OK) << "Unable to initialize provider manager";
530
531 ASSERT_EQ(provider->mCurrentState,
532 static_cast<hardware::hidl_bitfield<DeviceState>>(DeviceState::NORMAL))
533 << "Initial device state not set";
534
535 res = providerManager->notifyDeviceStateChange(
536 static_cast<hardware::hidl_bitfield<DeviceState>>(DeviceState::FOLDED));
537
538 ASSERT_EQ(res, OK) << "Unable to call notifyDeviceStateChange";
539 ASSERT_EQ(provider->mCurrentState,
540 static_cast<hardware::hidl_bitfield<DeviceState>>(DeviceState::FOLDED))
541 << "Unable to change device state";
542
543}
Eino-Ville Talvala998d1fe2019-10-23 10:34:53 -0700544
545// Test that CameraProviderManager doesn't get stuck when the camera HAL isn't really working
546TEST(CameraProviderManagerTest, BadHalStartupTest) {
547
548 std::vector<hardware::hidl_string> deviceNames;
549 deviceNames.push_back("device@3.2/test/0");
550 deviceNames.push_back("device@1.0/test/0");
551 deviceNames.push_back("device@3.2/test/1");
552 hardware::hidl_vec<common::V1_0::VendorTagSection> vendorSection;
553 status_t res;
554
555 sp<CameraProviderManager> providerManager = new CameraProviderManager();
556 sp<TestStatusListener> statusListener = new TestStatusListener();
557 TestInteractionProxy serviceProxy;
558 sp<TestICameraProvider> provider = new TestICameraProvider(deviceNames,
559 vendorSection);
560
561 // Not setting up provider in the service proxy yet, to test cases where a
562 // HAL isn't starting right
563 res = providerManager->initialize(statusListener, &serviceProxy);
564 ASSERT_EQ(res, OK) << "Unable to initialize provider manager";
565
566 // Now set up provider and trigger a registration
567 serviceProxy.setProvider(provider);
568 int numProviders = static_cast<int>(serviceProxy.listServices().size());
569
570 hardware::hidl_string testProviderFqInterfaceName =
571 "android.hardware.camera.provider@2.4::ICameraProvider";
572 hardware::hidl_string testProviderInstanceName = "test/0";
573 serviceProxy.mManagerNotificationInterface->onRegistration(
574 testProviderFqInterfaceName,
575 testProviderInstanceName, false);
576
577 // Check that new provider is called once for all the init methods
578 EXPECT_EQ(provider->mCalledCounter[TestICameraProvider::SET_CALLBACK], numProviders) <<
579 "Only one call to setCallback per provider expected during register";
580 EXPECT_EQ(provider->mCalledCounter[TestICameraProvider::GET_VENDOR_TAGS], numProviders) <<
581 "Only one call to getVendorTags per provider expected during register";
582 EXPECT_EQ(provider->mCalledCounter[TestICameraProvider::IS_SET_TORCH_MODE_SUPPORTED],
583 numProviders) <<
584 "Only one call to isSetTorchModeSupported per provider expected during init";
585 EXPECT_EQ(provider->mCalledCounter[TestICameraProvider::GET_CAMERA_ID_LIST], numProviders) <<
586 "Only one call to getCameraIdList per provider expected during init";
587 EXPECT_EQ(provider->mCalledCounter[TestICameraProvider::NOTIFY_DEVICE_STATE], numProviders) <<
588 "Only one call to notifyDeviceState per provider expected during init";
589
590 ASSERT_EQ(serviceProxy.mLastRequestedServiceNames.back(), testProviderInstanceName) <<
591 "Incorrect instance requested from service manager";
592}
Emilian Peevc93cac22020-08-17 16:00:10 -0700593
594// Test that CameraProviderManager can handle races between provider death notifications and
595// provider registration callbacks
596TEST(CameraProviderManagerTest, BinderDeathRegistrationRaceTest) {
597
598 std::vector<hardware::hidl_string> deviceNames;
599 deviceNames.push_back("device@3.2/test/0");
600 deviceNames.push_back("device@3.2/test/1");
601 hardware::hidl_vec<common::V1_0::VendorTagSection> vendorSection;
602 status_t res;
603
604 sp<CameraProviderManager> providerManager = new CameraProviderManager();
605 sp<TestStatusListener> statusListener = new TestStatusListener();
606 TestInteractionProxy serviceProxy;
607 sp<TestICameraProvider> provider = new TestICameraProvider(deviceNames,
608 vendorSection);
609
610 // Not setting up provider in the service proxy yet, to test cases where a
611 // HAL isn't starting right
612 res = providerManager->initialize(statusListener, &serviceProxy);
613 ASSERT_EQ(res, OK) << "Unable to initialize provider manager";
614
615 // Now set up provider and trigger a registration
616 serviceProxy.setProvider(provider);
617
618 hardware::hidl_string testProviderFqInterfaceName =
619 "android.hardware.camera.provider@2.4::ICameraProvider";
620 hardware::hidl_string testProviderInstanceName = "test/0";
621 serviceProxy.mManagerNotificationInterface->onRegistration(
622 testProviderFqInterfaceName,
623 testProviderInstanceName, false);
624
625 // Simulate artificial delay of the registration callback which arrives before the
626 // death notification
627 serviceProxy.mManagerNotificationInterface->onRegistration(
628 testProviderFqInterfaceName,
629 testProviderInstanceName, false);
630
631 provider->signalInitialBinderDeathRecipient();
632
633 auto deviceCount = static_cast<unsigned> (providerManager->getCameraCount().second);
634 ASSERT_EQ(deviceCount, deviceNames.size()) <<
635 "Unexpected amount of camera devices";
636}