| // META: script=/resources/testdriver.js |
| // META: script=/resources/testdriver-vendor.js |
| // META: script=/bluetooth/resources/bluetooth-test.js |
| // META: script=/bluetooth/resources/bluetooth-fake-devices.js |
| // Generated by //third_party/WebKit/LayoutTests/bluetooth/generate.py |
| 'use strict'; |
| const test_desc = 'Request for absent service without permission. Should ' + |
| 'Reject with SecurityError even if services have been discovered already.'; |
| const expected = new DOMException( |
| 'Origin is not allowed to access the service. Tip: Add the service ' + |
| 'UUID to \'optionalServices\' in requestDevice() options. ' + |
| 'https://goo.gl/HxfxSQ', |
| 'SecurityError'); |
| let device; |
| |
| bluetooth_test( |
| () => getHealthThermometerDeviceWithServicesDiscovered( |
| {filters: [{services: ['health_thermometer']}]}) |
| .then(_ => ({device} = _)) |
| .then(() => Promise.all([ |
| assert_promise_rejects_with_message( |
| device.gatt.getPrimaryServices(glucose.alias), expected), |
| assert_promise_rejects_with_message( |
| device.gatt.getPrimaryServices(glucose.name), expected), |
| assert_promise_rejects_with_message( |
| device.gatt.getPrimaryServices(glucose.uuid), expected) |
| ])), |
| test_desc); |