/****************************************************************************** * * Copyright 2016 Google, Inc. * * 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. * ******************************************************************************/ #include "adapter/bluetooth_test.h" #include "rfcomm/rfcomm_test.h" #include <sys/socket.h> #include <unistd.h> namespace { static const char HANDSHAKE_COMMAND[] = "AT+BRSF=29\r"; } // namespace namespace bttest { TEST_F(RFCommTest, RfcommConnectPairedDevice) { int fd = -1; int error = 0; size_t len = 0; error = socket_interface()->connect(&bt_remote_bdaddr_, BTSOCK_RFCOMM, &HFP_UUID, 0, &fd, 0, getuid()); EXPECT_TRUE(error == BT_STATUS_SUCCESS) << "Error creating RFCOMM socket: " << error; EXPECT_TRUE(fd != -1) << "Error creating RFCOMM socket: invalid fd"; int channel; sock_connect_signal_t signal; len = read(fd, &channel, sizeof(channel)); EXPECT_TRUE(len == sizeof(channel)) << "Channel not read from RFCOMM socket. Bytes read: " << len; len = read(fd, &signal, sizeof(signal)); EXPECT_TRUE(len == sizeof(signal)) << "Connection signal not read from RFCOMM socket. Bytes read: " << len; EXPECT_TRUE(signal.bd_addr == bt_remote_bdaddr_) << "Connected to a different bdaddr than expected."; EXPECT_TRUE(channel == signal.channel) << "Inconsistent channels returned: " << channel << " and " << signal.channel; len = write(fd, HANDSHAKE_COMMAND, sizeof(HANDSHAKE_COMMAND)); EXPECT_TRUE(len == sizeof(HANDSHAKE_COMMAND)) << "Unable to send HFP handshake. Bytes written: " << len; char response[1024]; len = read(fd, response, sizeof(response)); EXPECT_TRUE(len > 0) << "Read " << len << " bytes"; close(fd); } TEST_F(RFCommTest, RfcommRepeatedConnectPairedDevice) { static const int max_iterations = 128; int channel_fail = 0, signal_fail = 0, handshake_fail = 0, read_fail = 0; for (int i = 0; i < max_iterations; ++i) { int fd = -1; int error = 0; size_t len = 0; error = socket_interface()->connect(&bt_remote_bdaddr_, BTSOCK_RFCOMM, &HFP_UUID, 0, &fd, 0, getuid()); ASSERT_TRUE(error == BT_STATUS_SUCCESS) << "Error creating RFCOMM socket: " << error; ASSERT_TRUE(fd != -1) << "Error creating RFCOMM socket: invalid fd"; int channel; sock_connect_signal_t signal; len = read(fd, &channel, sizeof(channel)); if (len != sizeof(channel)) { ADD_FAILURE() << "Channel not read from RFCOMM socket. Bytes read: " << len << ", Sizeof channel: " << sizeof(channel); channel_fail++; } len = read(fd, &signal, sizeof(signal)); if (len != sizeof(signal)) { ADD_FAILURE() << "Connection signal not read from RFCOMM socket. Bytes read: " << len; signal_fail++; } EXPECT_TRUE(signal.bd_addr == bt_remote_bdaddr_) << "Connected to a different bdaddr than expected."; EXPECT_TRUE(channel == signal.channel) << "Inconsistent channels returned: " << channel << " and " << signal.channel; len = write(fd, HANDSHAKE_COMMAND, sizeof(HANDSHAKE_COMMAND)); if (len != sizeof(HANDSHAKE_COMMAND)) { ADD_FAILURE() << "Unable to send HFP handshake. Bytes written: " << len; handshake_fail++; } char response[1024]; len = read(fd, response, sizeof(response)); if (len <= 0) { ADD_FAILURE() << "Read " << len << " bytes"; read_fail++; } close(fd); } if (channel_fail > 0 || signal_fail > 0 || handshake_fail > 0 || read_fail > 0) { ADD_FAILURE() << "Number of channel read fails: " << channel_fail << "\n" << "Number of signal read fails: " << signal_fail << "\n" << "Number of handshake send fails: " << handshake_fail << "\n" << "Number of read response fails: " << read_fail; } } } // bttest