OLD | NEW |
1 <!DOCTYPE html> | 1 <!DOCTYPE html> |
2 <script src="../../resources/testharness.js"></script> | 2 <script src="../../resources/testharness.js"></script> |
3 <script src="../../resources/testharnessreport.js"></script> | 3 <script src="../../resources/testharnessreport.js"></script> |
4 <script src="../../resources/bluetooth/bluetooth-helpers.js"></script> | 4 <script src="../../resources/bluetooth/bluetooth-helpers.js"></script> |
5 <script> | 5 <script> |
6 'use strict'; | 6 'use strict'; |
7 promise_test(t => { | 7 promise_test(t => { |
8 return setBluetoothFakeAdapter('DisconnectingHeartRateAdapter') | 8 return setBluetoothFakeAdapter('DisconnectingHeartRateAdapter') |
9 .then(() => requestDeviceWithKeyDown({ | 9 .then(() => requestDeviceWithKeyDown({ |
10 filters: [{services: ['heart_rate']}], | 10 filters: [{services: ['heart_rate']}], |
11 optionalServices: [request_disconnection_service_uuid] | 11 optionalServices: [request_disconnection_service_uuid] |
12 })) | 12 })) |
13 .then(device => { | 13 .then(device => { |
14 return device.gatt.connect() | 14 return device.gatt.connect() |
15 .then(gattServer => gattServer.getPrimaryService(request_disconnection_s
ervice_uuid)) | 15 .then(gattServer => get_request_disconnection(gattServer)) |
16 .then(service => service.getCharacteristic(request_disconnection_charact
eristic_uuid)) | |
17 .then(requestDisconnection => { | 16 .then(requestDisconnection => { |
18 // 1. Attach a listener that tries to reconnect. | 17 // 1. Attach a listener that tries to reconnect. |
19 let reconnection = new Promise(resolve => { | 18 let reconnection = new Promise(resolve => { |
20 let wrapper = function(event) { | 19 let wrapper = function(event) { |
21 device.removeEventListener('gattserverdisconnected', wrapper); | 20 device.removeEventListener('gattserverdisconnected', wrapper); |
22 device.gatt.connect().then(resolve); | 21 device.gatt.connect().then(resolve); |
23 }; | 22 }; |
24 device.addEventListener('gattserverdisconnected', wrapper); | 23 device.addEventListener('gattserverdisconnected', wrapper); |
25 }); | 24 }); |
26 // 2. Disconnect. | 25 // 2. Disconnect. |
27 requestDisconnection.writeValue(new Uint8Array([0])); | 26 requestDisconnection(); |
28 return reconnection.then(() => { | 27 return reconnection.then(() => { |
29 // Resolves after disconnected event. | 28 // Resolves after disconnected event. |
30 let disconnected = eventPromise(device, 'gattserverdisconnected'); | 29 let disconnected = eventPromise(device, 'gattserverdisconnected'); |
31 // 3. Disconnect after reconnecting. | 30 // 3. Disconnect after reconnecting. |
32 requestDisconnection.writeValue(new Uint8Array([0])); | 31 requestDisconnection(); |
33 return disconnected; | 32 return disconnected; |
34 }); | 33 }); |
35 }); | 34 }); |
36 }); | 35 }); |
37 }, 'A device that reconnects during the gattserverdisconnected event ' + | 36 }, 'A device that reconnects during the gattserverdisconnected event ' + |
38 'should still receive gattserverdisconnected events after re-connection.'); | 37 'should still receive gattserverdisconnected events after re-connection.'); |
39 </script> | 38 </script> |
OLD | NEW |