Я пытаюсь протестировать некоторый код, который работает с файлом, и я не могу понять, как заменить использование реального файла на mock
и io.StringIO
. Мой код в значительной степени выглядит следующим образом:
class CheckConfig(object):
def __init__(self, config):
self.config = self._check_input_data(config)
def _check_input_data(self, data):
if isinstance(data, list):
return self._parse(data)
elif os.path.isfile(data):
with open(data) as f:
return self._parse(f.readlines())
def _parse(self, data):
return data
У меня есть класс, который может принимать либо список, либо файл, если это файл, он открывает его и извлекает содержимое в список, а затем делает то, что ему нужно сделать с результирующим списком.
У меня есть рабочий тест следующим образом:
def test_CheckConfig_with_file():
config = 'config.txt'
expected = parsed_file_data
actual = CheckConfig(config).config
assert expected == actual
Я хочу заменить вызов файловой системы. Я попытался заменить файл на io.StringIO
, но я получаю TypeError
из os.path.isfile()
, так как он ожидает строку, байты или целое число. Я также пытался издеваться над методом isfile
следующим образом:
@mock.patch('mymodule.os.path')
def test_CheckConfig_with_file(mock_path):
mock_path.isfile.return_value = True
config = io.StringIO('data')
expected = parsed_file_data
actual = CheckConfig(config).config
assert expected == actual
но я все еще получаю то же самое TypeError
, поскольку тип _io.StringIO
вызывает исключение до того, как isfile
получит возможность что-то вернуть.
Как я могу заставить os.path.isfile
возвращать True, когда я передаю ему поддельный файл? Или это предложение изменить код?