| Index: third_party/WebKit/LayoutTests/bluetooth/script-tests/characteristic-disconnect-invalidates-objects.js
|
| diff --git a/third_party/WebKit/LayoutTests/bluetooth/script-tests/characteristic-disconnect-invalidates-objects.js b/third_party/WebKit/LayoutTests/bluetooth/script-tests/characteristic-disconnect-invalidates-objects.js
|
| new file mode 100644
|
| index 0000000000000000000000000000000000000000..bf7a8c8965735c9917def9ab650f6ae28673a0ce
|
| --- /dev/null
|
| +++ b/third_party/WebKit/LayoutTests/bluetooth/script-tests/characteristic-disconnect-invalidates-objects.js
|
| @@ -0,0 +1,49 @@
|
| +'use strict';
|
| +promise_test(() => {
|
| + return setBluetoothFakeAdapter('DisconnectingHealthThermometerAdapter')
|
| + .then(() => requestDeviceWithKeyDown({
|
| + filters: [{services: ['health_thermometer']}],
|
| + optionalServices: [request_disconnection_service_uuid]}))
|
| + .then(device => device.gatt.connect())
|
| + .then(gattServer => {
|
| + return gattServer.getPrimaryService('health_thermometer')
|
| + .then(service => service.CALLS([
|
| + getCharacteristic('measurement_interval')|
|
| + getCharacteristics()|
|
| + getCharacteristics('measurement_interval')[UUID]]))
|
| + .then(c => {
|
| + // Convert to array if necessary.
|
| + let characteristics = [].concat(c);
|
| + gattServer.disconnect();
|
| + return gattServer.connect()
|
| + .then(() => characteristics);
|
| + });
|
| + })
|
| + .then(characteristics => {
|
| + let promises = Promise.resolve();
|
| + for (let characteristic of characteristics) {
|
| + let error = new DOMException(
|
| + 'Characteristic is no longer valid. Remember to retrieve the ' +
|
| + 'characteristic again after reconnecting.',
|
| + 'InvalidStateError');
|
| + promises = promises.then(() =>
|
| + assert_promise_rejects_with_message(
|
| + characteristic.readValue(),
|
| + error));
|
| + promises = promises.then(() =>
|
| + assert_promise_rejects_with_message(
|
| + characteristic.writeValue(new Uint8Array([1])),
|
| + error));
|
| + promises = promises.then(() =>
|
| + assert_promise_rejects_with_message(
|
| + characteristic.startNotifications(),
|
| + error));
|
| + promises = promises.then(() =>
|
| + assert_promise_rejects_with_message(
|
| + characteristic.stopNotifications(),
|
| + error));
|
| + }
|
| + return promises;
|
| + });
|
| +}, 'Calls on characteristics after we disconnects and connect again. ' +
|
| + 'Should reject with InvalidStateError.');
|
|
|