{
  "id": "django__django-12286",
  "question": "translation.E004 shouldn't be raised on sublanguages when a base language is available.\nDescription\n\t\nAccording to Django documentation:\nIf a base language is available but the sublanguage specified is not, Django uses the base language. For example, if a user specifies de-at (Austrian German) but Django only has de available, Django uses de.\nHowever, when using Django 3.0.2, if my settings.py has\nLANGUAGE_CODE = \"de-at\"\nI get this error message:\nSystemCheckError: System check identified some issues:\nERRORS:\n?: (translation.E004) You have provided a value for the LANGUAGE_CODE setting that is not in the LANGUAGES setting.\nIf using\nLANGUAGE_CODE = \"es-ar\"\nDjango works fine (es-ar is one of the translations provided out of the box).\n",
  "answer": "{\"task_id\": \"342f0b06-3ca3-4f7e-89dc-a19e58a60fc6\", \"workflow_run_id\": \"2f0c5876-d278-4e47-9cbf-8562dae437ec\", \"data\": {\"id\": \"2f0c5876-d278-4e47-9cbf-8562dae437ec\", \"workflow_id\": \"bc5a1a30-852f-4fd7-98f0-8fca2f23c564\", \"status\": \"succeeded\", \"outputs\": {\"ranked_patches\": \"```json\\n{\\n  \\\"ranked_patches\\\": [\\n    {\\n      \\\"patch_id\\\": 2,\\n      \\\"patch\\\": \\\"diff --git a/django/core/checks/translation.py b/django/core/checks/translation.py\\\\nindex 8a2b3e7..7f14abc 100644\\\\n--- a/django/core/checks/translation.py\\\\n+++ b/django/core/checks/translation.py\\\\n@@ -47,8 +47,12 @@ def check_language_settings_consistent(app_configs, **kwargs):\\\\n     # Check if LANGUAGE_CODE is in LANGUAGES\\\\n     language_codes = dict(settings.LANGUAGES)\\\\n     if settings.LANGUAGE_CODE not in language_codes:\\\\n-        check_messages.append(\\\\n-            Error(\\\\n+        # Check if the base language is available\\\\n+        base_language = settings.LANGUAGE_CODE.split('-')[0]\\\\n+        if base_language not in language_codes:\\\\n+            check_messages.append(\\\\n+                Error(\\\\n                     \\\\\\\"You have provided a value for the LANGUAGE_CODE setting that is not in the LANGUAGES setting.\\\\\\\",\\\\n                     id='translation.E004',\\\\n                 )\\\\n@@ -55,10 +59,6 @@ def check_language_settings_consistent(app_configs, **kwargs):\\\\n             )\\\\n \\\\n     return check_messages\\\\n \\\\ndiff --git a/tests/check_framework/test_checks.py b/tests/check_framework/test_checks.py\\\\nindex da6f371..d5e9dac 100644\\\\n--- a/tests/check_framework/test_checks.py\\\\n+++ b/tests/check_framework/test_checks.py\\\\n@@ -150,6 +150,22 @@ class TranslationCheckTests(SimpleTestCase):\\\\n         self.assertEqual(errors, [])\\\\n \\\\n \\\\n+    def test_language_code_base_fallback_case(self):\\\\n+        test_cases = [\\\\n+            ('de-at', [('de', 'German')]),\\\\n+            ('pt-br', [('pt', 'Portuguese')]),\\\\n+            ('fr-ca', [('fr', 'French')]),\\\\n+        ]\\\\n+        for lang_code, languages in test_cases:\\\\n+            with self.settings(LANGUAGE_CODE=lang_code, LANGUAGES=languages):\\\\n+                errors = check_language_settings_consistent(None)\\\\n+                self.assertEqual(errors, [])\\\\n+        \\\\n+        # Negative test case\\\\n+        with self.settings(LANGUAGE_CODE='it-ch', LANGUAGES=[('fr', 'French')]):\\\\n+            errors = check_language_settings_consistent(None)\\\\n+            self.assertEqual(len(errors), 1)\\\\n+\\\\n class FileStorageCheckTests(SimpleTestCase):\\\\n     def test_file_storage_check_passes(self):\\\\n         errors = check_all_files([default_storage])\\\\n\\\",\\n      \\\"rank\\\": 1,\\n      \\\"score\\\": 0.97,\\n      \\\"evaluation\\\": {\\n        \\\"correctness\\\": 0.95,\\n        \\\"code_quality\\\": 0.95,\\n        \\\"risk_level\\\": 0.05,\\n        \\\"best_practices\\\": 0.95,\\n        \\\"test_coverage\\\": 0.95\\n      },\\n      \\\"reasoning\\\": \\\"This patch correctly addresses the issue by checking for the base language and includes comprehensive test cases that cover multiple scenarios, including negative cases. The use of a loop for testing multiple language code scenarios improves maintainability and readability.\\\",\\n      \\\"recommendation\\\": \\\"Highly recommended\\\"\\n    },\\n    {\\n      \\\"patch_id\\\": 1,\\n      \\\"patch\\\": \\\"diff --git a/django/core/checks/translation.py b/django/core/checks/translation.py\\\\nindex 8a2b3e7..4c3f51d 100644\\\\n--- a/django/core/checks/translation.py\\\\n+++ b/django/core/checks/translation.py\\\\n@@ -47,7 +47,8 @@ def check_language_settings_consistent(app_configs, **kwargs):\\\\n     # Check if LANGUAGE_CODE is in LANGUAGES\\\\n     language_codes = dict(settings.LANGUAGES)\\\\n     if settings.LANGUAGE_CODE not in language_codes:\\\\n-        check_messages.append(\\\\n+        base_language = settings.LANGUAGE_CODE.split('-')[0]\\\\n+        if base_language not in language_codes:\\\\n             Error(\\\\n                 \\\\\\\"You have provided a value for the LANGUAGE_CODE setting that is not in the LANGUAGES setting.\\\\\\\",\\\\n                 id='translation.E004',\\\\n@@ -55,6 +56,10 @@ def check_language_settings_consistent(app_configs, **kwargs):\\\\n             )\\\\n \\\\n     return check_messages\\\\n\\\\ndiff --git a/tests/check_framework/test_checks.py b/tests/check_framework/test_checks.py\\\\nindex da6f371..906cabc 100644\\\\n--- a/tests/check_framework/test_checks.py\\\\n+++ b/tests/check_framework/test_checks.py\\\\n@@ -150,6 +150,20 @@ class TranslationCheckTests(SimpleTestCase):\\\\n         self.assertEqual(errors, [])\\\\n \\\\n \\\\n+    def test_language_code_base_fallback(self):\\\\n+        with self.settings(LANGUAGE_CODE='de-at', LANGUAGES=[('de', 'German')]):\\\\n+            errors = check_language_settings_consistent(None)\\\\n+            self.assertEqual(errors, [])\\\\n+\\\\n+        with self.settings(LANGUAGE_CODE='fr-be', LANGUAGES=[('fr', 'French')]):\\\\n+            errors = check_language_settings_consistent(None)\\\\n+            self.assertEqual(errors, [])\\\\n+\\\\n+        with self.settings(LANGUAGE_CODE='fr-ca', LANGUAGES=[('fr', 'French')] ):\\\\n+            errors = check_language_settings_consistent(None)\\\\n+            self.assertEqual(errors, [])\\\\n+\\\\n+\\\\n class FileStorageCheckTests(SimpleTestCase):\\\\n     def test_file_storage_check_passes(self):\\\\n         errors = check_all_files([default_storage])\\\\n\\\",\\n      \\\"rank\\\": 2,\\n      \\\"score\\\": 0.90,\\n      \\\"evaluation\\\": {\\n        \\\"correctness\\\": 0.9,\\n        \\\"code_quality\\\": 0.9,\\n        \\\"risk_level\\\": 0.1,\\n        \\\"best_practices\\\": 0.9,\\n        \\\"test_coverage\\\": 0.85\\n      },\\n      \\\"reasoning\\\": \\\"This patch also correctly addresses the issue by checking for the base language. However, the test cases are less comprehensive compared to Patch 2, lacking negative test cases and a more structured approach to testing multiple scenarios.\\\",\\n      \\\"recommendation\\\": \\\"Recommended\\\"\\n    }\\n  ],\\n  \\\"evaluation_summary\\\": \\\"Both patches effectively resolve the issue by checking for the base language before raising an error. Patch 2 is ranked higher due to its comprehensive test coverage, including both positive and negative test cases, and a more maintainable approach to testing multiple scenarios. Patch 1 is also correct but lacks the same level of test coverage and maintainability.\\\"\\n}\\n```\", \"generated_tests\": \"{\\n  \\\"reproduction_tests\\\": [\\n    {\\n      \\\"test_name\\\": \\\"test_reproduce_original_issue\\\",\\n      \\\"test_code\\\": \\\"def test_reproduce_original_issue():\\\\n    with self.settings(LANGUAGE_CODE='de-at', LANGUAGES=[('de', 'German')]):\\\\n        errors = check_language_settings_consistent(None)\\\\n        assert len(errors) == 0\\\\n\\\\n    with self.settings(LANGUAGE_CODE='es-ar', LANGUAGES=[('es-ar', 'Spanish Argentina')]):\\\\n        errors = check_language_settings_consistent(None)\\\\n        assert len(errors) == 0\\\\n\\\\n    with self.settings(LANGUAGE_CODE='de-at', LANGUAGES=[('de', 'German'), ('es-ar', 'Spanish Argentina')]):\\\\n        errors = check_language_settings_consistent(None)\\\\n        assert len(errors) == 0\\\\n\\\",\\n      \\\"description\\\": \\\"This test reproduces the original issue by setting the language code to 'de-at' and testing that no errors are raised when the base language 'de' is available. It also tests with 'es-ar' language code to show correct behavior when the specified sublanguage is available, and with a combination of 'de-at' and 'es-ar' in LANGUAGES settings.\\\",\\n      \\\"expected_behavior\\\": \\\"The test should pass for all cases after the patch is applied.\\\"\\n    },\\n    {\\n      \\\"test_name\\\": \\\"test_edge_cases\\\",\\n      \\\"test_code\\\": \\\"def test_edge_cases():\\\\n    with self.settings(LANGUAGE_CODE='de', LANGUAGES=[('de', 'German')]):\\\\n        errors = check_language_settings_consistent(None)\\\\n        assert len(errors) == 0\\\\n\\\\n    with self.settings(LANGUAGE_CODE='de', LANGUAGES=[('en', 'English')]):\\\\n        errors = check_language_settings_consistent(None)\\\\n        assert len(errors) == 0\\\\n\\\",\\n      \\\"description\\\": \\\"This test covers edge cases by setting the language code to base language 'de' directly and confirms no errors are raised. It also tests when the base language is different from the specified language code ('de') to validate that the patch considers base language availability.\\\",\\n      \\\"expected_behavior\\\": \\\"The test should pass for both cases after the patch is applied.\\\"\\n    }\\n  ],\\n  \\\"validation_tests\\\": [\\n    {\\n      \\\"test_name\\\": \\\"test_patch_validation\\\",\\n      \\\"test_code\\\": \\\"def test_patch_validation():\\\\n    with self.settings(LANGUAGE_CODE='de-at', LANGUAGES=[('de', 'German')]):\\\\n        errors = check_language_settings_consistent(None)\\\\n        assert len(errors) == 0\\\\n\\\\n    with self.settings(LANGUAGE_CODE='fr-ca', LANGUAGES=[('fr', 'French')]):\\\\n        errors = check_language_settings_consistent(None)\\\\n        assert len(errors) == 0\\\\n\\\\n    with self.settings(LANGUAGE_CODE='pt-br', LANGUAGES=[('pt', 'Portuguese')]):\\\\n        errors = check_language_settings_consistent(None)\\\\n        assert len(errors) == 0\\\\n\\\\n    with self.settings(LANGUAGE_CODE='it-ch', LANGUAGES=[('fr', 'French')]):\\\\n        errors = check_language_settings_consistent(None)\\\\n        assert len(errors) == 1\\\\n\\\",\\n      \\\"description\\\": \\\"This test validates the patch works correctly by setting various language codes and corresponding languages in the settings to ensure that the base language fallback logic is applied as expected.\\\",\\n      \\\"expected_behavior\\\": \\\"The test should pass for all cases, with errors only when the base language is not available.\\\"\\n    }\\n  ],\\n  \\\"test_summary\\\": \\\"Comprehensive test cases have been generated to reproduce the original issue, cover edge cases, and validate the effectiveness of the provided patches.\\\"\\n}\"}, \"error\": \"\", \"elapsed_time\": 337.480395, \"total_tokens\": 21786, \"total_steps\": 9, \"created_at\": 1753290921, \"finished_at\": 1753291258}}"
}