refactor handling of missing config files for better testing
Rather than testing that we log a message, place the handling in its own method and verify that we call that. This allows us to change the logging in the configuration class without counting messages and updating the test. Change-Id: Ic3067d8ab6699ceb82db7dd64f892a757f5cc12f Signed-off-by: Doug Hellmann <doug@doughellmann.com>
This commit is contained in:
parent
caadd1d11c
commit
1fa03dc495
@ -218,7 +218,7 @@ class Config(object):
|
|||||||
if os.path.isfile(filename):
|
if os.path.isfile(filename):
|
||||||
break
|
break
|
||||||
else:
|
else:
|
||||||
LOG.info('no configuration file in: %s', ', '.join(filenames))
|
self._report_missing_config_files(filenames)
|
||||||
return
|
return
|
||||||
|
|
||||||
try:
|
try:
|
||||||
@ -226,10 +226,20 @@ class Config(object):
|
|||||||
self._contents = yaml.safe_load(fd)
|
self._contents = yaml.safe_load(fd)
|
||||||
LOG.info('loaded configuration file %s', filename)
|
LOG.info('loaded configuration file %s', filename)
|
||||||
except IOError as err:
|
except IOError as err:
|
||||||
LOG.warning('did not load config file %s: %s', filename, err)
|
self._report_failure_config_file(filename, err)
|
||||||
else:
|
else:
|
||||||
self.override(**self._contents)
|
self.override(**self._contents)
|
||||||
|
|
||||||
|
def _report_missing_config_files(self, filenames):
|
||||||
|
# NOTE(dhellmann): This is extracted so we can mock it for
|
||||||
|
# testing.
|
||||||
|
LOG.info('no configuration file in: %s', ', '.join(filenames))
|
||||||
|
|
||||||
|
def _report_failure_config_file(self, filename, err):
|
||||||
|
# NOTE(dhellmann): This is extracted so we can mock it for
|
||||||
|
# testing.
|
||||||
|
LOG.warning('did not load config file %s: %s', filename, err)
|
||||||
|
|
||||||
def _rename_prelude_section(self, **kwargs):
|
def _rename_prelude_section(self, **kwargs):
|
||||||
key = 'prelude_section_name'
|
key = 'prelude_section_name'
|
||||||
if key in kwargs and kwargs[key] != self._OPTS[key].default:
|
if key in kwargs and kwargs[key] != self._OPTS[key].default:
|
||||||
|
@ -73,9 +73,10 @@ collapse_pre_releases: false
|
|||||||
self.assertEqual(expected, actual)
|
self.assertEqual(expected, actual)
|
||||||
|
|
||||||
def test_load_file_not_present(self):
|
def test_load_file_not_present(self):
|
||||||
with mock.patch.object(config.LOG, 'info') as logger:
|
missing = 'reno.config.Config._report_missing_config_files'
|
||||||
|
with mock.patch(missing) as error_handler:
|
||||||
config.Config(self.tempdir.path)
|
config.Config(self.tempdir.path)
|
||||||
self.assertEqual(1, logger.call_count)
|
self.assertEqual(1, error_handler.call_count)
|
||||||
|
|
||||||
def _test_load_file(self, config_path):
|
def _test_load_file(self, config_path):
|
||||||
with open(config_path, 'w') as fd:
|
with open(config_path, 'w') as fd:
|
||||||
|
Loading…
Reference in New Issue
Block a user