| 'use strict'; |
| const test_desc = 'Calls to FUNCTION_NAME 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.CALLS([ |
| getPrimaryService('health_thermometer')| |
| getPrimaryServices()| |
| getPrimaryServices('health_thermometer')[UUID]])) |
| .then(services => services_first_connection = services) |
| .then(() => device.gatt.disconnect()) |
| .then(() => device.gatt.connect()) |
| .then(() => device.gatt.PREVIOUS_CALL) |
| .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); |