 Chromium Code Reviews
 Chromium Code Reviews Issue 1334763002:
  bluetooth: Subscribe to notifications  (Closed) 
  Base URL: https://chromium.googlesource.com/chromium/src.git@bluetooth-origin
    
  
    Issue 1334763002:
  bluetooth: Subscribe to notifications  (Closed) 
  Base URL: https://chromium.googlesource.com/chromium/src.git@bluetooth-origin| Index: third_party/WebKit/LayoutTests/bluetooth/notifications.html | 
| diff --git a/third_party/WebKit/LayoutTests/bluetooth/notifications.html b/third_party/WebKit/LayoutTests/bluetooth/notifications.html | 
| new file mode 100644 | 
| index 0000000000000000000000000000000000000000..dc9052533e9684bedf81eeee24f62f654f102cd4 | 
| --- /dev/null | 
| +++ b/third_party/WebKit/LayoutTests/bluetooth/notifications.html | 
| @@ -0,0 +1,126 @@ | 
| +<!DOCTYPE html> | 
| +<script src="../resources/testharness.js"></script> | 
| +<script src="../resources/testharnessreport.js"></script> | 
| +<script src="resources/bluetooth-helpers.js"></script> | 
| +<script> | 
| +'use strict'; | 
| +test(t => { assert_true(window.testRunner instanceof Object); t.done(); }, | 
| + 'window.testRunner is required for the following tests.'); | 
| + | 
| +promise_test(() => { | 
| + testRunner.setBluetoothMockDataSet('HeartRateAdapter'); | 
| + return requestDeviceWithKeyDown({filters: [{services: ['heart_rate']}]}) | 
| + .then(device => device.connectGATT()) | 
| + .then(gattServer => gattServer.getPrimaryService('heart_rate')) | 
| + .then(service => service.getCharacteristic('heart_rate_measurement')) | 
| + .then(characteristic => { | 
| + return characteristic.startNotifications() | 
| + .then(() => characteristic.stopNotifications()); | 
| + }); | 
| +}, 'Single start notifications succeeds.'); | 
| + | 
| + | 
| +promise_test(() => { | 
| + testRunner.setBluetoothMockDataSet('HeartRateAdapter'); | 
| + return requestDeviceWithKeyDown({filters: [{services: ['heart_rate']}]}) | 
| + .then(device => device.connectGATT()) | 
| + .then(gattServer => gattServer.getPrimaryService('heart_rate')) | 
| + .then(service => service.getCharacteristic('heart_rate_measurement')) | 
| + .then(characteristic => { | 
| + return characteristic.startNotifications().then(() => { | 
| + return characteristic.startNotifications() | 
| + .then(() => characteristic.stopNotifications()); | 
| + }); | 
| + }); | 
| +}, 'Start notifications after succesfully starting before.'); | 
| + | 
| +promise_test(() => { | 
| + testRunner.setBluetoothMockDataSet('HeartRateAdapter'); | 
| + return requestDeviceWithKeyDown({filters: [{services: ['heart_rate']}]}) | 
| + .then(device => device.connectGATT()) | 
| + .then(gattServer => gattServer.getPrimaryService('heart_rate')) | 
| + .then(service => service.getCharacteristic('heart_rate_measurement')) | 
| + .then(characteristic => { | 
| + return characteristic.startNotifications() | 
| + .then(() => characteristic.stopNotifications()) | 
| + .then(() => characteristic.startNotifications()) | 
| + .then(() => characteristic.stopNotifications()); | 
| + }); | 
| +}, 'Start -> stop -> start -> stop.'); | 
| + | 
| +promise_test(() => { | 
| + testRunner.setBluetoothMockDataSet('HeartRateAdapter'); | 
| + return requestDeviceWithKeyDown({filters: [{services: ['heart_rate']}]}) | 
| + .then(device => device.connectGATT()) | 
| + .then(gattServer => gattServer.getPrimaryService('heart_rate')) | 
| + .then(service => service.getCharacteristic('heart_rate_measurement')) | 
| + .then(characteristic => { | 
| + return Promise.all([characteristic.startNotifications(), | 
| + characteristic.startNotifications(), | 
| + characteristic.startNotifications()]) | 
| + .then(() => characteristic.stopNotifications()); | 
| + }); | 
| +}, 'Multiple starts in a row.'); | 
| + | 
| +promise_test(() => { | 
| + testRunner.setBluetoothMockDataSet('HeartRateAdapter'); | 
| + return requestDeviceWithKeyDown({filters: [{services: ['heart_rate']}]}) | 
| + .then(device => device.connectGATT()) | 
| + .then(gattServer => gattServer.getPrimaryService('heart_rate')) | 
| + .then(service => service.getCharacteristic('heart_rate_measurement')) | 
| + .then(characteristic => { | 
| + return Promise.all([characteristic.startNotifications(), | 
| + characteristic.stopNotifications()]); | 
| + }); | 
| +}, "Parallel start and stop."); | 
| + | 
| +promise_test(() => { | 
| + testRunner.setBluetoothMockDataSet('HeartRateAdapter'); | 
| + return requestDeviceWithKeyDown({filters: [{services: ['heart_rate']}]}) | 
| + .then(device => device.connectGATT()) | 
| + .then(gattServer => gattServer.getPrimaryService('heart_rate')) | 
| + .then(service => service.getCharacteristic('heart_rate_measurement')) | 
| + .then(characteristic => { | 
| + return characteristic.startNotifications().then(() => { | 
| + return Promise.all([characteristic.stopNotifications(), | 
| + characteristic.stopNotifications()]); | 
| + }); | 
| + }); | 
| +}, "Concurrent stop requests."); | 
| + | 
| +promise_test(() => { | 
| + testRunner.setBluetoothMockDataSet('HeartRateAdapter'); | 
| + return requestDeviceWithKeyDown({filters: [{services: ['heart_rate']}]}) | 
| + .then(device => device.connectGATT()) | 
| + .then(gattServer => gattServer.getPrimaryService('heart_rate')) | 
| + .then(service => service.getCharacteristic('heart_rate_measurement')) | 
| + .then(characteristic => { | 
| + return characteristic.startNotifications() | 
| + .then(() => characteristic.stopNotifications()) | 
| + .then(() => characteristic.stopNotifications()); | 
| + }); | 
| +}, "Stopping twice."); | 
| + | 
| +promise_test(() => { | 
| + testRunner.setBluetoothMockDataSet('HeartRateAdapter'); | 
| + return requestDeviceWithKeyDown({filters: [{services: ['heart_rate']}]}) | 
| + .then(device => device.connectGATT()) | 
| + .then(gattServer => gattServer.getPrimaryService('heart_rate')) | 
| + .then(service => service.getCharacteristic('heart_rate_measurement')) | 
| + .then(characteristic => { | 
| + return characteristic.startNotifications().then(() => { | 
| + return Promise.all([characteristic.stopNotifications(), | 
| + characteristic.startNotifications()]); | 
| + }).then(() => characteristic.stopNotifications()); | 
| + }); | 
| +}, "Start request before stop request resolves"); | 
| + | 
| +promise_test(() => { | 
| + testRunner.setBluetoothMockDataSet('HeartRateAdapter'); | 
| + return requestDeviceWithKeyDown({filters: [{services: ['heart_rate']}]}) | 
| + .then(device => device.connectGATT()) | 
| + .then(gattServer => gattServer.getPrimaryService('heart_rate')) | 
| + .then(service => service.getCharacteristic('heart_rate_measurement')) | 
| + .then(characteristic => characteristic.stopNotifications()); | 
| +}, "Stop without starting."); | 
| +</script> | 
| 
scheib
2015/10/01 22:05:23
No tests here for object deletion. Can it be accom
 
ortuno
2015/10/03 04:03:04
I checked battery, geolocation, midi, web sockets,
 
scheib
2015/10/04 01:39:05
I'd feel better if we have an issue for this and a
 
ortuno
2015/10/06 02:38:43
Done. Added GC tests.
 
scheib
2015/10/06 05:35:24
YAY. So... I'm not 100% on when we think the chara
 
ortuno
2015/10/06 17:14:42
Added another test for a stop request pending. htt
 |