// META: script=/resources/testdriver.js
// META: script=/resources/testdriver-vendor.js
// META: script=/common/gc.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.getPrimaryService(glucose.alias), expected),
assert_promise_rejects_with_message(
device.gatt.getPrimaryService(glucose.name), expected),
assert_promise_rejects_with_message(
device.gatt.getPrimaryService(glucose.uuid), expected)])),
test_desc);