# Copyright 2014 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. import common from autotest_lib.client.cros.cellular.mbim_compliance import mbim_constants from autotest_lib.client.cros.cellular.mbim_compliance import mbim_errors from autotest_lib.client.cros.cellular.mbim_compliance import mbim_test_base from autotest_lib.client.cros.cellular.mbim_compliance.sequences \ import connect_sequence from autotest_lib.client.cros.cellular.mbim_compliance.sequences \ import get_descriptors_sequence from autotest_lib.client.cros.cellular.mbim_compliance.sequences \ import mbim_open_generic_sequence class cellular_MbimComplianceERR01(mbim_test_base.MbimTestBase): """ Validation of function's response to messages with variable-length encoding errors. This test verifies that incoming messages are rejected when variable-length encoding rules are not followed. Reference: [1] Universal Serial Bus Communication Class MBIM Compliance Testing: 45 http://www.usb.org/developers/docs/devclass_docs/MBIM-Compliance-1.0.pdf """ version = 1 def run_internal(self): """ Run ERR_01 test. """ # Precondition descriptors = get_descriptors_sequence.GetDescriptorsSequence( self.device_context).run() self.device_context.update_descriptor_cache(descriptors) open_sequence = mbim_open_generic_sequence.MBIMOpenGenericSequence( self.device_context) open_sequence.run() # Step 1 request_message, response_message, _ = ( connect_sequence.ConnectSequence(self.device_context).run( introduce_error_in_access_offset=True, raise_exception_on_failure=False)) # Step 2 if ((response_message.transaction_id != request_message.transaction_id) or (response_message.device_service_id != request_message.device_service_id) or (response_message.cid != request_message.cid)): mbim_errors.log_and_raise( mbim_errors.MBIMComplianceTestError, 'Mismatch in request/response message params: ' '(transaction_id, service_id, cid). ' 'Request Message: (%s, %s, %s), ' 'Response Message: (%s, %s, %s)' % ( request_message.transaction_id, request_message.device_service_id, request_message.cid, response_message.transaction_id, response_message.device_service_id, response_message.cid)) # Step 3 if ((response_message.message_type != mbim_constants.MBIM_COMMAND_DONE) or (response_message.status_codes != mbim_constants.MBIM_STATUS_INVALID_PARAMETERS)): mbim_errors.log_and_raise(mbim_errors.MBIMComplianceAssertionError, 'mbim1.0:10.3#2')