-
-
Notifications
You must be signed in to change notification settings - Fork 2.7k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
AttributeError with import-mode importlib and doctest modules #12194
Comments
It occurred to me that the fix in #12169 might also address this issue, but it does not:
|
Thanks @jaraco, I can reproduce the issue (also verified that #12169 does not fix this). Will investigate which incantation is necessary for this to work. Currently we import modules in Lines 635 to 641 in 74f0564
|
I found an issue that might be related. If not, please direct me in the right direction. My problem so far is that I haven’t figured out a minimal reproducer yet: Somehow the Minimal (not yet) reproducer:$ mkdir bar
$ mkdir foo
$ touch foo/bar.py
$ tree
+ foo/
| + bar.py
+ bar/ Now running a pytest test that imports mod = import_path('foo/bar.py', mode='importlib', root='.')
→
mod = _import_module_using_spec('foo.bar', 'foo/bar.py', '.')
→
spec = meta_importer.find_spec('foo.bar', ['.']) where
instead of
The documentation of
and since meta_importer.find_spec('foo.bar', None) right? |
Thanks for the tip. I did find that adding this patch works around the issue (at least in the repro): diff --git a/src/_pytest/pathlib.py b/src/_pytest/pathlib.py
index 254d9d946..bb26a433f 100644
--- a/src/_pytest/pathlib.py
+++ b/src/_pytest/pathlib.py
@@ -638,6 +638,7 @@ def _import_module_using_spec(
assert spec is not None
mod = importlib.util.module_from_spec(spec)
sys.modules[module_name] = mod
+ _set_name_in_parent(mod)
spec.loader.exec_module(mod) # type: ignore[union-attr]
if insert_modules:
insert_missing_modules(sys.modules, module_name)
@@ -646,6 +647,13 @@ def _import_module_using_spec(
return None
+def _set_name_in_parent(mod):
+ parent, sep, name = mod.__name__.rpartition(".")
+ if not sep:
+ return
+ setattr(sys.modules[parent], name, mod)
+
+
def spec_matches_module_path(
module_spec: Optional[ModuleSpec], module_path: Path
) -> bool: I wonder if there's similar logic in CPython's importlib logic that should be modeled. |
Here's where that happens in CPython. Doesn't seem to be particularly re-usable, but at least shows how that behavior is implemented there. |
This needs to be done manually, not being done as part of the import mechanism: https://github.com/python/cpython/blob/73906d5c908c1e0b73c5436faeff7d93698fc074/Lib/importlib/_bootstrap.py#L1335-L1342 Fix pytest-dev#12194
This needs to be done manually, not being done as part of the import mechanism: https://github.com/python/cpython/blob/73906d5c908c1e0b73c5436faeff7d93698fc074/Lib/importlib/_bootstrap.py#L1335-L1342 Fix pytest-dev#12194
Now `importlib` mode will correctly set the imported modules as an attribute of their parent modules. As helpfully posted on #12194, that's how the Python import module works so we should follow suit. In addition, we also try to import the parent modules as part of the process of importing a child module, again mirroring how Python importing works. Fix #12194
…0 to version 4.0.1 Avasam (1): Allow mypy on PyPy (jaraco/skeleton#111) Bartosz Sławecki (3): Tweak coverage configuration for type checking (jaraco/skeleton#97) Add link to blog entry from jaraco/skeleton#115 above CI build matrix. Move project metadata to `pyproject.toml` (jaraco/skeleton#122) Christian Clauss (2): Upgrade GitHub Actions checkout (jaraco/skeleton#94) GitHub Actions: Combine tox jobs diffcov and docs (jaraco/skeleton#95) Dimitri Papadopoulos Orfanos (2): Use the ruff formatter (jaraco/skeleton#99) ruff: extended-ignore → ignore (jaraco/skeleton#105) Jason R. Coombs (24): Limit sphinxlint jobs to 1. Workaround for sphinx-contrib/sphinx-lint#83. Remove news fragment after allowing time to be processed downstream. Suppress deprecation warning in dateutil. Workaround for dateutil/dateutil#1284. Update Github Actions badge per actions/starter-workflows#1525. Separate collateral jobs on different lines for easier override/extension. Drop minimum requirement on pytest-mypy as most environments are already running much later. Closes jaraco/skeleton#96. Remove sole entry for branches-ignore. Workaround for and closes jaraco/skeleton#103. Bump year on badge Remove build and dist from excludes. It appears they are not needed and their presence blocks the names of packages like 'builder' and 'distutils'. Ref pypa/distutils#224. Exclude docs and tests directories properly per Setuptools behavior. Rely on default discovery for good heuristics for finding packages. Enable preview to enable preserving quotes. Use latest versions in RTD boilerplate. Remove Sphinx pin. Ref sphinx-doc/sphinx#11662. Include deps from the base config in diffcov. Enable complexity check and pycodestyle warnings. Closes jaraco/skeleton#110. Use 'extend-select' to avoid disabling the default config. Ref jaraco/skeleton#110. Re-enable ignoring of temporary merge queue branches. Closes jaraco/skeleton#103. Fetch unshallow clones in readthedocs. Closes jaraco/skeleton#114. Move Python 3.11 out of the test matrix. Configure pytest to support namespace packages. Ref pytest-dev/pytest#12112. Pin against pytest 8.1.x due to pytest-dev/pytest#12194. Migrated config to pyproject.toml using jaraco.develop.migrate-config and ini2toml. Finalize Sviatoslav Sydorenko (1): Enable testing merge queues @ GitHub Actions CI/CD (jaraco/skeleton#93) bswck (1): Remove deprecated `call_aside` from __init__.pyi
…ion 7.2.1 Bartosz Sławecki (2): Add link to blog entry from jaraco/skeleton#115 above CI build matrix. Move project metadata to `pyproject.toml` (jaraco/skeleton#122) Jason R. Coombs (25): Configure pytest to support namespace packages. Ref pytest-dev/pytest#12112. Pin against pytest 8.1.x due to pytest-dev/pytest#12194. Migrated config to pyproject.toml using jaraco.develop.migrate-config and ini2toml. Extract _handle_chunk function, one small step toward simplification. Simplify a bit by using booleans instead of ints. Extract _sub_ord function. Re-use _sub_ord where the same pattern appears. Remove unnecessary variable and type assignment Implemented _sub_ord as one regex operation. Prefer expression algebra Remove comment that's redundant to the docstring. Extract _chunk_num and _remove_last_blank functions. Avoid repetition in call and assignment and vary on the parameter. Extract function for _get_sign Prefer None for tri-state variable Remove remnant comment Refactor signout handling to consolidate some behavior and limit interacting branches. Re-write first as a single assignment of a boolean expression. Extract _render method for rendering the chunks. Simplify logic by yielding the comma separately. Consolidate returns across group and non-group. Reformat Add news fragment. Finalize Restore Python 3.8 compatibility in annotations.
…sion 25.2.0 BakerNet (9): add getcreds to cli for interface to get_credentials Syntax ruff fix _check_args format switch to --get-mode instead of separate operation Add output format argument for get operation typos change --get-mode to --mode Bartosz Sławecki (2): Add link to blog entry from jaraco/skeleton#115 above CI build matrix. Move project metadata to `pyproject.toml` (jaraco/skeleton#122) Jason R. Coombs (11): Pin against pytest 8.1.x due to pytest-dev/pytest#12194. Migrated config to pyproject.toml using jaraco.develop.migrate-config and ini2toml. Allow macos on Python 3.8 to fail as GitHub CI has dropped support. Move project.urls to appear in the order that ini2toml generates it. Remove project.scripts. Extract methods for getting the credential or password. Extract methods for emitting a credential. Re-write do_get to re-use credential objects. Move checks for 'no result' back into do_get. Rewrite _check_args using rules for required params. Consolidates logic and reduces cyclomatic complexity to 2. Add news fragment. Finalize
…n 3.18.2 Avasam (1): Allow mypy on PyPy (jaraco/skeleton#111) Bartosz Sławecki (2): Add link to blog entry from jaraco/skeleton#115 above CI build matrix. Move project metadata to `pyproject.toml` (jaraco/skeleton#122) Jason R. Coombs (13): Update compatibility matrix to reflect changes merged in Python 3.12 and anticipated for 3.13. Re-enable ignoring of temporary merge queue branches. Closes jaraco/skeleton#103. Fetch unshallow clones in readthedocs. Closes jaraco/skeleton#114. Move Python 3.11 out of the test matrix. Configure pytest to support namespace packages. Ref pytest-dev/pytest#12112. Pin against pytest 8.1.x due to pytest-dev/pytest#12194. Migrated config to pyproject.toml using jaraco.develop.migrate-config and ini2toml. Allow macos on Python 3.8 to fail as GitHub CI has dropped support. Move project.urls to appear in the order that ini2toml generates it. Remove project.scripts. Revert "Allow macos on Python 3.8 to fail as GitHub CI has dropped support." Utilize temp_dir from os_helper. Use an overlay object to make tests appear to use zipfile.Path to reduce diff with CPython. Finalize Serhiy Storchaka (1): gh-119064: Use os_helper.FakePath instead of pathlib.Path in tests (python/cpython#119065) Xie Yanbo (1): Fix typo in Lib/zipfile/_path/__init__.py
… version 3.12.1 Avasam (1): Allow mypy on PyPy (jaraco/skeleton#111) Bartosz Sławecki (3): Tweak coverage configuration for type checking (jaraco/skeleton#97) Add link to blog entry from jaraco/skeleton#115 above CI build matrix. Move project metadata to `pyproject.toml` (jaraco/skeleton#122) Christian Clauss (2): Upgrade GitHub Actions checkout (jaraco/skeleton#94) GitHub Actions: Combine tox jobs diffcov and docs (jaraco/skeleton#95) Dimitri Papadopoulos Orfanos (2): Use the ruff formatter (jaraco/skeleton#99) ruff: extended-ignore → ignore (jaraco/skeleton#105) Jason R. Coombs (27): Remove news fragment after allowing time to be processed downstream. Suppress deprecation warning in dateutil. Workaround for dateutil/dateutil#1284. Update Github Actions badge per actions/starter-workflows#1525. Separate collateral jobs on different lines for easier override/extension. Drop minimum requirement on pytest-mypy as most environments are already running much later. Closes jaraco/skeleton#96. Remove sole entry for branches-ignore. Workaround for and closes jaraco/skeleton#103. Bump year on badge Remove build and dist from excludes. It appears they are not needed and their presence blocks the names of packages like 'builder' and 'distutils'. Ref pypa/distutils#224. Exclude docs and tests directories properly per Setuptools behavior. Rely on default discovery for good heuristics for finding packages. Enable preview to enable preserving quotes. Use latest versions in RTD boilerplate. Remove Sphinx pin. Ref sphinx-doc/sphinx#11662. Include deps from the base config in diffcov. Enable complexity check and pycodestyle warnings. Closes jaraco/skeleton#110. Use 'extend-select' to avoid disabling the default config. Ref jaraco/skeleton#110. Re-enable ignoring of temporary merge queue branches. Closes jaraco/skeleton#103. Fetch unshallow clones in readthedocs. Closes jaraco/skeleton#114. Move Python 3.11 out of the test matrix. Configure pytest to support namespace packages. Ref pytest-dev/pytest#12112. Pin against pytest 8.1.x due to pytest-dev/pytest#12194. Migrated config to pyproject.toml using jaraco.develop.migrate-config and ini2toml. Allow macos on Python 3.8 to fail as GitHub CI has dropped support. Move project.urls to appear in the order that ini2toml generates it. Remove project.scripts. Revert "Allow macos on Python 3.8 to fail as GitHub CI has dropped support." Rename extras to align with core metadata spec. Finalize Sviatoslav Sydorenko (1): Enable testing merge queues @ GitHub Actions CI/CD (jaraco/skeleton#93)
…ion 5.6.0 Avasam (1): Allow mypy on PyPy (jaraco/skeleton#111) Bartosz Sławecki (2): Add link to blog entry from jaraco/skeleton#115 above CI build matrix. Move project metadata to `pyproject.toml` (jaraco/skeleton#122) Jason R. Coombs (27): Remove superfluous list comprehension. Enable complexity check and pycodestyle warnings. Closes jaraco/skeleton#110. Use 'extend-select' to avoid disabling the default config. Ref jaraco/skeleton#110. Re-enable ignoring of temporary merge queue branches. Closes jaraco/skeleton#103. Fetch unshallow clones in readthedocs. Closes jaraco/skeleton#114. Move Python 3.11 out of the test matrix. Configure pytest to support namespace packages. Ref pytest-dev/pytest#12112. Pin against pytest 8.1.x due to pytest-dev/pytest#12194. Migrated config to pyproject.toml using jaraco.develop.migrate-config and ini2toml. Allow macos on Python 3.8 to fail as GitHub CI has dropped support. Move project.urls to appear in the order that ini2toml generates it. Remove project.scripts. Revert "Allow macos on Python 3.8 to fail as GitHub CI has dropped support." Rename extras to align with core metadata spec. 👹 Feed the hobgoblins (delint). Add test capturing missed expectation. In utc.now(), bind late to allow for monkeypatching. Port the functionality from pytz to zoneinfo. Remove assertion that two commands can be compared to determine the delay between each. Capture expectations about commands coming due at a particular time. Remove use of pytz.localize and rely entirely on zoneinfo. Exclude coverage of compatibility logic. Move dependency on zoneinfo into tests only. Include tzdata on Windows Require tzdata unconditionally on windows (tests). Move compatibility logic into its own module. Add news fragment. Finalize
…version 70.2.0 Anderson Bravalheri (4): Add doctest to capture edge cases of PEP 625 Use canonicalize_version to produce fullname Add news fragment Add another test case for version Avasam (2): Use `set` instead of `True`-only `dict` Use actual boolean parameters and variables Bartosz Sławecki (1): Move project metadata to `pyproject.toml` (jaraco/skeleton#122) Christoph Reiter (2): CI: run pytest without arguments to avoid stdlib distutils being imported CI: explicitely CC/CXX for clang only mingw environments DWesl (1): Port code from CygwinCCompiler to UnixCCompiler Dimitri Papadopoulos (21): Remove extra pairs of quotes from litteral strings Use brackets for the default value of option arguments Enforce ruff/flake8-implicit-str-concat rule ISC001 A round of `ruff format` after `ruff check --fix` Enforce ruff/flake8-implicit-str-concat rule ISC003 Apply ruff rule RUF100 Apply ruff rule RUF010 Enable ruff rule RUF010 Apply ruff/pyupgrade rule UP031 Round of `ruff format` after `ruff check` Enable ruff/pyupgrade rules (UP) Apply ruff/flake8-implicit-str-concat rule ISC001 Apply ruff/flake8-implicit-str-concat rule ISC003 Enable ruff/flake8-implicit-str-concat rules (ISC) Use brackets for the default value of option arguments Apply ruff rule RUF100 Apply ruff/flake8-raise rule RSE102 Apply ruff/flake8-return rule RET502 Apply ruff/flake8-return rule RET503 Apply ruff/Perflint rule PERF401 Enforce ruff/tryceratops rule TRY300 Dustin Ingram (2): Support PEP 625 Fix canonicalization Jason R. Coombs (49): Expect to find canonicalize_* functions in packaging. Update tests to match new expectation. In test_sdist, provide a more complex name to capture canonicalization behavior. Add packaging as a vendored package. Use vendored packaging. Revert the canonicalization of the version. Ref pypa/setuptools#3593. Revert "Update tests to match new expectation." Pin against pytest 8.1.x due to pytest-dev/pytest#12194. Allow macos on Python 3.8 to fail as GitHub CI has dropped support. Move project.urls to appear in the order that ini2toml generates it. Remove project.scripts. Revert "Allow macos on Python 3.8 to fail as GitHub CI has dropped support." Rename extras to align with core metadata spec. Prefer "Source" to "Homepage" for the repository label. Add 'consolidate_linker_args' wrapper to protect the old behavior for now. Exclude compat package from coverage. Add type declaration for runtime_library_dir_option, making explicit the different return types one might expect. Extend the retention of the compatibility. 👹 Feed the hobgoblins (delint). Move compatibility modules into compat package. Move compatibility module into compat package. Fix return type to match implementation. 🧎♀️ Genuflect to the types. Oops. Meant 2025. Migrated config to pyproject.toml using jaraco.develop.migrate-config and ini2toml. Extract _make_executable for TestSpawn. Move and reword comment for brevity and clarity. Remove C901 exclusion; code is now compliant. Remove apparently unnecessary cast to list. Use proper boolean literals. Replace Popen with check_call. Extract function for _debug wrapper. Extract function to inject macos version. 👹 Feed the hobgoblins (delint). Use mkstemp unconditionally. mktemp has been deprecated since Python 2.3. Pin to pytest<8.1. Deprecate find_executable. Apply canonicalize_version with strip_trailing_zero=False. Move local ruff rules into a local section. Combine strings for clarity. Extract method for checking macro definition. Extract method for _is_valid_macro. Remove unnecessary override to the same value. Suppress EncodingWarnings in docutils. Replace use of deprecated find_executable with shutil.which. Add news fragment Remove 'normally supplied to setup()'. Declarative styles are normalized. Add a section on interpolation. Prefer relative imports for better portability. Bump version: 70.1.1 → 70.2.0 Naveen M K (9): Add support for building extensions using MinGW compilers Fix tests for `get_msvcr` function Make `test_customize_compiler` run on mingw CI: add msys2 mingw test Fix path separator issue in change_root function test_install: fix an issue specific to mingw Remove testing dependency on jaraco.text Add test for dll_libraries attribute in CygwinCCompiler class Add some tests for Mingw32CCompiler class Stephen Brennan (1): Use a separate build directory for free-threading Sviatoslav Sydorenko (3): Let codecov-action autodetect the coverage report 🧪 Unignore errors in `coverage xml` @ Cygwin Revert "🧪 Unignore errors in `coverage xml` @ Cygwin"
…1.0 to version 8.0.0 Adam Turner (1): GH-109653: Defer import of ``importlib.metadata._adapters`` (python/cpython#109829) Avasam (1): Allow mypy on PyPy (jaraco/skeleton#111) Bartosz Sławecki (2): Add link to blog entry from jaraco/skeleton#115 above CI build matrix. Move project metadata to `pyproject.toml` (jaraco/skeleton#122) Dan Blanchard (4): Add support for egg packages with files outside site-packages Tweak test Update importlib_metadata/__init__.py Fix mypy failure that has nothing to do with this PR Jason R. Coombs (23): Re-enable ignoring of temporary merge queue branches. Closes jaraco/skeleton#103. Fetch unshallow clones in readthedocs. Closes jaraco/skeleton#114. Move Python 3.11 out of the test matrix. Configure pytest to support namespace packages. Ref pytest-dev/pytest#12112. Pin against pytest 8.1.x due to pytest-dev/pytest#12194. Migrated config to pyproject.toml using jaraco.develop.migrate-config and ini2toml. Allow macos on Python 3.8 to fail as GitHub CI has dropped support. Move project.urls to appear in the order that ini2toml generates it. Remove project.scripts. Revert "Allow macos on Python 3.8 to fail as GitHub CI has dropped support." Rename extras to align with core metadata spec. gh-120801: Update fixtures. Finalize Prefer "Source" to "Homepage" for the repository label. Move _relative_to compatibility to a compat module. Update wrapper to rely on 'relative_to(walk_up=True)' on Python 3.12 and compatibility wrapper on Python 3.11 and earlier. Mark compat code as uncovered. Revert "Fix mypy failure that has nothing to do with this PR" Remove additional method in SimplePath. Add news fragment Finalize Removed deprecated support for Distribution subclasses not implementing abstract methods. Message.__getitem__ now raises a KeyError on missing keys. Finalize
… version 7.1.0 Bartosz Sławecki (1): Move project metadata to `pyproject.toml` (jaraco/skeleton#122) Dimitri Papadopoulos Orfanos (2): "preserve" does not require preview any more (jaraco/skeleton#133) Enforce ruff/Perflint rule PERF401 (jaraco/skeleton#132) Jason R. Coombs (19): Pin against pytest 8.1.x due to pytest-dev/pytest#12194. Migrated config to pyproject.toml using jaraco.develop.migrate-config and ini2toml. Allow macos on Python 3.8 to fail as GitHub CI has dropped support. Move project.urls to appear in the order that ini2toml generates it. Remove project.scripts. Revert "Allow macos on Python 3.8 to fail as GitHub CI has dropped support." Rename extras to align with core metadata spec. Prefer "Source" to "Homepage" for the repository label. Exclude pytest-ruff (and thus ruff), which cannot build on cygwin. Re-enable preview, this time not for one specific feature, but for all features in preview. Use /usr/bin/env to launch py from the path. cpython-v3.13.0rc1 rev=e4a3e786a5eb 👹 Feed the hobgoblins (delint). Reformatted using ruff Converted sync script to use typer instead of autocommand. Add news fragment. Finalize Allow to specify any ref to sync. cpython-main rev=be257c58152e Finalize
…to version 6.0.0 Bartosz Sławecki (2): Add link to blog entry from jaraco/skeleton#115 above CI build matrix. Move project metadata to `pyproject.toml` (jaraco/skeleton#122) Dimitri Papadopoulos Orfanos (2): "preserve" does not require preview any more (jaraco/skeleton#133) Enforce ruff/Perflint rule PERF401 (jaraco/skeleton#132) Jason R. Coombs (24): Pin against pytest 8.1.x due to pytest-dev/pytest#12194. Migrated config to pyproject.toml using jaraco.develop.migrate-config and ini2toml. Allow macos on Python 3.8 to fail as GitHub CI has dropped support. Move project.urls to appear in the order that ini2toml generates it. Remove project.scripts. Revert "Allow macos on Python 3.8 to fail as GitHub CI has dropped support." Rename extras to align with core metadata spec. Prefer "Source" to "Homepage" for the repository label. Exclude pytest-ruff (and thus ruff), which cannot build on cygwin. Re-enable preview, this time not for one specific feature, but for all features in preview. Replace stale comment with a docstring explaining the behavior. Expand the docstring for on_interrupt to explain where it might be useful. Removed deprecated 'tarball_context', 'infer_compression', and 'null' contexts. Moved module into its own package. Replace if block with algebraic expression. Replace explicit devnull with subprocess.devnull. Added test coverage for repo_context. Fixed bug in repo_context where standard output from git would not be hidden (because git emits standard output on the stderr stream). Suppress logging from the tarfile_served. Expanded test coverage to cover 100% of the code. Declare project as typed. Finalize Apply Gemini's ideas for improving the types. Add workaround for cleaning out read-only files when wiping repo context. 🚡 Toil the docs.
…0.1 to version 5.1.0 Anderson Bravalheri (1): Add `--fix` flag to ruff pre-commit hook for automatic suggestion of fixes (jaraco/skeleton#140) Avasam (4): Add Protocols, remove @overload, from `.coveragerc` `exclude_also` (jaraco/skeleton#135) Loosen restrictions on mypy (jaraco/skeleton#136) Pass mypy and link issues Fully typed `RangeMap` and avoid complete iterations to find matches (#16) Bartosz Sławecki (1): Move project metadata to `pyproject.toml` (jaraco/skeleton#122) Dimitri Papadopoulos Orfanos (3): "preserve" does not require preview any more (jaraco/skeleton#133) Enforce ruff/Perflint rule PERF401 (jaraco/skeleton#132) Update to the latest ruff version (jaraco/skeleton#137) Jason R. Coombs (14): Pin against pytest 8.1.x due to pytest-dev/pytest#12194. Migrated config to pyproject.toml using jaraco.develop.migrate-config and ini2toml. Allow macos on Python 3.8 to fail as GitHub CI has dropped support. Move project.urls to appear in the order that ini2toml generates it. Remove project.scripts. Revert "Allow macos on Python 3.8 to fail as GitHub CI has dropped support." Rename extras to align with core metadata spec. Prefer "Source" to "Homepage" for the repository label. Exclude pytest-ruff (and thus ruff), which cannot build on cygwin. Re-enable preview, this time not for one specific feature, but for all features in preview. Split the test dependencies into four classes (test, cover, type, check). (jaraco/skeleton#139) Add upstream and local sections for 'type' extra, since many projects will have 'types-*' dependencies. Disable mypy for now. Ref jaraco/skeleton#143 Finalize Remove unsupported attribution. See jaraco/skeleton#144.
Likely related to #12112, discovered in jaraco/keyring#676, a new regression appears in pytest 8.1 relating to collection. Consider this minimal example:
It seems that once the
foo/bar/__init__.py
has been collected for doctesting, the collection of the tests in test_something will start to fail whenfoo
has no attributebar
. Any of the following tweaks will bypass the failure:import-mode
Something about the pytest discovery and import machinery is breaking the Python convention that importing a submodule causes the submodule to be added as an attribute of the parent module.
The text was updated successfully, but these errors were encountered: