mirror of
				https://github.com/django/django.git
				synced 2025-10-24 14:16:09 +00:00 
			
		
		
		
	Fixed #34952 -- Copied dir list when processing locale folders to avoid missing entries during os.walk traversal.
Co-authored-by: Natalia <124304+nessita@users.noreply.github.com>
This commit is contained in:
		
				
					committed by
					
						 Natalia Bidart
						Natalia Bidart
					
				
			
			
				
	
			
			
			
						parent
						
							b863c5ffde
						
					
				
				
					commit
					ad41f1c53a
				
			| @@ -91,7 +91,8 @@ class Command(BaseCommand): | ||||
|  | ||||
|         # Walk entire tree, looking for locale directories | ||||
|         for dirpath, dirnames, filenames in os.walk(".", topdown=True): | ||||
|             for dirname in dirnames: | ||||
|             # As we may modify dirnames, iterate through a copy of it instead | ||||
|             for dirname in list(dirnames): | ||||
|                 if is_ignored_path( | ||||
|                     os.path.normpath(os.path.join(dirpath, dirname)), ignore_patterns | ||||
|                 ): | ||||
|   | ||||
| @@ -195,6 +195,64 @@ class IgnoreDirectoryCompilationTests(MessageCompilationTests): | ||||
|         self.assertNoneExist(self.CACHE_DIR, ["en", "fr", "it"]) | ||||
|         self.assertNoneExist(self.NESTED_DIR, ["en", "fr", "it"]) | ||||
|  | ||||
|     def test_no_dirs_accidentally_skipped(self): | ||||
|         os_walk_results = [ | ||||
|             # To discover .po filepaths, compilemessages uses with a starting list of | ||||
|             # basedirs to inspect, which in this scenario are: | ||||
|             #   ["conf/locale", "locale"] | ||||
|             # Then os.walk is used to discover other locale dirs, ignoring dirs matching | ||||
|             # `ignore_patterns`. Mock the results to place an ignored directory directly | ||||
|             # before and after a directory named "locale". | ||||
|             [("somedir", ["ignore", "locale", "ignore"], [])], | ||||
|             # This will result in three basedirs discovered: | ||||
|             #   ["conf/locale", "locale", "somedir/locale"] | ||||
|             # os.walk is called for each locale in each basedir looking for .po files. | ||||
|             # In this scenario, we need to mock os.walk results for "en", "fr", and "it" | ||||
|             # locales for each basedir: | ||||
|             [("exclude/locale/LC_MESSAGES", [], ["en.po"])], | ||||
|             [("exclude/locale/LC_MESSAGES", [], ["fr.po"])], | ||||
|             [("exclude/locale/LC_MESSAGES", [], ["it.po"])], | ||||
|             [("exclude/conf/locale/LC_MESSAGES", [], ["en.po"])], | ||||
|             [("exclude/conf/locale/LC_MESSAGES", [], ["fr.po"])], | ||||
|             [("exclude/conf/locale/LC_MESSAGES", [], ["it.po"])], | ||||
|             [("exclude/somedir/locale/LC_MESSAGES", [], ["en.po"])], | ||||
|             [("exclude/somedir/locale/LC_MESSAGES", [], ["fr.po"])], | ||||
|             [("exclude/somedir/locale/LC_MESSAGES", [], ["it.po"])], | ||||
|         ] | ||||
|  | ||||
|         module_path = "django.core.management.commands.compilemessages" | ||||
|         with mock.patch(f"{module_path}.os.walk", side_effect=os_walk_results): | ||||
|             with mock.patch(f"{module_path}.os.path.isdir", return_value=True): | ||||
|                 with mock.patch( | ||||
|                     f"{module_path}.Command.compile_messages" | ||||
|                 ) as mock_compile_messages: | ||||
|                     call_command("compilemessages", ignore=["ignore"], verbosity=4) | ||||
|  | ||||
|         expected = [ | ||||
|             ( | ||||
|                 [ | ||||
|                     ("exclude/locale/LC_MESSAGES", "en.po"), | ||||
|                     ("exclude/locale/LC_MESSAGES", "fr.po"), | ||||
|                     ("exclude/locale/LC_MESSAGES", "it.po"), | ||||
|                 ], | ||||
|             ), | ||||
|             ( | ||||
|                 [ | ||||
|                     ("exclude/conf/locale/LC_MESSAGES", "en.po"), | ||||
|                     ("exclude/conf/locale/LC_MESSAGES", "fr.po"), | ||||
|                     ("exclude/conf/locale/LC_MESSAGES", "it.po"), | ||||
|                 ], | ||||
|             ), | ||||
|             ( | ||||
|                 [ | ||||
|                     ("exclude/somedir/locale/LC_MESSAGES", "en.po"), | ||||
|                     ("exclude/somedir/locale/LC_MESSAGES", "fr.po"), | ||||
|                     ("exclude/somedir/locale/LC_MESSAGES", "it.po"), | ||||
|                 ], | ||||
|             ), | ||||
|         ] | ||||
|         self.assertEqual([c.args for c in mock_compile_messages.mock_calls], expected) | ||||
|  | ||||
|  | ||||
| class CompilationErrorHandling(MessageCompilationTests): | ||||
|     def test_error_reported_by_msgfmt(self): | ||||
|   | ||||
		Reference in New Issue
	
	Block a user