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 | |
Ralph Nathan | 1fc77f2 | 2015-04-21 15:05:48 -0700 | [diff] [blame] | 9 | from chromite.lib import commandline |
Ryan Cui | 47f80e4 | 2013-04-01 19:01:54 -0700 | [diff] [blame] | 10 | from chromite.lib import cros_test_lib |
| 11 | from chromite.lib import stats |
| 12 | from chromite.lib import stats_unittest |
| 13 | from chromite.scripts import cros |
| 14 | |
| 15 | |
Don Garrett | 4c2b917 | 2015-10-09 13:27:44 -0700 | [diff] [blame^] | 16 | class RunScriptTest(cros_test_lib.MockTempDirTestCase): |
Ryan Cui | 47f80e4 | 2013-04-01 19:01:54 -0700 | [diff] [blame] | 17 | """Test the main functionality.""" |
| 18 | |
| 19 | def setUp(self): |
Ryan Cui | cbd9bb6 | 2013-04-30 11:17:02 -0700 | [diff] [blame] | 20 | self.stats_module_mock = stats_unittest.StatsModuleMock() |
| 21 | self.StartPatcher(self.stats_module_mock) |
Ryan Cui | 47f80e4 | 2013-04-01 19:01:54 -0700 | [diff] [blame] | 22 | self.PatchObject(cros, '_RunSubCommand', autospec=True) |
| 23 | |
Ryan Cui | cbd9bb6 | 2013-04-30 11:17:02 -0700 | [diff] [blame] | 24 | def testStatsUpload(self, upload_count=1, return_value=0): |
Ryan Cui | 47f80e4 | 2013-04-01 19:01:54 -0700 | [diff] [blame] | 25 | """Test stats uploading.""" |
| 26 | return_value = cros.main(['chrome-sdk', '--board', 'lumpy']) |
David Pursell | ffb9004 | 2015-03-23 09:21:41 -0700 | [diff] [blame] | 27 | # pylint: disable=protected-access |
Ryan Cui | cbd9bb6 | 2013-04-30 11:17:02 -0700 | [diff] [blame] | 28 | self.assertEquals(stats.StatsUploader._Upload.call_count, upload_count) |
David Pursell | ffb9004 | 2015-03-23 09:21:41 -0700 | [diff] [blame] | 29 | # pylint: enable=protected-access |
Ryan Cui | cbd9bb6 | 2013-04-30 11:17:02 -0700 | [diff] [blame] | 30 | self.assertEquals(return_value, return_value) |
| 31 | |
| 32 | def testStatsUploadError(self): |
| 33 | """We don't upload stats if the stats creation failed.""" |
| 34 | self.stats_module_mock.stats_mock.init_exception = True |
| 35 | with cros_test_lib.LoggingCapturer(): |
| 36 | self.testStatsUpload(upload_count=0) |
Ralph Nathan | 1fc77f2 | 2015-04-21 15:05:48 -0700 | [diff] [blame] | 37 | |
David Pursell | c7ba784 | 2015-07-08 10:48:41 -0700 | [diff] [blame] | 38 | def testDefaultLogLevel(self): |
| 39 | """Test that the default log level is set to notice.""" |
Ralph Nathan | 1fc77f2 | 2015-04-21 15:05:48 -0700 | [diff] [blame] | 40 | arg_parser = self.PatchObject(commandline, 'ArgumentParser', |
| 41 | return_value=commandline.ArgumentParser()) |
| 42 | cros.GetOptions({}) |
Ralph Nathan | 38372f4 | 2015-05-19 15:56:25 -0700 | [diff] [blame] | 43 | arg_parser.assert_called_with(caching=True, default_log_level='notice') |