mirror of
				https://github.com/django/django.git
				synced 2025-10-25 14:46:09 +00:00 
			
		
		
		
	Fixed #17048 - Added docs for upgrading Django.
Thanks Donald Stufft for the suggestion and Susan Tan and Brian Fabian Crain for the patch.
This commit is contained in:
		
							
								
								
									
										1
									
								
								AUTHORS
									
									
									
									
									
								
							
							
						
						
									
										1
									
								
								AUTHORS
									
									
									
									
									
								
							| @@ -159,6 +159,7 @@ answer newbie questions, and generally made Django that much better: | |||||||
|     Paul Collins <paul.collins.iii@gmail.com> |     Paul Collins <paul.collins.iii@gmail.com> | ||||||
|     Robert Coup |     Robert Coup | ||||||
|     Deric Crago <deric.crago@gmail.com> |     Deric Crago <deric.crago@gmail.com> | ||||||
|  |     Brian Fabian Crain <http://www.bfc.do/> | ||||||
|     David Cramer <dcramer@gmail.com> |     David Cramer <dcramer@gmail.com> | ||||||
|     Pete Crosier <pete.crosier@gmail.com> |     Pete Crosier <pete.crosier@gmail.com> | ||||||
|     Matt Croydon <http://www.postneo.com/> |     Matt Croydon <http://www.postneo.com/> | ||||||
|   | |||||||
| @@ -15,6 +15,7 @@ you quickly accomplish common tasks. | |||||||
|    custom-template-tags |    custom-template-tags | ||||||
|    custom-file-storage |    custom-file-storage | ||||||
|    deployment/index |    deployment/index | ||||||
|  |    upgrade-version | ||||||
|    error-reporting |    error-reporting | ||||||
|    initial-data |    initial-data | ||||||
|    jython |    jython | ||||||
|   | |||||||
							
								
								
									
										91
									
								
								docs/howto/upgrade-version.txt
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										91
									
								
								docs/howto/upgrade-version.txt
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,91 @@ | |||||||
|  | =================================== | ||||||
|  | Upgrading Django to a newer version | ||||||
|  | =================================== | ||||||
|  |  | ||||||
|  | While it can be a complex process at times, upgrading to the latest Django | ||||||
|  | version has several benefits: | ||||||
|  |  | ||||||
|  | * New features and improvements are added. | ||||||
|  | * Bugs are fixed. | ||||||
|  | * Older version of Django will eventually no longer receive security updates. | ||||||
|  |   (see :ref:`backwards-compatibility-policy`). | ||||||
|  | * Upgrading as each new Django release is available makes future upgrades less | ||||||
|  |   painful by keeping your code base up to date. | ||||||
|  |  | ||||||
|  | Here are some things to consider to help make your upgrade process as smooth as | ||||||
|  | possible. | ||||||
|  |  | ||||||
|  | Required Reading | ||||||
|  | ================ | ||||||
|  |  | ||||||
|  | If it's your first time doing an upgrade, it is useful to read the :doc:`guide | ||||||
|  | on the different release processes </internals/release-process>`. | ||||||
|  |  | ||||||
|  | Afterwards, you should familiarize yourself with the changes that were made in | ||||||
|  | the new Django version(s): | ||||||
|  |  | ||||||
|  | * Read the :doc:`release notes </releases/index>` for each 'final' release from | ||||||
|  |   the one after your current Django version, up to and including the version to | ||||||
|  |   which you plan to upgrade. | ||||||
|  | * Look at the :doc:`deprecation timeline</internals/deprecation>` for the | ||||||
|  |   relevant versions. | ||||||
|  |  | ||||||
|  | Pay particular attention to backwards incompatible changes to get a clear idea | ||||||
|  | of what will be needed for a successful upgrade. | ||||||
|  |  | ||||||
|  | Dependencies | ||||||
|  | ============ | ||||||
|  |  | ||||||
|  | In most cases it will be necessary to upgrade to the latest version of your | ||||||
|  | Django-related dependencies as well. If the Django version was recently | ||||||
|  | released or if some of your dependencies are not well-maintained, some of your | ||||||
|  | dependencies may not yet support the new Django version. In these cases you may | ||||||
|  | have to wait until new versions of your dependencies are released. | ||||||
|  |  | ||||||
|  | Installation | ||||||
|  | ============ | ||||||
|  |  | ||||||
|  | Once you're ready, it is time to :doc:`install the new Django version | ||||||
|  | </topics/install>`. If you are using virtualenv_ and it is a major upgrade, you | ||||||
|  | might want to set up a new environment will all the dependencies first. | ||||||
|  |  | ||||||
|  | Exactly which steps you will need to take depends on your installation process. | ||||||
|  | The most convenient way is to use pip_: | ||||||
|  |  | ||||||
|  | .. code-block:: bash | ||||||
|  |  | ||||||
|  |    pip install Django | ||||||
|  |  | ||||||
|  | pip_ also automatically uninstalls the previous version of Django. | ||||||
|  |  | ||||||
|  | If you use some other installation process, you might have to manually | ||||||
|  | :ref:`uninstall the old Django version <removing-old-versions-of-django>` and | ||||||
|  | should look at the complete installation instructions. | ||||||
|  |  | ||||||
|  | .. _pip: http://www.pip-installer.org/ | ||||||
|  | .. _virtualenv: http://www.virtualenv.org/ | ||||||
|  |  | ||||||
|  | Testing | ||||||
|  | ======= | ||||||
|  |  | ||||||
|  | When the new environment is set up, :doc:`run the full test suite | ||||||
|  | </topics/testing/overview>` for your application. In Python 2.7+, deprecation | ||||||
|  | warnings are silenced by default. It is useful to turn the warnings on so they | ||||||
|  | are shown in the test output (you can also use the flag if you test your app | ||||||
|  | manually using ``manage.py runserver``): | ||||||
|  |  | ||||||
|  | .. code-block:: bash | ||||||
|  |  | ||||||
|  |     python -Wall manage.py test | ||||||
|  |  | ||||||
|  | After you have run the tests, fix any failures. While you have the release | ||||||
|  | notes fresh in your mind, it may also be a good time to take advantage of new | ||||||
|  | features in Django by refactoring your code to eliminate any deprecation | ||||||
|  | warnings. | ||||||
|  |  | ||||||
|  | Deployment | ||||||
|  | ========== | ||||||
|  |  | ||||||
|  | When you are sufficiently confident your app works with the new version of | ||||||
|  | Django, you're ready to go ahead and :doc:`deploy </howto/deployment/index>` | ||||||
|  | your upgraded Django project. | ||||||
| @@ -6,10 +6,11 @@ Release notes for the official Django releases. Each release note will tell you | |||||||
| what's new in each version, and will also describe any backwards-incompatible | what's new in each version, and will also describe any backwards-incompatible | ||||||
| changes made in that version. | changes made in that version. | ||||||
|  |  | ||||||
| For those upgrading to a new version of Django, you will need to check | For those :doc:`upgrading to a new version of Django</howto/upgrade-version>`, | ||||||
| all the backwards-incompatible changes and deprecated features for | you will need to check all the backwards-incompatible changes and | ||||||
| each 'final' release from the one after your current Django version, | :doc:`deprecated features</internals/deprecation>` for each 'final' release | ||||||
| up to and including the new version. | from the one after your current Django version, up to and including the new | ||||||
|  | version. | ||||||
|  |  | ||||||
| Final releases | Final releases | ||||||
| ============== | ============== | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user