From abcc1cfaf70a934a38de8667d43d20aed3c28cbc Mon Sep 17 00:00:00 2001 From: Tadeu Manoel Date: Wed, 7 Oct 2020 07:47:54 -0300 Subject: [PATCH] Fix error with `--import-mode=importlib` and modules containing dataclasses fixes #7856 --- AUTHORS | 1 + changelog/7856.bugfix.rst | 1 + src/_pytest/pathlib.py | 1 + testing/test_pathlib.py | 27 +++++++++++++++++++++++++++ 4 files changed, 30 insertions(+) create mode 100644 changelog/7856.bugfix.rst diff --git a/AUTHORS b/AUTHORS index ab84a3e528..cdc256029b 100644 --- a/AUTHORS +++ b/AUTHORS @@ -90,6 +90,7 @@ Dmitry Pribysh Duncan Betts Edison Gustavo Muenz Edoardo Batini +Edson Tadeu M. Manoel Eduardo Schettino Eli Boyarski Elizaveta Shashkova diff --git a/changelog/7856.bugfix.rst b/changelog/7856.bugfix.rst new file mode 100644 index 0000000000..90ce045f30 --- /dev/null +++ b/changelog/7856.bugfix.rst @@ -0,0 +1 @@ +An error with ``--import-mode=importlib`` used with modules containing dataclasses was fixed. diff --git a/src/_pytest/pathlib.py b/src/_pytest/pathlib.py index 0bc5bff2bb..7df0d4ec5f 100644 --- a/src/_pytest/pathlib.py +++ b/src/_pytest/pathlib.py @@ -480,6 +480,7 @@ def import_path( "Can't find module {} at location {}".format(module_name, str(path)) ) mod = importlib.util.module_from_spec(spec) + sys.modules[module_name] = mod spec.loader.exec_module(mod) # type: ignore[union-attr] return mod diff --git a/testing/test_pathlib.py b/testing/test_pathlib.py index e37b33847e..31c95aebc7 100644 --- a/testing/test_pathlib.py +++ b/testing/test_pathlib.py @@ -401,3 +401,30 @@ def test_commonpath() -> None: assert commonpath(subpath, path) == path assert commonpath(Path(str(path) + "suffix"), path) == path.parent assert commonpath(path, path.parent.parent) == path.parent.parent + + +@pytest.fixture +def module_with_dataclass(tmpdir): + fn = tmpdir.join("test_dataclass.py") + fn.write( + dedent("""\ + from __future__ import annotations + + from dataclasses import dataclass + + @dataclass + class DataClass: + value: str + + def test_dataclass(): + assert DataClass(value='test').value == 'test' + """ + ) + ) + return fn + + +def test_importmode_importlib_with_dataclass(module_with_dataclass): + """Ensure that importlib mode works with a module containing dataclasses""" + module = import_path(module_with_dataclass, mode="importlib") + module.test_dataclass()