| OLD | NEW | 
|---|
| 1 <!-- Generated by //third_party/WebKit/LayoutTests/bluetooth/generate.py --> | 1 <!-- Generated by //third_party/WebKit/LayoutTests/bluetooth/generate.py --> | 
| 2 <!DOCTYPE html> | 2 <!DOCTYPE html> | 
| 3 <script src="../../../resources/testharness.js"></script> | 3 <script src="../../../resources/testharness.js"></script> | 
| 4 <script src="../../../resources/testharnessreport.js"></script> | 4 <script src="../../../resources/testharnessreport.js"></script> | 
| 5 <script src="../../../resources/bluetooth/bluetooth-helpers.js"></script> | 5 <script src="../../../resources/bluetooth/bluetooth-helpers.js"></script> | 
| 6 <script> | 6 <script> | 
| 7 'use strict'; | 7 'use strict'; | 
| 8 promise_test(() => { | 8 promise_test(() => { | 
| 9   let promise; | 9   let promise; | 
| 10   return setBluetoothFakeAdapter('TwoHeartRateServicesAdapter') | 10   return setBluetoothFakeAdapter('TwoHeartRateServicesAdapter') | 
| 11     .then(() => requestDeviceWithKeyDown({ | 11     .then(() => requestDeviceWithKeyDown({ | 
| 12       filters: [{services: ['heart_rate']}]})) | 12       filters: [{services: ['heart_rate']}]})) | 
| 13     .then(device => device.gatt.connect()) | 13     .then(device => device.gatt.connect()) | 
| 14     .then(gattServer => { | 14     .then(gattServer => { | 
| 15       return gattServer | 15       return gattServer | 
| 16         .getPrimaryService('heart_rate') | 16         .getPrimaryService('heart_rate') | 
| 17         // Convert to array if necessary. | 17         // Convert to array if necessary. | 
| 18         .then(s => { | 18         .then(s => { | 
| 19           let services = [].concat(s); | 19           let services = [].concat(s); | 
| 20           gattServer.disconnect(); | 20           gattServer.disconnect(); | 
| 21           return gattServer.connect() | 21           return gattServer.connect() | 
| 22             .then(() => services); | 22             .then(() => services); | 
| 23         }); | 23         }); | 
| 24     }) | 24     }) | 
| 25     .then(services => { | 25     .then(services => { | 
| 26       let promises = Promise.resolve(); | 26       let promises = Promise.resolve(); | 
| 27       for (let service of services) { | 27       for (let service of services) { | 
| 28         let error = new DOMException( | 28         let error = new DOMException( | 
| 29           'Service is no longer valid. Remember to retrieve the service ' + | 29           'Service with UUID ' + service.uuid + | 
|  | 30           ' is no longer valid. Remember to retrieve the service ' + | 
| 30           'again after reconnecting.', | 31           'again after reconnecting.', | 
| 31           'InvalidStateError'); | 32           'InvalidStateError'); | 
| 32         promises = promises.then(() => | 33         promises = promises.then(() => | 
| 33           assert_promise_rejects_with_message( | 34           assert_promise_rejects_with_message( | 
| 34             service.getCharacteristic('body_sensor_location'), | 35             service.getCharacteristic('body_sensor_location'), | 
| 35             error)); | 36             error)); | 
| 36         promises = promises.then(() => | 37         promises = promises.then(() => | 
| 37           assert_promise_rejects_with_message( | 38           assert_promise_rejects_with_message( | 
| 38             service.getCharacteristics(), | 39             service.getCharacteristics(), | 
| 39             error)); | 40             error)); | 
| 40         promises = promises.then(() => | 41         promises = promises.then(() => | 
| 41           assert_promise_rejects_with_message( | 42           assert_promise_rejects_with_message( | 
| 42             service.getCharacteristics('body_sensor_location'), | 43             service.getCharacteristics('body_sensor_location'), | 
| 43             error)); | 44             error)); | 
| 44       } | 45       } | 
| 45       return promises; | 46       return promises; | 
| 46     }); | 47     }); | 
| 47 }, 'Calls on services after we disconnect and connect again. '+ | 48 }, 'Calls on services after we disconnect and connect again. '+ | 
| 48    'Should reject with InvalidStateError.'); | 49    'Should reject with InvalidStateError.'); | 
| 49 | 50 | 
| 50 </script> | 51 </script> | 
| OLD | NEW | 
|---|