diff options
author | ortuno <ortuno@chromium.org> | 2015-11-02 01:37:13 -0800 |
---|---|---|
committer | Commit bot <commit-bot@chromium.org> | 2015-11-02 09:37:58 +0000 |
commit | 7bff37cc70e0e4fe323e0ec1917fa71b1f37674e (patch) | |
tree | d34e014918282f4f9d25bc260057efcc9a417338 /device/bluetooth | |
parent | c9e3e17bebc6b9950ac1d2d74ec506cb1764eddf (diff) | |
download | chromium_src-7bff37cc70e0e4fe323e0ec1917fa71b1f37674e.zip chromium_src-7bff37cc70e0e4fe323e0ec1917fa71b1f37674e.tar.gz chromium_src-7bff37cc70e0e4fe323e0ec1917fa71b1f37674e.tar.bz2 |
bluetooth: Wire up GattServices property from device
And add GattServicesDiscovered to BluetoothAdapter::Observer.
GattServicesDiscovered gets called when all GATT Services of a devices have
been discovered.
BUG=484504
Review URL: https://codereview.chromium.org/1413903009
Cr-Commit-Position: refs/heads/master@{#357325}
Diffstat (limited to 'device/bluetooth')
-rw-r--r-- | device/bluetooth/bluetooth_adapter.h | 5 | ||||
-rw-r--r-- | device/bluetooth/bluetooth_adapter_chromeos.cc | 12 | ||||
-rw-r--r-- | device/bluetooth/bluetooth_adapter_chromeos.h | 1 | ||||
-rw-r--r-- | device/bluetooth/bluetooth_gatt_chromeos_unittest.cc | 31 | ||||
-rw-r--r-- | device/bluetooth/test/test_bluetooth_adapter_observer.cc | 13 | ||||
-rw-r--r-- | device/bluetooth/test/test_bluetooth_adapter_observer.h | 6 |
6 files changed, 68 insertions, 0 deletions
diff --git a/device/bluetooth/bluetooth_adapter.h b/device/bluetooth/bluetooth_adapter.h index 0dc2b8f..63969fc 100644 --- a/device/bluetooth/bluetooth_adapter.h +++ b/device/bluetooth/bluetooth_adapter.h @@ -109,6 +109,11 @@ class DEVICE_BLUETOOTH_EXPORT BluetoothAdapter BluetoothDevice* device, BluetoothGattService* service) {} + // Called when all the GATT Services in |device| have been discovered + // and GattServiceAdded has been called for each service. + virtual void GattServicesDiscovered(BluetoothAdapter* adapter, + BluetoothDevice* device) {} + // Called when all characteristic and descriptor discovery procedures are // known to be completed for the GATT service |service|. This method will be // called after the initial discovery of a GATT service and will usually be diff --git a/device/bluetooth/bluetooth_adapter_chromeos.cc b/device/bluetooth/bluetooth_adapter_chromeos.cc index 851815f..70ec7fb 100644 --- a/device/bluetooth/bluetooth_adapter_chromeos.cc +++ b/device/bluetooth/bluetooth_adapter_chromeos.cc @@ -474,6 +474,10 @@ void BluetoothAdapterChromeOS::DevicePropertyChanged( NotifyDeviceChanged(device_chromeos); } + if (property_name == properties->gatt_services.name()) { + NotifyGattServicesDiscovered(device_chromeos); + } + // When a device becomes paired, mark it as trusted so that the user does // not need to approve every incoming connection if (property_name == properties->paired.name() && @@ -932,6 +936,14 @@ void BluetoothAdapterChromeOS::NotifyGattServiceChanged( GattServiceChanged(this, service)); } +void BluetoothAdapterChromeOS::NotifyGattServicesDiscovered( + BluetoothDeviceChromeOS* device) { + DCHECK(device->adapter_ == this); + + FOR_EACH_OBSERVER(BluetoothAdapter::Observer, observers_, + GattServicesDiscovered(this, device)); +} + void BluetoothAdapterChromeOS::NotifyGattDiscoveryComplete( BluetoothRemoteGattServiceChromeOS* service) { DCHECK_EQ(service->GetAdapter(), this); diff --git a/device/bluetooth/bluetooth_adapter_chromeos.h b/device/bluetooth/bluetooth_adapter_chromeos.h index 7570780..46c634f 100644 --- a/device/bluetooth/bluetooth_adapter_chromeos.h +++ b/device/bluetooth/bluetooth_adapter_chromeos.h @@ -128,6 +128,7 @@ class DEVICE_BLUETOOTH_EXPORT BluetoothAdapterChromeOS void NotifyGattServiceAdded(BluetoothRemoteGattServiceChromeOS* service); void NotifyGattServiceRemoved(BluetoothRemoteGattServiceChromeOS* service); void NotifyGattServiceChanged(BluetoothRemoteGattServiceChromeOS* service); + void NotifyGattServicesDiscovered(BluetoothDeviceChromeOS* device); void NotifyGattDiscoveryComplete(BluetoothRemoteGattServiceChromeOS* service); void NotifyGattCharacteristicAdded( BluetoothRemoteGattCharacteristicChromeOS* characteristic); diff --git a/device/bluetooth/bluetooth_gatt_chromeos_unittest.cc b/device/bluetooth/bluetooth_gatt_chromeos_unittest.cc index d93dcc2..5cf067c 100644 --- a/device/bluetooth/bluetooth_gatt_chromeos_unittest.cc +++ b/device/bluetooth/bluetooth_gatt_chromeos_unittest.cc @@ -352,6 +352,37 @@ TEST_F(BluetoothGattChromeOSTest, GattServiceAddedAndRemoved) { adapter_->GetDevice(FakeBluetoothDeviceClient::kLowEnergyAddress)); } +TEST_F(BluetoothGattChromeOSTest, ServicesDiscovered) { + // Create a fake LE device. We store the device pointer here because this is a + // test. It's unsafe to do this in production as the device might get deleted. + fake_bluetooth_device_client_->CreateDevice( + dbus::ObjectPath(FakeBluetoothAdapterClient::kAdapterPath), + dbus::ObjectPath(FakeBluetoothDeviceClient::kLowEnergyPath)); + BluetoothDevice* device = + adapter_->GetDevice(FakeBluetoothDeviceClient::kLowEnergyAddress); + FakeBluetoothDeviceClient::Properties* properties = + fake_bluetooth_device_client_->GetProperties( + dbus::ObjectPath(FakeBluetoothDeviceClient::kLowEnergyPath)); + + ASSERT_TRUE(device); + + TestBluetoothAdapterObserver observer(adapter_); + + EXPECT_EQ(0, observer.gatt_services_discovered_count()); + + // Expose the fake Heart Rate Service. + fake_bluetooth_gatt_service_client_->ExposeHeartRateService( + dbus::ObjectPath(FakeBluetoothDeviceClient::kLowEnergyPath)); + // Notify that all services have been discovered. + properties->gatt_services.ReplaceValue( + fake_bluetooth_gatt_service_client_->GetServices()); + + EXPECT_EQ(1, observer.gatt_services_discovered_count()); + EXPECT_EQ(device, observer.last_device()); + EXPECT_EQ(FakeBluetoothDeviceClient::kLowEnergyAddress, + observer.last_device_address()); +} + TEST_F(BluetoothGattChromeOSTest, GattCharacteristicAddedAndRemoved) { fake_bluetooth_device_client_->CreateDevice( dbus::ObjectPath(FakeBluetoothAdapterClient::kAdapterPath), diff --git a/device/bluetooth/test/test_bluetooth_adapter_observer.cc b/device/bluetooth/test/test_bluetooth_adapter_observer.cc index 811ffb6..5d20565 100644 --- a/device/bluetooth/test/test_bluetooth_adapter_observer.cc +++ b/device/bluetooth/test/test_bluetooth_adapter_observer.cc @@ -39,6 +39,7 @@ void TestBluetoothAdapterObserver::Reset() { last_device_address_.clear(); gatt_service_added_count_ = 0; gatt_service_removed_count_ = 0; + gatt_services_discovered_count_ = 0; gatt_service_changed_count_ = 0; gatt_discovery_complete_count_ = 0; gatt_characteristic_added_count_ = 0; @@ -175,6 +176,18 @@ void TestBluetoothAdapterObserver::GattServiceRemoved( QuitMessageLoop(); } +void TestBluetoothAdapterObserver::GattServicesDiscovered( + BluetoothAdapter* adapter, + BluetoothDevice* device) { + ASSERT_EQ(adapter_.get(), adapter); + + ++gatt_services_discovered_count_; + last_device_ = device; + last_device_address_ = device->GetAddress(); + + QuitMessageLoop(); +} + void TestBluetoothAdapterObserver::GattDiscoveryCompleteForService( BluetoothAdapter* adapter, BluetoothGattService* service) { diff --git a/device/bluetooth/test/test_bluetooth_adapter_observer.h b/device/bluetooth/test/test_bluetooth_adapter_observer.h index 7ec06889..60b3088 100644 --- a/device/bluetooth/test/test_bluetooth_adapter_observer.h +++ b/device/bluetooth/test/test_bluetooth_adapter_observer.h @@ -40,6 +40,8 @@ class TestBluetoothAdapterObserver : public BluetoothAdapter::Observer { void GattServiceRemoved(BluetoothAdapter* adapter, BluetoothDevice* device, BluetoothGattService* service) override; + void GattServicesDiscovered(BluetoothAdapter* adapter, + BluetoothDevice* device) override; void GattDiscoveryCompleteForService(BluetoothAdapter* adapter, BluetoothGattService* service) override; void GattServiceChanged(BluetoothAdapter* adapter, @@ -82,6 +84,9 @@ class TestBluetoothAdapterObserver : public BluetoothAdapter::Observer { // GATT related: int gatt_service_added_count() { return gatt_service_added_count_; } int gatt_service_removed_count() { return gatt_service_removed_count_; } + int gatt_services_discovered_count() { + return gatt_services_discovered_count_; + } int gatt_service_changed_count() { return gatt_service_changed_count_; } int gatt_discovery_complete_count() { return gatt_discovery_complete_count_; } int gatt_characteristic_added_count() { @@ -144,6 +149,7 @@ class TestBluetoothAdapterObserver : public BluetoothAdapter::Observer { // GATT related: int gatt_service_added_count_; int gatt_service_removed_count_; + int gatt_services_discovered_count_; int gatt_service_changed_count_; int gatt_discovery_complete_count_; int gatt_characteristic_added_count_; |