mirror of
				https://github.com/django/django.git
				synced 2025-10-24 22:26:08 +00:00 
			
		
		
		
	Fixed #4695 - Worked around a problem of xgettext ignoring some translation strings in JavaScript files. Thanks, Ramiro Morales.
git-svn-id: http://code.djangoproject.com/svn/django/trunk@12441 bcc190cf-cafb-0310-a4f2-bffc1f526a37
This commit is contained in:
		| @@ -9,7 +9,7 @@ from subprocess import PIPE, Popen | |||||||
| from django.core.management.base import CommandError, BaseCommand | from django.core.management.base import CommandError, BaseCommand | ||||||
| from django.utils.text import get_text_list | from django.utils.text import get_text_list | ||||||
|  |  | ||||||
| pythonize_re = re.compile(r'\n\s*//') | pythonize_re = re.compile(r'(?:^|\n)\s*//') | ||||||
|  |  | ||||||
| def handle_extensions(extensions=('html',)): | def handle_extensions(extensions=('html',)): | ||||||
|     """ |     """ | ||||||
|   | |||||||
							
								
								
									
										0
									
								
								tests/regressiontests/makemessages/__init__.py
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										0
									
								
								tests/regressiontests/makemessages/__init__.py
									
									
									
									
									
										Normal file
									
								
							
							
								
								
									
										4
									
								
								tests/regressiontests/makemessages/javascript.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										4
									
								
								tests/regressiontests/makemessages/javascript.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,4 @@ | |||||||
|  | // ' | ||||||
|  | gettext('This literal should be included.') | ||||||
|  | // ' | ||||||
|  | gettext('This one as well.') | ||||||
							
								
								
									
										0
									
								
								tests/regressiontests/makemessages/locale/dummy
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										0
									
								
								tests/regressiontests/makemessages/locale/dummy
									
									
									
									
									
										Normal file
									
								
							
							
								
								
									
										0
									
								
								tests/regressiontests/makemessages/models.py
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										0
									
								
								tests/regressiontests/makemessages/models.py
									
									
									
									
									
										Normal file
									
								
							
							
								
								
									
										42
									
								
								tests/regressiontests/makemessages/tests.py
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										42
									
								
								tests/regressiontests/makemessages/tests.py
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,42 @@ | |||||||
|  | import os | ||||||
|  | import re | ||||||
|  | import shutil | ||||||
|  | from django.test import TestCase | ||||||
|  | from django.core import management | ||||||
|  |  | ||||||
|  | LOCALE='de' | ||||||
|  |  | ||||||
|  | class ExtractorTests(TestCase): | ||||||
|  |  | ||||||
|  |     def setUp(self): | ||||||
|  |         self._cwd = os.getcwd() | ||||||
|  |         self.test_dir = os.path.abspath(os.path.dirname(__file__)) | ||||||
|  |  | ||||||
|  |     def _rmrf(self, dname): | ||||||
|  |         if os.path.commonprefix([self.test_dir, os.path.abspath(dname)]) != self.test_dir: | ||||||
|  |             return | ||||||
|  |         shutil.rmtree(dname) | ||||||
|  |  | ||||||
|  |     def tearDown(self): | ||||||
|  |         os.chdir(self.test_dir) | ||||||
|  |         try: | ||||||
|  |             self._rmrf('locale/%s' % LOCALE) | ||||||
|  |         except OSError: | ||||||
|  |             pass | ||||||
|  |         os.chdir(self._cwd) | ||||||
|  |  | ||||||
|  |     def assertMsgId(self, msgid, s): | ||||||
|  |         return self.assert_(re.search('^msgid "%s"' % msgid, s, re.MULTILINE)) | ||||||
|  |  | ||||||
|  |  | ||||||
|  | class JavascriptExtractorTests(ExtractorTests): | ||||||
|  |  | ||||||
|  |     PO_FILE='locale/%s/LC_MESSAGES/djangojs.po' % LOCALE | ||||||
|  |  | ||||||
|  |     def test_javascript_literals(self): | ||||||
|  |         os.chdir(self.test_dir) | ||||||
|  |         management.call_command('makemessages', domain='djangojs', locale=LOCALE, verbosity=0) | ||||||
|  |         self.assert_(os.path.exists(self.PO_FILE)) | ||||||
|  |         po_contents = open(self.PO_FILE, 'r').read() | ||||||
|  |         self.assertMsgId('This literal should be included.', po_contents) | ||||||
|  |         self.assertMsgId('This one as well.', po_contents) | ||||||
		Reference in New Issue
	
	Block a user