blob: 0086c6c5de8c6edb400ab2cb9cac5f335acab197 [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>
Eino-Ville Talvala2f09bac2016-12-13 11:29:54 -080026#include <gtest/gtest.h>
27
28using namespace android;
29using namespace android::hardware::camera;
30using android::hardware::camera::common::V1_0::Status;
Emilian Peev71c73a22017-03-21 16:35:51 +000031using android::hardware::camera::common::V1_0::VendorTag;
32using android::hardware::camera::common::V1_0::VendorTagSection;
33using android::hardware::camera::common::V1_0::CameraMetadataType;
34using android::hardware::camera::device::V3_2::ICameraDeviceCallback;
35using android::hardware::camera::device::V3_2::ICameraDeviceSession;
36
37/**
38 * Basic test implementation of a camera ver. 3.2 device interface
39 */
40struct TestDeviceInterface : public device::V3_2::ICameraDevice {
41 std::vector<hardware::hidl_string> mDeviceNames;
42 TestDeviceInterface(std::vector<hardware::hidl_string> deviceNames) :
43 mDeviceNames(deviceNames) {}
44 using getResourceCost_cb = std::function<void(
45 hardware::camera::common::V1_0::Status status,
46 const hardware::camera::common::V1_0::CameraResourceCost& resourceCost)>;
47 virtual ::android::hardware::Return<void> getResourceCost(
48 getResourceCost_cb _hidl_cb) override {
49 hardware::camera::common::V1_0::CameraResourceCost resourceCost = {100,
50 mDeviceNames};
51 _hidl_cb(Status::OK, resourceCost);
52 return hardware::Void();
53 }
54
55 using getCameraCharacteristics_cb = std::function<void(
56 hardware::camera::common::V1_0::Status status,
57 const hardware::hidl_vec<uint8_t>& cameraCharacteristics)>;
58 hardware::Return<void> getCameraCharacteristics(
59 getCameraCharacteristics_cb _hidl_cb) override {
60 hardware::hidl_vec<uint8_t> cameraCharacteristics;
61 _hidl_cb(Status::OK, cameraCharacteristics);
62 return hardware::Void();
63 }
64
65 hardware::Return<hardware::camera::common::V1_0::Status> setTorchMode(
66 ::android::hardware::camera::common::V1_0::TorchMode) override {
67 return Status::OK;
68 }
69
70 using open_cb = std::function<void(
71 ::android::hardware::camera::common::V1_0::Status status,
72 const ::android::sp<ICameraDeviceSession>& session)>;
73 hardware::Return<void> open(
74 const ::android::sp<ICameraDeviceCallback>&,
75 open_cb _hidl_cb) override {
76 sp<ICameraDeviceSession> deviceSession = nullptr;
77 _hidl_cb(Status::OK, deviceSession);
78 return hardware::Void();
79 }
80
81 hardware::Return<void> dumpState(
82 const ::android::hardware::hidl_handle&) override {
83 return hardware::Void();
84 }
85};
Eino-Ville Talvala2f09bac2016-12-13 11:29:54 -080086
87/**
88 * Basic test implementation of a camera provider
89 */
90struct TestICameraProvider : virtual public provider::V2_4::ICameraProvider {
Emilian Peev71c73a22017-03-21 16:35:51 +000091 sp<provider::V2_4::ICameraProviderCallback> mCallbacks;
Eino-Ville Talvala2f09bac2016-12-13 11:29:54 -080092 std::vector<hardware::hidl_string> mDeviceNames;
Emilian Peev71c73a22017-03-21 16:35:51 +000093 sp<device::V3_2::ICameraDevice> mDeviceInterface;
94 hardware::hidl_vec<common::V1_0::VendorTagSection> mVendorTagSections;
Eino-Ville Talvala2f09bac2016-12-13 11:29:54 -080095
Emilian Peev71c73a22017-03-21 16:35:51 +000096 TestICameraProvider(const std::vector<hardware::hidl_string> &devices,
97 const hardware::hidl_vec<common::V1_0::VendorTagSection> &vendorSection) :
98 mDeviceNames(devices),
99 mDeviceInterface(new TestDeviceInterface(devices)),
100 mVendorTagSections (vendorSection) {}
Eino-Ville Talvala2f09bac2016-12-13 11:29:54 -0800101
Emilian Peev71c73a22017-03-21 16:35:51 +0000102 virtual hardware::Return<Status> setCallback(
103 const sp<provider::V2_4::ICameraProviderCallback>& callbacks) override {
Eino-Ville Talvala2f09bac2016-12-13 11:29:54 -0800104 mCallbacks = callbacks;
105 return hardware::Return<Status>(Status::OK);
106 }
107
108 using getVendorTags_cb = std::function<void(Status status,
109 const hardware::hidl_vec<common::V1_0::VendorTagSection>& sections)>;
Emilian Peev71c73a22017-03-21 16:35:51 +0000110 hardware::Return<void> getVendorTags(getVendorTags_cb _hidl_cb) override {
111 _hidl_cb(Status::OK, mVendorTagSections);
112 return hardware::Void();
113 }
114
115 using isSetTorchModeSupported_cb = std::function<void(
116 ::android::hardware::camera::common::V1_0::Status status,
117 bool support)>;
118 virtual ::hardware::Return<void> isSetTorchModeSupported(
119 isSetTorchModeSupported_cb _hidl_cb) override {
120 _hidl_cb(Status::OK, false);
Eino-Ville Talvala2f09bac2016-12-13 11:29:54 -0800121 return hardware::Void();
122 }
123
124 using getCameraIdList_cb = std::function<void(Status status,
125 const hardware::hidl_vec<hardware::hidl_string>& cameraDeviceNames)>;
126 virtual hardware::Return<void> getCameraIdList(getCameraIdList_cb _hidl_cb) override {
127 _hidl_cb(Status::OK, mDeviceNames);
128 return hardware::Void();
129 }
130
131 using getCameraDeviceInterface_V1_x_cb = std::function<void(Status status,
132 const sp<device::V1_0::ICameraDevice>& device)>;
133 virtual hardware::Return<void> getCameraDeviceInterface_V1_x(
134 const hardware::hidl_string& cameraDeviceName,
135 getCameraDeviceInterface_V1_x_cb _hidl_cb) override {
136 (void) cameraDeviceName;
Emilian Peev71c73a22017-03-21 16:35:51 +0000137 _hidl_cb(Status::OK, nullptr); //TODO: impl. of ver. 1.0 device interface
138 // otherwise enumeration will fail.
Eino-Ville Talvala2f09bac2016-12-13 11:29:54 -0800139 return hardware::Void();
140 }
141
142 using getCameraDeviceInterface_V3_x_cb = std::function<void(Status status,
143 const sp<device::V3_2::ICameraDevice>& device)>;
144 virtual hardware::Return<void> getCameraDeviceInterface_V3_x(
Emilian Peev71c73a22017-03-21 16:35:51 +0000145 const hardware::hidl_string&,
Eino-Ville Talvala2f09bac2016-12-13 11:29:54 -0800146 getCameraDeviceInterface_V3_x_cb _hidl_cb) override {
Emilian Peev71c73a22017-03-21 16:35:51 +0000147 _hidl_cb(Status::OK, mDeviceInterface);
Eino-Ville Talvala2f09bac2016-12-13 11:29:54 -0800148 return hardware::Void();
149 }
150
151};
152
153/**
154 * Simple test version of the interaction proxy, to use to inject onRegistered calls to the
155 * CameraProviderManager
156 */
157struct TestInteractionProxy : public CameraProviderManager::ServiceInteractionProxy {
158 sp<hidl::manager::V1_0::IServiceNotification> mManagerNotificationInterface;
Emilian Peev71c73a22017-03-21 16:35:51 +0000159 sp<TestICameraProvider> mTestCameraProvider;
Eino-Ville Talvala2f09bac2016-12-13 11:29:54 -0800160
Emilian Peev71c73a22017-03-21 16:35:51 +0000161 TestInteractionProxy() {}
162 void setProvider(sp<TestICameraProvider> provider) {
163 mTestCameraProvider = provider;
Eino-Ville Talvala2f09bac2016-12-13 11:29:54 -0800164 }
Emilian Peev71c73a22017-03-21 16:35:51 +0000165
Eino-Ville Talvalabb6e4142018-08-21 14:17:40 -0700166 std::vector<std::string> mLastRequestedServiceNames;
Eino-Ville Talvala2f09bac2016-12-13 11:29:54 -0800167
168 virtual ~TestInteractionProxy() {}
169
170 virtual bool registerForNotifications(
171 const std::string &serviceName,
172 const sp<hidl::manager::V1_0::IServiceNotification> &notification) override {
173 (void) serviceName;
174 mManagerNotificationInterface = notification;
175 return true;
176 }
177
178 virtual sp<hardware::camera::provider::V2_4::ICameraProvider> getService(
179 const std::string &serviceName) override {
Eino-Ville Talvalabb6e4142018-08-21 14:17:40 -0700180 mLastRequestedServiceNames.push_back(serviceName);
Eino-Ville Talvala2f09bac2016-12-13 11:29:54 -0800181 return mTestCameraProvider;
182 }
183
184};
185
Emilian Peev71c73a22017-03-21 16:35:51 +0000186struct TestStatusListener : public CameraProviderManager::StatusListener {
187 ~TestStatusListener() {}
Eino-Ville Talvala2f09bac2016-12-13 11:29:54 -0800188
Emilian Peev71c73a22017-03-21 16:35:51 +0000189 void onDeviceStatusChanged(const String8 &,
190 hardware::camera::common::V1_0::CameraDeviceStatus) override {}
191 void onTorchStatusChanged(const String8 &,
192 hardware::camera::common::V1_0::TorchModeStatus) override {}
Eino-Ville Talvala7cffc832018-06-03 17:32:53 -0700193 void onNewProviderRegistered() override {}
Emilian Peev71c73a22017-03-21 16:35:51 +0000194};
195
196TEST(CameraProviderManagerTest, InitializeTest) {
197 std::vector<hardware::hidl_string> deviceNames;
198 deviceNames.push_back("device@3.2/test/0");
199 deviceNames.push_back("device@1.0/test/0");
200 deviceNames.push_back("device@3.2/test/1");
201 hardware::hidl_vec<common::V1_0::VendorTagSection> vendorSection;
Eino-Ville Talvala2f09bac2016-12-13 11:29:54 -0800202 status_t res;
203 sp<CameraProviderManager> providerManager = new CameraProviderManager();
Emilian Peev71c73a22017-03-21 16:35:51 +0000204 sp<TestStatusListener> statusListener = new TestStatusListener();
205 TestInteractionProxy serviceProxy;
206 sp<TestICameraProvider> provider = new TestICameraProvider(deviceNames,
207 vendorSection);
208 serviceProxy.setProvider(provider);
Eino-Ville Talvala2f09bac2016-12-13 11:29:54 -0800209
Emilian Peev71c73a22017-03-21 16:35:51 +0000210 res = providerManager->initialize(statusListener, &serviceProxy);
Eino-Ville Talvala2f09bac2016-12-13 11:29:54 -0800211 ASSERT_EQ(res, OK) << "Unable to initialize provider manager";
212
Eino-Ville Talvalabb6e4142018-08-21 14:17:40 -0700213 std::string legacyInstanceName = "legacy/0";
214 std::string externalInstanceName = "external/0";
215 bool gotLegacy = false;
216 bool gotExternal = false;
217 for (auto& serviceName : serviceProxy.mLastRequestedServiceNames) {
218 if (serviceName == legacyInstanceName) gotLegacy = true;
219 if (serviceName == externalInstanceName) gotExternal = true;
220 }
221 ASSERT_TRUE(gotLegacy) <<
Eino-Ville Talvala2f09bac2016-12-13 11:29:54 -0800222 "Legacy instance not requested from service manager";
Eino-Ville Talvalabb6e4142018-08-21 14:17:40 -0700223 ASSERT_TRUE(gotExternal) <<
224 "External instance not requested from service manager";
Eino-Ville Talvala2f09bac2016-12-13 11:29:54 -0800225
226 hardware::hidl_string testProviderFqInterfaceName =
227 "android.hardware.camera.provider@2.4::ICameraProvider";
228 hardware::hidl_string testProviderInstanceName = "test/0";
229 serviceProxy.mManagerNotificationInterface->onRegistration(
230 testProviderFqInterfaceName,
231 testProviderInstanceName, false);
232
Eino-Ville Talvalabb6e4142018-08-21 14:17:40 -0700233 ASSERT_EQ(serviceProxy.mLastRequestedServiceNames.back(), testProviderInstanceName) <<
Eino-Ville Talvala2f09bac2016-12-13 11:29:54 -0800234 "Incorrect instance requested from service manager";
235}
Emilian Peev71c73a22017-03-21 16:35:51 +0000236
237TEST(CameraProviderManagerTest, MultipleVendorTagTest) {
238 hardware::hidl_string sectionName = "VendorTestSection";
239 hardware::hidl_string tagName = "VendorTestTag";
240 uint32_t tagId = VENDOR_SECTION << 16;
241 hardware::hidl_vec<common::V1_0::VendorTagSection> vendorSection;
242 CameraMetadataType tagType = CameraMetadataType::BYTE;
243 vendorSection.resize(1);
244 vendorSection[0].sectionName = sectionName;
245 vendorSection[0].tags.resize(1);
246 vendorSection[0].tags[0].tagId = tagId;
247 vendorSection[0].tags[0].tagName = tagName;
248 vendorSection[0].tags[0].tagType = tagType;
249 std::vector<hardware::hidl_string> deviceNames = {"device@3.2/test/0"};
250
251 sp<CameraProviderManager> providerManager = new CameraProviderManager();
252 sp<TestStatusListener> statusListener = new TestStatusListener();
253 TestInteractionProxy serviceProxy;
254
255 sp<TestICameraProvider> provider = new TestICameraProvider(deviceNames,
256 vendorSection);
257 serviceProxy.setProvider(provider);
258
259 auto res = providerManager->initialize(statusListener, &serviceProxy);
260 ASSERT_EQ(res, OK) << "Unable to initialize provider manager";
261
262 hardware::hidl_string testProviderInstanceName = "test/0";
263 hardware::hidl_string testProviderFqInterfaceName =
264 "android.hardware.camera.provider@2.4::ICameraProvider";
265 serviceProxy.mManagerNotificationInterface->onRegistration(
266 testProviderFqInterfaceName, testProviderInstanceName, false);
Eino-Ville Talvalabb6e4142018-08-21 14:17:40 -0700267 ASSERT_EQ(serviceProxy.mLastRequestedServiceNames.back(), testProviderInstanceName) <<
Emilian Peev71c73a22017-03-21 16:35:51 +0000268 "Incorrect instance requested from service manager";
269
270 hardware::hidl_string sectionNameSecond = "SecondVendorTestSection";
271 hardware::hidl_string secondTagName = "SecondVendorTestTag";
272 CameraMetadataType secondTagType = CameraMetadataType::DOUBLE;
273 vendorSection[0].sectionName = sectionNameSecond;
274 vendorSection[0].tags[0].tagId = tagId;
275 vendorSection[0].tags[0].tagName = secondTagName;
276 vendorSection[0].tags[0].tagType = secondTagType;
277 deviceNames = {"device@3.2/test2/1"};
278
279 sp<TestICameraProvider> secondProvider = new TestICameraProvider(
280 deviceNames, vendorSection);
281 serviceProxy.setProvider(secondProvider);
282 hardware::hidl_string testProviderSecondInstanceName = "test2/0";
283 serviceProxy.mManagerNotificationInterface->onRegistration(
284 testProviderFqInterfaceName, testProviderSecondInstanceName, false);
Eino-Ville Talvalabb6e4142018-08-21 14:17:40 -0700285 ASSERT_EQ(serviceProxy.mLastRequestedServiceNames.back(),
Emilian Peev71c73a22017-03-21 16:35:51 +0000286 testProviderSecondInstanceName) <<
287 "Incorrect instance requested from service manager";
288
289 ASSERT_EQ(NO_ERROR , providerManager->setUpVendorTags());
290 sp<VendorTagDescriptorCache> vendorCache =
291 VendorTagDescriptorCache::getGlobalVendorTagCache();
292 ASSERT_NE(nullptr, vendorCache.get());
293
294 metadata_vendor_id_t vendorId = std::hash<std::string> {} (
295 testProviderInstanceName.c_str());
296 metadata_vendor_id_t vendorIdSecond = std::hash<std::string> {} (
297 testProviderSecondInstanceName.c_str());
298
299 hardware::hidl_string resultTag = vendorCache->getTagName(tagId, vendorId);
300 ASSERT_EQ(resultTag, tagName);
301
302 resultTag = vendorCache->getTagName(tagId, vendorIdSecond);
303 ASSERT_EQ(resultTag, secondTagName);
304
305 // Check whether we can create two separate CameraMetadata instances
306 // using different tag vendor vendors.
307 camera_metadata *metaBuffer = allocate_camera_metadata(10, 20);
308 ASSERT_NE(nullptr, metaBuffer);
309 set_camera_metadata_vendor_id(metaBuffer, vendorId);
310 CameraMetadata metadata(metaBuffer);
311
312 uint8_t byteVal = 10;
313 ASSERT_TRUE(metadata.isEmpty());
314 ASSERT_EQ(OK, metadata.update(tagId, &byteVal, 1));
315 ASSERT_FALSE(metadata.isEmpty());
316 ASSERT_TRUE(metadata.exists(tagId));
317
318 metaBuffer = allocate_camera_metadata(10, 20);
319 ASSERT_NE(nullptr, metaBuffer);
320 set_camera_metadata_vendor_id(metaBuffer, vendorIdSecond);
321 CameraMetadata secondMetadata(metaBuffer);
322
323 ASSERT_TRUE(secondMetadata.isEmpty());
324 double doubleVal = 1.0f;
325 ASSERT_EQ(OK, secondMetadata.update(tagId, &doubleVal, 1));
326 ASSERT_FALSE(secondMetadata.isEmpty());
327 ASSERT_TRUE(secondMetadata.exists(tagId));
328
329 // Check whether CameraMetadata copying works as expected
330 CameraMetadata metadataCopy(metadata);
331 ASSERT_FALSE(metadataCopy.isEmpty());
332 ASSERT_TRUE(metadataCopy.exists(tagId));
333 ASSERT_EQ(OK, metadataCopy.update(tagId, &byteVal, 1));
334 ASSERT_TRUE(metadataCopy.exists(tagId));
335
336 // Check whether values are as expected
337 camera_metadata_entry_t entry = metadata.find(tagId);
338 ASSERT_EQ(1u, entry.count);
339 ASSERT_EQ(byteVal, entry.data.u8[0]);
340 entry = secondMetadata.find(tagId);
341 ASSERT_EQ(1u, entry.count);
342 ASSERT_EQ(doubleVal, entry.data.d[0]);
343
344 // Swap and erase
345 secondMetadata.swap(metadataCopy);
346 ASSERT_TRUE(metadataCopy.exists(tagId));
347 ASSERT_TRUE(secondMetadata.exists(tagId));
348 ASSERT_EQ(OK, secondMetadata.erase(tagId));
349 ASSERT_TRUE(secondMetadata.isEmpty());
350 doubleVal = 0.0f;
351 ASSERT_EQ(OK, metadataCopy.update(tagId, &doubleVal, 1));
352 entry = metadataCopy.find(tagId);
353 ASSERT_EQ(1u, entry.count);
354 ASSERT_EQ(doubleVal, entry.data.d[0]);
355
356 // Append
357 uint8_t sceneMode = ANDROID_CONTROL_SCENE_MODE_ACTION;
358 secondMetadata.update(ANDROID_CONTROL_SCENE_MODE, &sceneMode, 1);
359 // Append from two different vendor tag providers is not supported!
360 ASSERT_NE(OK, metadataCopy.append(secondMetadata));
361 ASSERT_EQ(OK, metadataCopy.erase(tagId));
362 metadataCopy.update(ANDROID_CONTROL_SCENE_MODE, &sceneMode, 1);
363 // However appending from same vendor tag provider should be fine
364 ASSERT_EQ(OK, metadata.append(secondMetadata));
Emilian Peev68dbd4e2017-04-11 11:44:29 +0100365 // Append from a metadata without vendor tag provider should be supported
Emilian Peev71c73a22017-03-21 16:35:51 +0000366 CameraMetadata regularMetadata(10, 20);
367 uint8_t controlMode = ANDROID_CONTROL_MODE_AUTO;
368 regularMetadata.update(ANDROID_CONTROL_MODE, &controlMode, 1);
Emilian Peev68dbd4e2017-04-11 11:44:29 +0100369 ASSERT_EQ(OK, secondMetadata.append(regularMetadata));
370 ASSERT_EQ(2u, secondMetadata.entryCount());
Emilian Peev71c73a22017-03-21 16:35:51 +0000371 ASSERT_EQ(2u, metadata.entryCount());
372
373 // Dump
374 metadata.dump(1, 2);
375 metadataCopy.dump(1, 2);
376 secondMetadata.dump(1, 2);
377}