Skip to content
This repository was archived by the owner on Oct 20, 2020. It is now read-only.

Commit 9c03622

Browse files
create missing directory when creating package init file (#34)
1 parent 825ca18 commit 9c03622

File tree

2 files changed

+10
-0
lines changed

2 files changed

+10
-0
lines changed

extract_wheels/lib/namespace_pkgs.py

Lines changed: 2 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -84,6 +84,8 @@ def add_pkgutil_style_namespace_pkg_init(dir_path: str) -> None:
8484

8585
if os.path.isfile(ns_pkg_init_filepath):
8686
raise ValueError("%s already contains an __init__.py file." % dir_path)
87+
if not os.path.exists(dir_path):
88+
os.makedirs(dir_path)
8789
with open(ns_pkg_init_filepath, "w") as ns_pkg_init_f:
8890
# See https://packaging.python.org/guides/packaging-namespace-packages/#pkgutil-style-namespace-packages
8991
ns_pkg_init_f.write(

extract_wheels/lib/namespace_pkgs_test.py

Lines changed: 8 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -131,5 +131,13 @@ def test_empty_case(self):
131131
self.assertEqual(actual, set())
132132

133133

134+
class TestaddPkgutilStyleNamespacePkgInit(unittest.TestCase):
135+
def test_missing_directory_is_created(self):
136+
directory = TempDir()
137+
missing_directory = pathlib.Path(directory.root()) / "missing_directory"
138+
namespace_pkgs.add_pkgutil_style_namespace_pkg_init(str(missing_directory))
139+
self.assertTrue(missing_directory.is_dir())
140+
141+
134142
if __name__ == "__main__":
135143
unittest.main()

0 commit comments

Comments
 (0)