mirror of
				https://github.com/django/django.git
				synced 2025-10-25 22:56:12 +00:00 
			
		
		
		
	Refs #29713 -- Improved error message from translation system check.
This commit is contained in:
		
				
					committed by
					
						 Carlton Gibson
						Carlton Gibson
					
				
			
			
				
	
			
			
			
						parent
						
							ccf870ebf5
						
					
				
				
					commit
					570402ffd7
				
			| @@ -1,25 +1,19 @@ | |||||||
| import re |  | ||||||
|  |  | ||||||
| from django.conf import settings | from django.conf import settings | ||||||
| from django.utils.translation.trans_real import language_code_re | from django.utils.translation.trans_real import language_code_re | ||||||
|  |  | ||||||
| from . import Error, Tags, register | from . import Error, Tags, register | ||||||
|  |  | ||||||
|  | E001 = Error( | ||||||
|  |     'You have provided an invalid value for the LANGUAGE_CODE setting.', | ||||||
|  |     id='translation.E001', | ||||||
|  | ) | ||||||
|  |  | ||||||
|  |  | ||||||
| @register(Tags.translation) | @register(Tags.translation) | ||||||
| def check_setting_language_code(app_configs, **kwargs): | def check_setting_language_code(app_configs, **kwargs): | ||||||
|     """ |     """ | ||||||
|     Errors if language code is in the wrong format. Language codes specification outlined by |     Errors if language code setting is invalid. | ||||||
|     https://en.wikipedia.org/wiki/IETF_language_tag#Syntax_of_language_tags |  | ||||||
|     """ |     """ | ||||||
|     match_result = re.match(language_code_re, settings.LANGUAGE_CODE) |     if not language_code_re.match(settings.LANGUAGE_CODE): | ||||||
|     errors = [] |         return [E001] | ||||||
|     if not match_result: |     return [] | ||||||
|         errors.append(Error( |  | ||||||
|             "LANGUAGE_CODE in settings.py is {}. It should be in the form ll or ll-cc where ll is the language and cc " |  | ||||||
|             "is the country. Examples include: it, de-at, es, pt-br. The full set of language codes specifications is " |  | ||||||
|             "outlined by https://en.wikipedia.org/wiki/IETF_language_tag#Syntax_of_language_tags".format( |  | ||||||
|                 settings.LANGUAGE_CODE), |  | ||||||
|             id="translation.E001", |  | ||||||
|         )) |  | ||||||
|     return errors |  | ||||||
|   | |||||||
| @@ -85,8 +85,8 @@ Django's system checks are organized using the following tags: | |||||||
| * ``signals``: Checks on signal declarations and handler registrations. | * ``signals``: Checks on signal declarations and handler registrations. | ||||||
| * ``staticfiles``: Checks :mod:`django.contrib.staticfiles` configuration. | * ``staticfiles``: Checks :mod:`django.contrib.staticfiles` configuration. | ||||||
| * ``templates``: Checks template related configuration. | * ``templates``: Checks template related configuration. | ||||||
|  | * ``translation``: Checks translation related configuration. | ||||||
| * ``urls``: Checks URL configuration. | * ``urls``: Checks URL configuration. | ||||||
| * ``translation``: Checks language formats used for translation. |  | ||||||
|  |  | ||||||
| Some checks may be registered with multiple tags. | Some checks may be registered with multiple tags. | ||||||
|  |  | ||||||
| @@ -427,6 +427,14 @@ configured: | |||||||
|   :setting:`OPTIONS <TEMPLATES-OPTIONS>` must be a string but got: ``{value}`` |   :setting:`OPTIONS <TEMPLATES-OPTIONS>` must be a string but got: ``{value}`` | ||||||
|   (``{type}``). |   (``{type}``). | ||||||
|  |  | ||||||
|  | Translation | ||||||
|  | ----------- | ||||||
|  |  | ||||||
|  | The following checks are performed on your translation configuration: | ||||||
|  |  | ||||||
|  | * **translation.E001**: You have provided an invalid value for the | ||||||
|  |   :setting:`LANGUAGE_CODE` setting. | ||||||
|  |  | ||||||
| URLs | URLs | ||||||
| ---- | ---- | ||||||
|  |  | ||||||
| @@ -450,18 +458,6 @@ The following checks are performed on your URL configuration: | |||||||
| * **urls.E006**: The :setting:`MEDIA_URL`/ :setting:`STATIC_URL` setting must | * **urls.E006**: The :setting:`MEDIA_URL`/ :setting:`STATIC_URL` setting must | ||||||
|   end with a slash. |   end with a slash. | ||||||
|  |  | ||||||
| Translation |  | ||||||
| ----------- |  | ||||||
|  |  | ||||||
| The following checks are performed on your translation configuration: |  | ||||||
|  |  | ||||||
| * **translation.E001**: LANGUAGE_CODE in settings.py is ``<language_code>``. |  | ||||||
|    It should be in the form ll or ll-cc where ll is the language and cc is the |  | ||||||
|    country. Examples include: ``it``, ``de-at``, ``es``, ``pt-br``. The full |  | ||||||
|    set of language codes specifications is outlined by |  | ||||||
|    https://en.wikipedia.org/wiki/IETF_language_tag#Syntax_of_language_tags |  | ||||||
|  |  | ||||||
|  |  | ||||||
| ``contrib`` app checks | ``contrib`` app checks | ||||||
| ====================== | ====================== | ||||||
|  |  | ||||||
|   | |||||||
| @@ -1,39 +1,41 @@ | |||||||
| from django.core.checks.translation import check_setting_language_code | from django.core.checks.translation import E001, check_setting_language_code | ||||||
| from django.test import SimpleTestCase, override_settings | from django.test import SimpleTestCase, override_settings | ||||||
|  |  | ||||||
|  |  | ||||||
| class TranslationCheckTests(SimpleTestCase): | class TranslationCheckTests(SimpleTestCase): | ||||||
|  |  | ||||||
|     @override_settings(LANGUAGE_CODE="eu") |     def test_valid_language_code(self): | ||||||
|     def test_valid_language_code_format_ll_only(self): |         tags = ( | ||||||
|         result = check_setting_language_code(None) |             'en',              # language | ||||||
|         self.assertEqual(len(result), 0) |             'mas',             # language | ||||||
|  |             'sgn-ase',         # language+extlang | ||||||
|  |             'fr-CA',           # language+region | ||||||
|  |             'es-419',          # language+region | ||||||
|  |             'zh-Hans',         # language+script | ||||||
|  |             'ca-ES-valencia',  # language+region+variant | ||||||
|  |             # FIXME: The following should be invalid: | ||||||
|  |             'sr@latin',        # language+script | ||||||
|  |         ) | ||||||
|  |         for tag in tags: | ||||||
|  |             with self.subTest(tag), override_settings(LANGUAGE_CODE=tag): | ||||||
|  |                 self.assertEqual(check_setting_language_code(None), []) | ||||||
|  |  | ||||||
|     @override_settings(LANGUAGE_CODE="eü") |     def test_invalid_language_code(self): | ||||||
|     def test_invalid_language_code_format_ll_only(self): |         tags = ( | ||||||
|         result = check_setting_language_code(None) |             'eü',              # non-latin characters. | ||||||
|         self.assertEqual(len(result), 1) |             'en_US',           # locale format. | ||||||
|         error = result[0] |             'en--us',          # empty subtag. | ||||||
|         self.assertEqual(error.id, 'translation.E001') |             '-en',             # leading separator. | ||||||
|         self.assertEqual(error.msg, ( |             'en-',             # trailing separator. | ||||||
|             "LANGUAGE_CODE in settings.py is eü. It should be in the form ll or ll-cc where ll is the language and cc " |             'en-US.UTF-8',     # language tag w/ locale encoding. | ||||||
|             "is the country. Examples include: it, de-at, es, pt-br. The full set of language codes specifications is " |             'en_US.UTF-8',     # locale format - languate w/ region and encoding. | ||||||
|             "outlined by https://en.wikipedia.org/wiki/IETF_language_tag#Syntax_of_language_tags" |             'ca_ES@valencia',  # locale format - language w/ region and variant. | ||||||
|         )) |             # FIXME: The following should be invalid: | ||||||
|  |             # 'sr@latin',      # locale instead of language tag. | ||||||
|     @override_settings(LANGUAGE_CODE="en-US") |         ) | ||||||
|     def test_valid_language_code_format_ll_cc(self): |         for tag in tags: | ||||||
|         result = check_setting_language_code(None) |             with self.subTest(tag), override_settings(LANGUAGE_CODE=tag): | ||||||
|         self.assertEqual(len(result), 0) |                 result = check_setting_language_code(None) | ||||||
|  |                 self.assertEqual(result, [E001]) | ||||||
|     @override_settings(LANGUAGE_CODE="en_US") |                 self.assertEqual(result[0].id, 'translation.E001') | ||||||
|     def test_invalid_language_code_format_ll_cc(self): |                 self.assertEqual(result[0].msg, 'You have provided an invalid value for the LANGUAGE_CODE setting.') | ||||||
|         result = check_setting_language_code(None) |  | ||||||
|         self.assertEqual(len(result), 1) |  | ||||||
|         error = result[0] |  | ||||||
|         self.assertEqual(error.id, 'translation.E001') |  | ||||||
|         self.assertEqual(error.msg, ( |  | ||||||
|             "LANGUAGE_CODE in settings.py is en_US. It should be in the form ll or ll-cc where ll is the language and " |  | ||||||
|             "cc is the country. Examples include: it, de-at, es, pt-br. The full set of language codes specifications " |  | ||||||
|             "is outlined by https://en.wikipedia.org/wiki/IETF_language_tag#Syntax_of_language_tags" |  | ||||||
|         )) |  | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user