Ryan Cui | 47f80e4 | 2013-04-01 19:01:54 -0700 | [diff] [blame] | 1 | # Copyright (c) 2013 The Chromium OS Authors. All rights reserved. |
| 2 | # Use of this source code is governed by a BSD-style license that can be |
| 3 | # found in the LICENSE file. |
| 4 | |
Don Garrett | 25f309a | 2014-03-19 14:02:12 -0700 | [diff] [blame] | 5 | """Unittests for cros.""" |
| 6 | |
Mike Frysinger | 383367e | 2014-09-16 15:06:17 -0400 | [diff] [blame] | 7 | from __future__ import print_function |
| 8 | |
David Pursell | ffb9004 | 2015-03-23 09:21:41 -0700 | [diff] [blame] | 9 | from chromite.cli import command |
Ralph Nathan | 1fc77f2 | 2015-04-21 15:05:48 -0700 | [diff] [blame] | 10 | from chromite.lib import commandline |
Ryan Cui | 47f80e4 | 2013-04-01 19:01:54 -0700 | [diff] [blame] | 11 | from chromite.lib import cros_test_lib |
| 12 | from chromite.lib import stats |
| 13 | from chromite.lib import stats_unittest |
| 14 | from chromite.scripts import cros |
| 15 | |
| 16 | |
Ralph Nathan | 74e864d | 2015-05-11 12:13:53 -0700 | [diff] [blame] | 17 | class RunScriptTest(cros_test_lib.WorkspaceTestCase): |
Ryan Cui | 47f80e4 | 2013-04-01 19:01:54 -0700 | [diff] [blame] | 18 | """Test the main functionality.""" |
| 19 | |
| 20 | def setUp(self): |
Ryan Cui | cbd9bb6 | 2013-04-30 11:17:02 -0700 | [diff] [blame] | 21 | self.stats_module_mock = stats_unittest.StatsModuleMock() |
| 22 | self.StartPatcher(self.stats_module_mock) |
Ryan Cui | 47f80e4 | 2013-04-01 19:01:54 -0700 | [diff] [blame] | 23 | self.PatchObject(cros, '_RunSubCommand', autospec=True) |
David Pursell | ffb9004 | 2015-03-23 09:21:41 -0700 | [diff] [blame] | 24 | # Use the `cros` toolset for these tests. |
Ralph Nathan | 1fc77f2 | 2015-04-21 15:05:48 -0700 | [diff] [blame] | 25 | self.get_toolset_mock = self.PatchObject(command, 'GetToolset', |
| 26 | autospec=True) |
| 27 | self.get_toolset_mock.return_value = 'cros' |
Ryan Cui | 47f80e4 | 2013-04-01 19:01:54 -0700 | [diff] [blame] | 28 | |
Ryan Cui | cbd9bb6 | 2013-04-30 11:17:02 -0700 | [diff] [blame] | 29 | def testStatsUpload(self, upload_count=1, return_value=0): |
Ryan Cui | 47f80e4 | 2013-04-01 19:01:54 -0700 | [diff] [blame] | 30 | """Test stats uploading.""" |
| 31 | return_value = cros.main(['chrome-sdk', '--board', 'lumpy']) |
David Pursell | ffb9004 | 2015-03-23 09:21:41 -0700 | [diff] [blame] | 32 | # pylint: disable=protected-access |
Ryan Cui | cbd9bb6 | 2013-04-30 11:17:02 -0700 | [diff] [blame] | 33 | self.assertEquals(stats.StatsUploader._Upload.call_count, upload_count) |
David Pursell | ffb9004 | 2015-03-23 09:21:41 -0700 | [diff] [blame] | 34 | # pylint: enable=protected-access |
Ryan Cui | cbd9bb6 | 2013-04-30 11:17:02 -0700 | [diff] [blame] | 35 | self.assertEquals(return_value, return_value) |
| 36 | |
| 37 | def testStatsUploadError(self): |
| 38 | """We don't upload stats if the stats creation failed.""" |
| 39 | self.stats_module_mock.stats_mock.init_exception = True |
| 40 | with cros_test_lib.LoggingCapturer(): |
| 41 | self.testStatsUpload(upload_count=0) |
Ralph Nathan | 1fc77f2 | 2015-04-21 15:05:48 -0700 | [diff] [blame] | 42 | |
| 43 | def testDefaultLogLevelBrillo(self): |
| 44 | """Test that the default log level is notice for brillo tools.""" |
| 45 | self.get_toolset_mock.return_value = 'brillo' |
Ralph Nathan | 74e864d | 2015-05-11 12:13:53 -0700 | [diff] [blame] | 46 | self.CreateWorkspace() |
Ralph Nathan | 1fc77f2 | 2015-04-21 15:05:48 -0700 | [diff] [blame] | 47 | arg_parser = self.PatchObject(commandline, 'ArgumentParser', |
| 48 | return_value=commandline.ArgumentParser()) |
| 49 | cros.GetOptions({}) |
| 50 | arg_parser.assert_called_with(caching=True, default_log_level='notice') |
| 51 | |
| 52 | def testDefaultLogLevelCros(self): |
Ralph Nathan | 38372f4 | 2015-05-19 15:56:25 -0700 | [diff] [blame^] | 53 | """Test that the default log level is set to notice for cros tools.""" |
Ralph Nathan | 1fc77f2 | 2015-04-21 15:05:48 -0700 | [diff] [blame] | 54 | arg_parser = self.PatchObject(commandline, 'ArgumentParser', |
| 55 | return_value=commandline.ArgumentParser()) |
| 56 | cros.GetOptions({}) |
Ralph Nathan | 38372f4 | 2015-05-19 15:56:25 -0700 | [diff] [blame^] | 57 | arg_parser.assert_called_with(caching=True, default_log_level='notice') |