| Index: third_party/WebKit/LayoutTests/bluetooth/descriptor/readValue/gen-io-op-device-reconnects-during-error.html
 | 
| diff --git a/third_party/WebKit/LayoutTests/bluetooth/descriptor/readValue/gen-io-op-device-reconnects-during-error.html b/third_party/WebKit/LayoutTests/bluetooth/descriptor/readValue/gen-io-op-device-reconnects-during-error.html
 | 
| new file mode 100644
 | 
| index 0000000000000000000000000000000000000000..295f48d1a2b9abdd4c6c74c580fd5b3e6e76c3d9
 | 
| --- /dev/null
 | 
| +++ b/third_party/WebKit/LayoutTests/bluetooth/descriptor/readValue/gen-io-op-device-reconnects-during-error.html
 | 
| @@ -0,0 +1,40 @@
 | 
| +<!-- Generated by //third_party/WebKit/LayoutTests/bluetooth/generate.py -->
 | 
| +<!DOCTYPE html>
 | 
| +<script src="../../../resources/testharness.js"></script>
 | 
| +<script src="../../../resources/testharnessreport.js"></script>
 | 
| +<script src="../../../resources/bluetooth/bluetooth-helpers.js"></script>
 | 
| +<script>
 | 
| +promise_test(
 | 
| +    () => {
 | 
| +      let val = new Uint8Array([1]);
 | 
| +      return setBluetoothFakeAdapter(
 | 
| +                 'DisconnectingDuringFailureGATTOperationAdapter')
 | 
| +          .then(
 | 
| +              () => requestDeviceWithKeyDown(
 | 
| +                  {filters: [{services: ['health_thermometer']}]}))
 | 
| +          .then(device => device.gatt.connect())
 | 
| +          .then(gatt => gatt.getPrimaryService('health_thermometer'))
 | 
| +          .then(service => service.getCharacteristic('measurement_interval'))
 | 
| +          .then(
 | 
| +              characteristic =>
 | 
| +                  characteristic.getDescriptor(user_description.name))
 | 
| +          .then(descriptor => {
 | 
| +            let disconnected = eventPromise(
 | 
| +                descriptor.characteristic.service.device,
 | 
| +                'gattserverdisconnected');
 | 
| +            let promise = assert_promise_rejects_with_message(
 | 
| +                descriptor.readValue(),
 | 
| +                new DOMException(
 | 
| +                    'GATT Server disconnected while performing a GATT operation.',
 | 
| +                    'NetworkError'));
 | 
| +            return disconnected
 | 
| +                .then(
 | 
| +                    () =>
 | 
| +                        descriptor.characteristic.service.device.gatt.connect())
 | 
| +                .then(() => promise);
 | 
| +          });
 | 
| +    },
 | 
| +    'Device reconnects during a readValue call that fails. Reject ' +
 | 
| +        'with NetworkError.');
 | 
| +
 | 
| +</script>
 | 
| 
 |