mirror of
				https://github.com/python/cpython.git
				synced 2025-10-26 11:14:33 +00:00 
			
		
		
		
	gh-128030: Avoid error from PyModule_GetFilenameObject for non-module (#128047)
I missed the extra `PyModule_Check` in #127660 because I was looking at 3.12 as the base implementation for import from. This meant that I missed the `PyModuleCheck` introduced in #112661.
This commit is contained in:
		
							parent
							
								
									daa260ebb1
								
							
						
					
					
						commit
						45e6dd63b8
					
				
					 3 changed files with 25 additions and 1 deletions
				
			
		|  | @ -851,6 +851,29 @@ def test_frozen_module_from_import_error(self): | |||
|                 stdout, stderr = popen.communicate() | ||||
|                 self.assertIn(expected_error, stdout) | ||||
| 
 | ||||
|     def test_non_module_from_import_error(self): | ||||
|         prefix = """ | ||||
| import sys | ||||
| class NotAModule: ... | ||||
| nm = NotAModule() | ||||
| nm.symbol = 123 | ||||
| sys.modules["not_a_module"] = nm | ||||
| from not_a_module import symbol | ||||
| """ | ||||
|         scripts = [ | ||||
|             prefix + "from not_a_module import missing_symbol", | ||||
|             prefix + "nm.__spec__ = []\nfrom not_a_module import missing_symbol", | ||||
|         ] | ||||
|         for script in scripts: | ||||
|             with self.subTest(script=script): | ||||
|                 expected_error = ( | ||||
|                     b"ImportError: cannot import name 'missing_symbol' from " | ||||
|                     b"'<unknown module name>' (unknown location)" | ||||
|                 ) | ||||
|             popen = script_helper.spawn_python("-c", script) | ||||
|             stdout, stderr = popen.communicate() | ||||
|             self.assertIn(expected_error, stdout) | ||||
| 
 | ||||
|     def test_script_shadowing_stdlib(self): | ||||
|         script_errors = [ | ||||
|             ( | ||||
|  |  | |||
|  | @ -0,0 +1 @@ | |||
| Avoid error from calling ``PyModule_GetFilenameObject`` on a non-module object when importing a non-existent symbol from a non-module object. | ||||
|  | @ -2860,7 +2860,7 @@ _PyEval_ImportFrom(PyThreadState *tstate, PyObject *v, PyObject *name) | |||
|         } | ||||
|     } | ||||
| 
 | ||||
|     if (origin == NULL) { | ||||
|     if (origin == NULL && PyModule_Check(v)) { | ||||
|         // Fall back to __file__ for diagnostics if we don't have
 | ||||
|         // an origin that is a location
 | ||||
|         origin = PyModule_GetFilenameObject(v); | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 Shantanu
						Shantanu