blob: efda6cf4a4150ea58f895671d0e286105d7af883 [file] [log] [blame]
// 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 =
'Calls to getPrimaryServices after a disconnection should return ' +
'a different object.';
let device, services_first_connection, services_second_connection;
bluetooth_test(
() => getHealthThermometerDevice({
filters: [{services: ['health_thermometer']}],
optionalServices: ['generic_access']
})
.then(_ => ({device} = _))
.then(() => device.gatt.getPrimaryServices())
.then(services => services_first_connection = services)
.then(() => device.gatt.disconnect())
.then(() => device.gatt.connect())
.then(() => device.gatt.getPrimaryServices())
.then(services => services_second_connection = services)
.then(() => {
// Convert to arrays if necessary.
services_first_connection =
[].concat(services_first_connection);
services_second_connection =
[].concat(services_second_connection);
assert_equals(
services_first_connection.length,
services_second_connection.length);
let first_connection_set = new Set(services_first_connection);
let second_connection_set = new Set(services_second_connection);
// The two sets should be disjoint.
let common_services = services_first_connection.filter(
val => second_connection_set.has(val));
assert_equals(common_services.length, 0);
}),
test_desc);