242 lines
		
	
	
		
			9.5 KiB
		
	
	
	
		
			Python
		
	
	
	
			
		
		
	
	
			242 lines
		
	
	
		
			9.5 KiB
		
	
	
	
		
			Python
		
	
	
	
| # Copyright 2019 The Chromium OS Authors. All rights reserved.
 | |
| # Use of this source code is governed by a BSD-style license that can be
 | |
| # found in the LICENSE file.
 | |
| 
 | |
| """A Batch of of Bluetooth Classic health tests"""
 | |
| 
 | |
| 
 | |
| from autotest_lib.server.cros.bluetooth.bluetooth_adapter_quick_tests import \
 | |
|      BluetoothAdapterQuickTests
 | |
| from autotest_lib.server.cros.bluetooth.bluetooth_adapter_pairing_tests import \
 | |
|      BluetoothAdapterPairingTests
 | |
| from autotest_lib.server.cros.bluetooth.bluetooth_adapter_hidreports_tests \
 | |
|      import BluetoothAdapterHIDReportTests
 | |
| from autotest_lib.server.cros.bluetooth.bluetooth_sdp_tests import \
 | |
|      BluetoothSDPTests
 | |
| 
 | |
| 
 | |
| class bluetooth_AdapterCLHealth(BluetoothAdapterQuickTests,
 | |
|         BluetoothAdapterPairingTests,
 | |
|         BluetoothAdapterHIDReportTests,
 | |
|         BluetoothSDPTests):
 | |
|     """A Batch of Bluetooth Classic health tests. This test is written as a batch
 | |
|        of tests in order to reduce test time, since auto-test ramp up time is
 | |
|        costly. The batch is using BluetoothAdapterQuickTests wrapper methods to
 | |
|        start and end a test and a batch of tests.
 | |
| 
 | |
|        This class can be called to run the entire test batch or to run a
 | |
|        specific test only
 | |
|     """
 | |
| 
 | |
|     test_wrapper = BluetoothAdapterQuickTests.quick_test_test_decorator
 | |
|     batch_wrapper = BluetoothAdapterQuickTests.quick_test_batch_decorator
 | |
| 
 | |
| 
 | |
|     @test_wrapper('Discovery Test', devices={"MOUSE":1})
 | |
|     def cl_adapter_discovery_test(self):
 | |
|         """Performs pairing test with mouse peripheral"""
 | |
|         device = self.devices['MOUSE'][0]
 | |
| 
 | |
|         self.test_discover_device(device.address)
 | |
|         self.test_device_name(device.address, device.name)
 | |
| 
 | |
| 
 | |
|     @test_wrapper('Discoverable Test', devices={"MOUSE":1})
 | |
|     def cl_adapter_discoverable_test(self):
 | |
|         """Verifies that DUT can become discoverable and be discovered"""
 | |
| 
 | |
|         device = self.devices['MOUSE'][0]
 | |
| 
 | |
|         # Put DUT into discoverable state
 | |
|         self.test_discoverable()
 | |
| 
 | |
|         # Try and discover DUT from peripheral device
 | |
|         self.test_discover_by_device(device)
 | |
| 
 | |
| 
 | |
|     @test_wrapper('Pairing Test', devices={"MOUSE":1})
 | |
|     def cl_adapter_pairing_test(self):
 | |
|         """Performs pairing test with mouse peripheral"""
 | |
|         device = self.devices['MOUSE'][0]
 | |
|         self.pairing_test(device,
 | |
|                           check_connected_method=\
 | |
|                           self.test_mouse_right_click)
 | |
| 
 | |
| 
 | |
|     @test_wrapper('keyboard Pairing Test', devices={"KEYBOARD":1})
 | |
|     def cl_adapter_keyboard_pairing_test(self):
 | |
|         """Performs pairing test with keyboard peripheral"""
 | |
|         device = self.devices['KEYBOARD'][0]
 | |
|         self.pairing_test(device,
 | |
|                           check_connected_method=\
 | |
|                           self.run_keyboard_tests)
 | |
| 
 | |
| 
 | |
|     @test_wrapper('Pairing Suspend Resume Test', devices={"MOUSE": 1})
 | |
|     def cl_adapter_pairing_suspend_resume_test(self):
 | |
