Commit b206a80d authored by Brian Curtin's avatar Brian Curtin

Fix #10854. Make use of the new path and name attributes on ImportError

for extension modules on Windows.
parent 15439817
...@@ -337,6 +337,24 @@ class ImportTests(unittest.TestCase): ...@@ -337,6 +337,24 @@ class ImportTests(unittest.TestCase):
del sys.path[0] del sys.path[0]
remove_files(TESTFN) 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): class PycRewritingTests(unittest.TestCase):
# Test that the `co_filename` attribute on code objects always points # 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? ...@@ -10,6 +10,10 @@ What's New in Python 3.3.0 Alpha 3?
Core and Builtins 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 - Issue #14582: Import directly returns the module as returned by a loader when
possible instead of fetching it from sys.modules. possible instead of fetching it from sys.modules.
......
...@@ -254,8 +254,9 @@ dl_funcptr _PyImport_GetDynLoadWindows(const char *shortname, ...@@ -254,8 +254,9 @@ dl_funcptr _PyImport_GetDynLoadWindows(const char *shortname,
theLength)); theLength));
} }
if (message != NULL) { if (message != NULL) {
PyErr_SetObject(PyExc_ImportError, message); PyErr_SetFromImportErrorWithNameAndPath(message,
Py_DECREF(message); PyUnicode_FromString(shortname),
pathname);
} }
return NULL; return NULL;
} else { } else {
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment