mirror of
https://github.com/python/cpython.git
synced 2025-09-26 18:29:57 +00:00
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
3 changed files with 25 additions and 2 deletions
|
@ -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?
|
||||||
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,
|
||||||
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 {
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue