# Copyright 2022 Google Inc. # # Licensed under the Apache License, Version 2.0 (the "License"); # you may not use this file except in compliance with the License. # You may obtain a copy of the License at # # http://www.apache.org/licenses/LICENSE-2.0 # # Unless required by applicable law or agreed to in writing, software # distributed under the License is distributed on an "AS IS" BASIS, # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. # See the License for the specific language governing permissions and # limitations under the License. import unittest from unittest import mock from mobly.controllers.android_device_lib import fastboot class FastbootTest(unittest.TestCase): """Unit tests for mobly.controllers.android_device_lib.adb.""" @mock.patch('mobly.controllers.android_device_lib.fastboot.Popen') @mock.patch('logging.debug') def test_fastboot_commands_and_results_are_logged_to_debug_log( self, mock_debug_logger, mock_popen): expected_stdout = 'stdout' expected_stderr = b'stderr' mock_popen.return_value.communicate = mock.Mock( return_value=(expected_stdout, expected_stderr)) mock_popen.return_value.returncode = 123 fastboot.FastbootProxy().fake_command('extra', 'flags') mock_debug_logger.assert_called_with( 'cmd: %s, stdout: %s, stderr: %s, ret: %s', '\'fastboot fake-command extra flags\'', expected_stdout, expected_stderr, 123) if __name__ == '__main__': unittest.main()