Browse Source

tests: Compat w/ older pytest by using tmpdir instead of tmp_path

rdb 2 years ago
parent
commit
479774477b
2 changed files with 22 additions and 22 deletions
  1. 13 13
      tests/dist/test_FreezeTool.py
  2. 9 9
      tests/showbase/test_Loader.py

+ 13 - 13
tests/dist/test_FreezeTool.py

@@ -14,32 +14,32 @@ def test_Freezer_moduleSuffixes():
             assert mode == 'rb'
             assert mode == 'rb'
 
 
 
 
-def test_Freezer_getModulePath_getModuleStar(tmp_path):
+def test_Freezer_getModulePath_getModuleStar(tmpdir):
     # Package 1 can be imported
     # Package 1 can be imported
-    package1 = tmp_path / "package1"
+    package1 = tmpdir.join("package1")
     package1.mkdir()
     package1.mkdir()
-    (package1 / "submodule1.py").write_text(u"")
-    (package1 / "__init__.py").write_text(u"")
+    package1.join("submodule1.py").write("")
+    package1.join("__init__.py").write("")
 
 
     # Package 2 can not be imported
     # Package 2 can not be imported
-    package2 = tmp_path / "package2"
+    package2 = tmpdir.join("package2")
     package2.mkdir()
     package2.mkdir()
-    (package2 / "submodule2.py").write_text(u"")
-    (package2 / "__init__.py").write_text(u"raise ImportError\n")
+    package2.join("submodule2.py").write("")
+    package2.join("__init__.py").write("raise ImportError\n")
 
 
     # Module 1 can be imported
     # Module 1 can be imported
-    (tmp_path / "module1.py").write_text(u"")
+    tmpdir.join("module1.py").write("")
 
 
     # Module 2 can not be imported
     # Module 2 can not be imported
-    (tmp_path / "module2.py").write_text(u"raise ImportError\n")
+    tmpdir.join("module2.py").write("raise ImportError\n")
 
 
     # Module 3 has a custom __path__ and __all__
     # Module 3 has a custom __path__ and __all__
-    (tmp_path / "module3.py").write_text(u"__path__ = ['foobar']\n__all__ = ['test']\n")
+    tmpdir.join("module3.py").write("__path__ = ['foobar']\n__all__ = ['test']\n")
 
 
     backup = sys.path
     backup = sys.path
     try:
     try:
         # Don't fail if first item on path does not exist
         # Don't fail if first item on path does not exist
-        sys.path = [str(tmp_path / "nonexistent"), str(tmp_path)]
+        sys.path = [str(tmpdir.join("nonexistent")), str(tmpdir)]
 
 
         freezer = Freezer()
         freezer = Freezer()
         assert freezer.getModulePath("nonexist") == None
         assert freezer.getModulePath("nonexist") == None
@@ -68,7 +68,7 @@ def test_Freezer_getModulePath_getModuleStar(tmp_path):
 
 
 
 
 @pytest.mark.parametrize("use_console", (False, True))
 @pytest.mark.parametrize("use_console", (False, True))
-def test_Freezer_generateRuntimeFromStub(tmp_path, use_console):
+def test_Freezer_generateRuntimeFromStub(tmpdir, use_console):
     try:
     try:
         # If installed as a wheel
         # If installed as a wheel
         import panda3d_tools
         import panda3d_tools
@@ -91,7 +91,7 @@ def test_Freezer_generateRuntimeFromStub(tmp_path, use_console):
     if not os.path.isfile(stub_file):
     if not os.path.isfile(stub_file):
         pytest.skip("Unable to find deploy-stub executable")
         pytest.skip("Unable to find deploy-stub executable")
 
 
-    target = str(tmp_path / ('stubtest' + suffix))
+    target = str(tmpdir.join('stubtest' + suffix))
 
 
     freezer = Freezer()
     freezer = Freezer()
     freezer.addModule('module2', filename='module2.py', text='print("Module imported")')
     freezer.addModule('module2', filename='module2.py', text='print("Module imported")')

+ 9 - 9
tests/showbase/test_Loader.py

@@ -71,9 +71,9 @@ def test_load_model_okmissing(loader):
     assert model is None
     assert model is None
 
 
 
 
-def test_loader_entry_points(tmp_path):
+def test_loader_entry_points(tmpdir):
     # A dummy loader for .fnrgl files.
     # A dummy loader for .fnrgl files.
-    (tmp_path / "fnargle.py").write_text(u"""
+    tmpdir.join("fnargle.py").write("""
 from panda3d.core import ModelRoot
 from panda3d.core import ModelRoot
 import sys
 import sys
 
 
@@ -88,19 +88,19 @@ class FnargleLoader:
     def load_file(path, options, record=None):
     def load_file(path, options, record=None):
         return ModelRoot("fnargle")
         return ModelRoot("fnargle")
 """)
 """)
-    (tmp_path / "fnargle.dist-info").mkdir()
-    (tmp_path / "fnargle.dist-info" / "METADATA").write_text(u"""
+    tmpdir.join("fnargle.dist-info").mkdir()
+    tmpdir.join("fnargle.dist-info", "METADATA").write("""
 Metadata-Version: 2.0
 Metadata-Version: 2.0
 Name: fnargle
 Name: fnargle
 Version: 1.0.0
 Version: 1.0.0
 """)
 """)
-    (tmp_path / "fnargle.dist-info" / "entry_points.txt").write_text(u"""
+    tmpdir.join("fnargle.dist-info", "entry_points.txt").write("""
 [panda3d.loaders]
 [panda3d.loaders]
 fnrgl = fnargle:FnargleLoader
 fnrgl = fnargle:FnargleLoader
 """)
 """)
 
 
-    model_path = tmp_path / "test.fnrgl"
-    model_path.write_text(u"")
+    model_path = tmpdir.join("test.fnrgl")
+    model_path.write("")
 
 
     if sys.version_info >= (3, 11):
     if sys.version_info >= (3, 11):
         import sysconfig
         import sysconfig
@@ -126,7 +126,7 @@ fnrgl = fnargle:FnargleLoader
     file_type = None
     file_type = None
     try:
     try:
         # We do this so we don't re-register thirdparty loaders
         # We do this so we don't re-register thirdparty loaders
-        sys.path = [str(tmp_path), platstdlib, stdlib]
+        sys.path = [str(tmpdir), platstdlib, stdlib]
         if sys.version_info < (3, 8):
         if sys.version_info < (3, 8):
             pkg_resources._initialize_master_working_set()
             pkg_resources._initialize_master_working_set()
 
 
@@ -151,7 +151,7 @@ fnrgl = fnargle:FnargleLoader
         assert 'fnargle' in sys.modules
         assert 'fnargle' in sys.modules
 
 
         # Now try loading a fnargle file
         # Now try loading a fnargle file
-        model_fn = Filename(model_path)
+        model_fn = Filename.from_os_specific(str(model_path))
         model_fn.make_true_case()
         model_fn.make_true_case()
         model = loader.load_model(model_fn, noCache=True)
         model = loader.load_model(model_fn, noCache=True)
         assert model is not None
         assert model is not None