/* * Copyright (C) 2020 The Android Open Source Project * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ #ifndef ANDROID_HARDWARE_INTERFACES_NEURALNETWORKS_1_3_UTILS_TEST_MOCK_DEVICE_H #define ANDROID_HARDWARE_INTERFACES_NEURALNETWORKS_1_3_UTILS_TEST_MOCK_DEVICE_H #include #include #include #include namespace android::hardware::neuralnetworks::V1_3::utils { using CacheToken = hidl_array(V1_2::Constant::BYTE_SIZE_OF_CACHE_TOKEN)>; class MockDevice final : public IDevice { public: static sp create(); // IBase methods below. MOCK_METHOD(Return, ping, (), (override)); MOCK_METHOD(Return, linkToDeathRet, ()); Return linkToDeath(const sp& recipient, uint64_t /*cookie*/); // V1_0 methods below. MOCK_METHOD(Return, getCapabilities, (getCapabilities_cb cb), (override)); MOCK_METHOD(Return, getSupportedOperations, (const V1_0::Model& model, getSupportedOperations_cb cb), (override)); MOCK_METHOD(Return, prepareModel, (const V1_0::Model& model, const sp& callback), (override)); MOCK_METHOD(Return, getStatus, (), (override)); // V1_1 methods below. MOCK_METHOD(Return, getCapabilities_1_1, (getCapabilities_1_1_cb cb), (override)); MOCK_METHOD(Return, getSupportedOperations_1_1, (const V1_1::Model& model, getSupportedOperations_1_1_cb cb), (override)); MOCK_METHOD(Return, prepareModel_1_1, (const V1_1::Model& model, V1_1::ExecutionPreference preference, const sp& callback), (override)); // V1_2 methods below. MOCK_METHOD(Return, getVersionString, (getVersionString_cb cb), (override)); MOCK_METHOD(Return, getType, (getType_cb cb), (override)); MOCK_METHOD(Return, getCapabilities_1_2, (getCapabilities_1_2_cb cb), (override)); MOCK_METHOD(Return, getSupportedExtensions, (getSupportedExtensions_cb cb), (override)); MOCK_METHOD(Return, getSupportedOperations_1_2, (const V1_2::Model& model, getSupportedOperations_1_2_cb cb), (override)); MOCK_METHOD(Return, getNumberOfCacheFilesNeeded, (getNumberOfCacheFilesNeeded_cb cb), (override)); MOCK_METHOD(Return, prepareModel_1_2, (const V1_2::Model& model, V1_1::ExecutionPreference preference, const hidl_vec& modelCache, const hidl_vec& dataCache, const CacheToken& token, const sp& callback), (override)); MOCK_METHOD(Return, prepareModelFromCache, (const hidl_vec& modelCache, const hidl_vec& dataCache, const CacheToken& token, const sp& callback), (override)); // V1_3 methods below. MOCK_METHOD(Return, getCapabilities_1_3, (getCapabilities_1_3_cb cb), (override)); MOCK_METHOD(Return, getSupportedOperations_1_3, (const V1_3::Model& model, getSupportedOperations_1_3_cb cb), (override)); MOCK_METHOD(Return, prepareModel_1_3, (const V1_3::Model& model, V1_1::ExecutionPreference preference, V1_3::Priority priority, const V1_3::OptionalTimePoint& deadline, const hidl_vec& modelCache, const hidl_vec& dataCache, const CacheToken& token, const sp& callback), (override)); MOCK_METHOD(Return, prepareModelFromCache_1_3, (const V1_3::OptionalTimePoint& deadline, const hidl_vec& modelCache, const hidl_vec& dataCache, const CacheToken& token, const sp& callback), (override)); MOCK_METHOD(Return, allocate, (const V1_3::BufferDesc& desc, const hidl_vec>& preparedModels, const hidl_vec& inputRoles, const hidl_vec& outputRoles, allocate_cb cb), (override)); // Helper methods. void simulateCrash(); private: sp mDeathRecipient; }; inline sp MockDevice::create() { auto mockDevice = sp::make(); // Setup default actions for each relevant call. const auto ret = []() -> Return { return true; }; // Setup default actions for each relevant call. ON_CALL(*mockDevice, linkToDeathRet()).WillByDefault(testing::Invoke(ret)); // These EXPECT_CALL(...).Times(testing::AnyNumber()) calls are to suppress warnings on the // uninteresting methods calls. EXPECT_CALL(*mockDevice, linkToDeathRet()).Times(testing::AnyNumber()); return mockDevice; } inline Return MockDevice::linkToDeath(const sp& recipient, uint64_t /*cookie*/) { mDeathRecipient = recipient; return linkToDeathRet(); } inline void MockDevice::simulateCrash() { ASSERT_NE(nullptr, mDeathRecipient.get()); // Currently, the utils::Device will not use the `cookie` or `who` arguments, so we pass in 0 // and nullptr for these arguments instead. Normally, they are used by the hidl_death_recipient // to determine which object is dead. However, the utils::Device code only pairs a single death // recipient with a single HIDL interface object, so these arguments are redundant. mDeathRecipient->serviceDied(0, nullptr); } } // namespace android::hardware::neuralnetworks::V1_3::utils #endif // ANDROID_HARDWARE_INTERFACES_NEURALNETWORKS_1_3_UTILS_TEST_MOCK_DEVICE_H