summaryrefslogtreecommitdiffstats
path: root/Lib/test/test_zipimport.py
diff options
context:
space:
mode:
Diffstat (limited to 'Lib/test/test_zipimport.py')
-rw-r--r--Lib/test/test_zipimport.py17
1 files changed, 17 insertions, 0 deletions
diff --git a/Lib/test/test_zipimport.py b/Lib/test/test_zipimport.py
index daa5138..4a934ff 100644
--- a/Lib/test/test_zipimport.py
+++ b/Lib/test/test_zipimport.py
@@ -17,6 +17,10 @@ import doctest
import inspect
import io
from traceback import extract_tb, extract_stack, print_tb
+try:
+ import zlib
+except ImportError:
+ zlib = None
test_src = """\
def get_name():
@@ -669,6 +673,19 @@ class UncompressedZipImportTestCase(ImportHooksBaseTestCase):
class CompressedZipImportTestCase(UncompressedZipImportTestCase):
compression = ZIP_DEFLATED
+ @support.cpython_only
+ def test_issue31602(self):
+ # There shouldn't be an assertion failure in zipimporter.get_source()
+ # in case of a bad zlib.decompress().
+ def bad_decompress(*args):
+ return None
+ with ZipFile(TEMP_ZIP, 'w') as zip_file:
+ self.addCleanup(support.unlink, TEMP_ZIP)
+ zip_file.writestr('bar.py', b'print("hello world")', ZIP_DEFLATED)
+ zi = zipimport.zipimporter(TEMP_ZIP)
+ with support.swap_attr(zlib, 'decompress', bad_decompress):
+ self.assertRaises(TypeError, zi.get_source, 'bar')
+
class BadFileZipImportTestCase(unittest.TestCase):
def assertZipFailure(self, filename):