В python, как написать модульный тест для функции с открытым файлом? - PullRequest
0 голосов
/ 12 февраля 2020

Это функция для получения версии и использования с открытым для чтения файла из пути к файлу.

def get_version(self):
    try:
        with open("file_path") as openfile:
            for line in openfile:
                sline = line.split()
                for row, column in enumerate(sline):
                    if column == "version=":
                        version = sline[row+1].strip('"')
    return version

1 Ответ

0 голосов
/ 28 апреля 2020

Вы можете использовать unittest.mock.mock_open (mock = None, read_data = None) для макета функции open.

Например,

main.py :

class MyClass:
    def get_version(self):
        version = ''
        with open("file_path") as openfile:
            for line in openfile:
                sline = line.split()
                for row, column in enumerate(sline):
                    if column == "version=":
                        version = sline[row+1].strip('"')

        return version

test_main.py:

from main import MyClass
import unittest
from unittest.mock import mock_open, patch


class TestMain(unittest.TestCase):
    def test_get_version(self):
        m = mock_open(read_data='version= 1.0.0')
        with patch('builtins.open', m) as mocked_open:
            myclass_instace = MyClass()
            version = myclass_instace.get_version()
            self.assertEqual(version, '1.0.0')
            m.assert_called_with('file_path')


if __name__ == '__main__':
    unittest.main()

Результаты модульных испытаний со 100% покрытием:

.
----------------------------------------------------------------------
Ran 1 test in 0.011s

OK
Name                                      Stmts   Miss  Cover   Missing
-----------------------------------------------------------------------
src/stackoverflow/60183706/main.py           10      0   100%
src/stackoverflow/60183706/test_main.py      14      0   100%
-----------------------------------------------------------------------
TOTAL                                        24      0   100%

Python версия: Python 3.7.5

...