Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(444)

Unified Diff: device/bluetooth/bluetooth_gatt_characteristic_unittest.cc

Issue 1898643002: Refactor device::BluetoothGattXXX classes to split into remote/local. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Created 4 years, 8 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
Index: device/bluetooth/bluetooth_gatt_characteristic_unittest.cc
diff --git a/device/bluetooth/bluetooth_gatt_characteristic_unittest.cc b/device/bluetooth/bluetooth_gatt_characteristic_unittest.cc
deleted file mode 100644
index a9451b4069d72cf2e9902bea9b8de8185bddd145..0000000000000000000000000000000000000000
--- a/device/bluetooth/bluetooth_gatt_characteristic_unittest.cc
+++ /dev/null
@@ -1,1109 +0,0 @@
-// Copyright 2015 The Chromium Authors. All rights reserved.
-// Use of this source code is governed by a BSD-style license that can be
-// found in the LICENSE file.
-
-#include "device/bluetooth/bluetooth_gatt_characteristic.h"
-
-#include <stdint.h>
-
-#include "base/macros.h"
-#include "base/run_loop.h"
-#include "build/build_config.h"
-#include "device/bluetooth/bluetooth_gatt_service.h"
-#include "device/bluetooth/test/test_bluetooth_adapter_observer.h"
-#include "testing/gtest/include/gtest/gtest.h"
-
-#if defined(OS_ANDROID)
-#include "device/bluetooth/test/bluetooth_test_android.h"
-#elif defined(OS_MACOSX)
-#include "device/bluetooth/test/bluetooth_test_mac.h"
-#elif defined(OS_WIN)
-#include "device/bluetooth/test/bluetooth_test_win.h"
-#endif
-
-namespace device {
-
-#if defined(OS_ANDROID) || defined(OS_MACOSX) || defined(OS_WIN)
-class BluetoothGattCharacteristicTest : public BluetoothTest {
- public:
- // Creates adapter_, device_, service_, characteristic1_, & characteristic2_.
- // |properties| will be used for each characteristic.
- void FakeCharacteristicBoilerplate(int properties = 0) {
- InitWithFakeAdapter();
- StartLowEnergyDiscoverySession();
- device_ = DiscoverLowEnergyDevice(3);
- device_->CreateGattConnection(GetGattConnectionCallback(Call::EXPECTED),
- GetConnectErrorCallback(Call::NOT_EXPECTED));
- SimulateGattConnection(device_);
- std::vector<std::string> services;
- std::string uuid("00000000-0000-1000-8000-00805f9b34fb");
- services.push_back(uuid);
- SimulateGattServicesDiscovered(device_, services);
- ASSERT_EQ(1u, device_->GetGattServices().size());
- service_ = device_->GetGattServices()[0];
- SimulateGattCharacteristic(service_, uuid, properties);
- SimulateGattCharacteristic(service_, uuid, properties);
- ASSERT_EQ(2u, service_->GetCharacteristics().size());
- characteristic1_ = service_->GetCharacteristics()[0];
- characteristic2_ = service_->GetCharacteristics()[1];
- ResetEventCounts();
- }
-
- enum class StartNotifySetupError {
- CHARACTERISTIC_PROPERTIES,
- CONFIG_DESCRIPTOR_MISSING,
- CONFIG_DESCRIPTOR_DUPLICATE,
- SET_NOTIFY,
- WRITE_DESCRIPTOR,
- NONE
- };
- // Constructs characteristics with |properties|, calls StartNotifySession,
- // and verifies the appropriate |expected_config_descriptor_value| is written.
- // Error scenarios in this boilerplate are tested by setting |error| to the
- // setup stage to test.
- void StartNotifyBoilerplate(
- int properties,
- uint16_t expected_config_descriptor_value,
- StartNotifySetupError error = StartNotifySetupError::NONE) {
- if (error == StartNotifySetupError::CHARACTERISTIC_PROPERTIES) {
- properties = 0;
- }
- ASSERT_NO_FATAL_FAILURE(FakeCharacteristicBoilerplate(properties));
-
- size_t expected_descriptors_count = 0;
- if (error != StartNotifySetupError::CONFIG_DESCRIPTOR_MISSING) {
- SimulateGattDescriptor(
- characteristic1_,
- BluetoothGattDescriptor::ClientCharacteristicConfigurationUuid()
- .canonical_value());
- expected_descriptors_count++;
- }
- if (error == StartNotifySetupError::CONFIG_DESCRIPTOR_DUPLICATE) {
- SimulateGattDescriptor(
- characteristic1_,
- BluetoothGattDescriptor::ClientCharacteristicConfigurationUuid()
- .canonical_value());
- expected_descriptors_count++;
- }
- ASSERT_EQ(expected_descriptors_count,
- characteristic1_->GetDescriptors().size());
-
- if (error == StartNotifySetupError::SET_NOTIFY) {
- SimulateGattCharacteristicSetNotifyWillFailSynchronouslyOnce(
- characteristic1_);
- }
-
- if (error == StartNotifySetupError::WRITE_DESCRIPTOR) {
- SimulateGattDescriptorWriteWillFailSynchronouslyOnce(
- characteristic1_->GetDescriptors()[0]);
- }
-
- if (error != StartNotifySetupError::NONE) {
- characteristic1_->StartNotifySession(
- GetNotifyCallback(Call::NOT_EXPECTED),
- GetGattErrorCallback(Call::EXPECTED));
- return;
- }
-
- characteristic1_->StartNotifySession(
- GetNotifyCallback(Call::EXPECTED),
- GetGattErrorCallback(Call::NOT_EXPECTED));
-
- EXPECT_EQ(0, callback_count_);
- SimulateGattNotifySessionStarted(characteristic1_);
- EXPECT_EQ(1, gatt_notify_characteristic_attempts_);
- EXPECT_EQ(1, callback_count_);
- EXPECT_EQ(0, error_callback_count_);
- ASSERT_EQ(1u, notify_sessions_.size());
- ASSERT_TRUE(notify_sessions_[0]);
- EXPECT_EQ(characteristic1_->GetIdentifier(),
- notify_sessions_[0]->GetCharacteristicIdentifier());
- EXPECT_TRUE(notify_sessions_[0]->IsActive());
-
- // Verify the Client Characteristic Configuration descriptor was written to.
- EXPECT_EQ(1, gatt_write_descriptor_attempts_);
- EXPECT_EQ(2u, last_write_value_.size());
- uint8_t expected_byte0 = expected_config_descriptor_value & 0xFF;
- uint8_t expected_byte1 = (expected_config_descriptor_value >> 8) & 0xFF;
- EXPECT_EQ(expected_byte0, last_write_value_[0]);
- EXPECT_EQ(expected_byte1, last_write_value_[1]);
- }
-
- BluetoothDevice* device_ = nullptr;
- BluetoothGattService* service_ = nullptr;
- BluetoothGattCharacteristic* characteristic1_ = nullptr;
- BluetoothGattCharacteristic* characteristic2_ = nullptr;
-};
-#endif
-
-#if defined(OS_ANDROID) || defined(OS_WIN)
-TEST_F(BluetoothGattCharacteristicTest, GetIdentifier) {
- InitWithFakeAdapter();
- StartLowEnergyDiscoverySession();
- // 2 devices to verify unique IDs across them.
- BluetoothDevice* device1 = DiscoverLowEnergyDevice(3);
- BluetoothDevice* device2 = DiscoverLowEnergyDevice(4);
- device1->CreateGattConnection(GetGattConnectionCallback(Call::EXPECTED),
- GetConnectErrorCallback(Call::NOT_EXPECTED));
- device2->CreateGattConnection(GetGattConnectionCallback(Call::EXPECTED),
- GetConnectErrorCallback(Call::NOT_EXPECTED));
- SimulateGattConnection(device1);
- SimulateGattConnection(device2);
-
- // 3 services (all with same UUID).
- // 1 on the first device (to test characteristic instances across devices).
- // 2 on the second device (to test same device, multiple service instances).
- std::vector<std::string> services;
- std::string uuid = "00000000-0000-1000-8000-00805f9b34fb";
- services.push_back(uuid);
- SimulateGattServicesDiscovered(device1, services);
- services.push_back(uuid);
- SimulateGattServicesDiscovered(device2, services);
- BluetoothGattService* service1 = device1->GetGattServices()[0];
- BluetoothGattService* service2 = device2->GetGattServices()[0];
- BluetoothGattService* service3 = device2->GetGattServices()[1];
- // 6 characteristics (same UUID), 2 on each service.
- SimulateGattCharacteristic(service1, uuid, /* properties */ 0);
- SimulateGattCharacteristic(service1, uuid, /* properties */ 0);
- SimulateGattCharacteristic(service2, uuid, /* properties */ 0);
- SimulateGattCharacteristic(service2, uuid, /* properties */ 0);
- SimulateGattCharacteristic(service3, uuid, /* properties */ 0);
- SimulateGattCharacteristic(service3, uuid, /* properties */ 0);
- BluetoothGattCharacteristic* char1 = service1->GetCharacteristics()[0];
- BluetoothGattCharacteristic* char2 = service1->GetCharacteristics()[1];
- BluetoothGattCharacteristic* char3 = service2->GetCharacteristics()[0];
- BluetoothGattCharacteristic* char4 = service2->GetCharacteristics()[1];
- BluetoothGattCharacteristic* char5 = service3->GetCharacteristics()[0];
- BluetoothGattCharacteristic* char6 = service3->GetCharacteristics()[1];
-
- // All IDs are unique, even though they have the same UUID.
- EXPECT_NE(char1->GetIdentifier(), char2->GetIdentifier());
- EXPECT_NE(char1->GetIdentifier(), char3->GetIdentifier());
- EXPECT_NE(char1->GetIdentifier(), char4->GetIdentifier());
- EXPECT_NE(char1->GetIdentifier(), char5->GetIdentifier());
- EXPECT_NE(char1->GetIdentifier(), char6->GetIdentifier());
-
- EXPECT_NE(char2->GetIdentifier(), char3->GetIdentifier());
- EXPECT_NE(char2->GetIdentifier(), char4->GetIdentifier());
- EXPECT_NE(char2->GetIdentifier(), char5->GetIdentifier());
- EXPECT_NE(char2->GetIdentifier(), char6->GetIdentifier());
-
- EXPECT_NE(char3->GetIdentifier(), char4->GetIdentifier());
- EXPECT_NE(char3->GetIdentifier(), char5->GetIdentifier());
- EXPECT_NE(char3->GetIdentifier(), char6->GetIdentifier());
-
- EXPECT_NE(char4->GetIdentifier(), char5->GetIdentifier());
- EXPECT_NE(char4->GetIdentifier(), char6->GetIdentifier());
-
- EXPECT_NE(char5->GetIdentifier(), char6->GetIdentifier());
-}
-#endif // defined(OS_ANDROID) || defined(OS_WIN)
-
-#if defined(OS_ANDROID) || defined(OS_WIN)
-TEST_F(BluetoothGattCharacteristicTest, GetUUID) {
- InitWithFakeAdapter();
- StartLowEnergyDiscoverySession();
- BluetoothDevice* device = DiscoverLowEnergyDevice(3);
- device->CreateGattConnection(GetGattConnectionCallback(Call::EXPECTED),
- GetConnectErrorCallback(Call::NOT_EXPECTED));
- SimulateGattConnection(device);
- std::vector<std::string> services;
- services.push_back("00000000-0000-1000-8000-00805f9b34fb");
- SimulateGattServicesDiscovered(device, services);
- BluetoothGattService* service = device->GetGattServices()[0];
-
- // Create 3 characteristics. Two of them are duplicates.
- std::string uuid_str1("11111111-0000-1000-8000-00805f9b34fb");
- std::string uuid_str2("22222222-0000-1000-8000-00805f9b34fb");
- BluetoothUUID uuid1(uuid_str1);
- BluetoothUUID uuid2(uuid_str2);
- SimulateGattCharacteristic(service, uuid_str1, /* properties */ 0);
- SimulateGattCharacteristic(service, uuid_str2, /* properties */ 0);
- SimulateGattCharacteristic(service, uuid_str2, /* properties */ 0);
- BluetoothGattCharacteristic* char1 = service->GetCharacteristics()[0];
- BluetoothGattCharacteristic* char2 = service->GetCharacteristics()[1];
- BluetoothGattCharacteristic* char3 = service->GetCharacteristics()[2];
-
- // Swap as needed to have char1 point to the the characteristic with uuid1.
- if (char2->GetUUID() == uuid1) {
- std::swap(char1, char2);
- } else if (char3->GetUUID() == uuid1) {
- std::swap(char1, char3);
- }
-
- EXPECT_EQ(uuid1, char1->GetUUID());
- EXPECT_EQ(uuid2, char2->GetUUID());
- EXPECT_EQ(uuid2, char3->GetUUID());
-}
-#endif // defined(OS_ANDROID) || defined(OS_WIN)
-
-#if defined(OS_ANDROID) || defined(OS_WIN)
-TEST_F(BluetoothGattCharacteristicTest, GetProperties) {
- InitWithFakeAdapter();
- StartLowEnergyDiscoverySession();
- BluetoothDevice* device = DiscoverLowEnergyDevice(3);
- device->CreateGattConnection(GetGattConnectionCallback(Call::EXPECTED),
- GetConnectErrorCallback(Call::NOT_EXPECTED));
- SimulateGattConnection(device);
- std::vector<std::string> services;
- std::string uuid("00000000-0000-1000-8000-00805f9b34fb");
- services.push_back(uuid);
- SimulateGattServicesDiscovered(device, services);
- BluetoothGattService* service = device->GetGattServices()[0];
-
- // Create two characteristics with different properties:
- SimulateGattCharacteristic(service, uuid, /* properties */ 0);
- SimulateGattCharacteristic(service, uuid, /* properties */ 7);
-
- // Read the properties. Because ordering is unknown swap as necessary.
- int properties1 = service->GetCharacteristics()[0]->GetProperties();
- int properties2 = service->GetCharacteristics()[1]->GetProperties();
- if (properties2 == 0)
- std::swap(properties1, properties2);
- EXPECT_EQ(0, properties1);
- EXPECT_EQ(7, properties2);
-}
-#endif // defined(OS_ANDROID) || defined(OS_WIN)
-
-#if defined(OS_ANDROID) || defined(OS_WIN)
-// Tests GetService.
-TEST_F(BluetoothGattCharacteristicTest, GetService) {
- ASSERT_NO_FATAL_FAILURE(FakeCharacteristicBoilerplate());
-
- EXPECT_EQ(service_, characteristic1_->GetService());
- EXPECT_EQ(service_, characteristic2_->GetService());
-}
-#endif // defined(OS_ANDROID) || defined(OS_WIN)
-
-#if defined(OS_ANDROID) || defined(OS_WIN)
-// Tests ReadRemoteCharacteristic and GetValue with empty value buffer.
-TEST_F(BluetoothGattCharacteristicTest, ReadRemoteCharacteristic_Empty) {
- ASSERT_NO_FATAL_FAILURE(FakeCharacteristicBoilerplate(
- BluetoothGattCharacteristic::PROPERTY_READ));
-
- characteristic1_->ReadRemoteCharacteristic(
- GetReadValueCallback(Call::EXPECTED),
- GetGattErrorCallback(Call::NOT_EXPECTED));
- std::vector<uint8_t> empty_vector;
- SimulateGattCharacteristicRead(characteristic1_, empty_vector);
-
- // Duplicate read reported from OS shouldn't cause a problem:
- SimulateGattCharacteristicRead(characteristic1_, empty_vector);
-
- EXPECT_EQ(1, gatt_read_characteristic_attempts_);
- EXPECT_EQ(empty_vector, last_read_value_);
- EXPECT_EQ(empty_vector, characteristic1_->GetValue());
-}
-#endif // defined(OS_ANDROID) || defined(OS_WIN)
-
-#if defined(OS_ANDROID) || defined(OS_WIN)
-// Tests WriteRemoteCharacteristic with empty value buffer.
-TEST_F(BluetoothGattCharacteristicTest, WriteRemoteCharacteristic_Empty) {
- ASSERT_NO_FATAL_FAILURE(FakeCharacteristicBoilerplate(
- BluetoothGattCharacteristic::PROPERTY_WRITE));
-
- std::vector<uint8_t> empty_vector;
- characteristic1_->WriteRemoteCharacteristic(
- empty_vector, GetCallback(Call::EXPECTED),
- GetGattErrorCallback(Call::NOT_EXPECTED));
- SimulateGattCharacteristicWrite(characteristic1_);
- EXPECT_EQ(1, gatt_write_characteristic_attempts_);
-
- // Duplicate write reported from OS shouldn't cause a problem:
- SimulateGattCharacteristicWrite(characteristic1_);
-
- EXPECT_EQ(empty_vector, last_write_value_);
-}
-#endif // defined(OS_ANDROID) || defined(OS_WIN)
-
-#if defined(OS_ANDROID) || defined(OS_WIN)
-// Tests ReadRemoteCharacteristic completing after Chrome objects are deleted.
-TEST_F(BluetoothGattCharacteristicTest, ReadRemoteCharacteristic_AfterDeleted) {
- ASSERT_NO_FATAL_FAILURE(FakeCharacteristicBoilerplate(
- BluetoothGattCharacteristic::PROPERTY_READ));
-
- characteristic1_->ReadRemoteCharacteristic(
- GetReadValueCallback(Call::NOT_EXPECTED),
- GetGattErrorCallback(Call::NOT_EXPECTED));
-
- RememberCharacteristicForSubsequentAction(characteristic1_);
- DeleteDevice(device_); // TODO(576906) delete only the characteristic.
-
- std::vector<uint8_t> empty_vector;
- SimulateGattCharacteristicRead(/* use remembered characteristic */ nullptr,
- empty_vector);
- EXPECT_TRUE("Did not crash!");
-}
-#endif // defined(OS_ANDROID) || defined(OS_WIN)
-
-#if defined(OS_ANDROID) || defined(OS_WIN)
-// Tests WriteRemoteCharacteristic completing after Chrome objects are deleted.
-TEST_F(BluetoothGattCharacteristicTest,
- WriteRemoteCharacteristic_AfterDeleted) {
- ASSERT_NO_FATAL_FAILURE(FakeCharacteristicBoilerplate(
- BluetoothGattCharacteristic::PROPERTY_WRITE));
-
- std::vector<uint8_t> empty_vector;
- characteristic1_->WriteRemoteCharacteristic(
- empty_vector, GetCallback(Call::NOT_EXPECTED),
- GetGattErrorCallback(Call::NOT_EXPECTED));
-
- RememberCharacteristicForSubsequentAction(characteristic1_);
- DeleteDevice(device_); // TODO(576906) delete only the characteristic.
-
- SimulateGattCharacteristicWrite(/* use remembered characteristic */ nullptr);
- EXPECT_TRUE("Did not crash!");
-}
-#endif // defined(OS_ANDROID) || defined(OS_WIN)
-
-#if defined(OS_ANDROID) || defined(OS_WIN)
-// Tests ReadRemoteCharacteristic and GetValue with non-empty value buffer.
-TEST_F(BluetoothGattCharacteristicTest, ReadRemoteCharacteristic) {
- ASSERT_NO_FATAL_FAILURE(FakeCharacteristicBoilerplate(
- BluetoothGattCharacteristic::PROPERTY_READ));
-
- characteristic1_->ReadRemoteCharacteristic(
- GetReadValueCallback(Call::EXPECTED),
- GetGattErrorCallback(Call::NOT_EXPECTED));
-
- uint8_t values[] = {0, 1, 2, 3, 4, 0xf, 0xf0, 0xff};
- std::vector<uint8_t> test_vector(values, values + arraysize(values));
- SimulateGattCharacteristicRead(characteristic1_, test_vector);
-
- // Duplicate read reported from OS shouldn't cause a problem:
- std::vector<uint8_t> empty_vector;
- SimulateGattCharacteristicRead(characteristic1_, empty_vector);
-
- EXPECT_EQ(1, gatt_read_characteristic_attempts_);
- EXPECT_EQ(test_vector, last_read_value_);
- EXPECT_EQ(test_vector, characteristic1_->GetValue());
-}
-#endif // defined(OS_ANDROID) || defined(OS_WIN)
-
-#if defined(OS_ANDROID) || defined(OS_WIN)
-// Tests WriteRemoteCharacteristic with non-empty value buffer.
-TEST_F(BluetoothGattCharacteristicTest, WriteRemoteCharacteristic) {
- ASSERT_NO_FATAL_FAILURE(FakeCharacteristicBoilerplate(
- BluetoothGattCharacteristic::PROPERTY_WRITE));
-
- uint8_t values[] = {0, 1, 2, 3, 4, 0xf, 0xf0, 0xff};
- std::vector<uint8_t> test_vector(values, values + arraysize(values));
- characteristic1_->WriteRemoteCharacteristic(
- test_vector, GetCallback(Call::EXPECTED),
- GetGattErrorCallback(Call::NOT_EXPECTED));
-
- SimulateGattCharacteristicWrite(characteristic1_);
-
- EXPECT_EQ(1, gatt_write_characteristic_attempts_);
- EXPECT_EQ(test_vector, last_write_value_);
-}
-#endif // defined(OS_ANDROID) || defined(OS_WIN)
-
-#if defined(OS_ANDROID) || defined(OS_WIN)
-// Tests ReadRemoteCharacteristic and GetValue multiple times.
-TEST_F(BluetoothGattCharacteristicTest, ReadRemoteCharacteristic_Twice) {
- ASSERT_NO_FATAL_FAILURE(FakeCharacteristicBoilerplate(
- BluetoothGattCharacteristic::PROPERTY_READ));
-
- characteristic1_->ReadRemoteCharacteristic(
- GetReadValueCallback(Call::EXPECTED),
- GetGattErrorCallback(Call::NOT_EXPECTED));
-
- uint8_t values[] = {0, 1, 2, 3, 4, 0xf, 0xf0, 0xff};
- std::vector<uint8_t> test_vector(values, values + arraysize(values));
- SimulateGattCharacteristicRead(characteristic1_, test_vector);
- EXPECT_EQ(1, gatt_read_characteristic_attempts_);
- EXPECT_EQ(1, callback_count_);
- EXPECT_EQ(0, error_callback_count_);
- EXPECT_EQ(test_vector, last_read_value_);
- EXPECT_EQ(test_vector, characteristic1_->GetValue());
-
- // Read again, with different value:
- ResetEventCounts();
- characteristic1_->ReadRemoteCharacteristic(
- GetReadValueCallback(Call::EXPECTED),
- GetGattErrorCallback(Call::NOT_EXPECTED));
- std::vector<uint8_t> empty_vector;
- SimulateGattCharacteristicRead(characteristic1_, empty_vector);
- EXPECT_EQ(1, gatt_read_characteristic_attempts_);
- EXPECT_EQ(1, callback_count_);
- EXPECT_EQ(0, error_callback_count_);
- EXPECT_EQ(empty_vector, last_read_value_);
- EXPECT_EQ(empty_vector, characteristic1_->GetValue());
-}
-#endif // defined(OS_ANDROID) || defined(OS_WIN)
-
-#if defined(OS_ANDROID) || defined(OS_WIN)
-// Tests WriteRemoteCharacteristic multiple times.
-TEST_F(BluetoothGattCharacteristicTest, WriteRemoteCharacteristic_Twice) {
- ASSERT_NO_FATAL_FAILURE(FakeCharacteristicBoilerplate(
- BluetoothGattCharacteristic::PROPERTY_WRITE));
-
- uint8_t values[] = {0, 1, 2, 3, 4, 0xf, 0xf0, 0xff};
- std::vector<uint8_t> test_vector(values, values + arraysize(values));
- characteristic1_->WriteRemoteCharacteristic(
- test_vector, GetCallback(Call::EXPECTED),
- GetGattErrorCallback(Call::NOT_EXPECTED));
-
- SimulateGattCharacteristicWrite(characteristic1_);
- EXPECT_EQ(1, gatt_write_characteristic_attempts_);
- EXPECT_EQ(1, callback_count_);
- EXPECT_EQ(0, error_callback_count_);
- EXPECT_EQ(test_vector, last_write_value_);
-
- // Write again, with different value:
- ResetEventCounts();
- std::vector<uint8_t> empty_vector;
- characteristic1_->WriteRemoteCharacteristic(
- empty_vector, GetCallback(Call::EXPECTED),
- GetGattErrorCallback(Call::NOT_EXPECTED));
-
- SimulateGattCharacteristicWrite(characteristic1_);
- EXPECT_EQ(1, gatt_write_characteristic_attempts_);
- EXPECT_EQ(1, callback_count_);
- EXPECT_EQ(0, error_callback_count_);
- EXPECT_EQ(empty_vector, last_write_value_);
-}
-#endif // defined(OS_ANDROID) || defined(OS_WIN)
-
-#if defined(OS_ANDROID) || defined(OS_WIN)
-// Tests ReadRemoteCharacteristic on two characteristics.
-TEST_F(BluetoothGattCharacteristicTest,
- ReadRemoteCharacteristic_MultipleCharacteristics) {
- ASSERT_NO_FATAL_FAILURE(FakeCharacteristicBoilerplate(
- BluetoothGattCharacteristic::PROPERTY_READ));
-
- characteristic1_->ReadRemoteCharacteristic(
- GetReadValueCallback(Call::EXPECTED),
- GetGattErrorCallback(Call::NOT_EXPECTED));
- characteristic2_->ReadRemoteCharacteristic(
- GetReadValueCallback(Call::EXPECTED),
- GetGattErrorCallback(Call::NOT_EXPECTED));
- EXPECT_EQ(0, callback_count_);
- EXPECT_EQ(0, error_callback_count_);
-
- std::vector<uint8_t> test_vector1;
- test_vector1.push_back(111);
- SimulateGattCharacteristicRead(characteristic1_, test_vector1);
- EXPECT_EQ(test_vector1, last_read_value_);
-
- std::vector<uint8_t> test_vector2;
- test_vector2.push_back(222);
- SimulateGattCharacteristicRead(characteristic2_, test_vector2);
- EXPECT_EQ(test_vector2, last_read_value_);
-
- EXPECT_EQ(2, gatt_read_characteristic_attempts_);
- EXPECT_EQ(2, callback_count_);
- EXPECT_EQ(0, error_callback_count_);
- EXPECT_EQ(test_vector1, characteristic1_->GetValue());
- EXPECT_EQ(test_vector2, characteristic2_->GetValue());
-}
-#endif // defined(OS_ANDROID) || defined(OS_WIN)
-
-#if defined(OS_ANDROID) || defined(OS_WIN)
-// Tests WriteRemoteCharacteristic on two characteristics.
-TEST_F(BluetoothGattCharacteristicTest,
- WriteRemoteCharacteristic_MultipleCharacteristics) {
- ASSERT_NO_FATAL_FAILURE(FakeCharacteristicBoilerplate(
- BluetoothGattCharacteristic::PROPERTY_WRITE));
-
- std::vector<uint8_t> test_vector1;
- test_vector1.push_back(111);
- characteristic1_->WriteRemoteCharacteristic(
- test_vector1, GetCallback(Call::EXPECTED),
- GetGattErrorCallback(Call::NOT_EXPECTED));
-#ifdef OS_ANDROID
- EXPECT_EQ(test_vector1, last_write_value_);
-#endif
-
- std::vector<uint8_t> test_vector2;
- test_vector2.push_back(222);
- characteristic2_->WriteRemoteCharacteristic(
- test_vector2, GetCallback(Call::EXPECTED),
- GetGattErrorCallback(Call::NOT_EXPECTED));
-#ifdef OS_ANDROID
- EXPECT_EQ(test_vector2, last_write_value_);
-#endif
-
- EXPECT_EQ(0, callback_count_);
- EXPECT_EQ(0, error_callback_count_);
-
- SimulateGattCharacteristicWrite(characteristic1_);
-#ifndef OS_ANDROID
- EXPECT_EQ(test_vector1, last_write_value_);
-#endif
-
- SimulateGattCharacteristicWrite(characteristic2_);
-#ifndef OS_ANDROID
- EXPECT_EQ(test_vector2, last_write_value_);
-#endif
-
- EXPECT_EQ(2, gatt_write_characteristic_attempts_);
- EXPECT_EQ(2, callback_count_);
- EXPECT_EQ(0, error_callback_count_);
-
- // TODO(591740): Remove if define for OS_ANDROID in this test.
-}
-#endif // defined(OS_ANDROID) || defined(OS_WIN)
-
-#if defined(OS_ANDROID) || defined(OS_WIN)
-// Tests ReadRemoteCharacteristic asynchronous error.
-TEST_F(BluetoothGattCharacteristicTest, ReadError) {
- ASSERT_NO_FATAL_FAILURE(FakeCharacteristicBoilerplate(
- BluetoothGattCharacteristic::PROPERTY_READ));
-
- characteristic1_->ReadRemoteCharacteristic(
- GetReadValueCallback(Call::NOT_EXPECTED),
- GetGattErrorCallback(Call::EXPECTED));
- SimulateGattCharacteristicReadError(
- characteristic1_, BluetoothGattService::GATT_ERROR_INVALID_LENGTH);
- SimulateGattCharacteristicReadError(characteristic1_,
- BluetoothGattService::GATT_ERROR_FAILED);
- EXPECT_EQ(BluetoothGattService::GATT_ERROR_INVALID_LENGTH,
- last_gatt_error_code_);
-}
-#endif // defined(OS_ANDROID) || defined(OS_WIN)
-
-#if defined(OS_ANDROID) || defined(OS_WIN)
-// Tests WriteRemoteCharacteristic asynchronous error.
-TEST_F(BluetoothGattCharacteristicTest, WriteError) {
- ASSERT_NO_FATAL_FAILURE(FakeCharacteristicBoilerplate(
- BluetoothGattCharacteristic::PROPERTY_WRITE));
-
- std::vector<uint8_t> empty_vector;
- characteristic1_->WriteRemoteCharacteristic(
- empty_vector, GetCallback(Call::NOT_EXPECTED),
- GetGattErrorCallback(Call::EXPECTED));
- SimulateGattCharacteristicWriteError(
- characteristic1_, BluetoothGattService::GATT_ERROR_INVALID_LENGTH);
- SimulateGattCharacteristicWriteError(characteristic1_,
- BluetoothGattService::GATT_ERROR_FAILED);
-
- EXPECT_EQ(BluetoothGattService::GATT_ERROR_INVALID_LENGTH,
- last_gatt_error_code_);
-}
-#endif // defined(OS_ANDROID) || defined(OS_WIN)
-
-#if defined(OS_ANDROID)
-// Tests ReadRemoteCharacteristic synchronous error.
-TEST_F(BluetoothGattCharacteristicTest, ReadSynchronousError) {
- ASSERT_NO_FATAL_FAILURE(FakeCharacteristicBoilerplate());
-
- SimulateGattCharacteristicReadWillFailSynchronouslyOnce(characteristic1_);
- characteristic1_->ReadRemoteCharacteristic(
- GetReadValueCallback(Call::NOT_EXPECTED),
- GetGattErrorCallback(Call::EXPECTED));
- EXPECT_EQ(0, gatt_read_characteristic_attempts_);
- base::RunLoop().RunUntilIdle();
- EXPECT_EQ(0, callback_count_);
- EXPECT_EQ(1, error_callback_count_);
- EXPECT_EQ(BluetoothGattService::GATT_ERROR_FAILED, last_gatt_error_code_);
-
- // After failing once, can succeed:
- ResetEventCounts();
- characteristic1_->ReadRemoteCharacteristic(
- GetReadValueCallback(Call::EXPECTED),
- GetGattErrorCallback(Call::NOT_EXPECTED));
- EXPECT_EQ(1, gatt_read_characteristic_attempts_);
- std::vector<uint8_t> empty_vector;
- SimulateGattCharacteristicRead(characteristic1_, empty_vector);
- EXPECT_EQ(1, callback_count_);
- EXPECT_EQ(0, error_callback_count_);
-}
-#endif // defined(OS_ANDROID)
-
-#if defined(OS_ANDROID)
-// Tests WriteRemoteCharacteristic synchronous error.
-TEST_F(BluetoothGattCharacteristicTest, WriteSynchronousError) {
- ASSERT_NO_FATAL_FAILURE(FakeCharacteristicBoilerplate());
-
- SimulateGattCharacteristicWriteWillFailSynchronouslyOnce(characteristic1_);
- std::vector<uint8_t> empty_vector;
- characteristic1_->WriteRemoteCharacteristic(
- empty_vector, GetCallback(Call::NOT_EXPECTED),
- GetGattErrorCallback(Call::EXPECTED));
- EXPECT_EQ(0, gatt_write_characteristic_attempts_);
- base::RunLoop().RunUntilIdle();
- EXPECT_EQ(0, callback_count_);
- EXPECT_EQ(1, error_callback_count_);
- EXPECT_EQ(BluetoothGattService::GATT_ERROR_FAILED, last_gatt_error_code_);
-
- // After failing once, can succeed:
- ResetEventCounts();
- characteristic1_->WriteRemoteCharacteristic(
- empty_vector, GetCallback(Call::EXPECTED),
- GetGattErrorCallback(Call::NOT_EXPECTED));
- EXPECT_EQ(1, gatt_write_characteristic_attempts_);
- SimulateGattCharacteristicWrite(characteristic1_);
- EXPECT_EQ(1, callback_count_);
- EXPECT_EQ(0, error_callback_count_);
-}
-#endif // defined(OS_ANDROID)
-
-#if defined(OS_ANDROID) || defined(OS_WIN)
-// Tests ReadRemoteCharacteristic error with a pending read operation.
-TEST_F(BluetoothGattCharacteristicTest, ReadRemoteCharacteristic_ReadPending) {
- ASSERT_NO_FATAL_FAILURE(FakeCharacteristicBoilerplate(
- BluetoothGattCharacteristic::PROPERTY_READ));
-
- characteristic1_->ReadRemoteCharacteristic(
- GetReadValueCallback(Call::EXPECTED),
- GetGattErrorCallback(Call::NOT_EXPECTED));
- characteristic1_->ReadRemoteCharacteristic(
- GetReadValueCallback(Call::NOT_EXPECTED),
- GetGattErrorCallback(Call::EXPECTED));
-
- base::RunLoop().RunUntilIdle();
-
- EXPECT_EQ(0, callback_count_);
- EXPECT_EQ(1, error_callback_count_);
- EXPECT_EQ(BluetoothGattService::GATT_ERROR_IN_PROGRESS,
- last_gatt_error_code_);
-
- // Initial read should still succeed:
- ResetEventCounts();
- std::vector<uint8_t> empty_vector;
- SimulateGattCharacteristicRead(characteristic1_, empty_vector);
- EXPECT_EQ(1, callback_count_);
- EXPECT_EQ(0, error_callback_count_);
-}
-#endif // defined(OS_ANDROID) || defined(OS_WIN)
-
-#if defined(OS_ANDROID) || defined(OS_WIN)
-// Tests WriteRemoteCharacteristic error with a pending write operation.
-TEST_F(BluetoothGattCharacteristicTest,
- WriteRemoteCharacteristic_WritePending) {
- ASSERT_NO_FATAL_FAILURE(FakeCharacteristicBoilerplate(
- BluetoothGattCharacteristic::PROPERTY_WRITE));
-
- std::vector<uint8_t> empty_vector;
- characteristic1_->WriteRemoteCharacteristic(
- empty_vector, GetCallback(Call::EXPECTED),
- GetGattErrorCallback(Call::NOT_EXPECTED));
- characteristic1_->WriteRemoteCharacteristic(
- empty_vector, GetCallback(Call::NOT_EXPECTED),
- GetGattErrorCallback(Call::EXPECTED));
-
- base::RunLoop().RunUntilIdle();
-
- EXPECT_EQ(0, callback_count_);
- EXPECT_EQ(1, error_callback_count_);
- EXPECT_EQ(BluetoothGattService::GATT_ERROR_IN_PROGRESS,
- last_gatt_error_code_);
-
- // Initial write should still succeed:
- ResetEventCounts();
- SimulateGattCharacteristicWrite(characteristic1_);
- EXPECT_EQ(1, callback_count_);
- EXPECT_EQ(0, error_callback_count_);
-}
-#endif // defined(OS_ANDROID) || defined(OS_WIN)
-
-#if defined(OS_ANDROID) || defined(OS_WIN)
-// Tests ReadRemoteCharacteristic error with a pending write operation.
-TEST_F(BluetoothGattCharacteristicTest, ReadRemoteCharacteristic_WritePending) {
- ASSERT_NO_FATAL_FAILURE(FakeCharacteristicBoilerplate(
- BluetoothGattCharacteristic::PROPERTY_READ |
- BluetoothGattCharacteristic::PROPERTY_WRITE));
-
- std::vector<uint8_t> empty_vector;
- characteristic1_->WriteRemoteCharacteristic(
- empty_vector, GetCallback(Call::EXPECTED),
- GetGattErrorCallback(Call::NOT_EXPECTED));
- characteristic1_->ReadRemoteCharacteristic(
- GetReadValueCallback(Call::NOT_EXPECTED),
- GetGattErrorCallback(Call::EXPECTED));
-
- base::RunLoop().RunUntilIdle();
-
- EXPECT_EQ(0, callback_count_);
- EXPECT_EQ(1, error_callback_count_);
- EXPECT_EQ(BluetoothGattService::GATT_ERROR_IN_PROGRESS,
- last_gatt_error_code_);
-
- // Initial write should still succeed:
- ResetEventCounts();
- SimulateGattCharacteristicWrite(characteristic1_);
- EXPECT_EQ(1, callback_count_);
- EXPECT_EQ(0, error_callback_count_);
-}
-#endif // defined(OS_ANDROID) || defined(OS_WIN)
-
-#if defined(OS_ANDROID) || defined(OS_WIN)
-// Tests WriteRemoteCharacteristic error with a pending Read operation.
-TEST_F(BluetoothGattCharacteristicTest, WriteRemoteCharacteristic_ReadPending) {
- ASSERT_NO_FATAL_FAILURE(FakeCharacteristicBoilerplate(
- BluetoothGattCharacteristic::PROPERTY_READ |
- BluetoothGattCharacteristic::PROPERTY_WRITE));
-
- std::vector<uint8_t> empty_vector;
- characteristic1_->ReadRemoteCharacteristic(
- GetReadValueCallback(Call::EXPECTED),
- GetGattErrorCallback(Call::NOT_EXPECTED));
- characteristic1_->WriteRemoteCharacteristic(
- empty_vector, GetCallback(Call::NOT_EXPECTED),
- GetGattErrorCallback(Call::EXPECTED));
- base::RunLoop().RunUntilIdle();
-
- EXPECT_EQ(0, callback_count_);
- EXPECT_EQ(1, error_callback_count_);
- EXPECT_EQ(BluetoothGattService::GATT_ERROR_IN_PROGRESS,
- last_gatt_error_code_);
-
- // Initial read should still succeed:
- ResetEventCounts();
- SimulateGattCharacteristicRead(characteristic1_, empty_vector);
- EXPECT_EQ(1, callback_count_);
- EXPECT_EQ(0, error_callback_count_);
-}
-#endif // defined(OS_ANDROID) || defined(OS_WIN)
-
-#if defined(OS_ANDROID) || defined(OS_WIN)
-// StartNotifySession fails if characteristic doesn't have Notify or Indicate
-// property.
-TEST_F(BluetoothGattCharacteristicTest, StartNotifySession_NoNotifyOrIndicate) {
- ASSERT_NO_FATAL_FAILURE(StartNotifyBoilerplate(
- /* properties: NOTIFY */ 0x10,
- /* expected_config_descriptor_value: NOTIFY */ 1,
- StartNotifySetupError::CHARACTERISTIC_PROPERTIES));
-
- EXPECT_EQ(0, gatt_notify_characteristic_attempts_);
-
- // The expected error callback is asynchronous:
- EXPECT_EQ(0, error_callback_count_);
- base::RunLoop().RunUntilIdle();
- EXPECT_EQ(1, error_callback_count_);
- EXPECT_EQ(BluetoothGattService::GATT_ERROR_NOT_SUPPORTED,
- last_gatt_error_code_);
-}
-#endif // defined(OS_ANDROID) || defined(OS_WIN)
-
-#if defined(OS_ANDROID) || defined(OS_WIN)
-// StartNotifySession fails if the characteristic is missing the Client
-// Characteristic Configuration descriptor.
-TEST_F(BluetoothGattCharacteristicTest, StartNotifySession_NoConfigDescriptor) {
- ASSERT_NO_FATAL_FAILURE(StartNotifyBoilerplate(
- /* properties: NOTIFY */ 0x10,
- /* expected_config_descriptor_value: NOTIFY */ 1,
- StartNotifySetupError::CONFIG_DESCRIPTOR_MISSING));
-
- EXPECT_EQ(0, gatt_notify_characteristic_attempts_);
-
- // The expected error callback is asynchronous:
- EXPECT_EQ(0, error_callback_count_);
- base::RunLoop().RunUntilIdle();
- EXPECT_EQ(1, error_callback_count_);
- EXPECT_EQ(BluetoothGattService::GATT_ERROR_NOT_SUPPORTED,
- last_gatt_error_code_);
-}
-#endif // defined(OS_ANDROID) || defined(OS_WIN)
-
-#if defined(OS_ANDROID) || defined(OS_WIN)
-// StartNotifySession fails if the characteristic has multiple Client
-// Characteristic Configuration descriptors.
-TEST_F(BluetoothGattCharacteristicTest,
- StartNotifySession_MultipleConfigDescriptor) {
- ASSERT_NO_FATAL_FAILURE(StartNotifyBoilerplate(
- /* properties: NOTIFY */ 0x10,
- /* expected_config_descriptor_value: NOTIFY */ 1,
- StartNotifySetupError::CONFIG_DESCRIPTOR_DUPLICATE));
-
- EXPECT_EQ(0, gatt_notify_characteristic_attempts_);
-
- // The expected error callback is asynchronous:
- EXPECT_EQ(0, error_callback_count_);
- base::RunLoop().RunUntilIdle();
- EXPECT_EQ(1, error_callback_count_);
- EXPECT_EQ(BluetoothGattService::GATT_ERROR_FAILED, last_gatt_error_code_);
-}
-#endif // defined(OS_ANDROID) || defined(OS_WIN)
-
-#if defined(OS_ANDROID)
-// StartNotifySession fails synchronously when failing to set a characteristic
-// to enable notifications.
-// Android: This is mBluetoothGatt.setCharacteristicNotification failing.
-// Windows: Synchronous Test Not Applicable: OS calls are all made
-// asynchronously from BluetoothTaskManagerWin.
-TEST_F(BluetoothGattCharacteristicTest,
- StartNotifySession_FailToSetCharacteristicNotification) {
- ASSERT_NO_FATAL_FAILURE(StartNotifyBoilerplate(
- /* properties: NOTIFY */ 0x10,
- /* expected_config_descriptor_value: NOTIFY */ 1,
- StartNotifySetupError::SET_NOTIFY));
-
- // The expected error callback is asynchronous:
- EXPECT_EQ(0, error_callback_count_);
- base::RunLoop().RunUntilIdle();
- EXPECT_EQ(1, error_callback_count_);
-
- EXPECT_EQ(0, gatt_notify_characteristic_attempts_);
- ASSERT_EQ(0u, notify_sessions_.size());
-}
-#endif // defined(OS_ANDROID)
-
-#if defined(OS_ANDROID)
-// Tests StartNotifySession descriptor write synchronous failure.
-// Windows: Synchronous Test Not Applicable: OS calls are all made
-// asynchronously from BluetoothTaskManagerWin.
-TEST_F(BluetoothGattCharacteristicTest,
- StartNotifySession_WriteDescriptorSynchronousError) {
- ASSERT_NO_FATAL_FAILURE(StartNotifyBoilerplate(
- /* properties: NOTIFY */ 0x10,
- /* expected_config_descriptor_value: NOTIFY */ 1,
- StartNotifySetupError::WRITE_DESCRIPTOR));
-
- // The expected error callback is asynchronous:
- EXPECT_EQ(0, error_callback_count_);
- base::RunLoop().RunUntilIdle();
- EXPECT_EQ(1, error_callback_count_);
-
- EXPECT_EQ(1, gatt_notify_characteristic_attempts_);
- ASSERT_EQ(0u, notify_sessions_.size());
-}
-#endif // defined(OS_ANDROID)
-
-#if defined(OS_ANDROID) || defined(OS_WIN)
-// Tests StartNotifySession success on a characteristic enabling Notify.
-TEST_F(BluetoothGattCharacteristicTest, StartNotifySession) {
- ASSERT_NO_FATAL_FAILURE(StartNotifyBoilerplate(
- /* properties: NOTIFY */ 0x10,
- /* expected_config_descriptor_value: NOTIFY */ 1));
-}
-#endif // defined(OS_ANDROID) || defined(OS_WIN)
-
-#if defined(OS_ANDROID) || defined(OS_WIN)
-// Tests StartNotifySession success on a characteristic enabling Indicate.
-TEST_F(BluetoothGattCharacteristicTest, StartNotifySession_OnIndicate) {
- ASSERT_NO_FATAL_FAILURE(StartNotifyBoilerplate(
- /* properties: INDICATE */ 0x20,
- /* expected_config_descriptor_value: INDICATE */ 2));
-}
-#endif // defined(OS_ANDROID) || defined(OS_WIN)
-
-#if defined(OS_ANDROID) || defined(OS_WIN)
-// Tests StartNotifySession success on a characteristic enabling Notify &
-// Indicate.
-TEST_F(BluetoothGattCharacteristicTest,
- StartNotifySession_OnNotifyAndIndicate) {
- ASSERT_NO_FATAL_FAILURE(StartNotifyBoilerplate(
- /* properties: NOTIFY and INDICATE bits set */ 0x30,
- /* expected_config_descriptor_value: NOTIFY */ 1));
-}
-#endif // defined(OS_ANDROID) || defined(OS_WIN)
-
-#if defined(OS_ANDROID) || defined(OS_WIN)
-// Tests multiple StartNotifySession success.
-TEST_F(BluetoothGattCharacteristicTest, StartNotifySession_Multiple) {
- ASSERT_NO_FATAL_FAILURE(
- FakeCharacteristicBoilerplate(/* properties: NOTIFY */ 0x10));
- SimulateGattDescriptor(
- characteristic1_,
- BluetoothGattDescriptor::ClientCharacteristicConfigurationUuid()
- .canonical_value());
- ASSERT_EQ(1u, characteristic1_->GetDescriptors().size());
-
- characteristic1_->StartNotifySession(
- GetNotifyCallback(Call::EXPECTED),
- GetGattErrorCallback(Call::NOT_EXPECTED));
- characteristic1_->StartNotifySession(
- GetNotifyCallback(Call::EXPECTED),
- GetGattErrorCallback(Call::NOT_EXPECTED));
- EXPECT_EQ(0, callback_count_);
- SimulateGattNotifySessionStarted(characteristic1_);
- EXPECT_EQ(1, gatt_notify_characteristic_attempts_);
- EXPECT_EQ(2, callback_count_);
- EXPECT_EQ(0, error_callback_count_);
- ASSERT_EQ(2u, notify_sessions_.size());
- ASSERT_TRUE(notify_sessions_[0]);
- ASSERT_TRUE(notify_sessions_[1]);
- EXPECT_EQ(characteristic1_->GetIdentifier(),
- notify_sessions_[0]->GetCharacteristicIdentifier());
- EXPECT_EQ(characteristic1_->GetIdentifier(),
- notify_sessions_[1]->GetCharacteristicIdentifier());
- EXPECT_TRUE(notify_sessions_[0]->IsActive());
- EXPECT_TRUE(notify_sessions_[1]->IsActive());
-}
-#endif // defined(OS_ANDROID) || defined(OS_WIN)
-
-#if defined(OS_ANDROID)
-// Tests multiple StartNotifySessions pending and then an error.
-TEST_F(BluetoothGattCharacteristicTest, StartNotifySessionError_Multiple) {
- ASSERT_NO_FATAL_FAILURE(
- FakeCharacteristicBoilerplate(/* properties: NOTIFY */ 0x10));
- SimulateGattDescriptor(
- characteristic1_,
- BluetoothGattDescriptor::ClientCharacteristicConfigurationUuid()
- .canonical_value());
- ASSERT_EQ(1u, characteristic1_->GetDescriptors().size());
-
- characteristic1_->StartNotifySession(GetNotifyCallback(Call::NOT_EXPECTED),
- GetGattErrorCallback(Call::EXPECTED));
- characteristic1_->StartNotifySession(GetNotifyCallback(Call::NOT_EXPECTED),
- GetGattErrorCallback(Call::EXPECTED));
- EXPECT_EQ(1, gatt_notify_characteristic_attempts_);
- EXPECT_EQ(0, callback_count_);
- SimulateGattNotifySessionStartError(characteristic1_,
- BluetoothGattService::GATT_ERROR_FAILED);
- EXPECT_EQ(0, callback_count_);
- EXPECT_EQ(2, error_callback_count_);
- ASSERT_EQ(0u, notify_sessions_.size());
- EXPECT_EQ(BluetoothGattService::GATT_ERROR_FAILED, last_gatt_error_code_);
-}
-#endif // defined(OS_ANDROID)
-
-#if defined(OS_ANDROID)
-// Tests StartNotifySession completing after chrome objects are deleted.
-TEST_F(BluetoothGattCharacteristicTest, StartNotifySession_AfterDeleted) {
- ASSERT_NO_FATAL_FAILURE(
- FakeCharacteristicBoilerplate(/* properties: NOTIFY */ 0x10));
- SimulateGattDescriptor(
- characteristic1_,
- BluetoothGattDescriptor::ClientCharacteristicConfigurationUuid()
- .canonical_value());
- ASSERT_EQ(1u, characteristic1_->GetDescriptors().size());
-
- characteristic1_->StartNotifySession(GetNotifyCallback(Call::NOT_EXPECTED),
- GetGattErrorCallback(Call::EXPECTED));
- EXPECT_EQ(1, gatt_notify_characteristic_attempts_);
- EXPECT_EQ(0, callback_count_);
-
- RememberCharacteristicForSubsequentAction(characteristic1_);
- RememberCCCDescriptorForSubsequentAction(characteristic1_);
- DeleteDevice(device_); // TODO(576906) delete only the characteristic.
-
- SimulateGattNotifySessionStarted(/* use remembered characteristic */ nullptr);
- EXPECT_EQ(0, callback_count_);
- EXPECT_EQ(1, error_callback_count_);
- ASSERT_EQ(0u, notify_sessions_.size());
- EXPECT_EQ(BluetoothGattService::GATT_ERROR_FAILED, last_gatt_error_code_);
-}
-#endif // defined(OS_ANDROID)
-
-#if defined(OS_ANDROID) || defined(OS_WIN)
-// Tests Characteristic Value changes during a Notify Session.
-TEST_F(BluetoothGattCharacteristicTest, GattCharacteristicValueChanged) {
- ASSERT_NO_FATAL_FAILURE(StartNotifyBoilerplate(
- /* properties: NOTIFY */ 0x10,
- /* expected_config_descriptor_value: NOTIFY */ 1));
-
- TestBluetoothAdapterObserver observer(adapter_);
-
- std::vector<uint8_t> test_vector1, test_vector2;
- test_vector1.push_back(111);
- test_vector2.push_back(222);
-
- SimulateGattCharacteristicChanged(characteristic1_, test_vector1);
- EXPECT_EQ(1, observer.gatt_characteristic_value_changed_count());
- EXPECT_EQ(test_vector1, characteristic1_->GetValue());
-
- SimulateGattCharacteristicChanged(characteristic1_, test_vector2);
- EXPECT_EQ(2, observer.gatt_characteristic_value_changed_count());
- EXPECT_EQ(test_vector2, characteristic1_->GetValue());
-}
-#endif // defined(OS_ANDROID) || defined(OS_WIN)
-
-#if defined(OS_ANDROID) || defined(OS_WIN)
-// Tests Characteristic Value changing after a Notify Session and objects being
-// destroyed.
-TEST_F(BluetoothGattCharacteristicTest,
- GattCharacteristicValueChanged_AfterDeleted) {
- ASSERT_NO_FATAL_FAILURE(StartNotifyBoilerplate(
- /* properties: NOTIFY */ 0x10,
- /* expected_config_descriptor_value: NOTIFY */ 1));
- TestBluetoothAdapterObserver observer(adapter_);
-
- RememberCharacteristicForSubsequentAction(characteristic1_);
- DeleteDevice(device_); // TODO(576906) delete only the characteristic.
-
- std::vector<uint8_t> empty_vector;
- SimulateGattCharacteristicChanged(/* use remembered characteristic */ nullptr,
- empty_vector);
- EXPECT_TRUE("Did not crash!");
- EXPECT_EQ(0, observer.gatt_characteristic_value_changed_count());
-}
-#endif // defined(OS_ANDROID) || defined(OS_WIN)
-
-#if defined(OS_ANDROID) || defined(OS_WIN)
-TEST_F(BluetoothGattCharacteristicTest, GetDescriptors_FindNone) {
- ASSERT_NO_FATAL_FAILURE(FakeCharacteristicBoilerplate());
-
- EXPECT_EQ(0u, characteristic1_->GetDescriptors().size());
-}
-#endif // defined(OS_ANDROID) || defined(OS_WIN)
-
-#if defined(OS_ANDROID) || defined(OS_WIN)
-TEST_F(BluetoothGattCharacteristicTest, GetDescriptors_and_GetDescriptor) {
- ASSERT_NO_FATAL_FAILURE(FakeCharacteristicBoilerplate());
-
- // Add several Descriptors:
- BluetoothUUID uuid1("11111111-0000-1000-8000-00805f9b34fb");
- BluetoothUUID uuid2("22222222-0000-1000-8000-00805f9b34fb");
- BluetoothUUID uuid3("33333333-0000-1000-8000-00805f9b34fb");
- BluetoothUUID uuid4("44444444-0000-1000-8000-00805f9b34fb");
- SimulateGattDescriptor(characteristic1_, uuid1.canonical_value());
- SimulateGattDescriptor(characteristic1_, uuid2.canonical_value());
- SimulateGattDescriptor(characteristic2_, uuid3.canonical_value());
- SimulateGattDescriptor(characteristic2_, uuid4.canonical_value());
-
- // Verify that GetDescriptor can retrieve descriptors again by ID,
- // and that the same Descriptor is returned when searched by ID.
- EXPECT_EQ(2u, characteristic1_->GetDescriptors().size());
- EXPECT_EQ(2u, characteristic2_->GetDescriptors().size());
- std::string c1_id1 = characteristic1_->GetDescriptors()[0]->GetIdentifier();
- std::string c1_id2 = characteristic1_->GetDescriptors()[1]->GetIdentifier();
- std::string c2_id1 = characteristic2_->GetDescriptors()[0]->GetIdentifier();
- std::string c2_id2 = characteristic2_->GetDescriptors()[1]->GetIdentifier();
- BluetoothUUID c1_uuid1 = characteristic1_->GetDescriptors()[0]->GetUUID();
- BluetoothUUID c1_uuid2 = characteristic1_->GetDescriptors()[1]->GetUUID();
- BluetoothUUID c2_uuid1 = characteristic2_->GetDescriptors()[0]->GetUUID();
- BluetoothUUID c2_uuid2 = characteristic2_->GetDescriptors()[1]->GetUUID();
- EXPECT_EQ(c1_uuid1, characteristic1_->GetDescriptor(c1_id1)->GetUUID());
- EXPECT_EQ(c1_uuid2, characteristic1_->GetDescriptor(c1_id2)->GetUUID());
- EXPECT_EQ(c2_uuid1, characteristic2_->GetDescriptor(c2_id1)->GetUUID());
- EXPECT_EQ(c2_uuid2, characteristic2_->GetDescriptor(c2_id2)->GetUUID());
-
- // GetDescriptors & GetDescriptor return the same object for the same ID:
- EXPECT_EQ(characteristic1_->GetDescriptors()[0],
- characteristic1_->GetDescriptor(c1_id1));
- EXPECT_EQ(characteristic1_->GetDescriptor(c1_id1),
- characteristic1_->GetDescriptor(c1_id1));
-
- // Characteristic 1 has descriptor uuids 1 and 2 (we don't know the order).
- EXPECT_TRUE(c1_uuid1 == uuid1 || c1_uuid2 == uuid1);
- EXPECT_TRUE(c1_uuid1 == uuid2 || c1_uuid2 == uuid2);
- // ... but not uuid 3
- EXPECT_FALSE(c1_uuid1 == uuid3 || c1_uuid2 == uuid3);
-}
-#endif // defined(OS_ANDROID) || defined(OS_WIN)
-
-#if defined(OS_ANDROID) || defined(OS_WIN)
-TEST_F(BluetoothGattCharacteristicTest, GetDescriptorsByUUID) {
- ASSERT_NO_FATAL_FAILURE(FakeCharacteristicBoilerplate());
-
- // Add several Descriptors:
- BluetoothUUID id1("11111111-0000-1000-8000-00805f9b34fb");
- BluetoothUUID id2("22222222-0000-1000-8000-00805f9b34fb");
- BluetoothUUID id3("33333333-0000-1000-8000-00805f9b34fb");
- SimulateGattDescriptor(characteristic1_, id1.canonical_value());
- SimulateGattDescriptor(characteristic1_, id2.canonical_value());
- SimulateGattDescriptor(characteristic2_, id3.canonical_value());
- SimulateGattDescriptor(characteristic2_, id3.canonical_value());
-
- EXPECT_NE(characteristic2_->GetDescriptorsByUUID(id3).at(0)->GetIdentifier(),
- characteristic2_->GetDescriptorsByUUID(id3).at(1)->GetIdentifier());
-
- EXPECT_EQ(id1, characteristic1_->GetDescriptorsByUUID(id1).at(0)->GetUUID());
- EXPECT_EQ(id2, characteristic1_->GetDescriptorsByUUID(id2).at(0)->GetUUID());
- EXPECT_EQ(id3, characteristic2_->GetDescriptorsByUUID(id3).at(0)->GetUUID());
- EXPECT_EQ(id3, characteristic2_->GetDescriptorsByUUID(id3).at(1)->GetUUID());
- EXPECT_EQ(1u, characteristic1_->GetDescriptorsByUUID(id1).size());
- EXPECT_EQ(1u, characteristic1_->GetDescriptorsByUUID(id2).size());
- EXPECT_EQ(2u, characteristic2_->GetDescriptorsByUUID(id3).size());
-
- EXPECT_EQ(0u, characteristic2_->GetDescriptorsByUUID(id1).size());
- EXPECT_EQ(0u, characteristic2_->GetDescriptorsByUUID(id2).size());
- EXPECT_EQ(0u, characteristic1_->GetDescriptorsByUUID(id3).size());
-}
-#endif // defined(OS_ANDROID) || defined(OS_WIN)
-
-} // namespace device
« no previous file with comments | « device/bluetooth/bluetooth_gatt_characteristic_bluez.cc ('k') | device/bluetooth/bluetooth_gatt_connection_bluez.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698