mirror of
				https://github.com/django/django.git
				synced 2025-10-25 14:46:09 +00:00 
			
		
		
		
	Fixed #31380 -- Added deployment system check for DJANGO_ALLOW_ASYNC_UNSAFE environment variable.
This commit is contained in:
		
				
					committed by
					
						 Mariusz Felisiak
						Mariusz Felisiak
					
				
			
			
				
	
			
			
			
						parent
						
							e9b014fbc5
						
					
				
				
					commit
					4a6f2b63d7
				
			| @@ -5,6 +5,7 @@ from .messages import ( | |||||||
| from .registry import Tags, register, run_checks, tag_exists | from .registry import Tags, register, run_checks, tag_exists | ||||||
|  |  | ||||||
| # Import these to force registration of checks | # Import these to force registration of checks | ||||||
|  | import django.core.checks.async_checks  # NOQA isort:skip | ||||||
| import django.core.checks.caches  # NOQA isort:skip | import django.core.checks.caches  # NOQA isort:skip | ||||||
| import django.core.checks.database  # NOQA isort:skip | import django.core.checks.database  # NOQA isort:skip | ||||||
| import django.core.checks.model_checks  # NOQA isort:skip | import django.core.checks.model_checks  # NOQA isort:skip | ||||||
|   | |||||||
							
								
								
									
										16
									
								
								django/core/checks/async_checks.py
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										16
									
								
								django/core/checks/async_checks.py
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,16 @@ | |||||||
|  | import os | ||||||
|  |  | ||||||
|  | from . import Error, Tags, register | ||||||
|  |  | ||||||
|  | E001 = Error( | ||||||
|  |     'You should not set the DJANGO_ALLOW_ASYNC_UNSAFE environment variable in ' | ||||||
|  |     'deployment. This disables async safety protection.', | ||||||
|  |     id='async.E001', | ||||||
|  | ) | ||||||
|  |  | ||||||
|  |  | ||||||
|  | @register(Tags.async_support, deploy=True) | ||||||
|  | def check_async_unsafe(app_configs, **kwargs): | ||||||
|  |     if os.environ.get('DJANGO_ALLOW_ASYNC_UNSAFE'): | ||||||
|  |         return [E001] | ||||||
|  |     return [] | ||||||
| @@ -8,6 +8,7 @@ class Tags: | |||||||
|     Built-in tags for internal checks. |     Built-in tags for internal checks. | ||||||
|     """ |     """ | ||||||
|     admin = 'admin' |     admin = 'admin' | ||||||
|  |     async_support = 'async_support' | ||||||
|     caches = 'caches' |     caches = 'caches' | ||||||
|     compatibility = 'compatibility' |     compatibility = 'compatibility' | ||||||
|     database = 'database' |     database = 'database' | ||||||
|   | |||||||
| @@ -74,6 +74,7 @@ Builtin tags | |||||||
| Django's system checks are organized using the following tags: | Django's system checks are organized using the following tags: | ||||||
|  |  | ||||||
| * ``admin``: Checks of any admin site declarations. | * ``admin``: Checks of any admin site declarations. | ||||||
|  | * ``async_support``: Checks asynchronous-related configuration. | ||||||
| * ``caches``: Checks cache related configuration. | * ``caches``: Checks cache related configuration. | ||||||
| * ``compatibility``: Flags potential problems with version upgrades. | * ``compatibility``: Flags potential problems with version upgrades. | ||||||
| * ``database``: Checks database-related configuration issues. Database checks | * ``database``: Checks database-related configuration issues. Database checks | ||||||
| @@ -91,6 +92,10 @@ Django's system checks are organized using the following tags: | |||||||
|  |  | ||||||
| Some checks may be registered with multiple tags. | Some checks may be registered with multiple tags. | ||||||
|  |  | ||||||
|  | .. versionchanged:: 3.1 | ||||||
|  |  | ||||||
|  |     The ``async_support`` tag was added. | ||||||
|  |  | ||||||
| .. versionchanged:: 3.1 | .. versionchanged:: 3.1 | ||||||
|  |  | ||||||
|     The ``database`` checks are now run only for database aliases specified |     The ``database`` checks are now run only for database aliases specified | ||||||
| @@ -99,6 +104,17 @@ Some checks may be registered with multiple tags. | |||||||
| Core system checks | Core system checks | ||||||
| ================== | ================== | ||||||
|  |  | ||||||
|  | Asynchronous support | ||||||
|  | -------------------- | ||||||
|  |  | ||||||
|  | .. versionadded:: 3.1 | ||||||
|  |  | ||||||
|  | The following checks verify your setup for :doc:`/topics/async`: | ||||||
|  |  | ||||||
|  | * **async.E001**: You should not set the ``DJANGO_ALLOW_ASYNC_UNSAFE`` | ||||||
|  |   environment variable in deployment. This disables :ref:`async safety | ||||||
|  |   protection <async-safety>`. | ||||||
|  |  | ||||||
| Backwards compatibility | Backwards compatibility | ||||||
| ----------------------- | ----------------------- | ||||||
|  |  | ||||||
|   | |||||||
							
								
								
									
										15
									
								
								tests/check_framework/test_async_checks.py
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										15
									
								
								tests/check_framework/test_async_checks.py
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,15 @@ | |||||||
|  | import os | ||||||
|  | from unittest import mock | ||||||
|  |  | ||||||
|  | from django.core.checks.async_checks import E001, check_async_unsafe | ||||||
|  | from django.test import SimpleTestCase | ||||||
|  |  | ||||||
|  |  | ||||||
|  | class AsyncCheckTests(SimpleTestCase): | ||||||
|  |     @mock.patch.dict(os.environ, {'DJANGO_ALLOW_ASYNC_UNSAFE': ''}) | ||||||
|  |     def test_no_allowed_async_unsafe(self): | ||||||
|  |         self.assertEqual(check_async_unsafe(None), []) | ||||||
|  |  | ||||||
|  |     @mock.patch.dict(os.environ, {'DJANGO_ALLOW_ASYNC_UNSAFE': 'true'}) | ||||||
|  |     def test_allowed_async_unsafe_set(self): | ||||||
|  |         self.assertEqual(check_async_unsafe(None), [E001]) | ||||||
		Reference in New Issue
	
	Block a user