From f467336a8b08fb1c001c0fc93968a814fa69aa72 Mon Sep 17 00:00:00 2001 From: Alan Hamlett Date: Sat, 26 Sep 2015 19:10:12 -0700 Subject: [PATCH] test for config file not passed via command line --- tests/test_main.py | 20 ++++++++++++++++++++ wakatime/logger.py | 2 +- 2 files changed, 21 insertions(+), 1 deletion(-) diff --git a/tests/test_main.py b/tests/test_main.py index 3bd75fc..3650041 100644 --- a/tests/test_main.py +++ b/tests/test_main.py @@ -63,6 +63,26 @@ class BaseTestCase(utils.TestCase): self.patched['wakatime.offlinequeue.Queue.push'].assert_not_called() self.patched['wakatime.offlinequeue.Queue.pop'].assert_called_once_with() + def test_config_file_not_passed_in_command_line_args(self): + response = Response() + response.status_code = 201 + self.patched['wakatime.packages.requests.adapters.HTTPAdapter.send'].return_value = response + + with utils.mock.patch('wakatime.main.open') as mock_open: + mock_open.side_effect = IOError('') + + config = os.path.join(os.path.expanduser('~'), '.wakatime.cfg') + entity = 'tests/samples/codefiles/emptyfile.txt' + args = ['--file', entity] + + with self.assertRaises(SystemExit): + execute(args) + expected_stdout = u("Error: Could not read from config file {0}\n").format(u(config)) + expected_stderr = open('tests/samples/output/test_missing_config_file').read() + self.assertEquals(sys.stdout.getvalue(), expected_stdout) + self.assertEquals(sys.stderr.getvalue(), expected_stderr) + self.patched['wakatime.session_cache.SessionCache.get'].assert_not_called() + def test_missing_config_file(self): config = 'foo' entity = 'tests/samples/codefiles/emptyfile.txt' diff --git a/wakatime/logger.py b/wakatime/logger.py index 5229fc6..19f8581 100644 --- a/wakatime/logger.py +++ b/wakatime/logger.py @@ -117,7 +117,7 @@ def setup_logging(args, version): logging.getLogger('py.warnings').addHandler(warnings_handler) try: logging.captureWarnings(True) - except AttributeError: + except AttributeError: # pragma: nocover pass # Python >= 2.7 is needed to capture warnings return logger