mirror of
				https://github.com/django/django.git
				synced 2025-10-24 14:16:09 +00:00 
			
		
		
		
	Fixed #19941 -- Modified runtests.py to make running the tests easier.
1. Automatically use tests/../django as the Django version. 2. If settings aren't provided through --settings or DJANGO_SETTINGS_MODULE) then use test_sqlite.
This commit is contained in:
		
				
					committed by
					
						 Tim Graham
						Tim Graham
					
				
			
			
				
	
			
			
			
						parent
						
							372158a3cf
						
					
				
				
					commit
					b2314d9e1e
				
			| @@ -25,16 +25,26 @@ Quickstart | |||||||
| ~~~~~~~~~~ | ~~~~~~~~~~ | ||||||
|  |  | ||||||
| Running the tests requires a Django settings module that defines the | Running the tests requires a Django settings module that defines the | ||||||
| databases to use. To make it easy to get started, Django provides a | databases to use. To make it easy to get started, Django provides and uses a | ||||||
| sample settings module that uses the SQLite database. To run the tests | sample settings module that uses the SQLite database. To run the tests: | ||||||
| with this sample ``settings`` module: |  | ||||||
|  |  | ||||||
| .. code-block:: bash | .. code-block:: bash | ||||||
|  |  | ||||||
|     git clone git@github.com:django/django.git django-repo |     git clone git@github.com:django/django.git django-repo | ||||||
|     cd django-repo/tests |     cd django-repo/tests | ||||||
|  |     ./runtests.py | ||||||
|  |  | ||||||
|  | .. versionchanged:: 1.7 | ||||||
|  |  | ||||||
|  | Older versions of Django required running the tests like this:: | ||||||
|  |  | ||||||
|     PYTHONPATH=..:$PYTHONPATH python ./runtests.py --settings=test_sqlite |     PYTHONPATH=..:$PYTHONPATH python ./runtests.py --settings=test_sqlite | ||||||
|  |  | ||||||
|  | ``runtests.py`` now uses the Django package found at ``tests/../django`` (there | ||||||
|  | isn't a need to add this on your ``PYTHONPATH``) and ``test_sqlite`` for the | ||||||
|  | settings if settings aren't provided through either ``--settings`` or | ||||||
|  | :envvar:`DJANGO_SETTINGS_MODULE`. | ||||||
|  |  | ||||||
| .. _running-unit-tests-settings: | .. _running-unit-tests-settings: | ||||||
|  |  | ||||||
| Using another ``settings`` module | Using another ``settings`` module | ||||||
|   | |||||||
| @@ -7,6 +7,20 @@ import sys | |||||||
| import tempfile | import tempfile | ||||||
| import warnings | import warnings | ||||||
|  |  | ||||||
|  | def upath(path): | ||||||
|  |     """ | ||||||
|  |     Separate version of django.utils._os.upath. The django.utils version isn't | ||||||
|  |     usable here, as upath is needed for RUNTESTS_DIR which is needed before | ||||||
|  |     django can be imported. | ||||||
|  |     """ | ||||||
|  |     if sys.version_info[0] != 3 and not isinstance(path, bytes): | ||||||
|  |         fs_encoding = sys.getfilesystemencoding() or sys.getdefaultencoding() | ||||||
|  |         return path.decode(fs_encoding) | ||||||
|  |     return path | ||||||
|  |  | ||||||
|  | RUNTESTS_DIR = os.path.abspath(os.path.dirname(upath(__file__))) | ||||||
|  | sys.path.insert(0, os.path.dirname(RUNTESTS_DIR))  # 'tests/../' | ||||||
|  |  | ||||||
| from django import contrib | from django import contrib | ||||||
| from django.utils._os import upath | from django.utils._os import upath | ||||||
| from django.utils import six | from django.utils import six | ||||||
| @@ -15,7 +29,6 @@ CONTRIB_MODULE_PATH = 'django.contrib' | |||||||
|  |  | ||||||
| TEST_TEMPLATE_DIR = 'templates' | TEST_TEMPLATE_DIR = 'templates' | ||||||
|  |  | ||||||
| RUNTESTS_DIR = os.path.abspath(os.path.dirname(upath(__file__))) |  | ||||||
| CONTRIB_DIR = os.path.dirname(upath(contrib.__file__)) | CONTRIB_DIR = os.path.dirname(upath(contrib.__file__)) | ||||||
|  |  | ||||||
| TEMP_DIR = tempfile.mkdtemp(prefix='django_') | TEMP_DIR = tempfile.mkdtemp(prefix='django_') | ||||||
| @@ -331,10 +344,9 @@ if __name__ == "__main__": | |||||||
|     options, args = parser.parse_args() |     options, args = parser.parse_args() | ||||||
|     if options.settings: |     if options.settings: | ||||||
|         os.environ['DJANGO_SETTINGS_MODULE'] = options.settings |         os.environ['DJANGO_SETTINGS_MODULE'] = options.settings | ||||||
|     elif "DJANGO_SETTINGS_MODULE" not in os.environ: |  | ||||||
|         parser.error("DJANGO_SETTINGS_MODULE is not set in the environment. " |  | ||||||
|                       "Set it or use --settings.") |  | ||||||
|     else: |     else: | ||||||
|  |         if "DJANGO_SETTINGS_MODULE" not in os.environ: | ||||||
|  |             os.environ['DJANGO_SETTINGS_MODULE'] = 'test_sqlite' | ||||||
|         options.settings = os.environ['DJANGO_SETTINGS_MODULE'] |         options.settings = os.environ['DJANGO_SETTINGS_MODULE'] | ||||||
|  |  | ||||||
|     if options.liveserver is not None: |     if options.liveserver is not None: | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user