Fix #10854. Make use of the new path and name attributes on ImportError
for extension modules on Windows.
This commit is contained in:
parent
15439817bf
commit
b206a80dab
|
@ -337,6 +337,24 @@ class ImportTests(unittest.TestCase):
|
|||
del sys.path[0]
|
||||
remove_files(TESTFN)
|
||||
|
||||
@unittest.skipUnless(sys.platform == "win32", "Windows specific")
|
||||
def test_extension_import_fail(self):
|
||||
# Issue 1559549 added `name` and `path` attributes to ImportError
|
||||
# in order to provide better detail. Issue 10854 implemented those
|
||||
# attributes on import failures of extensions on Windows.
|
||||
debug = True if sys.executable[-6:] == "_d.exe" else False
|
||||
pkg_name = "extension"
|
||||
pkg_file = pkg_name + "{}".format("_d.pyd" if debug else ".pyd")
|
||||
with open(pkg_file, "w"): pass
|
||||
try:
|
||||
with self.assertRaises(ImportError) as err:
|
||||
import extension
|
||||
self.assertEqual(err.exception.name, pkg_name)
|
||||
# The path we get back has the dot-slash, e.g., ".\\extension.pyd"
|
||||
self.assertEqual(os.path.relpath(err.exception.path), pkg_file)
|
||||
finally:
|
||||
unlink(pkg_file)
|
||||
|
||||
|
||||
class PycRewritingTests(unittest.TestCase):
|
||||
# Test that the `co_filename` attribute on code objects always points
|
||||
|
|
|
@ -10,6 +10,10 @@ What's New in Python 3.3.0 Alpha 3?
|
|||
Core and Builtins
|
||||
-----------------
|
||||
|
||||
- Issue #10854: The ImportError raised when an extension module on Windows
|
||||
fails to import now uses the new path and name attributes from
|
||||
Issue #1559549.
|
||||
|
||||
- Issue #14582: Import directly returns the module as returned by a loader when
|
||||
possible instead of fetching it from sys.modules.
|
||||
|
||||
|
|
|
@ -254,8 +254,9 @@ dl_funcptr _PyImport_GetDynLoadWindows(const char *shortname,
|
|||
theLength));
|
||||
}
|
||||
if (message != NULL) {
|
||||
PyErr_SetObject(PyExc_ImportError, message);
|
||||
Py_DECREF(message);
|
||||
PyErr_SetFromImportErrorWithNameAndPath(message,
|
||||
PyUnicode_FromString(shortname),
|
||||
pathname);
|
||||
}
|
||||
return NULL;
|
||||
} else {
|
||||
|
|
Loading…
Reference in New Issue