1 /*
2 * Copyright 2021 HIMSA II K/S - www.himsa.com.
3 * Represented by EHIMA - www.ehima.com
4 *
5 * Licensed under the Apache License, Version 2.0 (the "License");
6 * you may not use this file except in compliance with the License.
7 * You may obtain a copy of the License at
8 *
9 * http://www.apache.org/licenses/LICENSE-2.0
10 *
11 * Unless required by applicable law or agreed to in writing, software
12 * distributed under the License is distributed on an "AS IS" BASIS,
13 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14 * See the License for the specific language governing permissions and
15 * limitations under the License.
16 */
17
18 #include "btm_api_mock.h"
19
20 #include <bluetooth/log.h>
21
22 #include <optional>
23
24 #include "bt_octets.h"
25 #include "stack/include/btm_ble_sec_api.h"
26 #include "test/mock/mock_stack_btm_interface.h"
27 #include "types/raw_address.h"
28
29 // TODO(b/369381361) Enfore -Wmissing-prototypes
30 #pragma GCC diagnostic ignored "-Wmissing-prototypes"
31
32 using namespace bluetooth;
33
34 static bluetooth::manager::MockBtmInterface* btm_interface = nullptr;
35
SetMockBtmInterface(MockBtmInterface * mock_btm_interface)36 void bluetooth::manager::SetMockBtmInterface(MockBtmInterface* mock_btm_interface) {
37 btm_interface = mock_btm_interface;
38 mock_btm_client_interface.peer.BTM_IsPhy2mSupported = [](const RawAddress& remote_bda,
39 tBT_TRANSPORT transport) {
40 return btm_interface->IsPhy2mSupported(remote_bda, transport);
41 };
42 mock_btm_client_interface.peer.BTM_GetHCIConnHandle = [](RawAddress const& bd_addr,
43 tBT_TRANSPORT transport) -> uint16_t {
44 return btm_interface->GetHCIConnHandle(bd_addr, transport);
45 };
46 mock_btm_client_interface.peer.BTM_GetPeerSCA = [](const RawAddress& remote_bda,
47 tBT_TRANSPORT transport) {
48 return btm_interface->GetPeerSCA(remote_bda, transport);
49 };
50 mock_btm_client_interface.peer.BTM_RequestPeerSCA = [](RawAddress const& bd_addr,
51 tBT_TRANSPORT transport) {
52 btm_interface->RequestPeerSCA(bd_addr, transport);
53 };
54 mock_btm_client_interface.ble.BTM_BleSetPhy = [](const RawAddress& bd_addr, uint8_t tx_phys,
55 uint8_t rx_phys, uint16_t phy_options) {
56 btm_interface->BleSetPhy(bd_addr, tx_phys, rx_phys, phy_options);
57 };
58 mock_btm_client_interface.peer.BTM_IsAclConnectionUp = [](const RawAddress& remote_bda,
59 tBT_TRANSPORT transport) {
60 return btm_interface->BTM_IsAclConnectionUp(remote_bda, transport);
61 };
62 }
63
BTM_IsLinkKeyKnown(const RawAddress & bd_addr,tBT_TRANSPORT transport)64 bool BTM_IsLinkKeyKnown(const RawAddress& bd_addr, tBT_TRANSPORT transport) {
65 log::assert_that(btm_interface != nullptr, "Mock btm interface not set!");
66 return btm_interface->IsLinkKeyKnown(bd_addr, transport);
67 }
68
BTM_IsEncrypted(const RawAddress & bd_addr,tBT_TRANSPORT transport)69 bool BTM_IsEncrypted(const RawAddress& bd_addr, tBT_TRANSPORT transport) {
70 return btm_interface->BTM_IsEncrypted(bd_addr, transport);
71 }
72
BTM_SetEncryption(const RawAddress & bd_addr,tBT_TRANSPORT transport,tBTM_SEC_CALLBACK * p_callback,void * p_ref_data,tBTM_BLE_SEC_ACT sec_act)73 tBTM_STATUS BTM_SetEncryption(const RawAddress& bd_addr, tBT_TRANSPORT transport,
74 tBTM_SEC_CALLBACK* p_callback, void* p_ref_data,
75 tBTM_BLE_SEC_ACT sec_act) {
76 return btm_interface->SetEncryption(bd_addr, transport, p_callback, p_ref_data, sec_act);
77 }
78
BTM_SecIsSecurityPending(const RawAddress & bd_addr)79 bool BTM_SecIsSecurityPending(const RawAddress& bd_addr) {
80 log::assert_that(btm_interface != nullptr, "Mock btm interface not set!");
81 return btm_interface->SecIsSecurityPending(bd_addr);
82 }
83
btm_find_dev(const RawAddress & bd_addr)84 tBTM_SEC_DEV_REC* btm_find_dev(const RawAddress& bd_addr) {
85 log::assert_that(btm_interface != nullptr, "Mock btm interface not set!");
86 return btm_interface->FindDevice(bd_addr);
87 }
88
acl_disconnect_from_handle(uint16_t handle,tHCI_STATUS reason,std::string)89 void acl_disconnect_from_handle(uint16_t handle, tHCI_STATUS reason, std::string /*comment*/) {
90 log::assert_that(btm_interface != nullptr, "Mock btm interface not set!");
91 return btm_interface->AclDisconnectFromHandle(handle, reason);
92 }
93
BTM_InqDbFirst(void)94 tBTM_INQ_INFO* BTM_InqDbFirst(void) {
95 log::assert_that(btm_interface != nullptr, "Mock btm interface not set!");
96 return btm_interface->BTM_InqDbFirst();
97 }
BTM_InqDbNext(tBTM_INQ_INFO * p_cur)98 tBTM_INQ_INFO* BTM_InqDbNext(tBTM_INQ_INFO* p_cur) {
99 log::assert_that(btm_interface != nullptr, "Mock btm interface not set!");
100 return btm_interface->BTM_InqDbNext(p_cur);
101 }
102
BTM_BleGetPeerLTK(const RawAddress address)103 std::optional<Octet16> BTM_BleGetPeerLTK(const RawAddress address) {
104 log::assert_that(btm_interface != nullptr, "Mock btm interface not set!");
105 return btm_interface->BTM_BleGetPeerLTK(address);
106 }
107
BTM_BleGetPeerIRK(const RawAddress address)108 std::optional<Octet16> BTM_BleGetPeerIRK(const RawAddress address) {
109 log::assert_that(btm_interface != nullptr, "Mock btm interface not set!");
110 return btm_interface->BTM_BleGetPeerIRK(address);
111 }
112
BTM_BleIsLinkKeyKnown(const RawAddress address)113 bool BTM_BleIsLinkKeyKnown(const RawAddress address) {
114 log::assert_that(btm_interface != nullptr, "Mock btm interface not set!");
115 return btm_interface->BTM_BleIsLinkKeyKnown(address);
116 }
117
BTM_BleGetIdentityAddress(const RawAddress address)118 std::optional<tBLE_BD_ADDR> BTM_BleGetIdentityAddress(const RawAddress address) {
119 log::assert_that(btm_interface != nullptr, "Mock btm interface not set!");
120 return btm_interface->BTM_BleGetIdentityAddress(address);
121 }
122