blob: 5cc19c6cb32360a365e6900b92bb72cd572fae15 [file] [log] [blame]
<!-- Generated by //third_party/blink/web_tests/bluetooth/generate.py -->
<!DOCTYPE html>
<script src="/resources/testharness.js"></script>
<script src="/resources/testharnessreport.js"></script>
<script src="/resources/testdriver.js"></script>
<script src="/resources/testdriver-vendor.js"></script>
<script src="/bluetooth/resources/bluetooth-test.js"></script>
<script src="/bluetooth/resources/bluetooth-fake-devices.js"></script>
<script>
bluetooth_test(() => {
let val = new Uint8Array([1]);
return setBluetoothFakeAdapter('DisconnectingDuringSuccessGATTOperationAdapter')
.then(() => requestDeviceWithTrustedClick({
filters: [{services: ['health_thermometer']}]}))
.then(device => device.gatt.connect())
.then(gatt => gatt.getPrimaryService('health_thermometer'))
.then(service => service.getCharacteristic('measurement_interval'))
.then(characteristic => {
let disconnected = eventPromise(characteristic.service.device, 'gattserverdisconnected');
let promise = assert_promise_rejects_with_message(
characteristic.startNotifications(),
new DOMException('GATT Server is disconnected. Cannot perform GATT operations. ' +
'(Re)connect first with `device.gatt.connect`.',
'NetworkError'));
return disconnected.then(() => characteristic.service.device.gatt.connect())
.then(() => promise);
});
}, 'Device reconnects during a startNotifications call that succeeds. Reject ' +
'with NetworkError.');
</script>