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

for extension modules on Windows.
This commit is contained in:
Brian Curtin 2012-04-16 00:10:17 -05:00
parent 15439817bf
commit b206a80dab
3 changed files with 25 additions and 2 deletions

View File

@ -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

View File

@ -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.

View File

@ -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 {