|         """Performs pairing test over resume with mouse peripheral"""
 | |
|         device = self.devices['MOUSE'][0]
 | |
|         self.pairing_test(device,
 | |
|                           check_connected_method=\
 | |
|                           self.test_mouse_right_click,
 | |
|                           suspend_resume=True)
 | |
| 
 | |
| 
 | |
|     @test_wrapper('Pairing Twice Test', devices={"MOUSE":1})
 | |
|     def cl_adapter_pairing_twice_test(self):
 | |
|         """Performs pairing twice test with  mouse peripheral"""
 | |
|         device = self.devices['MOUSE'][0]
 | |
|         self.pairing_test(device,
 | |
|                           check_connected_method=\
 | |
|                           self.test_mouse_right_click,
 | |
|                           pairing_twice=True)
 | |
| 
 | |
| 
 | |
|     @test_wrapper('HID Reports Test', devices={"MOUSE":1})
 | |
|     def cl_HID_reports_test(self):
 | |
|         """Performs HID report test with mouse peripheral"""
 | |
|         device = self.devices['MOUSE'][0]
 | |
|         self.run_hid_reports_test(device,
 | |
|                           check_connected_method=\
 | |
|                           self.test_mouse_right_click)
 | |
| 
 | |
| 
 | |
|     @test_wrapper('HID keyboard Reports Test', devices={'KEYBOARD':1})
 | |
|     def cl_HID_keyboard_reports_test(self):
 | |
|         """Performs HID report test with keyboard peripheral"""
 | |
|         device = self.devices['KEYBOARD'][0]
 | |
|         self.run_hid_reports_test(device,
 | |
|                           check_connected_method=\
 | |
|                           self.run_keyboard_tests)
 | |
| 
 | |
| 
 | |
|     @test_wrapper('HID Reports Suspend Resume Test', devices={"MOUSE": 1})
 | |
|     def cl_HID_reports_suspend_resume_test(self):
 | |
|         """Performs HID report test over resume with mouse peripheral"""
 | |
|         device = self.devices['MOUSE'][0]
 | |
|         self.run_hid_reports_test(device,
 | |
|                           check_connected_method=\
 | |
|                           self.test_mouse_right_click, suspend_resume=True)
 | |
| 
 | |
| 
 | |
|     @test_wrapper('HID Reports Reboot Test', devices={"MOUSE":1})
 | |
|     def cl_HID_reports_reboot_test(self):
 | |
|         """Performs HID report test over reboot with mouse peripheral"""
 | |
|         device = self.devices['MOUSE'][0]
 | |
|         self.run_hid_reports_test(device,
 | |
|                           check_connected_method=\
 | |
|                           self.test_mouse_right_click, reboot=True)
 | |
| 
 | |
| 
 | |
|     @test_wrapper('Connect Disconnect Loop Test', devices={"MOUSE":1})
 | |
|     def cl_connect_disconnect_loop_test(self):
 | |
|         """Performs connect/disconnect test with mouse peripheral"""
 | |
|         device = self.devices['MOUSE'][0]
 | |
|         self.connect_disconnect_loop(device=device, loops=3)
 | |
| 
 | |
| 
 | |
|     @test_wrapper('Page scan during Inquiry', devices={"MOUSE": 1})
 | |
|     def cl_page_scan_during_inquiry(self):
 | |
|         """Checks page scan is working during inquiry.
 | |
| 
 | |
|         Scan and pair peer device.
 | |
|         Start inquiry.
 | |
|         Disconnect peer device from DUT.
 | |
|         Reconnect peer device by initiating connection from peer.
 | |
|         """
 | |
|         device = self.devices['MOUSE'][0]
 | |
| 
 | |
|         # Setup
 | |
|         self.assert_discover_and_pair(device)
 | |
|         self.test_start_discovery()
 | |
| 
 | |
|         # Disconnection should set up page scan so a reconnect immediately
 | |
|         # afterwards should always succeed
 | |
|         self.test_disconnection_by_adapter(device.address)
 | |
|         self.test_connection_by_device(device)
 | |
| 
 | |
|         # Cleanup
 | |
|         self.test_stop_discovery()
 | |
| 
 | |
|     @test_wrapper('SDP Service Browse Test', devices={"BLUETOOTH_TESTER":1})
 | |
|     def cl_sdp_service_browse_test(self):
 | |
|         """Performs sdp browse with tester peripheral"""
 | |
|         device = self.devices['BLUETOOTH_TESTER'][0]
 | |
|         self.sdp_service_browse_test(device=device)
 | |
| 
 | |
| 
 | |
|     @test_wrapper('SDP Service Attribute Request Test', \
 | |
|                   devices={"BLUETOOTH_TESTER":1})
 | |
|     def cl_sdp_service_attribute_request_test(self):
 | |
|         """Performs sdp browse with tester peripheral"""
 | |
|         device = self.devices['BLUETOOTH_TESTER'][0]
 | |
|         self.sdp_service_attribute_request_test(device=device)
 | |
| 
 | |
| 
 | |
|     @test_wrapper('SDP Service Search Attribute Request Test', \
 | |
|                   devices={"BLUETOOTH_TESTER":1})
 | |
|     def cl_sdp_service_search_attribute_request_test(self):
 | |
|         """Performs sdp browse with tester peripheral"""
 | |
|         device = self.devices['BLUETOOTH_TESTER'][0]
 | |
|         self.sdp_service_search_attribute_request_test(device=device)
 | |
| 
 | |
| 
 | |
|     @test_wrapper('SDP Service Search Request Basic Test', \
 | |
|                   devices={"BLUETOOTH_TESTER":1})
 | |
|     def cl_sdp_service_search_request_basic_test(self):
 | |
|         """Performs sdp browse with tester peripheral"""
 | |
|         device = self.devices['BLUETOOTH_TESTER'][0]
 | |
|         self.sdp_service_search_request_basic_test(device=device)
 | |
| 
 | |
| 
 | |
|     @batch_wrapper('Classic Health')
 | |
|     def cl_health_batch_run(self, num_iterations=1, test_name=None):
 | |
|         """Run the Classic health test batch or a specific given test.
 | |
|            The wrapper of this method is implemented in batch_decorator.
 | |
|            Using the decorator a test batch method can implement the only its
 | |
|            core tests invocations and let the decorator handle the wrapper,
 | |
|            which is taking care for whether to run a specific test or the
 | |
|            batch as a whole, and running the batch in iterations
 | |
| 
 | |
|            @param num_iterations: how many interations to run
 | |
|            @param test_name: specifc test to run otherwise None to run the
 | |
|                              whole batch
 | |
|         """
 | |
|         self.cl_HID_keyboard_reports_test()
 | |
|         self.cl_HID_reports_reboot_test()
 | |
|         self.cl_HID_reports_suspend_resume_test()
 | |
|         self.cl_HID_reports_test()
 | |
|         self.cl_adapter_discoverable_test()
 | |
|         self.cl_adapter_discovery_test()
 | |
|         self.cl_adapter_keyboard_pairing_test()
 | |
|         self.cl_adapter_pairing_suspend_resume_test()
 | |
|         self.cl_adapter_pairing_test()
 | |
|         self.cl_adapter_pairing_twice_test()
 | |
|         self.cl_connect_disconnect_loop_test()
 | |
|         self.cl_sdp_service_attribute_request_test()
 | |
|         self.cl_sdp_service_browse_test()
 | |
|         self.cl_sdp_service_search_attribute_request_test()
 | |
|         self.cl_sdp_service_search_request_basic_test()
 | |
| 
 | |
| 
 | |
|     def run_once(self,
 | |
|                  host,
 | |
|                  num_iterations=1,
 | |
|                  args_dict=None,
 | |
|                  test_name=None,
 | |
|                  flag='Quick Health'):
 | |
|         """Run the batch of Bluetooth Classic health tests
 | |
| 
 | |
|         @param host: the DUT, usually a chromebook
 | |
|         @param num_iterations: the number of rounds to execute the test
 | |
|         @test_name: the test to run, or None for all tests
 | |
|         """
 | |
| 
 | |
|         # Initialize and run the test batch or the requested specific test
 | |
|         self.quick_test_init(host,
 | |
|                              use_btpeer=True,
 | |
|                              flag=flag,
 | |
|                              args_dict=args_dict)
 | |
|         self.cl_health_batch_run(num_iterations, test_name)
 | |
|         self.quick_test_cleanup()
 |