mirror of
				https://github.com/django/django.git
				synced 2025-10-25 14:46:09 +00:00 
			
		
		
		
	Fixed #23692 -- Removed alpha/beta/rc release notes.
This commit is contained in:
		| @@ -1,161 +0,0 @@ | ||||
| ================================ | ||||
| Django 1.0 alpha release notes | ||||
| ================================ | ||||
|  | ||||
| Welcome to Django 1.0 alpha! | ||||
|  | ||||
| This is the first in a series of preview/development releases leading | ||||
| up to the eventual release of Django 1.0, currently scheduled to take | ||||
| place in early September 2008. This release is primarily targeted at | ||||
| developers who are interested in testing the Django codebase and | ||||
| helping to identify and resolve bugs prior to the final 1.0 release. | ||||
|  | ||||
| As such, this release is *not* intended for production use, and any | ||||
| such use is strongly discouraged. | ||||
|  | ||||
|  | ||||
| What's new in Django 1.0 alpha | ||||
| ============================== | ||||
|  | ||||
| Django's development trunk has been the site of nearly constant | ||||
| activity over the past year, with several major new features landing | ||||
| since the 0.96 release. Some of the highlights include: | ||||
|  | ||||
| Refactored admin application (newforms-admin) | ||||
|     The Django administrative interface (``django.contrib.admin``) has | ||||
|     been completely refactored; admin definitions are now completely | ||||
|     decoupled from model definitions (no more ``class Admin`` | ||||
|     declaration in models!), rewritten to use Django's new | ||||
|     form-handling library (introduced in the 0.96 release as | ||||
|     ``django.newforms``, and now available as simply ``django.forms``) | ||||
|     and redesigned with extensibility and customization in mind. Full | ||||
|     documentation for the admin application is available online in the | ||||
|     official Django documentation: | ||||
|  | ||||
|     * :doc:`admin reference </ref/contrib/admin/index>` | ||||
|  | ||||
| Improved Unicode handling | ||||
|     Django's internals have been refactored to use Unicode throughout; | ||||
|     this drastically simplifies the task of dealing with | ||||
|     non-Western-European content and data in Django. Additionally, | ||||
|     utility functions have been provided to ease interoperability with | ||||
|     third-party libraries and systems which may or may not handle | ||||
|     Unicode gracefully. Details are available in Django's | ||||
|     Unicode-handling documentation: | ||||
|  | ||||
|     * :doc:`unicode reference </ref/unicode>` | ||||
|  | ||||
| An improved Django ORM | ||||
|     Django's object-relational mapper -- the component which provides | ||||
|     the mapping between Django model classes and your database, and | ||||
|     which mediates your database queries -- has been dramatically | ||||
|     improved by a massive refactoring. For most users of Django this | ||||
|     is backwards-compatible; the public-facing API for database | ||||
|     querying underwent a few minor changes, but most of the updates | ||||
|     took place in the ORM's internals. A guide to the changes, | ||||
|     including backwards-incompatible modifications and mentions of new | ||||
|     features opened up by this refactoring, is available on the Django | ||||
|     wiki: | ||||
|  | ||||
|     * https://code.djangoproject.com/wiki/QuerysetRefactorBranch | ||||
|  | ||||
| Automatic escaping of template variables | ||||
|     To provide improved security against cross-site scripting (XSS) | ||||
|     vulnerabilities, Django's template system now automatically | ||||
|     escapes the output of variables. This behavior is configurable, | ||||
|     and allows both variables and larger template constructs to be | ||||
|     marked as safe (requiring no escaping) or unsafe (requiring | ||||
|     escaping). A full guide to this feature is in the documentation | ||||
|     for the :ttag:`autoescape` tag. | ||||
|  | ||||
| There are many more new features, many bugfixes and many enhancements | ||||
| to existing features from previous releases. The ``newforms`` library, | ||||
| for example, has undergone massive improvements including several | ||||
| useful add-ons in ``django.contrib`` which complement and build on | ||||
| Django's form-handling capabilities, and Django's file-uploading | ||||
| handlers have been refactored to allow finer-grained control over the | ||||
| uploading process as well as streaming uploads of large files. | ||||
|  | ||||
| Along with these improvements and additions, we've made a number of | ||||
| backwards-incompatible changes to the framework, as features have been | ||||
| fleshed out and APIs have been finalized for the 1.0 release. A | ||||
| complete guide to these changes will be available as part of the final | ||||
| Django 1.0 release, and a comprehensive list of backwards-incompatible | ||||
| changes is also available on the Django wiki for those who want to | ||||
| begin developing and testing their upgrade process: | ||||
|  | ||||
| * https://code.djangoproject.com/wiki/BackwardsIncompatibleChanges | ||||
|  | ||||
|  | ||||
| The Django 1.0 roadmap | ||||
| ====================== | ||||
|  | ||||
| One of the primary goals of this alpha release is to focus attention | ||||
| on the remaining features to be implemented for Django 1.0, and on the | ||||
| bugs that need to be resolved before the final release. Following | ||||
| this release, we'll be conducting a series of sprints building up to a | ||||
| series of beta releases and a release-candidate stage, followed soon | ||||
| after by Django 1.0. The timeline is projected to be: | ||||
|  | ||||
| * August 1, 2008: Sprint (based in Washington, DC, and online). | ||||
|  | ||||
| * August 5, 2008: Django 1.0 beta 1 release. This will also constitute | ||||
|   the feature freeze for 1.0. Any feature to be included in 1.0 must | ||||
|   be completed and in trunk by this time. | ||||
|  | ||||
| * August 8, 2008: Sprint (based in Lawrence, KS, and online). | ||||
|  | ||||
| * August 12, 2008: Django 1.0 beta 2 release. | ||||
|  | ||||
| * August 15, 2008: Sprint (based in Austin, TX, and online). | ||||
|  | ||||
| * August 19, 2008: Django 1.0 release candidate 1. | ||||
|  | ||||
| * August 22, 2008: Sprint (based in Portland, OR, and online). | ||||
|  | ||||
| * August 26, 2008: Django 1.0 release candidate 2. | ||||
|  | ||||
| * September 2, 2008: Django 1.0 final release. The official Django 1.0 | ||||
|   release party will take place during the first-ever DjangoCon, to be | ||||
|   held in Mountain View, CA, September 6-7. | ||||
|  | ||||
| Of course, like any estimated timeline, this is subject to change as | ||||
| requirements dictate. The latest information will always be available | ||||
| on the Django project wiki: | ||||
|  | ||||
| * https://code.djangoproject.com/wiki/VersionOneRoadmap | ||||
|  | ||||
|  | ||||
| What you can do to help | ||||
| ======================= | ||||
|  | ||||
| In order to provide a high-quality 1.0 release, we need your | ||||
| help. Although this alpha release is, again, *not* intended for | ||||
| production use, you can help the Django team by trying out the alpha | ||||
| codebase in a safe test environment and reporting any bugs or issues | ||||
| you encounter. The Django ticket tracker is the central place to | ||||
| search for open issues: | ||||
|  | ||||
| * https://code.djangoproject.com/timeline | ||||
|  | ||||
| Please open new tickets if no existing ticket corresponds to a problem | ||||
| you're running into. | ||||
|  | ||||
| Additionally, discussion of Django development, including progress | ||||
| toward the 1.0 release, takes place daily on the django-developers | ||||
| mailing list: | ||||
|  | ||||
| * http://groups.google.com/group/django-developers | ||||
|  | ||||
| ...and in the ``#django-dev`` IRC channel on ``irc.freenode.net``. If | ||||
| you're interested in helping out with Django's development, feel free | ||||
| to join the discussions there. | ||||
|  | ||||
| Django's online documentation also includes pointers on how to | ||||
| contribute to Django: | ||||
|  | ||||
| * :doc:`contributing to Django </internals/contributing/index>` | ||||
|  | ||||
| Contributions on any level -- developing code, writing | ||||
| documentation or simply triaging tickets and helping to test proposed | ||||
| bugfixes -- are always welcome and appreciated. | ||||
| @@ -1,135 +0,0 @@ | ||||
| ================================ | ||||
| Django 1.0 alpha 2 release notes | ||||
| ================================ | ||||
|  | ||||
| Welcome to Django 1.0 alpha 2! | ||||
|  | ||||
| This is the second in a series of preview/development releases leading | ||||
| up to the eventual release of Django 1.0, currently scheduled to take | ||||
| place in early September 2008. This releases is primarily targeted at | ||||
| developers who are interested in testing the Django codebase and | ||||
| helping to identify and resolve bugs prior to the final 1.0 release. | ||||
|  | ||||
| As such, this release is *not* intended for production use, and any | ||||
| such use is strongly discouraged. | ||||
|  | ||||
|  | ||||
| What's new in Django 1.0 alpha 2 | ||||
| ================================ | ||||
|  | ||||
| Django's development trunk has been the site of nearly constant activity over | ||||
| the past year, with several major new features landing since the 0.96 release. | ||||
| For features which were new as of Django 1.0 alpha 1, see :doc:`the 1.0 alpha 1 | ||||
| release notes </releases/1.0-alpha-1>`. Since the 1.0 alpha 1 release several new | ||||
| features have landed, including: | ||||
|  | ||||
| ``django.contrib.gis`` (`GeoDjango`_) | ||||
|     A project over a year in the making, this adds world-class GIS | ||||
|     (`Geographic Information Systems`_) support to Django, in the form | ||||
|     of a ``contrib`` application. Its documentation is currently | ||||
|     being maintained externally, and will be merged into the main | ||||
|     Django documentation prior to the final 1.0 release. Huge thanks | ||||
|     go to Justin Bronn, Jeremy Dunck, Brett Hoerner and Travis Pinney | ||||
|     for their efforts in creating and completing this feature. | ||||
|  | ||||
| Pluggable file storage | ||||
|     Django's built-in ``FileField`` and ``ImageField`` now can take advantage of | ||||
|     pluggable file-storage backends, allowing extensive customization of where | ||||
|     and how uploaded files get stored by Django. For details, see :doc:`the | ||||
|     files documentation </topics/files>`; big thanks go to Marty Alchin for | ||||
|     putting in the hard work to get this completed. | ||||
|  | ||||
| Jython compatibility | ||||
|     Thanks to a lot of work from Leo Soto during a Google Summer of | ||||
|     Code project, Django's codebase has been refactored to remove | ||||
|     incompatibilities with `Jython`_, an implementation of Python | ||||
|     written in Java, which runs Python code on the Java Virtual | ||||
|     Machine. Django is now compatible with the forthcoming Jython 2.5 | ||||
|     release. | ||||
|  | ||||
| There are many other new features and improvements in this release, including | ||||
| two major performance boosts: strings marked for translation using | ||||
| :doc:`Django's internationalization system </topics/i18n/index>` now consume far less | ||||
| memory, and Django's internal dispatcher -- which is invoked frequently during | ||||
| request/response processing and when working with Django's object-relational | ||||
| mapper -- is now significantly faster. | ||||
|  | ||||
| .. _GeoDjango: http://geodjango.org/ | ||||
| .. _Geographic Information Systems: http://en.wikipedia.org/wiki/Geographic_information_system | ||||
| .. _Jython: http://www.jython.org/ | ||||
|  | ||||
|  | ||||
| The Django 1.0 roadmap | ||||
| ====================== | ||||
|  | ||||
| One of the primary goals of this alpha release is to focus attention | ||||
| on the remaining features to be implemented for Django 1.0, and on the | ||||
| bugs that need to be resolved before the final release. Following this | ||||
| release, we'll be conducting a series of development sprints building | ||||
| up to the beta and release-candidate stages, followed soon after by | ||||
| Django 1.0. The timeline is projected to be: | ||||
|  | ||||
| * **August 14, 2008: Django 1.0 beta release.** Past this point Django | ||||
|   will be in a "feature freeze" for the 1.0 release; after Django 1.0 | ||||
|   beta, the development focus will be solely on bug fixes and | ||||
|   stabilization. | ||||
|  | ||||
| * August 15, 2008: Sprint (based in Austin, Texas, USA, and online). | ||||
|  | ||||
| * August 17, 2008: Sprint (based in Tel Aviv, Israel, and online). | ||||
|  | ||||
| * **August 21, 2008: Django 1.0 release candidate 1.** At this point, | ||||
|   all strings marked for translation within Django's codebase will be | ||||
|   frozen, to provide contributors time to check and finalize all of | ||||
|   Django's bundled translation files prior to the final 1.0 release. | ||||
|  | ||||
| * August 22, 2008: Sprint (based in Portland, Oregon, USA, and online). | ||||
|  | ||||
| * **August 26, 2008: Django 1.0 release candidate 2.** | ||||
|  | ||||
| * August 30, 2008: Sprint (based in London, England, UK, and online). | ||||
|  | ||||
| * **September 2, 2008: Django 1.0 final release.** The official Django | ||||
|   1.0 release party will take place during the first-ever DjangoCon, | ||||
|   to be held in Mountain View, California, USA, September 6-7. | ||||
|  | ||||
| Of course, like any estimated timeline, this is subject to change as | ||||
| requirements dictate. The latest information will always be available | ||||
| on the Django project wiki: | ||||
|  | ||||
| * https://code.djangoproject.com/wiki/VersionOneRoadmap | ||||
|  | ||||
|  | ||||
| What you can do to help | ||||
| ======================= | ||||
|  | ||||
| In order to provide a high-quality 1.0 release, we need your | ||||
| help. Although this alpha release is, again, *not* intended for | ||||
| production use, you can help the Django team by trying out the alpha | ||||
| codebase in a safe test environment and reporting any bugs or issues | ||||
| you encounter. The Django ticket tracker is the central place to | ||||
| search for open issues: | ||||
|  | ||||
| * https://code.djangoproject.com/timeline | ||||
|  | ||||
| Please open new tickets if no existing ticket corresponds to a problem | ||||
| you're running into. | ||||
|  | ||||
| Additionally, discussion of Django development, including progress | ||||
| toward the 1.0 release, takes place daily on the django-developers | ||||
| mailing list: | ||||
|  | ||||
| * http://groups.google.com/group/django-developers | ||||
|  | ||||
| ...and in the ``#django-dev`` IRC channel on ``irc.freenode.net``. If | ||||
| you're interested in helping out with Django's development, feel free | ||||
| to join the discussions there. | ||||
|  | ||||
| Django's online documentation also includes pointers on how to | ||||
| contribute to Django: | ||||
|  | ||||
| * :doc:`contributing to Django </internals/contributing/index>` | ||||
|  | ||||
| Contributions on any level -- developing code, writing | ||||
| documentation or simply triaging tickets and helping to test proposed | ||||
| bugfixes -- are always welcome and appreciated. | ||||
| @@ -1,115 +0,0 @@ | ||||
| =============================== | ||||
| Django 1.0 beta 2 release notes | ||||
| =============================== | ||||
|  | ||||
| Welcome to Django 1.0 beta 2! | ||||
|  | ||||
| This is the fourth in a series of preview/development releases leading | ||||
| up to the eventual release of Django 1.0, currently scheduled to take | ||||
| place in early September 2008. This releases is primarily targeted at | ||||
| developers who are interested in testing the Django codebase and | ||||
| helping to identify and resolve bugs prior to the final 1.0 release. | ||||
|  | ||||
| As such, this release is *not* intended for production use, and any | ||||
| such use is discouraged. | ||||
|  | ||||
| What's new in Django 1.0 beta 2 | ||||
| =============================== | ||||
|  | ||||
| Django's development trunk has been the site of nearly constant | ||||
| activity over the past year, with several major new features landing | ||||
| since the 0.96 release.  For features which were new as of Django 1.0 | ||||
| alpha 1, see :doc:`the 1.0 alpha 1 release notes | ||||
| </releases/1.0-alpha-1>`. For features which were new as of Django 1.0 | ||||
| alpha 2, see :doc:`the 1.0 alpha 2 release notes | ||||
| </releases/1.0-alpha-2>`. For features which were new as of Django 1.0 | ||||
| beta 1, see :doc:`the 1.0 beta 1 release notes </releases/1.0-beta>`. | ||||
|  | ||||
| This beta release includes two major features: | ||||
|  | ||||
| Refactored ``django.contrib.comments`` | ||||
|     As part of a Google Summer of Code project, Thejaswi Puthraya | ||||
|     carried out a major rewrite and refactoring of Django's bundled | ||||
|     comment system, greatly increasing its flexibility and customizability. | ||||
|  | ||||
| Refactored documentation | ||||
|     Django's bundled and online documentation has also been | ||||
|     significantly refactored; the new documentation system uses | ||||
|     `Sphinx`_ to build the docs and handle such niceties as topical | ||||
|     indexes, reference documentation and cross-references within the | ||||
|     docs. You can check out the new documentation `online`_ or, if you | ||||
|     have Sphinx installed, build the HTML yourself from the | ||||
|     documentation files bundled with Django. | ||||
|  | ||||
| .. _Sphinx: http://sphinx-doc.org/ | ||||
| .. _online: https://docs.djangoproject.com/ | ||||
|  | ||||
| Along with these new features, the Django team has also been hard at | ||||
| work polishing Django's codebase for the final 1.0 release; this beta | ||||
| release contains a large number of smaller improvements and bugfixes | ||||
| from the ongoing push to 1.0. | ||||
|  | ||||
| Also, as part of its ongoing deprecation process, Django's old | ||||
| form-handling system has been removed; this means ``django.oldforms`` | ||||
| no longer exists, and its various API hooks (such as automatic | ||||
| manipulators) are no longer present in Django. This system has been | ||||
| completely replaced by :doc:`the new form-handling system | ||||
| </topics/forms/index>` in ``django.forms``. | ||||
|  | ||||
|  | ||||
| The Django 1.0 roadmap | ||||
| ====================== | ||||
|  | ||||
| One of the primary goals of this beta release is to focus attention on | ||||
| the remaining features to be implemented for Django 1.0, and on the | ||||
| bugs that need to be resolved before the final release. As of this | ||||
| beta release, Django is in its final "feature freeze" for 1.0; feature | ||||
| requests will be deferred to later releases, and the development | ||||
| effort will be focused solely on bugfixing and stability. Django is | ||||
| also now in a "string freeze"; translatable strings (labels, error | ||||
| messages, etc.) in Django's codebase will not be changed prior to the | ||||
| release, in order to allow our translators to produce the final 1.0 | ||||
| version of Django's translation files. | ||||
|  | ||||
| Following this release, we'll be conducting a final development sprint | ||||
| on August 30, 2008, based in London and coordinated online; the goal | ||||
| of this sprint will be to squash as many bugs as possible in | ||||
| anticipation of the final 1.0 release, which is currently targeted for | ||||
| **September 2, 2008**. The official Django 1.0 release party will take | ||||
| place during the first-ever DjangoCon, to be held in Mountain View, | ||||
| California, USA, September 6-7. | ||||
|  | ||||
|  | ||||
| What you can do to help | ||||
| ======================= | ||||
|  | ||||
| In order to provide a high-quality 1.0 release, we need your | ||||
| help. Although this beta release is, again, *not* intended for | ||||
| production use, you can help the Django team by trying out the beta | ||||
| codebase in a safe test environment and reporting any bugs or issues | ||||
| you encounter. The Django ticket tracker is the central place to | ||||
| search for open issues: | ||||
|  | ||||
| * https://code.djangoproject.com/timeline | ||||
|  | ||||
| Please open new tickets if no existing ticket corresponds to a problem | ||||
| you're running into. | ||||
|  | ||||
| Additionally, discussion of Django development, including progress | ||||
| toward the 1.0 release, takes place daily on the django-developers | ||||
| mailing list: | ||||
|  | ||||
| * http://groups.google.com/group/django-developers | ||||
|  | ||||
| ...and in the ``#django-dev`` IRC channel on ``irc.freenode.net``. If | ||||
| you're interested in helping out with Django's development, feel free | ||||
| to join the discussions there. | ||||
|  | ||||
| Django's online documentation also includes pointers on how to | ||||
| contribute to Django: | ||||
|  | ||||
| * :doc:`contributing to Django </internals/contributing/index>` | ||||
|  | ||||
| Contributions on any level -- developing code, writing | ||||
| documentation or simply triaging tickets and helping to test proposed | ||||
| bugfixes -- are always welcome and appreciated. | ||||
| @@ -1,153 +0,0 @@ | ||||
| =============================== | ||||
| Django 1.0 beta 1 release notes | ||||
| =============================== | ||||
|  | ||||
| Welcome to Django 1.0 beta 1! | ||||
|  | ||||
| This is the third in a series of preview/development releases leading | ||||
| up to the eventual release of Django 1.0, currently scheduled to take | ||||
| place in early September 2008. This releases is primarily targeted at | ||||
| developers who are interested in testing the Django codebase and | ||||
| helping to identify and resolve bugs prior to the final 1.0 release. | ||||
|  | ||||
| As such, this release is *not* intended for production use, and any | ||||
| such use is discouraged. | ||||
|  | ||||
| What's new in Django 1.0 beta 1 | ||||
| =============================== | ||||
|  | ||||
| Django's development trunk has been the site of nearly constant activity over | ||||
| the past year, with several major new features landing since the 0.96 release. | ||||
| For features which were new as of Django 1.0 alpha 1, see :doc:`the 1.0 alpha 1 | ||||
| release notes </releases/1.0-alpha-1>`. For features which were new as of Django | ||||
| 1.0 alpha 2, see :doc:`the 1.0 alpha 2 release notes </releases/1.0-alpha-2>`. | ||||
|  | ||||
| This beta release does not contain any major new features, but does | ||||
| include several smaller updates and improvements to Django: | ||||
|  | ||||
| Generic relations in forms and admin | ||||
|     Classes are now included in ``django.contrib.contenttypes`` which | ||||
|     can be used to support generic relations in both the admin | ||||
|     interface and in end-user forms. See :ref:`the documentation for | ||||
|     generic relations <generic-relations>` for details. | ||||
|  | ||||
| Improved flexibility in the admin | ||||
|     Following up on the refactoring of Django's administrative | ||||
|     interface (``django.contrib.admin``), introduced in Django 1.0 | ||||
|     alpha 1, two new hooks have been added to allow customized pre- | ||||
|     and post-save handling of model instances in the admin. Full | ||||
|     details are in :doc:`the admin documentation </ref/contrib/admin/index>`. | ||||
|  | ||||
| ``INSERT``/``UPDATE`` distinction | ||||
|     Although Django's default behavior of having a model's ``save()`` | ||||
|     method automatically determine whether to perform an ``INSERT`` or | ||||
|     an ``UPDATE`` at the SQL level is suitable for the majority of | ||||
|     cases, there are occasional situations where forcing one or the | ||||
|     other is useful. As a result, models can now support an additional | ||||
|     parameter to ``save()`` which can force a specific | ||||
|     operation. Consult the database API documentation for details | ||||
|     and important notes about appropriate use of this parameter. | ||||
|  | ||||
| Split ``CacheMiddleware`` | ||||
|    Django's ``CacheMiddleware`` has been split into three classes: | ||||
|    ``CacheMiddleware`` itself still exists and retains all of its | ||||
|    previous functionality, but it is now built from two separate | ||||
|    middleware classes which handle the two parts of caching (inserting | ||||
|    into and reading from the cache) separately, offering additional | ||||
|    flexibility for situations where combining these functions into a | ||||
|    single middleware posed problems. Full details, including updated | ||||
|    notes on appropriate use, are in | ||||
|    :doc:`the caching documentation </topics/cache>`. | ||||
|  | ||||
| Removal of deprecated features | ||||
|     A number of features and methods which had previously been marked | ||||
|     as deprecated, and which were scheduled for removal prior to the | ||||
|     1.0 release, are no longer present in Django. These include | ||||
|     imports of the form library from ``django.newforms`` (now located | ||||
|     simply at ``django.forms``), the ``form_for_model`` and | ||||
|     ``form_for_instance`` helper functions (which have been replaced | ||||
|     by ``ModelForm``) and a number of deprecated features which were | ||||
|     replaced by the dispatcher, file-uploading and file-storage | ||||
|     refactorings introduced in the Django 1.0 alpha releases. A full | ||||
|     list of these and all other backwards-incompatible changes is | ||||
|     available on `the Django wiki`_. | ||||
|  | ||||
| A number of other improvements and bugfixes have also been included: | ||||
| some tricky cases involving case-sensitivity in differing MySQL | ||||
| collations have been resolved, Windows packaging and installation has | ||||
| been improved and the method by which Django generates unique session | ||||
| identifiers has been made much more robust. | ||||
|  | ||||
| .. _the documentation for generic relations: ../contenttypes/#generic-relations | ||||
| .. _the Django wiki: https://code.djangoproject.com/wiki/BackwardsIncompatibleChanges#Removedseveralmoredeprecatedfeaturesfor1.0 | ||||
|  | ||||
|  | ||||
| The Django 1.0 roadmap | ||||
| ====================== | ||||
|  | ||||
| One of the primary goals of this beta release is to focus attention on | ||||
| the remaining features to be implemented for Django 1.0, and on the | ||||
| bugs that need to be resolved before the final release. Following this | ||||
| release, we'll be conducting a series of development sprints building | ||||
| up to the release-candidate stage, followed soon after by Django | ||||
| 1.0. The timeline is projected to be: | ||||
|  | ||||
| * August 15, 2008: Sprint (based in Austin, Texas, USA, and online). | ||||
|  | ||||
| * August 17, 2008: Sprint (based in Tel Aviv, Israel, and online). | ||||
|  | ||||
| * **August 21, 2008: Django 1.0 release candidate 1.** At this point, | ||||
|   all strings marked for translation within Django's codebase will be | ||||
|   frozen, to provide contributors time to check and finalize all of | ||||
|   Django's bundled translation files prior to the final 1.0 release. | ||||
|  | ||||
| * August 22, 2008: Sprint (based in Portland, Oregon, USA, and online). | ||||
|  | ||||
| * **August 26, 2008: Django 1.0 release candidate 2.** | ||||
|  | ||||
| * August 30, 2008: Sprint (based in London, England, UK, and online). | ||||
|  | ||||
| * **September 2, 2008: Django 1.0 final release.** The official Django | ||||
|   1.0 release party will take place during the first-ever DjangoCon, | ||||
|   to be held in Mountain View, California, USA, September 6-7. | ||||
|  | ||||
| Of course, like any estimated timeline, this is subject to change as | ||||
| requirements dictate. The latest information will always be available | ||||
| on the Django project wiki: | ||||
|  | ||||
| * https://code.djangoproject.com/wiki/VersionOneRoadmap | ||||
|  | ||||
|  | ||||
| What you can do to help | ||||
| ======================= | ||||
|  | ||||
| In order to provide a high-quality 1.0 release, we need your | ||||
| help. Although this beta release is, again, *not* intended for | ||||
| production use, you can help the Django team by trying out the beta | ||||
| codebase in a safe test environment and reporting any bugs or issues | ||||
| you encounter. The Django ticket tracker is the central place to | ||||
| search for open issues: | ||||
|  | ||||
| * https://code.djangoproject.com/timeline | ||||
|  | ||||
| Please open new tickets if no existing ticket corresponds to a problem | ||||
| you're running into. | ||||
|  | ||||
| Additionally, discussion of Django development, including progress | ||||
| toward the 1.0 release, takes place daily on the django-developers | ||||
| mailing list: | ||||
|  | ||||
| * http://groups.google.com/group/django-developers | ||||
|  | ||||
| ...and in the ``#django-dev`` IRC channel on ``irc.freenode.net``. If | ||||
| you're interested in helping out with Django's development, feel free | ||||
| to join the discussions there. | ||||
|  | ||||
| Django's online documentation also includes pointers on how to | ||||
| contribute to Django: | ||||
|  | ||||
| * :doc:`contributing to Django </internals/contributing/index>` | ||||
|  | ||||
| Contributions on any level -- developing code, writing | ||||
| documentation or simply triaging tickets and helping to test proposed | ||||
| bugfixes -- are always welcome and appreciated. | ||||
| @@ -1,165 +0,0 @@ | ||||
| ================================ | ||||
| Django 1.1 alpha 1 release notes | ||||
| ================================ | ||||
|  | ||||
| February 23, 2009 | ||||
|  | ||||
| Welcome to Django 1.1 alpha 1! | ||||
|  | ||||
| This is the first in a series of preview/development releases leading up to the | ||||
| eventual release of Django 1.1, currently scheduled to take place in April 2009. | ||||
| This release is primarily targeted at developers who are interested in trying | ||||
| out new features and testing the Django codebase to help identify and resolve | ||||
| bugs prior to the final 1.1 release. | ||||
|  | ||||
| As such, this release is *not* intended for production use, and any such use is | ||||
| discouraged. | ||||
|  | ||||
| What's new in Django 1.1 alpha 1 | ||||
| ================================ | ||||
|  | ||||
| ORM improvements | ||||
| ---------------- | ||||
|  | ||||
| Two major enhancements have been added to Django's object-relational mapper | ||||
| (ORM): | ||||
|  | ||||
| Aggregate support | ||||
| ~~~~~~~~~~~~~~~~~ | ||||
|  | ||||
| .. currentmodule:: django.db.models | ||||
|  | ||||
| It's now possible to run SQL aggregate queries (i.e. ``COUNT()``, ``MAX()``, | ||||
| ``MIN()``, etc.) from within Django's ORM. You can choose to either return the | ||||
| results of the aggregate directly, or else annotate the objects in a | ||||
| :class:`~django.db.models.query.QuerySet` with the results of the aggregate | ||||
| query. | ||||
|  | ||||
| This feature is available as new | ||||
| :meth:`~django.db.models.query.QuerySet.aggregate` and | ||||
| :meth:`~django.db.models.query.QuerySet.annotate` methods, and is covered in | ||||
| detail in :doc:`the ORM aggregation documentation </topics/db/aggregation>`. | ||||
|  | ||||
| Query expressions | ||||
| ~~~~~~~~~~~~~~~~~ | ||||
|  | ||||
| Queries can now refer to a another field on the query and can traverse | ||||
| relationships to refer to fields on related models. This is implemented in the | ||||
| new :class:`F` object; for full details, including examples, consult the | ||||
| :class:`F expressions documentation <django.db.models.F>`. | ||||
|  | ||||
| Performance improvements | ||||
| ------------------------ | ||||
|  | ||||
| .. currentmodule:: django.test | ||||
|  | ||||
| Tests written using Django's :doc:`testing framework </topics/testing/index>` | ||||
| now run dramatically faster (as much as 10 times faster in many cases). | ||||
|  | ||||
| This was accomplished through the introduction of transaction-based tests: when | ||||
| using :class:`django.test.TestCase`, your tests will now be run in a transaction | ||||
| which is rolled back when finished, instead of by flushing and re-populating the | ||||
| database. This results in an immense speedup for most types of unit tests. See | ||||
| the documentation for :class:`TestCase` and :class:`TransactionTestCase` for a | ||||
| full description, and some important notes on database support. | ||||
|  | ||||
| Other improvements | ||||
| ------------------ | ||||
|  | ||||
| Other new features and changes introduced since Django 1.0 include: | ||||
|  | ||||
| * The :doc:`CSRF protection middleware </ref/contrib/csrf>` has been split into | ||||
|   two classes -- ``CsrfViewMiddleware`` checks incoming requests, and | ||||
|   ``CsrfResponseMiddleware`` processes outgoing responses. The combined | ||||
|   ``CsrfMiddleware`` class (which does both) remains for | ||||
|   backwards-compatibility, but using the split classes is now recommended in | ||||
|   order to allow fine-grained control of when and where the CSRF processing | ||||
|   takes place. | ||||
|  | ||||
| * :func:`~django.core.urlresolvers.reverse` and code which uses it (e.g., the | ||||
|   ``{% url %}`` template tag) now works with URLs in Django's administrative | ||||
|   site, provided that the admin URLs are set up via ``include(admin.site.urls)`` | ||||
|   (sending admin requests to the ``admin.site.root`` view still works, but URLs | ||||
|   in the admin will not be "reversible" when configured this way). | ||||
|  | ||||
| * The ``include()`` function in Django URLconf modules can now accept sequences | ||||
|   of URL patterns (generated by ``patterns()``) in addition to module names. | ||||
|  | ||||
| * Instances of Django forms (see :doc:`the forms overview </topics/forms/index>`) | ||||
|   now have two additional methods, ``hidden_fields()`` and ``visible_fields()``, | ||||
|   which return the list of hidden -- i.e., ``<input type="hidden">`` -- and | ||||
|   visible fields on the form, respectively. | ||||
|  | ||||
| * The ``redirect_to`` generic view | ||||
|   now accepts an additional keyword argument | ||||
|   ``permanent``. If ``permanent`` is ``True``, the view will emit an HTTP | ||||
|   permanent redirect (status code 301). If ``False``, the view will emit an HTTP | ||||
|   temporary redirect (status code 302). | ||||
|  | ||||
| * A new database lookup type -- ``week_day`` -- has been added for ``DateField`` | ||||
|   and ``DateTimeField``. This type of lookup accepts a number between 1 (Sunday) | ||||
|   and 7 (Saturday), and returns objects where the field value matches that day | ||||
|   of the week. See :ref:`the full list of lookup types <field-lookups>` for | ||||
|   details. | ||||
|  | ||||
| * The ``{% for %}`` tag in Django's template language now accepts an optional | ||||
|   ``{% empty %}`` clause, to be displayed when ``{% for %}`` is asked to loop | ||||
|   over an empty sequence. See :doc:`the list of built-in template tags | ||||
|   </ref/templates/builtins>` for examples of this. | ||||
|  | ||||
| The Django 1.1 roadmap | ||||
| ====================== | ||||
|  | ||||
| Before Django 1.1 goes final, several other preview/development releases will be | ||||
| made available. The current schedule consists of at least the following: | ||||
|  | ||||
| * Week of *March 20, 2009:* Django 1.1 beta 1, at which point Django 1.1 will | ||||
|   be in "feature freeze": no new features will be implemented for 1.1 | ||||
|   past that point, and all new feature work will be deferred to | ||||
|   Django 1.2. | ||||
|  | ||||
| * Week of *April 2, 2009:* Django 1.1 release candidate. At this point all | ||||
|   strings marked for translation must freeze to allow translations to | ||||
|   be submitted in advance of the final release. | ||||
|  | ||||
| * Week of *April 13, 2009:* Django 1.1 final. | ||||
|  | ||||
| If deemed necessary, additional alpha, beta or release candidate packages will | ||||
| be issued prior to the final 1.1 release. | ||||
|  | ||||
| What you can do to help | ||||
| ======================= | ||||
|  | ||||
| In order to provide a high-quality 1.1 release, we need your help. Although this | ||||
| alpha release is, again, *not* intended for production use, you can help the | ||||
| Django team by trying out the alpha codebase in a safe test environment and | ||||
| reporting any bugs or issues you encounter. The Django ticket tracker is the | ||||
| central place to search for open issues: | ||||
|  | ||||
| * https://code.djangoproject.com/timeline | ||||
|  | ||||
| Please open new tickets if no existing ticket corresponds to a problem you're | ||||
| running into. | ||||
|  | ||||
| Additionally, discussion of Django development, including progress toward the | ||||
| 1.1 release, takes place daily on the django-developers mailing list: | ||||
|  | ||||
| * http://groups.google.com/group/django-developers | ||||
|  | ||||
| ... and in the ``#django-dev`` IRC channel on ``irc.freenode.net``. If you're | ||||
| interested in helping out with Django's development, feel free to join the | ||||
| discussions there. | ||||
|  | ||||
| Django's online documentation also includes pointers on how to contribute to | ||||
| Django: | ||||
|  | ||||
| * :doc:`How to contribute to Django </internals/contributing/index>` | ||||
|  | ||||
| Contributions on any level -- developing code, writing documentation or simply | ||||
| triaging tickets and helping to test proposed bugfixes -- are always welcome and | ||||
| appreciated. | ||||
|  | ||||
| Development sprints for Django 1.1 will also be taking place at PyCon US 2009, | ||||
| on the dedicated sprint days (March 30 through April 2), and anyone who wants to | ||||
| help out is welcome to join in, either in person at PyCon or virtually in the | ||||
| IRC channel or on the mailing list. | ||||
| @@ -1,208 +0,0 @@ | ||||
| =============================== | ||||
| Django 1.1 beta 1 release notes | ||||
| =============================== | ||||
|  | ||||
| March 23, 2009 | ||||
|  | ||||
| Welcome to Django 1.1 beta 1! | ||||
|  | ||||
| This is the second in a series of preview/development releases leading up to | ||||
| the eventual release of Django 1.1, currently scheduled to take place in April | ||||
| 2009. This release is primarily targeted at developers who are interested in | ||||
| trying out new features and testing the Django codebase to help identify and | ||||
| resolve bugs prior to the final 1.1 release. | ||||
|  | ||||
| As such, this release is *not* intended for production use, and any such use | ||||
| is discouraged. | ||||
|  | ||||
| What's new in Django 1.1 beta 1 | ||||
| =============================== | ||||
|  | ||||
| .. seealso:: | ||||
|  | ||||
|     The :doc:`1.1 alpha release notes </releases/1.1-alpha-1>`, which has a | ||||
|     list of everything new between Django 1.0 and Django 1.1 alpha. | ||||
|  | ||||
| Model improvements | ||||
| ------------------ | ||||
|  | ||||
| .. currentmodule:: django.db.models | ||||
|  | ||||
| A number of features have been added to Django's model layer: | ||||
|  | ||||
| "Unmanaged" models | ||||
| ~~~~~~~~~~~~~~~~~~ | ||||
|  | ||||
| You can now control whether or not Django creates database tables for a model | ||||
| using the :attr:`~Options.managed` model option. This defaults to ``True``, | ||||
| meaning that Django will create the appropriate database tables in | ||||
| :djadmin:`syncdb` and remove them as part of ``reset`` command. That | ||||
| is, Django *manages* the database table's lifecycle. | ||||
|  | ||||
| If you set this to ``False``, however, no database table creating or deletion | ||||
| will be automatically performed for this model. This is useful if the model | ||||
| represents an existing table or a database view that has been created by some | ||||
| other means. | ||||
|  | ||||
| For more details, see the documentation for the :attr:`~Options.managed` | ||||
| option. | ||||
|  | ||||
| Proxy models | ||||
| ~~~~~~~~~~~~ | ||||
|  | ||||
| You can now create :ref:`proxy models <proxy-models>`: subclasses of existing | ||||
| models that only add Python behavior and aren't represented by a new table. | ||||
| That is, the new model is a *proxy* for some underlying model, which stores | ||||
| all the real data. | ||||
|  | ||||
| All the details can be found in the :ref:`proxy models documentation | ||||
| <proxy-models>`. This feature is similar on the surface to unmanaged models, | ||||
| so the documentation has an explanation of :ref:`how proxy models differ from | ||||
| unmanaged models <proxy-vs-unmanaged-models>`. | ||||
|  | ||||
| Deferred fields | ||||
| ~~~~~~~~~~~~~~~ | ||||
|  | ||||
| In some complex situations, your models might contain fields which could | ||||
| contain a lot of data (for example, large text fields), or require expensive | ||||
| processing to convert them to Python objects. If you know you don't need those | ||||
| particular fields, you can now tell Django not to retrieve them from the | ||||
| database. | ||||
|  | ||||
| You'll do this with the new queryset methods | ||||
| :meth:`~django.db.models.query.QuerySet.defer` and | ||||
| :meth:`~django.db.models.query.QuerySet.only`. | ||||
|  | ||||
| New admin features | ||||
| ------------------ | ||||
|  | ||||
| Since 1.1 alpha, a couple of new features have been added to Django's admin | ||||
| application: | ||||
|  | ||||
| Editable fields on the change list | ||||
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ | ||||
|  | ||||
| You can now make fields editable on the admin list views via the new | ||||
| :ref:`list_editable <admin-list-editable>` admin option. These fields will show | ||||
| up as form widgets on the list pages, and can be edited and saved in bulk. | ||||
|  | ||||
| Admin "actions" | ||||
| ~~~~~~~~~~~~~~~ | ||||
|  | ||||
| You can now define :doc:`admin actions </ref/contrib/admin/actions>` that can perform | ||||
| some action to a group of models in bulk. Users will be able to select objects on | ||||
| the change list page and then apply these bulk actions to all selected objects. | ||||
|  | ||||
| Django ships with one pre-defined admin action to delete a group of objects in | ||||
| one fell swoop. | ||||
|  | ||||
| Testing improvements | ||||
| -------------------- | ||||
|  | ||||
| .. currentmodule:: django.test | ||||
|  | ||||
| A couple of small but very useful improvements have been made to the | ||||
| :doc:`testing framework </topics/testing/index>`: | ||||
|  | ||||
| * The test :class:`Client` now can automatically follow redirects with the | ||||
|   ``follow`` argument to :meth:`Client.get` and :meth:`Client.post`. This | ||||
|   makes testing views that issue redirects simpler. | ||||
|  | ||||
| * It's now easier to get at the template context in the response returned | ||||
|   the test client: you'll simply access the context as | ||||
|   ``request.context[key]``. The old way, which treats ``request.context`` | ||||
|   as a list of contexts, one for each rendered template, is still | ||||
|   available if you need it. | ||||
|  | ||||
| Conditional view processing | ||||
| --------------------------- | ||||
|  | ||||
| Django now has much better support for :doc:`conditional view processing | ||||
| </topics/conditional-view-processing>` using the standard ``ETag`` and | ||||
| ``Last-Modified`` HTTP headers. This means you can now easily short-circuit | ||||
| view processing by testing less-expensive conditions. For many views this can | ||||
| lead to a serious improvement in speed and reduction in bandwidth. | ||||
|  | ||||
| Other improvements | ||||
| ------------------ | ||||
|  | ||||
| Finally, a grab-bag of other neat features made their way into this beta | ||||
| release, including: | ||||
|  | ||||
| * The :djadmin:`dumpdata` management command now accepts individual | ||||
|   model names as arguments, allowing you to export the data just from | ||||
|   particular models. | ||||
|  | ||||
| * There's a new :tfilter:`safeseq` template filter which works just like | ||||
|   :tfilter:`safe` for lists, marking each item in the list as safe. | ||||
|  | ||||
| * :doc:`Cache backends </topics/cache>` now support ``incr()`` and | ||||
|   ``decr()`` commands to increment and decrement the value of a cache key. | ||||
|   On cache backends that support atomic increment/decrement -- most | ||||
|   notably, the memcached backend -- these operations will be atomic, and | ||||
|   quite fast. | ||||
|  | ||||
| * Django now can :doc:`easily delegate authentication to the Web server | ||||
|   </howto/auth-remote-user>` via a new authentication backend that supports | ||||
|   the standard ``REMOTE_USER`` environment variable used for this purpose. | ||||
|  | ||||
| * There's a new :func:`django.shortcuts.redirect` function that makes it | ||||
|   easier to issue redirects given an object, a view name, or a URL. | ||||
|  | ||||
| * The ``postgresql_psycopg2`` backend now supports :ref:`native PostgreSQL | ||||
|   autocommit <postgresql-notes>`. This is an advanced, PostgreSQL-specific | ||||
|   feature, that can make certain read-heavy applications a good deal | ||||
|   faster. | ||||
|  | ||||
| The Django 1.1 roadmap | ||||
| ====================== | ||||
|  | ||||
| Before Django 1.1 goes final, at least one other preview/development release | ||||
| will be made available. The current schedule consists of at least the | ||||
| following: | ||||
|  | ||||
| * Week of *April 2, 2009:* Django 1.1 release candidate. At this point all | ||||
|   strings marked for translation must freeze to allow translations to | ||||
|   be submitted in advance of the final release. | ||||
|  | ||||
| * Week of *April 13, 2009:* Django 1.1 final. | ||||
|  | ||||
| If deemed necessary, additional beta or release candidate packages will be | ||||
| issued prior to the final 1.1 release. | ||||
|  | ||||
| What you can do to help | ||||
| ======================= | ||||
|  | ||||
| In order to provide a high-quality 1.1 release, we need your help. Although this | ||||
| beta release is, again, *not* intended for production use, you can help the | ||||
| Django team by trying out the beta codebase in a safe test environment and | ||||
| reporting any bugs or issues you encounter. The Django ticket tracker is the | ||||
| central place to search for open issues: | ||||
|  | ||||
| * https://code.djangoproject.com/timeline | ||||
|  | ||||
| Please open new tickets if no existing ticket corresponds to a problem you're | ||||
| running into. | ||||
|  | ||||
| Additionally, discussion of Django development, including progress toward the | ||||
| 1.1 release, takes place daily on the django-developers mailing list: | ||||
|  | ||||
| * http://groups.google.com/group/django-developers | ||||
|  | ||||
| ... and in the ``#django-dev`` IRC channel on ``irc.freenode.net``. If you're | ||||
| interested in helping out with Django's development, feel free to join the | ||||
| discussions there. | ||||
|  | ||||
| Django's online documentation also includes pointers on how to contribute to | ||||
| Django: | ||||
|  | ||||
| * :doc:`How to contribute to Django </internals/contributing/index>` | ||||
|  | ||||
| Contributions on any level -- developing code, writing documentation or simply | ||||
| triaging tickets and helping to test proposed bugfixes -- are always welcome and | ||||
| appreciated. | ||||
|  | ||||
| Development sprints for Django 1.1 will also be taking place at PyCon US 2009, | ||||
| on the dedicated sprint days (March 30 through April 2), and anyone who wants to | ||||
| help out is welcome to join in, either in person at PyCon or virtually in the | ||||
| IRC channel or on the mailing list. | ||||
| @@ -1,109 +0,0 @@ | ||||
| ============================= | ||||
| Django 1.1 RC 1 release notes | ||||
| ============================= | ||||
|  | ||||
|  | ||||
| July 21, 2009 | ||||
|  | ||||
| Welcome to the first Django 1.1 release candidate! | ||||
|  | ||||
| This is the third -- and likely last -- in a series of | ||||
| preview/development releases leading up to the eventual release of | ||||
| Django 1.1, currently scheduled to take place approximately one week | ||||
| after this release candidate. This release is targeted primarily at | ||||
| developers who are interested in trying out new features and testing | ||||
| the Django codebase to help identify and resolve any critical bugs | ||||
| prior to the final 1.1 release. | ||||
|  | ||||
| As such, this release is not yet intended for production use, and any | ||||
| such use is discouraged. | ||||
|  | ||||
|  | ||||
| What's new in Django 1.1 RC 1 | ||||
| ============================= | ||||
|  | ||||
| The Django codebase has -- with one exception -- been in feature | ||||
| freeze since the first 1.1 beta release, and so this release candidate | ||||
| contains only one new feature (see below); work leading up to this | ||||
| release candidate has instead been focused on bugfixing, particularly | ||||
| on the new features introduced prior to the 1.1 beta. | ||||
|  | ||||
| For an overview of those features, consult :doc:`the Django 1.1 beta | ||||
| release notes </releases/1.1-beta-1>`. | ||||
|  | ||||
|  | ||||
| URL namespaces | ||||
| -------------- | ||||
|  | ||||
| The 1.1 beta release introduced the ability to use reverse URL | ||||
| resolution with Django's admin application, which exposed a set of | ||||
| :ref:`named URLs <naming-url-patterns>`. Unfortunately, achieving | ||||
| consistent and correct reverse resolution for admin URLs proved | ||||
| extremely difficult, and so one additional feature was added to Django | ||||
| to resolve this issue: URL namespaces. | ||||
|  | ||||
| In short, this feature allows the same group of URLs, from the same | ||||
| application, to be included in a Django URLConf multiple times, with | ||||
| varying (and potentially nested) named prefixes which will be used | ||||
| when performing reverse resolution. For full details, see :ref:`the | ||||
| documentation on defining URL namespaces | ||||
| <topics-http-defining-url-namespaces>`. | ||||
|  | ||||
| Due to the changes needed to support this feature, the URL pattern | ||||
| names used when reversing admin URLs have changed since the 1.1 beta | ||||
| release; if you were developing applications which took advantage of | ||||
| this new feature, you will need to update your code to reflect the new | ||||
| names (for most purposes, changing ``admin_`` to ``admin:`` in names | ||||
| to be reversed will suffice). For a full list of URL pattern names | ||||
| used by the admin and information on how namespaces are applied to | ||||
| them, consult the documentation on :ref:`reversing admin URLs | ||||
| <admin-reverse-urls>`. | ||||
|  | ||||
|  | ||||
| The Django 1.1 roadmap | ||||
| ====================== | ||||
|  | ||||
| As of this release candidate, Django 1.1 is in both feature freeze and | ||||
| "string freeze" -- all strings marked for translation in the Django | ||||
| codebase will retain their current form in the final Django 1.1 | ||||
| release. Only critical release-blocking bugs will receive attention | ||||
| between now and the final 1.1 release. | ||||
|  | ||||
| If no such bugs are discovered, Django 1.1 will be released | ||||
| approximately one week after this release candidate, on or about July | ||||
| 28, 2009. | ||||
|  | ||||
|  | ||||
| What you can do to help | ||||
| ======================= | ||||
|  | ||||
| In order to provide a high-quality 1.1 release, we need your | ||||
| help. Although this release candidate is, again, *not* intended for | ||||
| production use, you can help the Django team by trying out this | ||||
| release candidate in a safe testing environment and reporting any bugs | ||||
| or issues you encounter. The Django ticket tracker is the central | ||||
| place to search for open issues: | ||||
|  | ||||
| * https://code.djangoproject.com/timeline | ||||
|  | ||||
| Please open a new ticket only if no existing ticket corresponds to a | ||||
| problem you're running into. | ||||
|  | ||||
| Additionally, discussion of Django development, including progress | ||||
| toward the 1.1 release, takes place daily on the django-developers | ||||
| mailing list: | ||||
|  | ||||
| * http://groups.google.com/group/django-developers | ||||
|  | ||||
| ... and in the ``#django-dev`` IRC channel on ``irc.freenode.net``. If you're | ||||
| interested in helping out with Django's development, feel free to join the | ||||
| discussions there. | ||||
|  | ||||
| Django's online documentation also includes pointers on how to contribute to | ||||
| Django: | ||||
|  | ||||
| * :doc:`How to contribute to Django </internals/contributing/index>` | ||||
|  | ||||
| Contributions on any level -- developing code, writing documentation or simply | ||||
| triaging tickets and helping to test proposed bugfixes -- are always welcome and | ||||
| appreciated. | ||||
| @@ -1,588 +0,0 @@ | ||||
| ================================ | ||||
| Django 1.2 alpha 1 release notes | ||||
| ================================ | ||||
|  | ||||
| January 5, 2010 | ||||
|  | ||||
| Welcome to Django 1.2 alpha 1! | ||||
|  | ||||
| This is the first in a series of preview/development releases leading up to the | ||||
| eventual release of Django 1.2, currently scheduled to take place in March 2010. | ||||
| This release is primarily targeted at developers who are interested in trying | ||||
| out new features and testing the Django codebase to help identify and resolve | ||||
| bugs prior to the final 1.2 release. | ||||
|  | ||||
| As such, this release is *not* intended for production use, and any such use is | ||||
| discouraged. | ||||
|  | ||||
|  | ||||
| Backwards-incompatible changes in 1.2 | ||||
| ===================================== | ||||
|  | ||||
| CSRF Protection | ||||
| --------------- | ||||
|  | ||||
| There have been large changes to the way that CSRF protection works, detailed in | ||||
| :doc:`the CSRF documentation </ref/contrib/csrf>`.  The following are the major | ||||
| changes that developers must be aware of: | ||||
|  | ||||
| * ``CsrfResponseMiddleware`` and ``CsrfMiddleware`` have been deprecated, and | ||||
|   **will be removed completely in Django 1.4**, in favor of a template tag that | ||||
|   should be inserted into forms. | ||||
|  | ||||
| * All contrib apps use a ``csrf_protect`` decorator to protect the view. This | ||||
|   requires the use of the ``csrf_token`` template tag in the template, so if you | ||||
|   have used custom templates for contrib views, you MUST READ THE UPGRADE | ||||
|   INSTRUCTIONS to fix those templates. | ||||
|  | ||||
|   .. admonition:: Documentation removed | ||||
|  | ||||
|      The upgrade notes have been removed in current Django docs. Please refer | ||||
|      to the docs for Django 1.3 or older to find these instructions. | ||||
|  | ||||
| * ``CsrfViewMiddleware`` is included in :setting:`MIDDLEWARE_CLASSES` by | ||||
|   default. This turns on CSRF protection by default, so that views that accept | ||||
|   POST requests need to be written to work with the middleware. Instructions | ||||
|   on how to do this are found in the CSRF docs. | ||||
|  | ||||
| * CSRF-related code has moved from ``contrib`` to ``core`` (with | ||||
|   backwards compatible imports in the old locations, which are | ||||
|   deprecated). | ||||
|  | ||||
| :ttag:`if` tag changes | ||||
| ---------------------- | ||||
|  | ||||
| Due to new features in the :ttag:`if` template tag, it no longer accepts 'and', | ||||
| 'or' and 'not' as valid **variable** names.  Previously that worked in some | ||||
| cases even though these strings were normally treated as keywords.  Now, the | ||||
| keyword status is always enforced, and template code like ``{% if not %}`` or | ||||
| ``{% if and %}`` will throw a TemplateSyntaxError. | ||||
|  | ||||
| ``LazyObject`` | ||||
| -------------- | ||||
|  | ||||
| ``LazyObject`` is an undocumented utility class used for lazily wrapping other | ||||
| objects of unknown type.  In Django 1.1 and earlier, it handled introspection in | ||||
| a non-standard way, depending on wrapped objects implementing a public method | ||||
| ``get_all_members()``. Since this could easily lead to name clashes, it has been | ||||
| changed to use the standard method, involving ``__members__`` and ``__dir__()``. | ||||
| If you used ``LazyObject`` in your own code, and implemented the | ||||
| ``get_all_members()`` method for wrapped objects, you need to make the following | ||||
| changes: | ||||
|  | ||||
| * If your class does not have special requirements for introspection (i.e. you | ||||
|   have not implemented ``__getattr__()`` or other methods that allow for | ||||
|   attributes not discoverable by normal mechanisms), you can simply remove the | ||||
|   ``get_all_members()`` method.  The default implementation on ``LazyObject`` | ||||
|   will do the right thing. | ||||
|  | ||||
| * If you have more complex requirements for introspection, first rename the | ||||
|   ``get_all_members()`` method to ``__dir__()``.  This is the standard method, | ||||
|   from Python 2.6 onwards, for supporting introspection.  If you are require | ||||
|   support for Python < 2.6, add the following code to the class:: | ||||
|  | ||||
|       __members__ = property(lambda self: self.__dir__()) | ||||
|  | ||||
| ``__dict__`` on Model instances | ||||
| ------------------------------- | ||||
|  | ||||
| Historically, the ``__dict__`` attribute of a model instance has only contained | ||||
| attributes corresponding to the fields on a model. | ||||
|  | ||||
| In order to support multiple database configurations, Django 1.2 has | ||||
| added a ``_state`` attribute to object instances. This attribute will | ||||
| appear in ``__dict__`` for a model instance. If your code relies on | ||||
| iterating over __dict__ to obtain a list of fields, you must now | ||||
| filter the ``_state`` attribute of out ``__dict__``. | ||||
|  | ||||
| ``get_db_prep_*()`` methods on Field | ||||
| ------------------------------------ | ||||
|  | ||||
| Prior to v1.2, a custom field had the option of defining several | ||||
| functions to support conversion of Python values into | ||||
| database-compatible values. A custom field might look something like:: | ||||
|  | ||||
|     class CustomModelField(models.Field): | ||||
|         # ... | ||||
|  | ||||
|         def get_db_prep_save(self, value): | ||||
|             # ... | ||||
|  | ||||
|         def get_db_prep_value(self, value): | ||||
|             # ... | ||||
|  | ||||
|         def get_db_prep_lookup(self, lookup_type, value): | ||||
|             # ... | ||||
|  | ||||
| In 1.2, these three methods have undergone a change in prototype, and | ||||
| two extra methods have been introduced:: | ||||
|  | ||||
|     class CustomModelField(models.Field): | ||||
|         # ... | ||||
|  | ||||
|         def get_prep_value(self, value): | ||||
|             # ... | ||||
|  | ||||
|         def get_prep_lookup(self, lookup_type, value): | ||||
|             # ... | ||||
|  | ||||
|         def get_db_prep_save(self, value, connection): | ||||
|             # ... | ||||
|  | ||||
|         def get_db_prep_value(self, value, connection, prepared=False): | ||||
|             # ... | ||||
|  | ||||
|         def get_db_prep_lookup(self, lookup_type, value, connection, prepared=False): | ||||
|             # ... | ||||
|  | ||||
| These changes are required to support multiple databases: | ||||
| ``get_db_prep_*`` can no longer make any assumptions regarding the | ||||
| database for which it is preparing. The ``connection`` argument now | ||||
| provides the preparation methods with the specific connection for | ||||
| which the value is being prepared. | ||||
|  | ||||
| The two new methods exist to differentiate general data preparation | ||||
| requirements, and requirements that are database-specific. The | ||||
| ``prepared`` argument is used to indicate to the database preparation | ||||
| methods whether generic value preparation has been performed. If | ||||
| an unprepared (i.e., ``prepared=False``) value is provided to the | ||||
| ``get_db_prep_*()`` calls, they should invoke the corresponding | ||||
| ``get_prep_*()`` calls to perform generic data preparation. | ||||
|  | ||||
| Conversion functions has been provided which will transparently | ||||
| convert functions adhering to the old prototype into functions | ||||
| compatible with the new prototype. However, this conversion function | ||||
| will be removed in Django 1.4, so you should upgrade your Field | ||||
| definitions to use the new prototype. | ||||
|  | ||||
| If your ``get_db_prep_*()`` methods made no use of the database | ||||
| connection, you should be able to upgrade by renaming | ||||
| ``get_db_prep_value()`` to ``get_prep_value()`` and | ||||
| ``get_db_prep_lookup()`` to ``get_prep_lookup()`. If you require | ||||
| database specific conversions, then you will need to provide an | ||||
| implementation ``get_db_prep_*`` that uses the ``connection`` | ||||
| argument to resolve database-specific values. | ||||
|  | ||||
| Stateful template tags | ||||
| ---------------------- | ||||
|  | ||||
| Template tags that store rendering state on the node itself may experience | ||||
| problems if they are used with the new :ref:`cached | ||||
| template loader<template-loaders>`. | ||||
|  | ||||
| All of the built-in Django template tags are safe to use with the cached | ||||
| loader, but if you're using custom template tags that come from third | ||||
| party packages, or that you wrote yourself, you should ensure that the | ||||
| ``Node`` implementation for each tag is thread-safe. For more | ||||
| information, see | ||||
| :ref:`template tag thread safety considerations<template_tag_thread_safety>`. | ||||
|  | ||||
| Test runner exit status code | ||||
| ---------------------------- | ||||
|  | ||||
| The exit status code of the test runners (``tests/runtests.py`` and ``python | ||||
| manage.py test``) no longer represents the number of failed tests, since a | ||||
| failure of 256 or more tests resulted in a wrong exit status code.  The exit | ||||
| status code for the test runner is now 0 for success (no failing tests) and 1 | ||||
| for any number of test failures.  If needed, the number of test failures can be | ||||
| found at the end of the test runner's output. | ||||
|  | ||||
| Features deprecated in 1.2 | ||||
| ========================== | ||||
|  | ||||
| CSRF response rewriting middleware | ||||
| ---------------------------------- | ||||
|  | ||||
| ``CsrfResponseMiddleware``, the middleware that automatically inserted CSRF | ||||
| tokens into POST forms in outgoing pages, has been deprecated in favor of a | ||||
| template tag method (see above), and will be removed completely in Django | ||||
| 1.4. ``CsrfMiddleware``, which includes the functionality of | ||||
| ``CsrfResponseMiddleware`` and ``CsrfViewMiddleware`` has likewise been | ||||
| deprecated. | ||||
|  | ||||
| Also, the CSRF module has moved from contrib to core, and the old | ||||
| imports are deprecated, as described in the upgrading notes. | ||||
|  | ||||
| .. admonition:: Documentation removed | ||||
|  | ||||
|    The upgrade notes have been removed in current Django docs. Please refer | ||||
|    to the docs for Django 1.3 or older to find these instructions. | ||||
|  | ||||
| ``SMTPConnection`` | ||||
| ------------------ | ||||
|  | ||||
| The ``SMTPConnection`` class has been deprecated in favor of a generic | ||||
| Email backend API. Old code that explicitly instantiated an instance | ||||
| of an SMTPConnection:: | ||||
|  | ||||
|     from django.core.mail import SMTPConnection | ||||
|     connection = SMTPConnection() | ||||
|     messages = get_notification_email() | ||||
|     connection.send_messages(messages) | ||||
|  | ||||
| should now call :meth:`~django.core.mail.get_connection()` to | ||||
| instantiate a generic email connection:: | ||||
|  | ||||
|     from django.core.mail import get_connection | ||||
|     connection = get_connection() | ||||
|     messages = get_notification_email() | ||||
|     connection.send_messages(messages) | ||||
|  | ||||
| Depending on the value of the :setting:`EMAIL_BACKEND` setting, this | ||||
| may not return an SMTP connection. If you explicitly require an SMTP | ||||
| connection with which to send email, you can explicitly request an | ||||
| SMTP connection:: | ||||
|  | ||||
|     from django.core.mail import get_connection | ||||
|     connection = get_connection('django.core.mail.backends.smtp.EmailBackend') | ||||
|     messages = get_notification_email() | ||||
|     connection.send_messages(messages) | ||||
|  | ||||
| If your call to construct an instance of ``SMTPConnection`` required | ||||
| additional arguments, those arguments can be passed to the | ||||
| :meth:`~django.core.mail.get_connection()` call:: | ||||
|  | ||||
|     connection = get_connection('django.core.mail.backends.smtp.EmailBackend', hostname='localhost', port=1234) | ||||
|  | ||||
| Specifying databases | ||||
| -------------------- | ||||
|  | ||||
| Prior to Django 1.1, Django used a number of settings to control access to a | ||||
| single database. Django 1.2 introduces support for multiple databases, and as | ||||
| a result, the way you define database settings has changed. | ||||
|  | ||||
| **Any existing Django settings file will continue to work as expected | ||||
| until Django 1.4.** Old-style database settings will be automatically | ||||
| translated to the new-style format. | ||||
|  | ||||
| In the old-style (pre 1.2) format, there were a number of | ||||
| ``DATABASE_`` settings at the top level of your settings file. For | ||||
| example:: | ||||
|  | ||||
|     DATABASE_NAME = 'test_db' | ||||
|     DATABASE_ENGINE = 'postgresql_psycopg2' | ||||
|     DATABASE_USER = 'myusername' | ||||
|     DATABASE_PASSWORD = 's3krit' | ||||
|  | ||||
| These settings are now contained inside a dictionary named | ||||
| :setting:`DATABASES`. Each item in the dictionary corresponds to a | ||||
| single database connection, with the name ``'default'`` describing the | ||||
| default database connection. The setting names have also been | ||||
| shortened to reflect the fact that they are stored in a dictionary. | ||||
| The sample settings given previously would now be stored using:: | ||||
|  | ||||
|     DATABASES = { | ||||
|         'default': { | ||||
|             'NAME': 'test_db', | ||||
|             'ENGINE': 'django.db.backends.postgresql_psycopg2', | ||||
|             'USER': 'myusername', | ||||
|             'PASSWORD': 's3krit', | ||||
|         } | ||||
|     } | ||||
|  | ||||
| This affects the following settings: | ||||
|  | ||||
| =========================================  ========================== | ||||
|  Old setting                                New Setting | ||||
| =========================================  ========================== | ||||
| `DATABASE_ENGINE`                          :setting:`ENGINE <DATABASE-ENGINE>` | ||||
| `DATABASE_HOST`                            :setting:`HOST` | ||||
| `DATABASE_NAME`                            :setting:`NAME` | ||||
| `DATABASE_OPTIONS`                         :setting:`OPTIONS` | ||||
| `DATABASE_PASSWORD`                        :setting:`PASSWORD` | ||||
| `DATABASE_PORT`                            :setting:`PORT` | ||||
| `DATABASE_USER`                            :setting:`USER` | ||||
| `TEST_DATABASE_CHARSET`                    :setting:`TEST_CHARSET` | ||||
| `TEST_DATABASE_COLLATION`                  :setting:`TEST_COLLATION` | ||||
| `TEST_DATABASE_NAME`                       :setting:`TEST_NAME` | ||||
| =========================================  ========================== | ||||
|  | ||||
| These changes are also required if you have manually created a database | ||||
| connection using ``DatabaseWrapper()`` from your database backend of choice. | ||||
|  | ||||
| In addition to the change in structure, Django 1.2 removes the special | ||||
| handling for the built-in database backends. All database backends | ||||
| must now be specified by a fully qualified module name (i.e., | ||||
| ``django.db.backends.postgresql_psycopg2``, rather than just | ||||
| ``postgresql_psycopg2``). | ||||
|  | ||||
| User Messages API | ||||
| ----------------- | ||||
|  | ||||
| The API for storing messages in the user ``Message`` model (via | ||||
| ``user.message_set.create``) is now deprecated and will be removed in Django | ||||
| 1.4 according to the standard :doc:`release process </internals/release-process>`. | ||||
|  | ||||
| To upgrade your code, you need to replace any instances of:: | ||||
|  | ||||
|     user.message_set.create('a message') | ||||
|  | ||||
| with the following:: | ||||
|  | ||||
|     from django.contrib import messages | ||||
|     messages.add_message(request, messages.INFO, 'a message') | ||||
|  | ||||
| Additionally, if you make use of the method, you need to replace the | ||||
| following:: | ||||
|  | ||||
|     for message in user.get_and_delete_messages(): | ||||
|         ... | ||||
|  | ||||
| with:: | ||||
|  | ||||
|     from django.contrib import messages | ||||
|     for message in messages.get_messages(request): | ||||
|         ... | ||||
|  | ||||
| For more information, see the full | ||||
| :doc:`messages documentation </ref/contrib/messages>`. You should begin to | ||||
| update your code to use the new API immediately. | ||||
|  | ||||
| Date format helper functions | ||||
| ---------------------------- | ||||
|  | ||||
| ``django.utils.translation.get_date_formats()`` and | ||||
| ``django.utils.translation.get_partial_date_formats()`` have been deprecated | ||||
| in favor of the appropriate calls to ``django.utils.formats.get_format()`` | ||||
| which is locale aware when :setting:`USE_L10N` is set to ``True``, and falls | ||||
| back to default settings if set to ``False``. | ||||
|  | ||||
| To get the different date formats, instead of writing:: | ||||
|  | ||||
|     from django.utils.translation import get_date_formats | ||||
|     date_format, datetime_format, time_format = get_date_formats() | ||||
|  | ||||
| use:: | ||||
|  | ||||
|     from django.utils import formats | ||||
|  | ||||
|     date_format = formats.get_format('DATE_FORMAT') | ||||
|     datetime_format = formats.get_format('DATETIME_FORMAT') | ||||
|     time_format = formats.get_format('TIME_FORMAT') | ||||
|  | ||||
| or, when directly formatting a date value:: | ||||
|  | ||||
|     from django.utils import formats | ||||
|     value_formatted = formats.date_format(value, 'DATETIME_FORMAT') | ||||
|  | ||||
| The same applies to the globals found in ``django.forms.fields``: | ||||
|  | ||||
| * ``DEFAULT_DATE_INPUT_FORMATS`` | ||||
| * ``DEFAULT_TIME_INPUT_FORMATS`` | ||||
| * ``DEFAULT_DATETIME_INPUT_FORMATS`` | ||||
|  | ||||
| Use ``django.utils.formats.get_format()`` to get the appropriate formats. | ||||
|  | ||||
|  | ||||
| What's new in Django 1.2 alpha 1 | ||||
| ================================ | ||||
|  | ||||
| The following new features are present as of this alpha release; this | ||||
| release also marks the end of major feature development for the 1.2 | ||||
| release cycle. Some minor features will continue development until the | ||||
| 1.2 beta release, however. | ||||
|  | ||||
|  | ||||
| CSRF support | ||||
| ------------ | ||||
|  | ||||
| Django now has much improved protection against :doc:`Cross-Site | ||||
| Request Forgery (CSRF) attacks</ref/contrib/csrf>`. This type of attack | ||||
| occurs when a malicious Web site contains a link, a form button or | ||||
| some javascript that is intended to perform some action on your Web | ||||
| site, using the credentials of a logged-in user who visits the | ||||
| malicious site in their browser. A related type of attack, 'login | ||||
| CSRF', where an attacking site tricks a user's browser into logging | ||||
| into a site with someone else's credentials, is also covered. | ||||
|  | ||||
| Email Backends | ||||
| -------------- | ||||
|  | ||||
| You can now :ref:`configure the way that Django sends email | ||||
| <topic-email-backends>`. Instead of using SMTP to send all email, you | ||||
| can now choose a configurable email backend to send messages. If your | ||||
| hosting provider uses a sandbox or some other non-SMTP technique for | ||||
| sending mail, you can now construct an email backend that will allow | ||||
| Django's standard :doc:`mail sending methods</topics/email>` to use | ||||
| those facilities. | ||||
|  | ||||
| This also makes it easier to debug mail sending - Django ships with | ||||
| backend implementations that allow you to send email to a | ||||
| :ref:`file<topic-email-file-backend>`, to the | ||||
| :ref:`console<topic-email-console-backend>`, or to | ||||
| :ref:`memory<topic-email-memory-backend>` - you can even configure all | ||||
| email to be :ref:`thrown away<topic-email-dummy-backend>`. | ||||
|  | ||||
| Messages Framework | ||||
| ------------------ | ||||
|  | ||||
| Django now includes a robust and configurable :doc:`messages framework | ||||
| </ref/contrib/messages>` with built-in support for cookie- and session-based | ||||
| messaging, for both anonymous and authenticated clients. The messages framework | ||||
| replaces the deprecated user message API and allows you to temporarily store | ||||
| messages in one request and retrieve them for display in a subsequent request | ||||
| (usually the next one). | ||||
|  | ||||
| Support for multiple databases | ||||
| ------------------------------ | ||||
|  | ||||
| Django 1.2 adds the ability to use :doc:`more than one database | ||||
| </topics/db/multi-db>` in your Django project. Queries can be | ||||
| issued at a specific database with the ``using()`` method on | ||||
| querysets; individual objects can be saved to a specific database | ||||
| by providing a ``using`` argument when you save the instance. | ||||
|  | ||||
| 'Smart' if tag | ||||
| -------------- | ||||
|  | ||||
| The :ttag:`if` tag has been upgraded to be much more powerful.  First, support | ||||
| for comparison operators has been added. No longer will you have to type: | ||||
|  | ||||
| .. code-block:: html+django | ||||
|  | ||||
|     {% ifnotequal a b %} | ||||
|      ... | ||||
|     {% endifnotequal %} | ||||
|  | ||||
| ...as you can now do: | ||||
|  | ||||
| .. code-block:: html+django | ||||
|  | ||||
|     {% if a != b %} | ||||
|      ... | ||||
|     {% endif %} | ||||
|  | ||||
| The operators supported are ``==``, ``!=``, ``<``, ``>``, ``<=``, ``>=`` and | ||||
| ``in``, all of which work like the Python operators, in addition to ``and``, | ||||
| ``or`` and ``not`` which were already supported. | ||||
|  | ||||
| Also, filters may now be used in the ``if`` expression. For example: | ||||
|  | ||||
| .. code-block:: html+django | ||||
|  | ||||
|       <div | ||||
|         {% if user.email|lower == message.recipient|lower %} | ||||
|           class="highlight" | ||||
|         {% endif %} | ||||
|       >{{ message }}</div> | ||||
|  | ||||
| Template caching | ||||
| ---------------- | ||||
|  | ||||
| In previous versions of Django, every time you rendered a template it | ||||
| would be reloaded from disk. In Django 1.2, you can use a :ref:`cached | ||||
| template loader <template-loaders>` to load templates once, then use | ||||
| the cached result for every subsequent render. This can lead to a | ||||
| significant performance improvement if your templates are broken into | ||||
| lots of smaller subtemplates (using the ``{% extends %}`` or ``{% | ||||
| include %}`` tags). | ||||
|  | ||||
| As a side effect, it is now much easier to support non-Django template | ||||
| languages. For more details, see the :ref:`notes on supporting | ||||
| non-Django template languages<topic-template-alternate-language>`. | ||||
|  | ||||
| Natural keys in fixtures | ||||
| ------------------------ | ||||
|  | ||||
| Fixtures can refer to remote objects using | ||||
| :ref:`topics-serialization-natural-keys`. This lookup scheme is an | ||||
| alternative to the normal primary-key based object references in a | ||||
| fixture, improving readability, and resolving problems referring to | ||||
| objects whose primary key value may not be predictable or known. | ||||
|  | ||||
| ``BigIntegerField`` | ||||
| ------------------- | ||||
|  | ||||
| Models can now use a 64 bit :class:`~django.db.models.BigIntegerField` type. | ||||
|  | ||||
| Fast Failure for Tests | ||||
| ---------------------- | ||||
|  | ||||
| The :djadmin:`test` subcommand of ``django-admin.py``, and the ``runtests.py`` | ||||
| script used to run Django's own test suite, support a new ``--failfast`` option. | ||||
| When specified, this option causes the test runner to exit after encountering | ||||
| a failure instead of continuing with the test run.  In addition, the handling | ||||
| of ``Ctrl-C`` during a test run has been improved to trigger a graceful exit | ||||
| from the test run that reports details of the tests run before the interruption. | ||||
|  | ||||
| Improved localization | ||||
| --------------------- | ||||
|  | ||||
| Django's :doc:`internationalization framework </topics/i18n/index>` has been | ||||
| expanded by locale aware formatting and form processing. That means, if | ||||
| enabled, dates and numbers on templates will be displayed using the format | ||||
| specified for the current locale. Django will also use localized formats | ||||
| when parsing data in forms. | ||||
| See :ref:`Format localization <format-localization>` for more details. | ||||
|  | ||||
| Added ``readonly_fields`` to ``ModelAdmin`` | ||||
| ------------------------------------------- | ||||
|  | ||||
| :attr:`django.contrib.admin.ModelAdmin.readonly_fields` has been added to | ||||
| enable non-editable fields in add/change pages for models and inlines. Field | ||||
| and calculated values can be displayed alongside editable fields. | ||||
|  | ||||
| Customizable syntax highlighting | ||||
| -------------------------------- | ||||
|  | ||||
| You can now use the ``DJANGO_COLORS`` environment variable to modify | ||||
| or disable the colors used by ``django-admin.py`` to provide | ||||
| :ref:`syntax highlighting <syntax-coloring>`. | ||||
|  | ||||
|  | ||||
| The Django 1.2 roadmap | ||||
| ====================== | ||||
|  | ||||
| Before the final Django 1.2 release, several other preview/development | ||||
| releases will be made available. The current schedule consists of at | ||||
| least the following: | ||||
|  | ||||
| * Week of **January 26, 2010**: First Django 1.2 beta release. Final | ||||
|   feature freeze for Django 1.2. | ||||
|  | ||||
| * Week of **March 2, 2010**: First Django 1.2 release | ||||
|   candidate. String freeze for translations. | ||||
|  | ||||
| * Week of **March 9, 2010**: Django 1.2 final release. | ||||
|  | ||||
| If necessary, additional alpha, beta or release-candidate packages | ||||
| will be issued prior to the final 1.2 release. Django 1.2 will be | ||||
| released approximately one week after the final release candidate. | ||||
|  | ||||
|  | ||||
| What you can do to help | ||||
| ======================= | ||||
|  | ||||
| In order to provide a high-quality 1.2 release, we need your help. Although this | ||||
| alpha release is, again, *not* intended for production use, you can help the | ||||
| Django team by trying out the alpha codebase in a safe test environment and | ||||
| reporting any bugs or issues you encounter. The Django ticket tracker is the | ||||
| central place to search for open issues: | ||||
|  | ||||
| * https://code.djangoproject.com/timeline | ||||
|  | ||||
| Please open new tickets if no existing ticket corresponds to a problem you're | ||||
| running into. | ||||
|  | ||||
| Additionally, discussion of Django development, including progress toward the | ||||
| 1.2 release, takes place daily on the django-developers mailing list: | ||||
|  | ||||
| * http://groups.google.com/group/django-developers | ||||
|  | ||||
| ... and in the ``#django-dev`` IRC channel on ``irc.freenode.net``. If you're | ||||
| interested in helping out with Django's development, feel free to join the | ||||
| discussions there. | ||||
|  | ||||
| Django's online documentation also includes pointers on how to contribute to | ||||
| Django: | ||||
|  | ||||
| * :doc:`How to contribute to Django </internals/contributing/index>` | ||||
|  | ||||
| Contributions on any level -- developing code, writing documentation or simply | ||||
| triaging tickets and helping to test proposed bugfixes -- are always welcome and | ||||
| appreciated. | ||||
|  | ||||
| Development sprints for Django 1.2 will also be taking place at PyCon | ||||
| US 2010, on the dedicated sprint days (February 22 through 25), and | ||||
| anyone who wants to help out is welcome to join in, either in person | ||||
| at PyCon or virtually in the IRC channel or on the mailing list. | ||||
| @@ -1,173 +0,0 @@ | ||||
| =============================== | ||||
| Django 1.2 beta 1 release notes | ||||
| =============================== | ||||
|  | ||||
| February 5, 2010 | ||||
|  | ||||
| Welcome to Django 1.2 beta 1! | ||||
|  | ||||
| This is the second in a series of preview/development releases leading | ||||
| up to the eventual release of Django 1.2, currently scheduled to take | ||||
| place in March 2010. This release is primarily targeted at developers | ||||
| who are interested in trying out new features and testing the Django | ||||
| codebase to help identify and resolve bugs prior to the final 1.2 | ||||
| release. | ||||
|  | ||||
| As such, this release is *not* intended for production use, and any | ||||
| such use is discouraged. | ||||
|  | ||||
| This document covers changes since the Django 1.2 alpha release; the | ||||
| :doc:`1.2 alpha release notes </releases/1.2-alpha-1>` cover new and | ||||
| updated features in Django between 1.1 and 1.2 alpha. | ||||
|  | ||||
|  | ||||
| Deprecations and other changes in 1.2 beta | ||||
| ========================================== | ||||
|  | ||||
| This beta release deprecates two portions of public API, and | ||||
| introduces a potentially backwards-incompatible change to | ||||
| another. Under :doc:`our API stability policy </misc/api-stability>`, | ||||
| deprecation proceeds over multiple release cycles: initially, the | ||||
| deprecated API will raise ``PendingDeprecationWarning``, followed by | ||||
| raising ``DeprecationWarning`` in the next release, and finally | ||||
| removal of the deprecated API in the release after that. APIs | ||||
| beginning the deprecation process in Django 1.2 will be removed in the | ||||
| Django 1.4 release. | ||||
|  | ||||
|  | ||||
| Unit test runners | ||||
| ----------------- | ||||
|  | ||||
| Django 1.2 changes the test runner tools to use a class-based | ||||
| approach. Old style function-based test runners will still work, but | ||||
| should be updated to use the new :ref:`class-based runners | ||||
| <topics-testing-test_runner>`. | ||||
|  | ||||
|  | ||||
| Syndication feeds | ||||
| ----------------- | ||||
|  | ||||
| The ``django.contrib.syndication.feeds.Feed`` class is being | ||||
| replaced by the :class:`django.contrib.syndication.views.Feed` class. | ||||
| The old ``feeds.Feed`` class is deprecated. The new class has an | ||||
| almost identical API, but allows instances to be used as views. | ||||
|  | ||||
| Also, in accordance with `RSS best practices`_, RSS feeds will now | ||||
| include an ``atom:link`` element. You may need to update your tests to | ||||
| take this into account. | ||||
|  | ||||
| For more information, see the full :doc:`syndication framework | ||||
| documentation </ref/contrib/syndication>`. | ||||
|  | ||||
| .. _RSS best practices: http://www.rssboard.org/rss-profile | ||||
|  | ||||
|  | ||||
| Cookie encoding | ||||
| --------------- | ||||
|  | ||||
| Due to cookie-handling bugs in Internet Explorer, Safari, and possibly | ||||
| other browsers, Django's encoding of cookie values was changed so that | ||||
| the characters comma (',') and semi-colon (';') are treated as | ||||
| non-safe characters, and are therefore encoded as ``\054`` and | ||||
| ``\073`` respectively. This could produce backwards incompatibilities | ||||
| if you are relying on the ability to set these characters directly in | ||||
| cookie values. | ||||
|  | ||||
|  | ||||
| What's new in 1.2 beta | ||||
| ====================== | ||||
|  | ||||
| This 1.2 beta release marks the final feature freeze for Django 1.2; | ||||
| while most feature development was completed for 1.2 alpha (which | ||||
| constituted a freeze on major features), a few other new features were | ||||
| added afterward and so are new as of 1.2 beta. | ||||
|  | ||||
|  | ||||
| Object-level permissions | ||||
| ------------------------ | ||||
|  | ||||
| A foundation for specifying permissions at the per-object level was | ||||
| added in Django 1.2 alpha but not documented with the alpha release. | ||||
|  | ||||
| The default authentication backends shipped with Django do not | ||||
| currently make use of this, but third-party authentication backends | ||||
| are free to do so. See the :doc:`authentication docs </topics/auth/index>` | ||||
| for more information. | ||||
|  | ||||
|  | ||||
| Permissions for anonymous users | ||||
| ------------------------------- | ||||
|  | ||||
| If you provide a custom authentication backend with the attribute | ||||
| ``supports_anonymous_user`` set to ``True``, the ``AnonymousUser`` | ||||
| class will check the backend for permissions, just as the normal | ||||
| ``User`` does. This is intended to help centralize permission | ||||
| handling; apps can always delegate the question of whether something | ||||
| is allowed or not to the authorization/authentication system. See the | ||||
| :doc:`authentication docs </topics/auth/index>` for more details. | ||||
|  | ||||
|  | ||||
| ``select_related()`` improvements | ||||
| --------------------------------- | ||||
|  | ||||
| The ``select_related()`` method of ``QuerySet`` now accepts the | ||||
| ``related_name`` of a reverse one-to-one relation in the list of | ||||
| fields to select. One-to-one relations will not, however, be traversed | ||||
| by a depth-based ``select_related()`` call. | ||||
|  | ||||
|  | ||||
| The Django 1.2 roadmap | ||||
| ====================== | ||||
|  | ||||
| Before the final Django 1.2 release, at least one additional | ||||
| preview/development releases will be made available. The current | ||||
| schedule consists of at least the following: | ||||
|  | ||||
| * Week of **March 2, 2010**: First Django 1.2 release | ||||
|   candidate. String freeze for translations. | ||||
|  | ||||
| * Week of **March 9, 2010**: Django 1.2 final release. | ||||
|  | ||||
| If necessary, additional beta or release-candidate packages will be | ||||
| issued prior to the final 1.2 release. Django 1.2 will be released | ||||
| approximately one week after the final release candidate. | ||||
|  | ||||
|  | ||||
| What you can do to help | ||||
| ======================= | ||||
|  | ||||
| In order to provide a high-quality 1.2 release, we need your | ||||
| help. Although this beta release is, again, *not* intended for | ||||
| production use, you can help the Django team by trying out the beta | ||||
| codebase in a safe test environment and reporting any bugs or issues | ||||
| you encounter. The Django ticket tracker is the central place to | ||||
| search for open issues: | ||||
|  | ||||
| * https://code.djangoproject.com/timeline | ||||
|  | ||||
| Please open new tickets if no existing ticket corresponds to a problem | ||||
| you're running into. | ||||
|  | ||||
| Additionally, discussion of Django development, including progress | ||||
| toward the 1.2 release, takes place daily on the django-developers | ||||
| mailing list: | ||||
|  | ||||
| * http://groups.google.com/group/django-developers | ||||
|  | ||||
| ... and in the ``#django-dev`` IRC channel on ``irc.freenode.net``. If you're | ||||
| interested in helping out with Django's development, feel free to join the | ||||
| discussions there. | ||||
|  | ||||
| Django's online documentation also includes pointers on how to | ||||
| contribute to Django: | ||||
|  | ||||
| * :doc:`How to contribute to Django </internals/contributing/index>` | ||||
|  | ||||
| Contributions on any level -- developing code, writing documentation | ||||
| or simply triaging tickets and helping to test proposed bugfixes -- | ||||
| are always welcome and appreciated. | ||||
|  | ||||
| Development sprints for Django 1.2 will also be taking place at PyCon | ||||
| US 2010, on the dedicated sprint days (February 22 through 25), and | ||||
| anyone who wants to help out is welcome to join in, either in person | ||||
| at PyCon or virtually in the IRC channel or on the mailing list. | ||||
| @@ -1,101 +0,0 @@ | ||||
| ============================= | ||||
| Django 1.2 RC 1 release notes | ||||
| ============================= | ||||
|  | ||||
|  | ||||
| May 5, 2010 | ||||
|  | ||||
| Welcome to the first Django 1.2 release candidate! | ||||
|  | ||||
| This is the third -- and likely last -- in a series of | ||||
| preview/development releases leading up to the eventual release of | ||||
| Django 1.2. This release is targeted primarily at developers who are | ||||
| interested in trying out new features and testing the Django codebase | ||||
| to help identify and resolve any critical bugs prior to the final 1.2 | ||||
| release. | ||||
|  | ||||
| As such, this release is not yet intended for production use, and any | ||||
| such use is discouraged. | ||||
|  | ||||
| Django has been feature frozen since the 1.2 beta release, so this | ||||
| release candidate contains no new features, only bugfixes; for a | ||||
| summary of features new to Django 1.2, consult the :doc:`1.2 alpha | ||||
| </releases/1.2-alpha-1>` and :doc:`1.2 beta </releases/1.2-beta-1>` | ||||
| release notes. | ||||
|  | ||||
|  | ||||
| Python compatibility | ||||
| ==================== | ||||
|  | ||||
| While not a new feature, it's important to note that Django 1.2 | ||||
| introduces the first shift in our Python compatibility policy since | ||||
| Django's initial public debut. Previous Django releases were tested | ||||
| and supported on 2.x Python versions from 2.3 up; Django 1.2, however, | ||||
| drops official support for Python 2.3. As such, the minimum Python | ||||
| version required for Django is now 2.4, and Django is tested and | ||||
| supported on Python 2.4, 2.5 and 2.6, and will be supported on the | ||||
| as-yet-unreleased Python 2.7. | ||||
|  | ||||
| This change should affect only a small number of Django users, as most | ||||
| operating-system vendors today are shipping Python 2.4 or newer as | ||||
| their default version. If you're still using Python 2.3, however, | ||||
| you'll need to stick to Django 1.1 until you can upgrade; per | ||||
| :doc:`our support policy </internals/release-process>`, Django 1.1 will | ||||
| continue to receive security support until the release of Django 1.3. | ||||
|  | ||||
| A roadmap for Django's overall 2.x Python support, and eventual | ||||
| transition to Python 3.x, is currently being developed, and will be | ||||
| announced prior to the release of Django 1.3. | ||||
|  | ||||
|  | ||||
| The Django 1.2 roadmap | ||||
| ====================== | ||||
|  | ||||
| As of this release candidate, Django 1.2 is in both feature freeze and | ||||
| "string freeze" -- all strings marked for translation in the Django | ||||
| codebase will retain their current form in the final Django 1.2 | ||||
| release. Only critical release-blocking bugs, documentation and | ||||
| updated translation files will receive attention between now and the | ||||
| final 1.2 release. Note that Django's localization infrastructure has | ||||
| been expanded for 1.2, and translation packages should now include a | ||||
| ``formats.py`` file containing data for localized formatting of | ||||
| numbers and dates. | ||||
|  | ||||
| If no critical bugs are discovered, Django 1.2 will be released | ||||
| approximately one week after this release candidate, on or about May | ||||
| 12, 2010. | ||||
|  | ||||
|  | ||||
| What you can do to help | ||||
| ======================= | ||||
|  | ||||
| In order to provide a high-quality 1.2 release, we need your | ||||
| help. Although this release candidate is, again, *not* intended for | ||||
| production use, you can help the Django team by trying out this | ||||
| release candidate in a safe testing environment and reporting any bugs | ||||
| or issues you encounter. The Django ticket tracker is the central | ||||
| place to search for open issues: | ||||
|  | ||||
| * https://code.djangoproject.com/timeline | ||||
|  | ||||
| Please open a new ticket only if no existing ticket corresponds to a | ||||
| problem you're running into. | ||||
|  | ||||
| Additionally, discussion of Django development, including progress | ||||
| toward the 1.2 release, takes place daily on the django-developers | ||||
| mailing list: | ||||
|  | ||||
| * http://groups.google.com/group/django-developers | ||||
|  | ||||
| ... and in the ``#django-dev`` IRC channel on ``irc.freenode.net``. If you're | ||||
| interested in helping out with Django's development, feel free to join the | ||||
| discussions there. | ||||
|  | ||||
| Django's online documentation also includes pointers on how to contribute to | ||||
| Django: | ||||
|  | ||||
| * :doc:`How to contribute to Django </internals/contributing/index>` | ||||
|  | ||||
| Contributions on any level -- developing code, writing documentation or simply | ||||
| triaging tickets and helping to test proposed bugfixes -- are always welcome and | ||||
| appreciated. | ||||
| @@ -1,396 +0,0 @@ | ||||
| ================================ | ||||
| Django 1.3 alpha 1 release notes | ||||
| ================================ | ||||
|  | ||||
| November 11, 2010 | ||||
|  | ||||
| Welcome to Django 1.3 alpha 1! | ||||
|  | ||||
| This is the first in a series of preview/development releases leading | ||||
| up to the eventual release of Django 1.3. This release is primarily | ||||
| targeted at developers who are interested in trying out new features | ||||
| and testing the Django codebase to help identify and resolve bugs | ||||
| prior to the final 1.3 release. | ||||
|  | ||||
| As such, this release is *not* intended for production use, and any such use is | ||||
| discouraged. | ||||
|  | ||||
| As of this alpha release, Django 1.3 contains a number of nifty `new | ||||
| features`_, lots of bug fixes, some minor `backwards incompatible | ||||
| changes`_ and an easy upgrade path from Django 1.2. | ||||
|  | ||||
| .. _new features: `What's new in Django 1.3 alpha 1`_ | ||||
|  | ||||
| .. _backwards incompatible changes: backwards-incompatible-changes-1.3-alpha-1_ | ||||
|  | ||||
| What's new in Django 1.3 alpha 1 | ||||
| ================================ | ||||
|  | ||||
| Class-based views | ||||
| ~~~~~~~~~~~~~~~~~ | ||||
|  | ||||
| Django 1.3 adds a framework that allows you to use a class as a view. | ||||
| This means you can compose a view out of a collection of methods that | ||||
| can be subclassed and overridden to provide common views of data without | ||||
| having to write too much code. | ||||
|  | ||||
| Analogs of all the old function-based generic views have been provided, | ||||
| along with a completely generic view base class that can be used as | ||||
| the basis for reusable applications that can be easily extended. | ||||
|  | ||||
| See :doc:`the documentation on Class-based Generic Views | ||||
| </topics/class-based-views/index>` for more details. There is also a document to | ||||
| help you `convert your function-based generic views to class-based | ||||
| views <https://docs.djangoproject.com/en/1.4/topics/generic-views-migration/>`_. | ||||
|  | ||||
| Logging | ||||
| ~~~~~~~ | ||||
|  | ||||
| Django 1.3 adds framework-level support for Python's logging module. | ||||
| This means you can now easily configure and control logging as part of | ||||
| your Django project. A number of logging handlers and logging calls | ||||
| have been added to Django's own code as well -- most notably, the | ||||
| error emails sent on a HTTP 500 server error are now handled as a | ||||
| logging activity. See :doc:`the documentation on Django's logging | ||||
| interface </topics/logging>` for more details. | ||||
|  | ||||
| Extended static files handling | ||||
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ | ||||
|  | ||||
| Django 1.3 ships with a new contrib app ``'django.contrib.staticfiles'`` | ||||
| to help developers handle the static media files (images, CSS, Javascript, | ||||
| etc.) that are needed to render a complete web page. | ||||
|  | ||||
| In previous versions of Django, it was common to place static assets | ||||
| in :setting:`MEDIA_ROOT` along with user-uploaded files, and serve | ||||
| them both at :setting:`MEDIA_URL`. Part of the purpose of introducing | ||||
| the ``staticfiles`` app is to make it easier to keep static files | ||||
| separate from user-uploaded files. Static assets should now go in | ||||
| ``static/`` subdirectories of your apps or in other static assets | ||||
| directories listed in :setting:`STATICFILES_DIRS`, and will be served | ||||
| at :setting:`STATIC_URL`. | ||||
|  | ||||
| See the :doc:`reference documentation of the app </ref/contrib/staticfiles>` | ||||
| for more details or learn how to :doc:`manage static files | ||||
| </howto/static-files/index>`. | ||||
|  | ||||
| ``unittest2`` support | ||||
| ~~~~~~~~~~~~~~~~~~~~~ | ||||
|  | ||||
| Python 2.7 introduced some major changes to the unittest library, | ||||
| adding some extremely useful features. To ensure that every Django | ||||
| project can benefit from these new features, Django ships with a | ||||
| copy of unittest2_, a copy of the Python 2.7 unittest library, | ||||
| backported for Python 2.4 compatibility. | ||||
|  | ||||
| To access this library, Django provides the | ||||
| ``django.utils.unittest`` module alias. If you are using Python | ||||
| 2.7, or you have installed unittest2 locally, Django will map the | ||||
| alias to the installed version of the unittest library. Otherwise, | ||||
| Django will use its own bundled version of unittest2. | ||||
|  | ||||
| To use this alias, simply use:: | ||||
|  | ||||
|     from django.utils import unittest | ||||
|  | ||||
| wherever you would have historically used:: | ||||
|  | ||||
|     import unittest | ||||
|  | ||||
| If you want to continue to use the base unittest library, you can -- | ||||
| you just won't get any of the nice new unittest2 features. | ||||
|  | ||||
| .. _unittest2: http://pypi.python.org/pypi/unittest2 | ||||
|  | ||||
| Transaction context managers | ||||
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~ | ||||
|  | ||||
| Users of Python 2.5 and above may now use transaction management functions as | ||||
| `context managers`_. For example:: | ||||
|  | ||||
|     with transaction.autocommit(): | ||||
|         # ... | ||||
|  | ||||
| .. _context managers: http://docs.python.org/glossary.html#term-context-manager | ||||
|  | ||||
| Configurable delete-cascade | ||||
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~ | ||||
|  | ||||
| :class:`~django.db.models.ForeignKey` and | ||||
| :class:`~django.db.models.OneToOneField` now accept an | ||||
| :attr:`~django.db.models.ForeignKey.on_delete` argument to customize behavior | ||||
| when the referenced object is deleted. Previously, deletes were always | ||||
| cascaded; available alternatives now include set null, set default, set to any | ||||
| value, protect, or do nothing. | ||||
|  | ||||
| For more information, see the :attr:`~django.db.models.ForeignKey.on_delete` | ||||
| documentation. | ||||
|  | ||||
| Contextual markers in translatable strings | ||||
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ | ||||
|  | ||||
| For translation strings with ambiguous meaning, you can now | ||||
| use the ``pgettext`` function to specify the context of the string. | ||||
|  | ||||
| For more information, see :ref:`contextual-markers` | ||||
|  | ||||
| Everything else | ||||
| ~~~~~~~~~~~~~~~ | ||||
|  | ||||
| Django :doc:`1.1 <1.1>` and :doc:`1.2 <1.2>` added | ||||
| lots of big ticket items to Django, like multiple-database support, | ||||
| model validation, and a session-based messages framework. However, | ||||
| this focus on big features came at the cost of lots of smaller | ||||
| features. | ||||
|  | ||||
| To compensate for this, the focus of the Django 1.3 development | ||||
| process has been on adding lots of smaller, long standing feature | ||||
| requests. These include: | ||||
|  | ||||
| * Improved tools for accessing and manipulating the current Site via | ||||
|   ``django.contrib.sites.models.get_current_site()``. | ||||
|  | ||||
| * A :class:`~django.test.RequestFactory` for mocking | ||||
|   requests in tests. | ||||
|  | ||||
| * A new test assertion -- | ||||
|   :meth:`~django.test.TransactionTestCase.assertNumQueries` -- making it | ||||
|   easier to test the database activity associated with a view. | ||||
|  | ||||
|  | ||||
| .. _backwards-incompatible-changes-1.3-alpha-1: | ||||
|  | ||||
| Backwards-incompatible changes in 1.3 alpha 1 | ||||
| ============================================= | ||||
|  | ||||
| PasswordInput default rendering behavior | ||||
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ | ||||
|  | ||||
| The :class:`~django.forms.PasswordInput` form widget, intended for use | ||||
| with form fields which represent passwords, accepts a boolean keyword | ||||
| argument ``render_value`` indicating whether to send its data back to | ||||
| the browser when displaying a submitted form with errors. Prior to | ||||
| Django 1.3, this argument defaulted to ``True``, meaning that the | ||||
| submitted password would be sent back to the browser as part of the | ||||
| form. Developers who wished to add a bit of additional security by | ||||
| excluding that value from the redisplayed form could instantiate a | ||||
| :class:`~django.forms.PasswordInput` passing ``render_value=False`` . | ||||
|  | ||||
| Due to the sensitive nature of passwords, however, Django 1.3 takes | ||||
| this step automatically; the default value of ``render_value`` is now | ||||
| ``False``, and developers who want the password value returned to the | ||||
| browser on a submission with errors (the previous behavior) must now | ||||
| explicitly indicate this. For example:: | ||||
|  | ||||
|     class LoginForm(forms.Form): | ||||
|         username = forms.CharField(max_length=100) | ||||
|         password = forms.CharField(widget=forms.PasswordInput(render_value=True)) | ||||
|  | ||||
|  | ||||
| Clearable default widget for FileField | ||||
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ | ||||
|  | ||||
| Django 1.3 now includes a ``ClearableFileInput`` form widget in addition to | ||||
| ``FileInput``. ``ClearableFileInput`` renders with a checkbox to clear the | ||||
| field's value (if the field has a value and is not required); ``FileInput`` | ||||
| provided no means for clearing an existing file from a ``FileField``. | ||||
|  | ||||
| ``ClearableFileInput`` is now the default widget for a ``FileField``, so | ||||
| existing forms including ``FileField`` without assigning a custom widget will | ||||
| need to account for the possible extra checkbox in the rendered form output. | ||||
|  | ||||
| To return to the previous rendering (without the ability to clear the | ||||
| ``FileField``), use the ``FileInput`` widget in place of | ||||
| ``ClearableFileInput``. For instance, in a ``ModelForm`` for a hypothetical | ||||
| ``Document`` model with a ``FileField`` named ``document``:: | ||||
|  | ||||
|     from django import forms | ||||
|     from myapp.models import Document | ||||
|  | ||||
|     class DocumentForm(forms.ModelForm): | ||||
|         class Meta: | ||||
|             model = Document | ||||
|             widgets = {'document': forms.FileInput} | ||||
|  | ||||
| New index on database session table | ||||
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ | ||||
|  | ||||
| Prior to Django 1.3, the database table used by the database backend | ||||
| for the :doc:`sessions </topics/http/sessions>` app had no index on | ||||
| the ``expire_date`` column. As a result, date-based queries on the | ||||
| session table -- such as the query that is needed to purge old | ||||
| sessions -- would be very slow if there were lots of sessions. | ||||
|  | ||||
| If you have an existing project that is using the database session | ||||
| backend, you don't have to do anything to accommodate this change. | ||||
| However, you may get a significant performance boost if you manually | ||||
| add the new index to the session table. The SQL that will add the | ||||
| index can be found by running the :djadmin:`sqlindexes` admin | ||||
| command:: | ||||
|  | ||||
|     python manage.py sqlindexes sessions | ||||
|  | ||||
| No more naughty words | ||||
| ~~~~~~~~~~~~~~~~~~~~~ | ||||
|  | ||||
| Django has historically provided (and enforced) a list of profanities. | ||||
| The comments app has enforced this list of profanities, preventing people from | ||||
| submitting comments that contained one of those profanities. | ||||
|  | ||||
| Unfortunately, the technique used to implement this profanities list | ||||
| was woefully naive, and prone to the `Scunthorpe problem`_. Fixing the | ||||
| built in filter to fix this problem would require significant effort, | ||||
| and since natural language processing isn't the normal domain of a web | ||||
| framework, we have "fixed" the problem by making the list of | ||||
| prohibited words an empty list. | ||||
|  | ||||
| If you want to restore the old behavior, simply put a | ||||
| ``PROFANITIES_LIST`` setting in your settings file that includes the | ||||
| words that you want to prohibit (see the `commit that implemented this | ||||
| change`_ if you want to see the list of words that was historically | ||||
| prohibited). However, if avoiding profanities is important to you, you | ||||
| would be well advised to seek out a better, less naive approach to the | ||||
| problem. | ||||
|  | ||||
| .. _Scunthorpe problem: http://en.wikipedia.org/wiki/Scunthorpe_problem | ||||
| .. _commit that implemented this change: https://code.djangoproject.com/changeset/13996 | ||||
|  | ||||
| Localflavor changes | ||||
| ~~~~~~~~~~~~~~~~~~~ | ||||
|  | ||||
| Django 1.3 introduces the following backwards-incompatible changes to | ||||
| local flavors: | ||||
|  | ||||
| * Indonesia (id) -- The province "Nanggroe Aceh Darussalam (NAD)" | ||||
|   has been removed from the province list in favor of the new | ||||
|   official designation "Aceh (ACE)". | ||||
|  | ||||
|  | ||||
| Features deprecated in 1.3 | ||||
| ========================== | ||||
|  | ||||
| Django 1.3 deprecates some features from earlier releases. | ||||
| These features are still supported, but will be gradually phased out | ||||
| over the next few release cycles. | ||||
|  | ||||
| Code taking advantage of any of the features below will raise a | ||||
| ``PendingDeprecationWarning`` in Django 1.3. This warning will be | ||||
| silent by default, but may be turned on using Python's :mod:`warnings` | ||||
| module, or by running Python with a ``-Wd`` or ``-Wall`` flag. | ||||
|  | ||||
| In Django 1.4, these warnings will become a ``DeprecationWarning``, | ||||
| which is *not* silent. In Django 1.5 support for these features will | ||||
| be removed entirely. | ||||
|  | ||||
| .. seealso:: | ||||
|  | ||||
|     For more details, see the documentation :doc:`Django's release process | ||||
|     </internals/release-process>` and our :doc:`deprecation timeline | ||||
|     </internals/deprecation>`. | ||||
|  | ||||
| ``mod_python`` support | ||||
| ~~~~~~~~~~~~~~~~~~~~~~ | ||||
|  | ||||
| The ``mod_python`` library has not had a release since 2007 or a commit since | ||||
| 2008. The Apache Foundation board voted to remove ``mod_python`` from the set | ||||
| of active projects in its version control repositories, and its lead developer | ||||
| has shifted all of his efforts toward the lighter, slimmer, more stable, and | ||||
| more flexible ``mod_wsgi`` backend. | ||||
|  | ||||
| If you are currently using the ``mod_python`` request handler, you are strongly | ||||
| encouraged to redeploy your Django instances using :doc:`mod_wsgi | ||||
| </howto/deployment/wsgi/modwsgi>`. | ||||
|  | ||||
| Function-based generic views | ||||
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~ | ||||
|  | ||||
| As a result of the introduction of class-based generic views, the | ||||
| function-based generic views provided by Django have been deprecated. | ||||
| The following modules and the views they contain have been deprecated: | ||||
|  | ||||
| * ``django.views.generic.create_update`` | ||||
| * ``django.views.generic.date_based`` | ||||
| * ``django.views.generic.list_detail`` | ||||
| * ``django.views.generic.simple`` | ||||
|  | ||||
| Test client response ``template`` attribute | ||||
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ | ||||
|  | ||||
| Django's :ref:`test client <test-client>` returns | ||||
| :class:`~django.test.Response` objects annotated with extra testing | ||||
| information. In Django versions prior to 1.3, this included a ``template`` | ||||
| attribute containing information about templates rendered in generating the | ||||
| response: either None, a single :class:`~django.template.Template` object, or a | ||||
| list of :class:`~django.template.Template` objects. This inconsistency in | ||||
| return values (sometimes a list, sometimes not) made the attribute difficult | ||||
| to work with. | ||||
|  | ||||
| In Django 1.3 the ``template`` attribute is deprecated in favor of a new | ||||
| :attr:`~django.test.Response.templates` attribute, which is always a | ||||
| list, even if it has only a single element or no elements. | ||||
|  | ||||
| ``DjangoTestRunner`` | ||||
| ~~~~~~~~~~~~~~~~~~~~ | ||||
|  | ||||
| As a result of the introduction of support for unittest2, the features | ||||
| of ``django.test.simple.DjangoTestRunner`` (including fail-fast | ||||
| and Ctrl-C test termination) have been made redundant. In view of this | ||||
| redundancy, ``DjangoTestRunner`` has been turned into an empty placeholder | ||||
| class, and will be removed entirely in Django 1.5. | ||||
|  | ||||
| The Django 1.3 roadmap | ||||
| ====================== | ||||
|  | ||||
| Before the final Django 1.3 release, several other preview/development | ||||
| releases will be made available. The current schedule consists of at | ||||
| least the following: | ||||
|  | ||||
| * Week of **November 29, 2010**: First Django 1.3 beta release. Final | ||||
|   feature freeze for Django 1.3. | ||||
|  | ||||
| * Week of **January 10, 2011**: First Django 1.3 release | ||||
|   candidate. String freeze for translations. | ||||
|  | ||||
| * Week of **January 17, 2011**: Django 1.3 final release. | ||||
|  | ||||
| If necessary, additional alpha, beta or release-candidate packages | ||||
| will be issued prior to the final 1.3 release. Django 1.3 will be | ||||
| released approximately one week after the final release candidate. | ||||
|  | ||||
|  | ||||
| What you can do to help | ||||
| ======================= | ||||
|  | ||||
| In order to provide a high-quality 1.3 release, we need your help. Although this | ||||
| alpha release is, again, *not* intended for production use, you can help the | ||||
| Django team by trying out the alpha codebase in a safe test environment and | ||||
| reporting any bugs or issues you encounter. The Django ticket tracker is the | ||||
| central place to search for open issues: | ||||
|  | ||||
| * https://code.djangoproject.com/timeline | ||||
|  | ||||
| Please open new tickets if no existing ticket corresponds to a problem you're | ||||
| running into. | ||||
|  | ||||
| Additionally, discussion of Django development, including progress toward the | ||||
| 1.3 release, takes place daily on the django-developers mailing list: | ||||
|  | ||||
| * http://groups.google.com/group/django-developers | ||||
|  | ||||
| ... and in the ``#django-dev`` IRC channel on ``irc.freenode.net``. If you're | ||||
| interested in helping out with Django's development, feel free to join the | ||||
| discussions there. | ||||
|  | ||||
| Django's online documentation also includes pointers on how to contribute to | ||||
| Django: | ||||
|  | ||||
| * :doc:`How to contribute to Django </internals/contributing/index>` | ||||
|  | ||||
| Contributions on any level -- developing code, writing documentation or simply | ||||
| triaging tickets and helping to test proposed bugfixes -- are always welcome and | ||||
| appreciated. | ||||
|  | ||||
| Several development sprints will also be taking place before the 1.3 | ||||
| release; these will typically be announced in advance on the | ||||
| django-developers mailing list, and anyone who wants to help is | ||||
| welcome to join in. | ||||
| @@ -1,231 +0,0 @@ | ||||
| ================================ | ||||
| Django 1.3 beta 1 release notes | ||||
| ================================ | ||||
|  | ||||
| Welcome to Django 1.3 beta 1! | ||||
|  | ||||
| This is the second in a series of preview/development releases leading | ||||
| up to the eventual release of Django 1.3. This release is primarily | ||||
| targeted at developers who are interested in trying out new features | ||||
| and testing the Django codebase to help identify and resolve bugs | ||||
| prior to the final 1.3 release. | ||||
|  | ||||
| As such, this release is *not* intended for production use, and any such use | ||||
| is discouraged. | ||||
|  | ||||
| What's new in Django 1.3 beta 1 | ||||
| =============================== | ||||
|  | ||||
| Further tweaks to the staticfiles app | ||||
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ | ||||
|  | ||||
| Django 1.3 ships with a new contrib app :mod:`django.contrib.staticfiles` | ||||
| to help developers handle the static media files (images, CSS, JavaScript, | ||||
| etc.) that are needed to render a complete web page. | ||||
|  | ||||
| The :mod:`~django.contrib.staticfiles` app ships with the ability to | ||||
| automatically serve static files during development (if the :setting:`DEBUG` | ||||
| setting is ``True``) when using the :djadmin:`runserver` management command. | ||||
| Based on feedback from the community this release adds two new options to the | ||||
| :djadmin:`runserver` command to modify this behavior: | ||||
|  | ||||
| * ``--nostatic``: prevents the :djadmin:`runserver` command from serving | ||||
|   files completely. | ||||
|  | ||||
| * ``--insecure``: enables serving of static files even if running with | ||||
|   :setting:`DEBUG` set to False. (This is **not** recommended!) | ||||
|  | ||||
| See the :doc:`staticfiles reference documentation </ref/contrib/staticfiles>` | ||||
| for more details, or learn :doc:`how to manage static files | ||||
| </howto/static-files/index>`. | ||||
|  | ||||
| Translation comments | ||||
| ~~~~~~~~~~~~~~~~~~~~ | ||||
|  | ||||
| If you would like to give translators hints about a translatable string, you | ||||
| can add a comment prefixed with the ``Translators`` keyword on the line | ||||
| preceding the string, e.g.:: | ||||
|  | ||||
|     def my_view(request): | ||||
|         # Translators: This message appears on the home page only | ||||
|         output = ugettext("Welcome to my site.") | ||||
|  | ||||
| The comment will appear in the resulting .po file and should also be | ||||
| displayed by most translation tools. | ||||
|  | ||||
| For more information, see :ref:`translator-comments`. | ||||
|  | ||||
| Permissions for inactive users | ||||
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ | ||||
|  | ||||
| If you provide a custom auth backend with ``supports_inactive_user`` set to | ||||
| ``True``, an inactive user model will check the backend for permissions. | ||||
| This is useful for further centralizing the permission handling. See the | ||||
| :doc:`authentication docs </topics/auth/index>` for more details. | ||||
|  | ||||
| Backwards-incompatible changes in 1.3 alpha 2 | ||||
| ============================================= | ||||
|  | ||||
| Change to admin lookup filters | ||||
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ | ||||
|  | ||||
| The Django admin has long had an undocumented "feature" allowing savvy | ||||
| users to manipulate the query string of changelist pages to filter the | ||||
| list of objects displayed. However, this also creates a security | ||||
| issue, as a staff user with sufficient knowledge of model structure | ||||
| could use this "feature" to gain access to information not normally accessible. | ||||
|  | ||||
| As a result, changelist filtering now explicitly validates all lookup | ||||
| arguments in the query string, and permits only fields which are | ||||
| directly on the model, or relations explicitly permitted by the | ||||
| ``ModelAdmin`` definition. If you were relying on this undocumented | ||||
| feature, you will need to update your ``ModelAdmin`` definitions to | ||||
| whitelist the relations you choose to expose for filtering. | ||||
|  | ||||
| Introduction of STATIC_URL and STATIC_ROOT settings | ||||
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ | ||||
|  | ||||
| The newly introduced :mod:`~django.contrib.staticfiles` app -- which extends | ||||
| Django's abilities to handle static files for apps and projects -- required the | ||||
| addition of two new settings to refer to those files in templates and code, | ||||
| especially in contrast to the :setting:`MEDIA_URL` and :setting:`MEDIA_ROOT` | ||||
| settings that refer to user-uploaded files. | ||||
|  | ||||
| Prior to 1.3 alpha 2 these settings were called ``STATICFILES_URL`` and | ||||
| ``STATICFILES_ROOT`` to follow the naming scheme for app-centric settings. | ||||
| Based on feedback from the community it became apparent that those settings | ||||
| created confusion, especially given the fact that handling static files is also | ||||
| desired outside the use of the optional :mod:`~django.contrib.staticfiles` app. | ||||
|  | ||||
| As a result, we took the following steps to rectify the issue: | ||||
|  | ||||
| * Two new global settings were added that will be used by, **but are not | ||||
|   limited to**, the :doc:`staticfiles</ref/contrib/staticfiles>` app: | ||||
|  | ||||
| * :setting:`STATIC_ROOT` (formally ``STATICFILES_ROOT``) | ||||
|  | ||||
| * :setting:`STATIC_URL` (formally ``STATICFILES_URL``) | ||||
|  | ||||
| * The ``django.contrib.staticfiles.templatetags.staticfiles.get_staticfiles_prefix`` | ||||
|   template tag was moved to Django's core (``django.templatetags.static``) and | ||||
|   renamed to :ttag:`get_static_prefix`. | ||||
|  | ||||
| * The ``django.contrib.staticfiles.context_processors.staticfiles`` | ||||
|   context processor was moved to Django's core | ||||
|   (``django.core.context_processors.static``) and renamed to | ||||
|   :func:`~django.core.context_processors.static`. | ||||
|  | ||||
| * :ref:`form-asset-paths` now uses :setting:`STATIC_URL` as the prefix | ||||
|   **if the value is not None**, and falls back to the previously used | ||||
|   :setting:`MEDIA_URL` setting otherwise. | ||||
|  | ||||
| Changes to the login methods of the admin | ||||
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ | ||||
|  | ||||
| In previous version the admin app defined login methods in multiple locations | ||||
| and ignored the almost identical implementation in the already used auth app. | ||||
| A side effect of this duplication was the missing adoption of the changes made | ||||
| in r12634_ to support a broader set of characters for usernames. | ||||
|  | ||||
| This release refactors the admin's login mechanism to use a subclass of the | ||||
| :class:`~django.contrib.auth.forms.AuthenticationForm` instead of a manual | ||||
| form validation. The previously undocumented method | ||||
| ``'django.contrib.admin.sites.AdminSite.display_login_form'`` has been removed | ||||
| in favor of a new :attr:`~django.contrib.admin.AdminSite.login_form` | ||||
| attribute. | ||||
|  | ||||
| .. _r12634: https://code.djangoproject.com/changeset/12634 | ||||
|  | ||||
| Changes to ``USStateField`` | ||||
| =========================== | ||||
|  | ||||
| The ``django.contrib.localflavor`` application contains collections | ||||
| of code relevant to specific countries or cultures. One such is | ||||
| ``USStateField``, which provides a field for storing the two-letter postal | ||||
| abbreviation of a U.S. state. This field has consistently caused problems, | ||||
| however, because it is often used to store the state portion of a U.S postal | ||||
| address, but not all "states" recognized by the U.S Postal Service are | ||||
| actually states of the U.S. or even U.S. territory. Several | ||||
| compromises over the list of choices resulted in some users feeling | ||||
| the field supported too many locations, while others felt it supported | ||||
| too few. | ||||
|  | ||||
| In Django 1.3 we're taking a new approach to this problem, implemented | ||||
| as a pair of changes: | ||||
|  | ||||
| * The choice list for ``USStateField`` has changed. Previously, it | ||||
|   consisted of the 50 U.S. states, the District of Columbia and | ||||
|   U.S. overseas territories. As of Django 1.3 it includes all previous | ||||
|   choices, plus the U.S. Armed Forces postal codes. | ||||
|  | ||||
| * A new model field, | ||||
|   ``django.contrib.localflavor.us.models.USPostalCodeField``, has | ||||
|   been added which draws its choices from a list of all postal | ||||
|   abbreviations recognized by the U.S Postal Service. This includes | ||||
|   all abbreviations recognized by ``USStateField``, plus three | ||||
|   independent nations -- the Federated States of Micronesia, the | ||||
|   Republic of the Marshall Islands and the Republic of Palau -- which | ||||
|   are serviced under treaty by the U.S. postal system. A new form | ||||
|   widget, ``django.contrib.localflavor.us.forms.USPSSelect``, is | ||||
|   also available and provides the same set of choices. | ||||
|  | ||||
| Additionally, several finer-grained choice tuples are provided which | ||||
| allow mixing and matching of subsets of the U.S. states and | ||||
| territories, and other locations serviced by the U.S. postal | ||||
| system. Consult the ``django.contrib.localflavor`` documentation | ||||
| for more details. | ||||
|  | ||||
| The change to ``USStateField`` is technically backwards-incompatible for | ||||
| users who expect this field to exclude Armed Forces locations. If you | ||||
| need to support U.S. mailing addresses without Armed Forces locations, | ||||
| see the list of choice tuples available in the localflavor | ||||
| documentation. | ||||
|  | ||||
| The Django 1.3 roadmap | ||||
| ====================== | ||||
|  | ||||
| Before the final Django 1.3 release, several other preview/development | ||||
| releases will be made available. The current schedule consists of at | ||||
| least the following: | ||||
|  | ||||
| * Week of **January 24, 2011**: First Django 1.3 release | ||||
|   candidate. String freeze for translations. | ||||
|  | ||||
| * Week of **January 31, 2011**: Django 1.3 final release. | ||||
|  | ||||
| If necessary, additional beta or release-candidate packages | ||||
| will be issued prior to the final 1.3 release. Django 1.3 will be | ||||
| released approximately one week after the final release candidate. | ||||
|  | ||||
|  | ||||
| What you can do to help | ||||
| ======================= | ||||
|  | ||||
| In order to provide a high-quality 1.3 release, we need your help. Although this | ||||
| beta release is, again, *not* intended for production use, you can help the | ||||
| Django team by trying out the beta codebase in a safe test environment and | ||||
| reporting any bugs or issues you encounter. The Django ticket tracker is the | ||||
| central place to search for open issues: | ||||
|  | ||||
| * https://code.djangoproject.com/timeline | ||||
|  | ||||
| Please open new tickets if no existing ticket corresponds to a problem you're | ||||
| running into. | ||||
|  | ||||
| Additionally, discussion of Django development, including progress toward the | ||||
| 1.3 release, takes place daily on the django-developers mailing list: | ||||
|  | ||||
| * http://groups.google.com/group/django-developers | ||||
|  | ||||
| ... and in the ``#django-dev`` IRC channel on ``irc.freenode.net``. If you're | ||||
| interested in helping out with Django's development, feel free to join the | ||||
| discussions there. | ||||
|  | ||||
| Django's online documentation also includes pointers on how to contribute to | ||||
| Django: | ||||
|  | ||||
| * :doc:`How to contribute to Django </internals/contributing/index>` | ||||
|  | ||||
| Contributions on any level -- developing code, writing documentation or simply | ||||
| triaging tickets and helping to test proposed bugfixes -- are always welcome and | ||||
| appreciated. | ||||
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							| @@ -1,634 +0,0 @@ | ||||
| ============================== | ||||
| Django 1.5 alpha release notes | ||||
| ============================== | ||||
|  | ||||
| October 25, 2012. | ||||
|  | ||||
| Welcome to Django 1.5 alpha! | ||||
|  | ||||
| This is the first in a series of preview/development releases leading up to the | ||||
| eventual release of Django 1.5, scheduled for December 2012. This release is | ||||
| primarily targeted at developers who are interested in trying out new features | ||||
| and testing the Django codebase to help identify and resolve bugs prior to the | ||||
| final 1.5 release. | ||||
|  | ||||
| As such, this release is *not* intended for production use, and any such use | ||||
| is discouraged. | ||||
|  | ||||
| In particular, we need the community's help to test Django 1.5's new `Python 3 | ||||
| support`_ -- not just to report bugs on Python 3, but also regressions on Python | ||||
| 2. While Django is very conservative with regards to backwards compatibility, | ||||
| mistakes are always possible, and it's likely that the Python 3 refactoring work | ||||
| introduced some regressions. | ||||
|  | ||||
| Django 1.5 alpha includes various `new features`_ and some minor `backwards | ||||
| incompatible changes`_. There are also some features that have been dropped, | ||||
| which are detailed in :doc:`our deprecation plan </internals/deprecation>`, | ||||
| and we've `begun the deprecation process for some features`_. | ||||
|  | ||||
| .. _`new features`: `What's new in Django 1.5`_ | ||||
| .. _`backwards incompatible changes`: `Backwards incompatible changes in 1.5`_ | ||||
| .. _`begun the deprecation process for some features`: `Features deprecated in 1.5`_ | ||||
|  | ||||
| Overview | ||||
| ======== | ||||
|  | ||||
| The biggest new feature in Django 1.5 is the `configurable User model`_. Before | ||||
| Django 1.5, applications that wanted to use Django's auth framework | ||||
| (:mod:`django.contrib.auth`) were forced to use Django's definition of a "user". | ||||
| In Django 1.5, you can now swap out the ``User`` model for one that you write | ||||
| yourself. This could be a simple extension to the existing ``User`` model -- for | ||||
| example, you could add a Twitter or Facebook ID field -- or you could completely | ||||
| replace the ``User`` with one totally customized for your site. | ||||
|  | ||||
| Django 1.5 is also the first release with `Python 3 support`_! We're labeling | ||||
| this support "experimental" because we don't yet consider it production-ready, | ||||
| but everything's in place for you to start porting your apps to Python 3. | ||||
| Our next release, Django 1.6, will support Python 3 without reservations. | ||||
|  | ||||
| Other notable new features in Django 1.5 include: | ||||
|  | ||||
| * `Support for saving a subset of model's fields`_ - | ||||
|   :meth:`Model.save() <django.db.models.Model.save()>` now accepts an | ||||
|   ``update_fields`` argument, letting you specify which fields are | ||||
|   written back to the database when you call ``save()``. This can help | ||||
|   in high-concurrency operations, and can improve performance. | ||||
|  | ||||
| * Better `support for streaming responses <#explicit-streaming-responses>`_ via | ||||
|   the new  :class:`~django.http.StreamingHttpResponse` response class. | ||||
|  | ||||
| * `GeoDjango`_ now supports PostGIS 2.0. | ||||
|  | ||||
| * ... and more; `see below <#what-s-new-in-django-1-5>`_. | ||||
|  | ||||
| Wherever possible we try to introduce new features in a backwards-compatible | ||||
| manner per :doc:`our API stability policy </misc/api-stability>` policy. | ||||
| However, as with previous releases, Django 1.5 ships with some minor | ||||
| `backwards incompatible changes`_; people upgrading from previous versions | ||||
| of Django should read that list carefully. | ||||
|  | ||||
| One deprecated feature worth noting is the shift to "new-style" :ttag:`url` tag. | ||||
| Prior to Django 1.3, syntax like ``{% url myview %}`` was interpreted | ||||
| incorrectly (Django considered ``"myview"`` to be a literal name of a view, not | ||||
| a template variable named ``myview``). Django 1.3 and above introduced the | ||||
| ``{% load url from future %}`` syntax to bring in the corrected behavior where | ||||
| ``myview`` was seen as a variable. | ||||
|  | ||||
| The upshot of this is that if you are not using ``{% load url from future %}`` | ||||
| in your templates, you'll need to change tags like ``{% url myview %}`` to | ||||
| ``{% url "myview" %}``. If you *were* using ``{% load url from future %}`` you | ||||
| can simply remove that line under Django 1.5 | ||||
|  | ||||
| Python compatibility | ||||
| ==================== | ||||
|  | ||||
| Django 1.5 requires Python 2.6.5 or above, though we **highly recommended** | ||||
| Python 2.7.3 or above. Support for Python 2.5 and below has been dropped. | ||||
|  | ||||
| This change should affect only a small number of Django users, as most | ||||
| operating-system vendors today are shipping Python 2.6 or newer as their default | ||||
| version. If you're still using Python 2.5, however, you'll need to stick to | ||||
| Django 1.4 until you can upgrade your Python version. Per :doc:`our support | ||||
| policy </internals/release-process>`, Django 1.4 will continue to receive | ||||
| security support until the release of Django 1.6. | ||||
|  | ||||
| Django 1.5 does not run on a Jython final release, because Jython's latest | ||||
| release doesn't currently support Python 2.6. However, Jython currently does | ||||
| offer an alpha release featuring 2.7 support, and Django 1.5 supports that alpha | ||||
| release. | ||||
|  | ||||
| Python 3 support | ||||
| ~~~~~~~~~~~~~~~~ | ||||
|  | ||||
| Django 1.5 introduces support for Python 3 - specifically, Python | ||||
| 3.2 and above. This comes in the form of a **single** codebase; you don't | ||||
| need to install a different version of Django on Python 3. This means that | ||||
| you can write application targeted for just Python 2, just Python 3, or single | ||||
| applications that support both platforms. | ||||
|  | ||||
| However, we're labeling this support "experimental" for now: although it's | ||||
| received extensive testing via our automated test suite, it's received very | ||||
| little real-world testing. We've done our best to eliminate bugs, but we can't | ||||
| be sure we covered all possible uses of Django. Further, Django's more than a | ||||
| web framework; it's an ecosystem of pluggable components. At this point, very | ||||
| few third-party applications have been ported to Python 3, so it's unlikely | ||||
| that a real-world application will have all its dependencies satisfied under | ||||
| Python 3. | ||||
|  | ||||
| Thus, we're recommending that Django 1.5 not be used in production under Python | ||||
| 3. Instead, use this opportunity to begin :doc:`porting applications to Python 3 | ||||
| </topics/python3>`. If you're an author of a pluggable component, we encourage you | ||||
| to start porting now. | ||||
|  | ||||
| We plan to offer first-class, production-ready support for Python 3 in our next | ||||
| release, Django 1.6. | ||||
|  | ||||
| What's new in Django 1.5 | ||||
| ======================== | ||||
|  | ||||
| Configurable User model | ||||
| ~~~~~~~~~~~~~~~~~~~~~~~ | ||||
|  | ||||
| In Django 1.5, you can now use your own model as the store for user-related | ||||
| data. If your project needs a username with more than 30 characters, or if | ||||
| you want to store usernames in a format other than first name/last name, or | ||||
| you want to put custom profile information onto your User object, you can | ||||
| now do so. | ||||
|  | ||||
| If you have a third-party reusable application that references the User model, | ||||
| you may need to make some changes to the way you reference User instances. You | ||||
| should also document any specific features of the User model that your | ||||
| application relies upon. | ||||
|  | ||||
| See the :ref:`documentation on custom User models <auth-custom-user>` for | ||||
| more details. | ||||
|  | ||||
| Support for saving a subset of model's fields | ||||
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ | ||||
|  | ||||
| The method :meth:`Model.save() <django.db.models.Model.save()>` has a new | ||||
| keyword argument ``update_fields``. By using this argument it is possible to | ||||
| save only a select list of model's fields. This can be useful for performance | ||||
| reasons or when trying to avoid overwriting concurrent changes. | ||||
|  | ||||
| Deferred instances (those loaded by .only() or .defer()) will automatically | ||||
| save just the loaded fields. If any field is set manually after load, that | ||||
| field will also get updated on save. | ||||
|  | ||||
| See the :meth:`Model.save() <django.db.models.Model.save()>` documentation for | ||||
| more details. | ||||
|  | ||||
| Caching of related model instances | ||||
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ | ||||
|  | ||||
| When traversing relations, the ORM will avoid re-fetching objects that were | ||||
| previously loaded. For example, with the tutorial's models:: | ||||
|  | ||||
|     >>> first_poll = Poll.objects.all()[0] | ||||
|     >>> first_choice = first_poll.choice_set.all()[0] | ||||
|     >>> first_choice.poll is first_poll | ||||
|     True | ||||
|  | ||||
| In Django 1.5, the third line no longer triggers a new SQL query to fetch | ||||
| ``first_choice.poll``; it was set by the second line. | ||||
|  | ||||
| For one-to-one relationships, both sides can be cached. For many-to-one | ||||
| relationships, only the single side of the relationship can be cached. This | ||||
| is particularly helpful in combination with ``prefetch_related``. | ||||
|  | ||||
| Explicit support for streaming responses | ||||
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ | ||||
|  | ||||
| Before Django 1.5, it was possible to create a streaming response by passing | ||||
| an iterator to :class:`~django.http.HttpResponse`. But this was unreliable: | ||||
| any middleware that accessed the :attr:`~django.http.HttpResponse.content` | ||||
| attribute would consume the iterator prematurely. | ||||
|  | ||||
| You can now explicitly generate a streaming response with the new | ||||
| :class:`~django.http.StreamingHttpResponse` class. This class exposes a | ||||
| :class:`~django.http.StreamingHttpResponse.streaming_content` attribute which | ||||
| is an iterator. | ||||
|  | ||||
| Since :class:`~django.http.StreamingHttpResponse` does not have a ``content`` | ||||
| attribute, middleware that needs access to the response content must test for | ||||
| streaming responses and behave accordingly. See :ref:`response-middleware` for | ||||
| more information. | ||||
|  | ||||
| ``{% verbatim %}`` template tag | ||||
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ | ||||
|  | ||||
| To make it easier to deal with javascript templates which collide with Django's | ||||
| syntax, you can now use the :ttag:`verbatim` block tag to avoid parsing the | ||||
| tag's content. | ||||
|  | ||||
| Retrieval of ``ContentType`` instances associated with proxy models | ||||
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ | ||||
|  | ||||
| The methods :meth:`ContentTypeManager.get_for_model() <django.contrib.contenttypes.models.ContentTypeManager.get_for_model()>` | ||||
| and :meth:`ContentTypeManager.get_for_models() <django.contrib.contenttypes.models.ContentTypeManager.get_for_models()>` | ||||
| have a new keyword argument – respectively ``for_concrete_model`` and ``for_concrete_models``. | ||||
| By passing ``False`` using this argument it is now possible to retrieve the | ||||
| :class:`ContentType <django.contrib.contenttypes.models.ContentType>` | ||||
| associated with proxy models. | ||||
|  | ||||
| New ``view`` variable in class-based views context | ||||
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ | ||||
|  | ||||
| In all :doc:`generic class-based views </topics/class-based-views/index>` | ||||
| (or any class-based view inheriting from ``ContextMixin``), the context dictionary | ||||
| contains a ``view`` variable that points to the ``View`` instance. | ||||
|  | ||||
| GeoDjango | ||||
| ~~~~~~~~~ | ||||
|  | ||||
| * :class:`~django.contrib.gis.geos.LineString` and | ||||
|   :class:`~django.contrib.gis.geos.MultiLineString` GEOS objects now support the | ||||
|   :meth:`~django.contrib.gis.geos.GEOSGeometry.interpolate()` and | ||||
|   :meth:`~django.contrib.gis.geos.GEOSGeometry.project()` methods | ||||
|   (so-called linear referencing). | ||||
|  | ||||
| * The ``wkb`` and ``hex`` properties of | ||||
|   :class:`~django.contrib.gis.geos.GEOSGeometry` objects preserve the Z | ||||
|   dimension. | ||||
|  | ||||
| * Support for PostGIS 2.0 has been added and support for GDAL < 1.5 has been | ||||
|   dropped. | ||||
|  | ||||
| Minor features | ||||
| ~~~~~~~~~~~~~~ | ||||
|  | ||||
| Django 1.5 also includes several smaller improvements worth noting: | ||||
|  | ||||
| * The template engine now interprets ``True``, ``False`` and ``None`` as the | ||||
|   corresponding Python objects. | ||||
|  | ||||
| * :mod:`django.utils.timezone` provides a helper for converting aware | ||||
|   datetimes between time zones. See :func:`~django.utils.timezone.localtime`. | ||||
|  | ||||
| * The generic views support OPTIONS requests. | ||||
|  | ||||
| * Management commands do not raise ``SystemExit`` any more when called by code | ||||
|   from :ref:`call_command <call-command>`. Any exception raised by the command | ||||
|   (mostly :ref:`CommandError <ref-command-exceptions>`) is propagated. | ||||
|  | ||||
| * The dumpdata management command outputs one row at a time, preventing | ||||
|   out-of-memory errors when dumping large datasets. | ||||
|  | ||||
| * In the localflavor for Canada, "pq" was added to the acceptable codes for | ||||
|   Quebec. It's an old abbreviation. | ||||
|  | ||||
| * The :ref:`receiver <connecting-receiver-functions>` decorator is now able to | ||||
|   connect to more than one signal by supplying a list of signals. | ||||
|  | ||||
| * In the admin, you can now filter users by groups which they are members of. | ||||
|  | ||||
| * :meth:`QuerySet.bulk_create() | ||||
|   <django.db.models.query.QuerySet.bulk_create>` now has a batch_size | ||||
|   argument. By default the batch_size is unlimited except for SQLite where | ||||
|   single batch is limited so that 999 parameters per query isn't exceeded. | ||||
|  | ||||
| * The :setting:`LOGIN_URL` and :setting:`LOGIN_REDIRECT_URL` settings now also | ||||
|   accept view function names and | ||||
|   :ref:`named URL patterns <naming-url-patterns>`. This allows you to reduce | ||||
|   configuration duplication. More information can be found in the | ||||
|   :func:`~django.contrib.auth.decorators.login_required` documentation. | ||||
|  | ||||
| * Django now provides a mod_wsgi :doc:`auth handler | ||||
|   </howto/deployment/wsgi/apache-auth>`. | ||||
|  | ||||
| * The :meth:`QuerySet.delete() <django.db.models.query.QuerySet.delete>` | ||||
|   and :meth:`Model.delete() <django.db.models.Model.delete()>` can now take | ||||
|   fast-path in some cases. The fast-path allows for less queries and less | ||||
|   objects fetched into memory. See :meth:`QuerySet.delete() | ||||
|   <django.db.models.query.QuerySet.delete>` for details. | ||||
|  | ||||
| * An instance of :class:`~django.core.urlresolvers.ResolverMatch` is stored on | ||||
|   the request as ``resolver_match``. | ||||
|  | ||||
| * By default, all logging messages reaching the ``django`` logger when | ||||
|   :setting:`DEBUG` is ``True`` are sent to the console (unless you redefine the | ||||
|   logger in your :setting:`LOGGING` setting). | ||||
|  | ||||
| * When using :class:`~django.template.RequestContext`, it is now possible to | ||||
|   look up permissions by using ``{% if 'someapp.someperm' in perms %}`` | ||||
|   in templates. | ||||
|  | ||||
| * It's not required any more to have ``404.html`` and ``500.html`` templates in | ||||
|   the root templates directory. Django will output some basic error messages for | ||||
|   both situations when those templates are not found. Of course, it's still | ||||
|   recommended as good practice to provide those templates in order to present | ||||
|   pretty error pages to the user. | ||||
|  | ||||
| * :mod:`django.contrib.auth` provides a new signal that is emitted | ||||
|   whenever a user fails to login successfully. See | ||||
|   :data:`~django.contrib.auth.signals.user_login_failed` | ||||
|  | ||||
| * The loaddata management command now supports an | ||||
|   :djadminopt:`--ignorenonexistent` option to ignore data for fields that no | ||||
|   longer exist. | ||||
|  | ||||
| * :meth:`~django.test.SimpleTestCase.assertXMLEqual` and | ||||
|   :meth:`~django.test.SimpleTestCase.assertXMLNotEqual` new assertions allow | ||||
|   you to test equality for XML content at a semantic level, without caring for | ||||
|   syntax differences (spaces, attribute order, etc.). | ||||
|  | ||||
| Backwards incompatible changes in 1.5 | ||||
| ===================================== | ||||
|  | ||||
| .. warning:: | ||||
|  | ||||
|     In addition to the changes outlined in this section, be sure to review the | ||||
|     :doc:`deprecation plan </internals/deprecation>` for any features that | ||||
|     have been removed. If you haven't updated your code within the | ||||
|     deprecation timeline for a given feature, its removal may appear as a | ||||
|     backwards incompatible change. | ||||
|  | ||||
| Context in year archive class-based views | ||||
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ | ||||
|  | ||||
| For consistency with the other date-based generic views, | ||||
| :class:`~django.views.generic.dates.YearArchiveView` now passes ``year`` in | ||||
| the context as a :class:`datetime.date` rather than a string.  If you are | ||||
| using ``{{ year }}`` in your templates, you must replace it with ``{{ | ||||
| year|date:"Y" }}``. | ||||
|  | ||||
| ``next_year`` and ``previous_year`` were also added in the context. They are | ||||
| calculated according to ``allow_empty`` and ``allow_future``. | ||||
|  | ||||
| Context in year and month archive class-based views | ||||
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ | ||||
|  | ||||
| :class:`~django.views.generic.dates.YearArchiveView` and | ||||
| :class:`~django.views.generic.dates.MonthArchiveView` were documented to | ||||
| provide a ``date_list`` sorted in ascending order in the context, like their | ||||
| function-based predecessors, but it actually was in descending order. In 1.5, | ||||
| the documented order was restored. You may want to add (or remove) the | ||||
| ``reversed`` keyword when you're iterating on ``date_list`` in a template:: | ||||
|  | ||||
|     {% for date in date_list reversed %} | ||||
|  | ||||
| :class:`~django.views.generic.dates.ArchiveIndexView` still provides a | ||||
| ``date_list`` in descending order. | ||||
|  | ||||
| Context in TemplateView | ||||
| ~~~~~~~~~~~~~~~~~~~~~~~ | ||||
|  | ||||
| For consistency with the design of the other generic views, | ||||
| :class:`~django.views.generic.base.TemplateView` no longer passes a ``params`` | ||||
| dictionary into the context, instead passing the variables from the URLconf | ||||
| directly into the context. | ||||
|  | ||||
| Non-form data in HTTP requests | ||||
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ | ||||
|  | ||||
| :attr:`request.POST <django.http.HttpRequest.POST>` will no longer include data | ||||
| posted via HTTP requests with non form-specific content-types in the header. | ||||
| In prior versions, data posted with content-types other than | ||||
| ``multipart/form-data`` or ``application/x-www-form-urlencoded`` would still | ||||
| end up represented in the :attr:`request.POST <django.http.HttpRequest.POST>` | ||||
| attribute. Developers wishing to access the raw POST data for these cases, | ||||
| should use the :attr:`request.body <django.http.HttpRequest.body>` attribute | ||||
| instead. | ||||
|  | ||||
| OPTIONS, PUT and DELETE requests in the test client | ||||
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ | ||||
|  | ||||
| Unlike GET and POST, these HTTP methods aren't implemented by web browsers. | ||||
| Rather, they're used in APIs, which transfer data in various formats such as | ||||
| JSON or XML. Since such requests may contain arbitrary data, Django doesn't | ||||
| attempt to decode their body. | ||||
|  | ||||
| However, the test client used to build a query string for OPTIONS and DELETE | ||||
| requests like for GET, and a request body for PUT requests like for POST. This | ||||
| encoding was arbitrary and inconsistent with Django's behavior when it | ||||
| receives the requests, so it was removed in Django 1.5. | ||||
|  | ||||
| If you were using the ``data`` parameter in an OPTIONS or a DELETE request, | ||||
| you must convert it to a query string and append it to the ``path`` parameter. | ||||
|  | ||||
| If you were using the ``data`` parameter in a PUT request without a | ||||
| ``content_type``, you must encode your data before passing it to the test | ||||
| client and set the ``content_type`` argument. | ||||
|  | ||||
| System version of :mod:`simplejson` no longer used | ||||
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ | ||||
|  | ||||
| As explained below, Django 1.5 deprecates | ||||
| ``django.utils.simplejson`` in favor of Python 2.6's built-in :mod:`json` | ||||
| module. In theory, this change is harmless. Unfortunately, because of | ||||
| incompatibilities between versions of :mod:`simplejson`, it may trigger errors | ||||
| in some circumstances. | ||||
|  | ||||
| JSON-related features in Django 1.4 always used ``django.utils.simplejson``. | ||||
| This module was actually: | ||||
|  | ||||
| - A system version of :mod:`simplejson`, if one was available (ie. ``import | ||||
|   simplejson`` works), if it was more recent than Django's built-in copy or it | ||||
|   had the C speedups, or | ||||
| - The :mod:`json` module from the standard library, if it was available (ie. | ||||
|   Python 2.6 or greater), or | ||||
| - A built-in copy of version 2.0.7 of :mod:`simplejson`. | ||||
|  | ||||
| In Django 1.5, those features use Python's :mod:`json` module, which is based | ||||
| on version 2.0.9 of :mod:`simplejson`. | ||||
|  | ||||
| There are no known incompatibilities between Django's copy of version 2.0.7 and | ||||
| Python's copy of version 2.0.9. However, there are some incompatibilities | ||||
| between other versions of :mod:`simplejson`: | ||||
|  | ||||
| - While the :mod:`simplejson` API is documented as always returning unicode | ||||
|   strings, the optional C implementation can return a byte string. This was | ||||
|   fixed in Python 2.7. | ||||
| - :class:`simplejson.JSONEncoder` gained a ``namedtuple_as_object`` keyword | ||||
|   argument in version 2.2. | ||||
|  | ||||
| More information on these incompatibilities is available in `ticket #18023`_. | ||||
|  | ||||
| The net result is that, if you have installed :mod:`simplejson` and your code | ||||
| uses Django's serialization internals directly -- for instance | ||||
| ``django.core.serializers.json.DjangoJSONEncoder``, the switch from | ||||
| :mod:`simplejson` to :mod:`json` could break your code. (In general, changes to | ||||
| internals aren't documented; we're making an exception here.) | ||||
|  | ||||
| At this point, the maintainers of Django believe that using :mod:`json` from | ||||
| the standard library offers the strongest guarantee of backwards-compatibility. | ||||
| They recommend to use it from now on. | ||||
|  | ||||
| .. _ticket #18023: https://code.djangoproject.com/ticket/18023#comment:10 | ||||
|  | ||||
| String types of hasher method parameters | ||||
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ | ||||
|  | ||||
| If you have written a :ref:`custom password hasher <auth_password_storage>`, | ||||
| your ``encode()``, ``verify()`` or ``safe_summary()`` methods should accept | ||||
| Unicode parameters (``password``, ``salt`` or ``encoded``). If any of the | ||||
| hashing methods need byte strings, you can use the | ||||
| :func:`~django.utils.encoding.force_bytes` utility to encode the strings. | ||||
|  | ||||
| Validation of previous_page_number and next_page_number | ||||
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ | ||||
|  | ||||
| When using :doc:`object pagination </topics/pagination>`, | ||||
| the ``previous_page_number()`` and ``next_page_number()`` methods of the | ||||
| :class:`~django.core.paginator.Page` object did not check if the returned | ||||
| number was inside the existing page range. | ||||
| It does check it now and raises an :exc:`~django.core.paginator.InvalidPage` | ||||
| exception when the number is either too low or too high. | ||||
|  | ||||
| Behavior of autocommit database option on PostgreSQL changed | ||||
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ | ||||
|  | ||||
| PostgreSQL's autocommit option didn't work as advertised previously. It did | ||||
| work for single transaction block, but after the first block was left the | ||||
| autocommit behavior was never restored. This bug is now fixed in 1.5. While | ||||
| this is only a bug fix, it is worth checking your applications behavior if | ||||
| you are using PostgreSQL together with the autocommit option. | ||||
|  | ||||
| Session not saved on 500 responses | ||||
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ | ||||
|  | ||||
| Django's session middleware will skip saving the session data if the | ||||
| response's status code is 500. | ||||
|  | ||||
| Email checks on failed admin login | ||||
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ | ||||
|  | ||||
| Prior to Django 1.5, if you attempted to log into the admin interface and | ||||
| mistakenly used your email address instead of your username, the admin | ||||
| interface would provide a warning advising that your email address was | ||||
| not your username. In Django 1.5, the introduction of | ||||
| :ref:`custom User models <auth-custom-user>` has required the removal of this | ||||
| warning. This doesn't change the login behavior of the admin site; it only | ||||
| affects the warning message that is displayed under one particular mode of | ||||
| login failure. | ||||
|  | ||||
| Changes in tests execution | ||||
| ~~~~~~~~~~~~~~~~~~~~~~~~~~ | ||||
|  | ||||
| Some changes have been introduced in the execution of tests that might be | ||||
| backward-incompatible for some testing setups: | ||||
|  | ||||
| Database flushing in ``django.test.TransactionTestCase`` | ||||
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ | ||||
|  | ||||
| Previously, the test database was truncated *before* each test run in a | ||||
| :class:`~django.test.TransactionTestCase`. | ||||
|  | ||||
| In order to be able to run unit tests in any order and to make sure they are | ||||
| always isolated from each other, :class:`~django.test.TransactionTestCase` will | ||||
| now reset the database *after* each test run instead. | ||||
|  | ||||
| No more implicit DB sequences reset | ||||
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ | ||||
|  | ||||
| :class:`~django.test.TransactionTestCase` tests used to reset primary key | ||||
| sequences automatically together with the database flushing actions described | ||||
| above. | ||||
|  | ||||
| This has been changed so no sequences are implicitly reset. This can cause | ||||
| :class:`~django.test.TransactionTestCase` tests that depend on hard-coded | ||||
| primary key values to break. | ||||
|  | ||||
| The new :attr:`~django.test.TransactionTestCase.reset_sequences` attribute can | ||||
| be used to force the old behavior for :class:`~django.test.TransactionTestCase` | ||||
| that might need it. | ||||
|  | ||||
| Ordering of tests | ||||
| ^^^^^^^^^^^^^^^^^ | ||||
|  | ||||
| In order to make sure all ``TestCase`` code starts with a clean database, | ||||
| tests are now executed in the following order: | ||||
|  | ||||
| * First, all unittests (including :class:`unittest.TestCase`, | ||||
|   :class:`~django.test.SimpleTestCase`, :class:`~django.test.TestCase` and | ||||
|   :class:`~django.test.TransactionTestCase`) are run with no particular ordering | ||||
|   guaranteed nor enforced among them. | ||||
|  | ||||
| * Then any other tests (e.g. doctests) that may alter the database without | ||||
|   restoring it to its original state are run. | ||||
|  | ||||
| This should not cause any problems unless you have existing doctests which | ||||
| assume a :class:`~django.test.TransactionTestCase` executed earlier left some | ||||
| database state behind or unit tests that rely on some form of state being | ||||
| preserved after the execution of other tests. Such tests are already very | ||||
| fragile, and must now be changed to be able to run independently. | ||||
|  | ||||
| `cleaned_data` dictionary kept for invalid forms | ||||
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ | ||||
|  | ||||
| The :attr:`~django.forms.Form.cleaned_data` dictionary is now always present | ||||
| after form validation. When the form doesn't validate, it contains only the | ||||
| fields that passed validation. You should test the success of the validation | ||||
| with the :meth:`~django.forms.Form.is_valid()` method and not with the | ||||
| presence or absence of the :attr:`~django.forms.Form.cleaned_data` attribute | ||||
| on the form. | ||||
|  | ||||
| Miscellaneous | ||||
| ~~~~~~~~~~~~~ | ||||
|  | ||||
| * :class:`django.forms.ModelMultipleChoiceField` now returns an empty | ||||
|   ``QuerySet`` as the empty value instead of an empty list. | ||||
|  | ||||
| * :func:`~django.utils.http.int_to_base36` properly raises a | ||||
|   :exc:`TypeError` instead of :exc:`ValueError` for non-integer inputs. | ||||
|  | ||||
| * The ``slugify`` template filter is now available as a standard python | ||||
|   function at :func:`django.utils.text.slugify`. Similarly, ``remove_tags`` is | ||||
|   available at :func:`django.utils.html.remove_tags`. | ||||
|  | ||||
| * Uploaded files are no longer created as executable by default. If you need | ||||
|   them to be executable change :setting:`FILE_UPLOAD_PERMISSIONS` to your | ||||
|   needs. The new default value is ``0o666`` (octal) and the current umask value | ||||
|   is first masked out. | ||||
|  | ||||
| * The :class:`F expressions <django.db.models.F>` supported bitwise operators | ||||
|   by ``&`` and ``|``. These operators are now available using ``.bitand()`` and | ||||
|   ``.bitor()`` instead. The removal of ``&`` and ``|`` was done to be | ||||
|   consistent with :ref:`Q() expressions <complex-lookups-with-q>` and | ||||
|   ``QuerySet`` combining where the operators are used as boolean AND and OR | ||||
|   operators. | ||||
|  | ||||
| * The :ttag:`csrf_token` template tag is no longer enclosed in a div. If you need | ||||
|   HTML validation against pre-HTML5 Strict DTDs, you should add a div around it | ||||
|   in your pages. | ||||
|  | ||||
| Features deprecated in 1.5 | ||||
| ========================== | ||||
|  | ||||
| ``AUTH_PROFILE_MODULE`` setting | ||||
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ | ||||
|  | ||||
| With the introduction of :ref:`custom User models <auth-custom-user>`, there is | ||||
| no longer any need for a built-in mechanism to store user profile data. | ||||
|  | ||||
| You can still define user profiles models that have a one-to-one relation with | ||||
| the User model - in fact, for many applications needing to associate data with | ||||
| a User account, this will be an appropriate design pattern to follow. However, | ||||
| the ``AUTH_PROFILE_MODULE`` setting, and the | ||||
| ``django.contrib.auth.models.User.get_profile()`` method for accessing | ||||
| the user profile model, should not be used any longer. | ||||
|  | ||||
| Streaming behavior of :class:`~django.http.HttpResponse` | ||||
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ | ||||
|  | ||||
| Django 1.5 deprecates the ability to stream a response by passing an iterator | ||||
| to :class:`~django.http.HttpResponse`. If you rely on this behavior, switch to | ||||
| :class:`~django.http.StreamingHttpResponse`. See above for more details. | ||||
|  | ||||
| In Django 1.7 and above, the iterator will be consumed immediately by | ||||
| :class:`~django.http.HttpResponse`. | ||||
|  | ||||
| ``django.utils.simplejson`` | ||||
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~ | ||||
|  | ||||
| Since Django 1.5 drops support for Python 2.5, we can now rely on the | ||||
| :mod:`json` module being available in Python's standard library, so we've | ||||
| removed our own copy of :mod:`simplejson`. You should now import :mod:`json` | ||||
| instead of ``django.utils.simplejson``. | ||||
|  | ||||
| Unfortunately, this change might have unwanted side-effects, because of | ||||
| incompatibilities between versions of :mod:`simplejson` -- see the backwards- | ||||
| incompatible changes section. If you rely on features added to :mod:`simplejson` | ||||
| after it became Python's :mod:`json`, you should import :mod:`simplejson` | ||||
| explicitly. | ||||
|  | ||||
| ``django.utils.encoding.StrAndUnicode`` | ||||
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ | ||||
|  | ||||
| The ``django.utils.encoding.StrAndUnicode`` mix-in has been deprecated. | ||||
| Define a ``__str__`` method and apply the | ||||
| :func:`~django.utils.encoding.python_2_unicode_compatible` decorator instead. | ||||
|  | ||||
| ``django.utils.itercompat.product`` | ||||
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ | ||||
|  | ||||
| The ``django.utils.itercompat.product`` function has been deprecated. Use | ||||
| the built-in :func:`itertools.product` instead. | ||||
|  | ||||
| ``django.utils.markup`` | ||||
| ~~~~~~~~~~~~~~~~~~~~~~~ | ||||
|  | ||||
| The markup contrib module has been deprecated and will follow an accelerated | ||||
| deprecation schedule. Direct use of python markup libraries or 3rd party tag | ||||
| libraries is preferred to Django maintaining this functionality in the | ||||
| framework. | ||||
| @@ -1,706 +0,0 @@ | ||||
| ============================= | ||||
| Django 1.5 beta release notes | ||||
| ============================= | ||||
|  | ||||
| November 27, 2012. | ||||
|  | ||||
| Welcome to Django 1.5 beta! | ||||
|  | ||||
| This is the second in a series of preview/development releases leading | ||||
| up to the eventual release of Django 1.5, scheduled for December | ||||
| 2012. This release is primarily targeted at developers who are | ||||
| interested in trying out new features and testing the Django codebase | ||||
| to help identify and resolve bugs prior to the final 1.5 release. | ||||
|  | ||||
| As such, this release is *not* intended for production use, and any such use | ||||
| is discouraged. | ||||
|  | ||||
| These release notes cover the `new features`_, as well | ||||
| as some `backwards incompatible changes`_ you'll want to be aware of | ||||
| when upgrading from Django 1.4 or older versions. We've also dropped some | ||||
| features, which are detailed in :doc:`our deprecation plan | ||||
| </internals/deprecation>`, and we've `begun the deprecation process for some | ||||
| features`_. | ||||
|  | ||||
| .. _`new features`: `What's new in Django 1.5`_ | ||||
| .. _`backwards incompatible changes`: `Backwards incompatible changes in 1.5`_ | ||||
| .. _`begun the deprecation process for some features`: `Features deprecated in 1.5`_ | ||||
|  | ||||
| Overview | ||||
| ======== | ||||
|  | ||||
| The biggest new feature in Django 1.5 is the `configurable User model`_. Before | ||||
| Django 1.5, applications that wanted to use Django's auth framework | ||||
| (:mod:`django.contrib.auth`) were forced to use Django's definition of a "user". | ||||
| In Django 1.5, you can now swap out the ``User`` model for one that you write | ||||
| yourself. This could be a simple extension to the existing ``User`` model -- for | ||||
| example, you could add a Twitter or Facebook ID field -- or you could completely | ||||
| replace the ``User`` with one totally customized for your site. | ||||
|  | ||||
| Django 1.5 is also the first release with `Python 3 support`_! We're labeling | ||||
| this support "experimental" because we don't yet consider it production-ready, | ||||
| but everything's in place for you to start porting your apps to Python 3. | ||||
| Our next release, Django 1.6, will support Python 3 without reservations. | ||||
|  | ||||
| Other notable new features in Django 1.5 include: | ||||
|  | ||||
| * `Support for saving a subset of model's fields`_ - | ||||
|   :meth:`Model.save() <django.db.models.Model.save()>` now accepts an | ||||
|   ``update_fields`` argument, letting you specify which fields are | ||||
|   written back to the database when you call ``save()``. This can help | ||||
|   in high-concurrency operations, and can improve performance. | ||||
|  | ||||
| * Better `support for streaming responses <#explicit-streaming-responses-beta-1>`_ via | ||||
|   the new  :class:`~django.http.StreamingHttpResponse` response class. | ||||
|  | ||||
| * `GeoDjango`_ now supports PostGIS 2.0. | ||||
|  | ||||
| * ... and more; `see below <#what-s-new-in-django-1-5>`_. | ||||
|  | ||||
| Wherever possible we try to introduce new features in a backwards-compatible | ||||
| manner per :doc:`our API stability policy </misc/api-stability>`. | ||||
| However, as with previous releases, Django 1.5 ships with some minor | ||||
| `backwards incompatible changes`_; people upgrading from previous versions | ||||
| of Django should read that list carefully. | ||||
|  | ||||
| One deprecated feature worth noting is the shift to "new-style" :ttag:`url` tag. | ||||
| Prior to Django 1.3, syntax like ``{% url myview %}`` was interpreted | ||||
| incorrectly (Django considered ``"myview"`` to be a literal name of a view, not | ||||
| a template variable named ``myview``). Django 1.3 and above introduced the | ||||
| ``{% load url from future %}`` syntax to bring in the corrected behavior where | ||||
| ``myview`` was seen as a variable. | ||||
|  | ||||
| The upshot of this is that if you are not using ``{% load url from future %}`` | ||||
| in your templates, you'll need to change tags like ``{% url myview %}`` to | ||||
| ``{% url "myview" %}``. If you *were* using ``{% load url from future %}`` you | ||||
| can simply remove that line under Django 1.5 | ||||
|  | ||||
| Python compatibility | ||||
| ==================== | ||||
|  | ||||
| Django 1.5 requires Python 2.6.5 or above, though we **highly recommend** | ||||
| Python 2.7.3 or above. Support for Python 2.5 and below has been dropped. | ||||
|  | ||||
| This change should affect only a small number of Django users, as most | ||||
| operating-system vendors today are shipping Python 2.6 or newer as their default | ||||
| version. If you're still using Python 2.5, however, you'll need to stick to | ||||
| Django 1.4 until you can upgrade your Python version. Per :doc:`our support | ||||
| policy </internals/release-process>`, Django 1.4 will continue to receive | ||||
| security support until the release of Django 1.6. | ||||
|  | ||||
| Django 1.5 does not run on a Jython final release, because Jython's latest | ||||
| release doesn't currently support Python 2.6. However, Jython currently does | ||||
| offer an alpha release featuring 2.7 support, and Django 1.5 supports that alpha | ||||
| release. | ||||
|  | ||||
| Python 3 support | ||||
| ~~~~~~~~~~~~~~~~ | ||||
|  | ||||
| Django 1.5 introduces support for Python 3 - specifically, Python | ||||
| 3.2 and above. This comes in the form of a **single** codebase; you don't | ||||
| need to install a different version of Django on Python 3. This means that | ||||
| you can write applications targeted for just Python 2, just Python 3, or single | ||||
| applications that support both platforms. | ||||
|  | ||||
| However, we're labeling this support "experimental" for now: although it's | ||||
| received extensive testing via our automated test suite, it's received very | ||||
| little real-world testing. We've done our best to eliminate bugs, but we can't | ||||
| be sure we covered all possible uses of Django. Further, Django's more than a | ||||
| web framework; it's an ecosystem of pluggable components. At this point, very | ||||
| few third-party applications have been ported to Python 3, so it's unlikely | ||||
| that a real-world application will have all its dependencies satisfied under | ||||
| Python 3. | ||||
|  | ||||
| Thus, we're recommending that Django 1.5 not be used in production under Python | ||||
| 3. Instead, use this opportunity to begin :doc:`porting applications to Python 3 | ||||
| </topics/python3>`. If you're an author of a pluggable component, we encourage you | ||||
| to start porting now. | ||||
|  | ||||
| We plan to offer first-class, production-ready support for Python 3 in our next | ||||
| release, Django 1.6. | ||||
|  | ||||
| What's new in Django 1.5 | ||||
| ======================== | ||||
|  | ||||
| Configurable User model | ||||
| ~~~~~~~~~~~~~~~~~~~~~~~ | ||||
|  | ||||
| In Django 1.5, you can now use your own model as the store for user-related | ||||
| data. If your project needs a username with more than 30 characters, or if | ||||
| you want to store user's names in a format other than first name/last name, | ||||
| or you want to put custom profile information onto your User object, you can | ||||
| now do so. | ||||
|  | ||||
| If you have a third-party reusable application that references the User model, | ||||
| you may need to make some changes to the way you reference User instances. You | ||||
| should also document any specific features of the User model that your | ||||
| application relies upon. | ||||
|  | ||||
| See the :ref:`documentation on custom User models <auth-custom-user>` for | ||||
| more details. | ||||
|  | ||||
| Support for saving a subset of model's fields | ||||
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ | ||||
|  | ||||
| The method :meth:`Model.save() <django.db.models.Model.save()>` has a new | ||||
| keyword argument ``update_fields``. By using this argument it is possible to | ||||
| save only a select list of model's fields. This can be useful for performance | ||||
| reasons or when trying to avoid overwriting concurrent changes. | ||||
|  | ||||
| Deferred instances (those loaded by .only() or .defer()) will automatically | ||||
| save just the loaded fields. If any field is set manually after load, that | ||||
| field will also get updated on save. | ||||
|  | ||||
| See the :meth:`Model.save() <django.db.models.Model.save()>` documentation for | ||||
| more details. | ||||
|  | ||||
| Caching of related model instances | ||||
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ | ||||
|  | ||||
| When traversing relations, the ORM will avoid re-fetching objects that were | ||||
| previously loaded. For example, with the tutorial's models:: | ||||
|  | ||||
|     >>> first_poll = Poll.objects.all()[0] | ||||
|     >>> first_choice = first_poll.choice_set.all()[0] | ||||
|     >>> first_choice.poll is first_poll | ||||
|     True | ||||
|  | ||||
| In Django 1.5, the third line no longer triggers a new SQL query to fetch | ||||
| ``first_choice.poll``; it was set by the second line. | ||||
|  | ||||
| For one-to-one relationships, both sides can be cached. For many-to-one | ||||
| relationships, only the single side of the relationship can be cached. This | ||||
| is particularly helpful in combination with ``prefetch_related``. | ||||
|  | ||||
| .. _explicit-streaming-responses-beta-1: | ||||
|  | ||||
| Explicit support for streaming responses | ||||
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ | ||||
|  | ||||
| Before Django 1.5, it was possible to create a streaming response by passing | ||||
| an iterator to :class:`~django.http.HttpResponse`. But this was unreliable: | ||||
| any middleware that accessed the :attr:`~django.http.HttpResponse.content` | ||||
| attribute would consume the iterator prematurely. | ||||
|  | ||||
| You can now explicitly generate a streaming response with the new | ||||
| :class:`~django.http.StreamingHttpResponse` class. This class exposes a | ||||
| :class:`~django.http.StreamingHttpResponse.streaming_content` attribute which | ||||
| is an iterator. | ||||
|  | ||||
| Since :class:`~django.http.StreamingHttpResponse` does not have a ``content`` | ||||
| attribute, middleware that needs access to the response content must test for | ||||
| streaming responses and behave accordingly. See :ref:`response-middleware` for | ||||
| more information. | ||||
|  | ||||
| ``{% verbatim %}`` template tag | ||||
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ | ||||
|  | ||||
| To make it easier to deal with javascript templates which collide with Django's | ||||
| syntax, you can now use the :ttag:`verbatim` block tag to avoid parsing the | ||||
| tag's content. | ||||
|  | ||||
| Retrieval of ``ContentType`` instances associated with proxy models | ||||
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ | ||||
|  | ||||
| The methods :meth:`ContentTypeManager.get_for_model() <django.contrib.contenttypes.models.ContentTypeManager.get_for_model()>` | ||||
| and :meth:`ContentTypeManager.get_for_models() <django.contrib.contenttypes.models.ContentTypeManager.get_for_models()>` | ||||
| have a new keyword argument – respectively ``for_concrete_model`` and ``for_concrete_models``. | ||||
| By passing ``False`` using this argument it is now possible to retrieve the | ||||
| :class:`ContentType <django.contrib.contenttypes.models.ContentType>` | ||||
| associated with proxy models. | ||||
|  | ||||
| New ``view`` variable in class-based views context | ||||
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ | ||||
|  | ||||
| In all :doc:`generic class-based views </topics/class-based-views/index>` | ||||
| (or any class-based view inheriting from ``ContextMixin``), the context dictionary | ||||
| contains a ``view`` variable that points to the ``View`` instance. | ||||
|  | ||||
| GeoDjango | ||||
| ~~~~~~~~~ | ||||
|  | ||||
| * :class:`~django.contrib.gis.geos.LineString` and | ||||
|   :class:`~django.contrib.gis.geos.MultiLineString` GEOS objects now support the | ||||
|   :meth:`~django.contrib.gis.geos.GEOSGeometry.interpolate()` and | ||||
|   :meth:`~django.contrib.gis.geos.GEOSGeometry.project()` methods | ||||
|   (so-called linear referencing). | ||||
|  | ||||
| * The ``wkb`` and ``hex`` properties of | ||||
|   :class:`~django.contrib.gis.geos.GEOSGeometry` objects preserve the Z | ||||
|   dimension. | ||||
|  | ||||
| * Support for PostGIS 2.0 has been added and support for GDAL < 1.5 has been | ||||
|   dropped. | ||||
|  | ||||
| Minor features | ||||
| ~~~~~~~~~~~~~~ | ||||
|  | ||||
| Django 1.5 also includes several smaller improvements worth noting: | ||||
|  | ||||
| * The template engine now interprets ``True``, ``False`` and ``None`` as the | ||||
|   corresponding Python objects. | ||||
|  | ||||
| * :mod:`django.utils.timezone` provides a helper for converting aware | ||||
|   datetimes between time zones. See :func:`~django.utils.timezone.localtime`. | ||||
|  | ||||
| * The generic views support OPTIONS requests. | ||||
|  | ||||
| * Management commands do not raise ``SystemExit`` any more when called by code | ||||
|   from :ref:`call_command <call-command>`. Any exception raised by the command | ||||
|   (mostly :ref:`CommandError <ref-command-exceptions>`) is propagated. | ||||
|  | ||||
| * The dumpdata management command outputs one row at a time, preventing | ||||
|   out-of-memory errors when dumping large datasets. | ||||
|  | ||||
| * In the localflavor for Canada, "pq" was added to the acceptable codes for | ||||
|   Quebec. It's an old abbreviation. | ||||
|  | ||||
| * The :ref:`receiver <connecting-receiver-functions>` decorator is now able to | ||||
|   connect to more than one signal by supplying a list of signals. | ||||
|  | ||||
| * In the admin, you can now filter users by groups which they are members of. | ||||
|  | ||||
| * :meth:`QuerySet.bulk_create() | ||||
|   <django.db.models.query.QuerySet.bulk_create>` now has a batch_size | ||||
|   argument. By default the batch_size is unlimited except for SQLite where | ||||
|   single batch is limited so that 999 parameters per query isn't exceeded. | ||||
|  | ||||
| * The :setting:`LOGIN_URL` and :setting:`LOGIN_REDIRECT_URL` settings now also | ||||
|   accept view function names and | ||||
|   :ref:`named URL patterns <naming-url-patterns>`. This allows you to reduce | ||||
|   configuration duplication. More information can be found in the | ||||
|   :func:`~django.contrib.auth.decorators.login_required` documentation. | ||||
|  | ||||
| * Django now provides a mod_wsgi :doc:`auth handler | ||||
|   </howto/deployment/wsgi/apache-auth>`. | ||||
|  | ||||
| * The :meth:`QuerySet.delete() <django.db.models.query.QuerySet.delete>` | ||||
|   and :meth:`Model.delete() <django.db.models.Model.delete()>` can now take | ||||
|   fast-path in some cases. The fast-path allows for less queries and less | ||||
|   objects fetched into memory. See :meth:`QuerySet.delete() | ||||
|   <django.db.models.query.QuerySet.delete>` for details. | ||||
|  | ||||
| * An instance of :class:`~django.core.urlresolvers.ResolverMatch` is stored on | ||||
|   the request as ``resolver_match``. | ||||
|  | ||||
| * By default, all logging messages reaching the ``django`` logger when | ||||
|   :setting:`DEBUG` is ``True`` are sent to the console (unless you redefine the | ||||
|   logger in your :setting:`LOGGING` setting). | ||||
|  | ||||
| * When using :class:`~django.template.RequestContext`, it is now possible to | ||||
|   look up permissions by using ``{% if 'someapp.someperm' in perms %}`` | ||||
|   in templates. | ||||
|  | ||||
| * It's not required any more to have ``404.html`` and ``500.html`` templates in | ||||
|   the root templates directory. Django will output some basic error messages for | ||||
|   both situations when those templates are not found. Of course, it's still | ||||
|   recommended as good practice to provide those templates in order to present | ||||
|   pretty error pages to the user. | ||||
|  | ||||
| * :mod:`django.contrib.auth` provides a new signal that is emitted | ||||
|   whenever a user fails to login successfully. See | ||||
|   :data:`~django.contrib.auth.signals.user_login_failed` | ||||
|  | ||||
| * The loaddata management command now supports an | ||||
|   :djadminopt:`--ignorenonexistent` option to ignore data for fields that no | ||||
|   longer exist. | ||||
|  | ||||
| * :meth:`~django.test.SimpleTestCase.assertXMLEqual` and | ||||
|   :meth:`~django.test.SimpleTestCase.assertXMLNotEqual` new assertions allow | ||||
|   you to test equality for XML content at a semantic level, without caring for | ||||
|   syntax differences (spaces, attribute order, etc.). | ||||
|  | ||||
| * RemoteUserMiddleware now forces logout when the REMOTE_USER header | ||||
|   disappears during the same browser session. | ||||
|  | ||||
| * The :ref:`cache-based session backend <cached-sessions-backend>` can store | ||||
|   session data in a non-default cache. | ||||
|  | ||||
| * Multi-column indexes can now be created on models. Read the | ||||
|   :attr:`~django.db.models.Options.index_together` documentation for more | ||||
|   information. | ||||
|  | ||||
| * During Django's logging configuration verbose Deprecation warnings are | ||||
|   enabled and warnings are captured into the logging system. Logged warnings | ||||
|   are routed through the ``console`` logging handler, which by default requires | ||||
|   :setting:`DEBUG` to be True for output to be generated. The result is that | ||||
|   DeprecationWarnings should be printed to the console in development | ||||
|   environments the way they have been in Python versions < 2.7. | ||||
|  | ||||
| * The API for :meth:`django.contrib.admin.ModelAdmin.message_user` method has | ||||
|   been modified to accept additional arguments adding capabilities similar to | ||||
|   :func:`django.contrib.messages.add_message`. This is useful for generating | ||||
|   error messages from admin actions. | ||||
|  | ||||
| * The admin's list filters can now be customized per-request thanks to the new | ||||
|   :meth:`django.contrib.admin.ModelAdmin.get_list_filter` method. | ||||
|  | ||||
| Backwards incompatible changes in 1.5 | ||||
| ===================================== | ||||
|  | ||||
| .. warning:: | ||||
|  | ||||
|     In addition to the changes outlined in this section, be sure to review the | ||||
|     :doc:`deprecation plan </internals/deprecation>` for any features that | ||||
|     have been removed. If you haven't updated your code within the | ||||
|     deprecation timeline for a given feature, its removal may appear as a | ||||
|     backwards incompatible change. | ||||
|  | ||||
| Context in year archive class-based views | ||||
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ | ||||
|  | ||||
| For consistency with the other date-based generic views, | ||||
| :class:`~django.views.generic.dates.YearArchiveView` now passes ``year`` in | ||||
| the context as a :class:`datetime.date` rather than a string.  If you are | ||||
| using ``{{ year }}`` in your templates, you must replace it with ``{{ | ||||
| year|date:"Y" }}``. | ||||
|  | ||||
| ``next_year`` and ``previous_year`` were also added in the context. They are | ||||
| calculated according to ``allow_empty`` and ``allow_future``. | ||||
|  | ||||
| Context in year and month archive class-based views | ||||
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ | ||||
|  | ||||
| :class:`~django.views.generic.dates.YearArchiveView` and | ||||
| :class:`~django.views.generic.dates.MonthArchiveView` were documented to | ||||
| provide a ``date_list`` sorted in ascending order in the context, like their | ||||
| function-based predecessors, but it actually was in descending order. In 1.5, | ||||
| the documented order was restored. You may want to add (or remove) the | ||||
| ``reversed`` keyword when you're iterating on ``date_list`` in a template:: | ||||
|  | ||||
|     {% for date in date_list reversed %} | ||||
|  | ||||
| :class:`~django.views.generic.dates.ArchiveIndexView` still provides a | ||||
| ``date_list`` in descending order. | ||||
|  | ||||
| Context in TemplateView | ||||
| ~~~~~~~~~~~~~~~~~~~~~~~ | ||||
|  | ||||
| For consistency with the design of the other generic views, | ||||
| :class:`~django.views.generic.base.TemplateView` no longer passes a ``params`` | ||||
| dictionary into the context, instead passing the variables from the URLconf | ||||
| directly into the context. | ||||
|  | ||||
| Non-form data in HTTP requests | ||||
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ | ||||
|  | ||||
| :attr:`request.POST <django.http.HttpRequest.POST>` will no longer include data | ||||
| posted via HTTP requests with non form-specific content-types in the header. | ||||
| In prior versions, data posted with content-types other than | ||||
| ``multipart/form-data`` or ``application/x-www-form-urlencoded`` would still | ||||
| end up represented in the :attr:`request.POST <django.http.HttpRequest.POST>` | ||||
| attribute. Developers wishing to access the raw POST data for these cases, | ||||
| should use the :attr:`request.body <django.http.HttpRequest.body>` attribute | ||||
| instead. | ||||
|  | ||||
| OPTIONS, PUT and DELETE requests in the test client | ||||
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ | ||||
|  | ||||
| Unlike GET and POST, these HTTP methods aren't implemented by web browsers. | ||||
| Rather, they're used in APIs, which transfer data in various formats such as | ||||
| JSON or XML. Since such requests may contain arbitrary data, Django doesn't | ||||
| attempt to decode their body. | ||||
|  | ||||
| However, the test client used to build a query string for OPTIONS and DELETE | ||||
| requests like for GET, and a request body for PUT requests like for POST. This | ||||
| encoding was arbitrary and inconsistent with Django's behavior when it | ||||
| receives the requests, so it was removed in Django 1.5. | ||||
|  | ||||
| If you were using the ``data`` parameter in an OPTIONS or a DELETE request, | ||||
| you must convert it to a query string and append it to the ``path`` parameter. | ||||
|  | ||||
| If you were using the ``data`` parameter in a PUT request without a | ||||
| ``content_type``, you must encode your data before passing it to the test | ||||
| client and set the ``content_type`` argument. | ||||
|  | ||||
| .. _simplejson-incompatibilities-beta-1: | ||||
|  | ||||
| System version of :mod:`simplejson` no longer used | ||||
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ | ||||
|  | ||||
| :ref:`As explained below <simplejson-deprecation-beta-1>`, Django 1.5 deprecates | ||||
| ``django.utils.simplejson`` in favor of Python 2.6's built-in :mod:`json` | ||||
| module. In theory, this change is harmless. Unfortunately, because of | ||||
| incompatibilities between versions of :mod:`simplejson`, it may trigger errors | ||||
| in some circumstances. | ||||
|  | ||||
| JSON-related features in Django 1.4 always used ``django.utils.simplejson``. | ||||
| This module was actually: | ||||
|  | ||||
| - A system version of :mod:`simplejson`, if one was available (ie. ``import | ||||
|   simplejson`` works), if it was more recent than Django's built-in copy or it | ||||
|   had the C speedups, or | ||||
| - The :mod:`json` module from the standard library, if it was available (ie. | ||||
|   Python 2.6 or greater), or | ||||
| - A built-in copy of version 2.0.7 of :mod:`simplejson`. | ||||
|  | ||||
| In Django 1.5, those features use Python's :mod:`json` module, which is based | ||||
| on version 2.0.9 of :mod:`simplejson`. | ||||
|  | ||||
| There are no known incompatibilities between Django's copy of version 2.0.7 and | ||||
| Python's copy of version 2.0.9. However, there are some incompatibilities | ||||
| between other versions of :mod:`simplejson`: | ||||
|  | ||||
| - While the :mod:`simplejson` API is documented as always returning unicode | ||||
|   strings, the optional C implementation can return a byte string. This was | ||||
|   fixed in Python 2.7. | ||||
| - :class:`simplejson.JSONEncoder` gained a ``namedtuple_as_object`` keyword | ||||
|   argument in version 2.2. | ||||
|  | ||||
| More information on these incompatibilities is available in `ticket #18023`_. | ||||
|  | ||||
| The net result is that, if you have installed :mod:`simplejson` and your code | ||||
| uses Django's serialization internals directly -- for instance | ||||
| ``django.core.serializers.json.DjangoJSONEncoder``, the switch from | ||||
| :mod:`simplejson` to :mod:`json` could break your code. (In general, changes to | ||||
| internals aren't documented; we're making an exception here.) | ||||
|  | ||||
| At this point, the maintainers of Django believe that using :mod:`json` from | ||||
| the standard library offers the strongest guarantee of backwards-compatibility. | ||||
| They recommend to use it from now on. | ||||
|  | ||||
| .. _ticket #18023: https://code.djangoproject.com/ticket/18023#comment:10 | ||||
|  | ||||
| String types of hasher method parameters | ||||
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ | ||||
|  | ||||
| If you have written a :ref:`custom password hasher <auth_password_storage>`, | ||||
| your ``encode()``, ``verify()`` or ``safe_summary()`` methods should accept | ||||
| Unicode parameters (``password``, ``salt`` or ``encoded``). If any of the | ||||
| hashing methods need byte strings, you can use the | ||||
| :func:`~django.utils.encoding.force_bytes` utility to encode the strings. | ||||
|  | ||||
| Validation of previous_page_number and next_page_number | ||||
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ | ||||
|  | ||||
| When using :doc:`object pagination </topics/pagination>`, | ||||
| the ``previous_page_number()`` and ``next_page_number()`` methods of the | ||||
| :class:`~django.core.paginator.Page` object did not check if the returned | ||||
| number was inside the existing page range. | ||||
| It does check it now and raises an :exc:`~django.core.paginator.InvalidPage` | ||||
| exception when the number is either too low or too high. | ||||
|  | ||||
| Behavior of autocommit database option on PostgreSQL changed | ||||
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ | ||||
|  | ||||
| PostgreSQL's autocommit option didn't work as advertised previously. It did | ||||
| work for single transaction block, but after the first block was left the | ||||
| autocommit behavior was never restored. This bug is now fixed in 1.5. While | ||||
| this is only a bug fix, it is worth checking your applications behavior if | ||||
| you are using PostgreSQL together with the autocommit option. | ||||
|  | ||||
| Session not saved on 500 responses | ||||
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ | ||||
|  | ||||
| Django's session middleware will skip saving the session data if the | ||||
| response's status code is 500. | ||||
|  | ||||
| Email checks on failed admin login | ||||
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ | ||||
|  | ||||
| Prior to Django 1.5, if you attempted to log into the admin interface and | ||||
| mistakenly used your email address instead of your username, the admin | ||||
| interface would provide a warning advising that your email address was | ||||
| not your username. In Django 1.5, the introduction of | ||||
| :ref:`custom User models <auth-custom-user>` has required the removal of this | ||||
| warning. This doesn't change the login behavior of the admin site; it only | ||||
| affects the warning message that is displayed under one particular mode of | ||||
| login failure. | ||||
|  | ||||
| Changes in tests execution | ||||
| ~~~~~~~~~~~~~~~~~~~~~~~~~~ | ||||
|  | ||||
| Some changes have been introduced in the execution of tests that might be | ||||
| backward-incompatible for some testing setups: | ||||
|  | ||||
| Database flushing in ``django.test.TransactionTestCase`` | ||||
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ | ||||
|  | ||||
| Previously, the test database was truncated *before* each test run in a | ||||
| :class:`~django.test.TransactionTestCase`. | ||||
|  | ||||
| In order to be able to run unit tests in any order and to make sure they are | ||||
| always isolated from each other, :class:`~django.test.TransactionTestCase` will | ||||
| now reset the database *after* each test run instead. | ||||
|  | ||||
| No more implicit DB sequences reset | ||||
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ | ||||
|  | ||||
| :class:`~django.test.TransactionTestCase` tests used to reset primary key | ||||
| sequences automatically together with the database flushing actions described | ||||
| above. | ||||
|  | ||||
| This has been changed so no sequences are implicitly reset. This can cause | ||||
| :class:`~django.test.TransactionTestCase` tests that depend on hard-coded | ||||
| primary key values to break. | ||||
|  | ||||
| The new :attr:`~django.test.TransactionTestCase.reset_sequences` attribute can | ||||
| be used to force the old behavior for :class:`~django.test.TransactionTestCase` | ||||
| that might need it. | ||||
|  | ||||
| Ordering of tests | ||||
| ^^^^^^^^^^^^^^^^^ | ||||
|  | ||||
| In order to make sure all ``TestCase`` code starts with a clean database, | ||||
| tests are now executed in the following order: | ||||
|  | ||||
| * First, all unittests (including :class:`unittest.TestCase`, | ||||
|   :class:`~django.test.SimpleTestCase`, :class:`~django.test.TestCase` and | ||||
|   :class:`~django.test.TransactionTestCase`) are run with no particular ordering | ||||
|   guaranteed nor enforced among them. | ||||
|  | ||||
| * Then any other tests (e.g. doctests) that may alter the database without | ||||
|   restoring it to its original state are run. | ||||
|  | ||||
| This should not cause any problems unless you have existing doctests which | ||||
| assume a :class:`~django.test.TransactionTestCase` executed earlier left some | ||||
| database state behind or unit tests that rely on some form of state being | ||||
| preserved after the execution of other tests. Such tests are already very | ||||
| fragile, and must now be changed to be able to run independently. | ||||
|  | ||||
| `cleaned_data` dictionary kept for invalid forms | ||||
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ | ||||
|  | ||||
| The :attr:`~django.forms.Form.cleaned_data` dictionary is now always present | ||||
| after form validation. When the form doesn't validate, it contains only the | ||||
| fields that passed validation. You should test the success of the validation | ||||
| with the :meth:`~django.forms.Form.is_valid()` method and not with the | ||||
| presence or absence of the :attr:`~django.forms.Form.cleaned_data` attribute | ||||
| on the form. | ||||
|  | ||||
| Behavior of :djadmin:`syncdb` with multiple databases | ||||
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ | ||||
|  | ||||
| :djadmin:`syncdb` now queries the database routers to determine if content | ||||
| types (when :mod:`~django.contrib.contenttypes` is enabled) and permissions | ||||
| (when :mod:`~django.contrib.auth` is enabled) should be created in the target | ||||
| database. Previously, it created them in the default database, even when | ||||
| another database was specified with the :djadminopt:`--database` option. | ||||
|  | ||||
| If you use :djadmin:`syncdb` on multiple databases, you should ensure that | ||||
| your routers allow synchronizing content types and permissions to only one of | ||||
| them. See the docs on the :ref:`behavior of contrib apps with multiple | ||||
| databases <contrib_app_multiple_databases>` for more information. | ||||
|  | ||||
| Miscellaneous | ||||
| ~~~~~~~~~~~~~ | ||||
|  | ||||
| * :class:`django.forms.ModelMultipleChoiceField` now returns an empty | ||||
|   ``QuerySet`` as the empty value instead of an empty list. | ||||
|  | ||||
| * :func:`~django.utils.http.int_to_base36` properly raises a | ||||
|   :exc:`TypeError` instead of :exc:`ValueError` for non-integer inputs. | ||||
|  | ||||
| * The ``slugify`` template filter is now available as a standard python | ||||
|   function at :func:`django.utils.text.slugify`. Similarly, ``remove_tags`` is | ||||
|   available at :func:`django.utils.html.remove_tags`. | ||||
|  | ||||
| * Uploaded files are no longer created as executable by default. If you need | ||||
|   them to be executable change :setting:`FILE_UPLOAD_PERMISSIONS` to your | ||||
|   needs. The new default value is ``0o666`` (octal) and the current umask value | ||||
|   is first masked out. | ||||
|  | ||||
| * The :class:`F expressions <django.db.models.F>` supported bitwise operators by | ||||
|   ``&`` and ``|``. These operators are now available using ``.bitand()`` and | ||||
|   ``.bitor()`` instead. The removal of ``&`` and ``|`` was done to be | ||||
|   consistent with :ref:`Q() expressions <complex-lookups-with-q>` and | ||||
|   ``QuerySet`` combining where the operators are used as boolean AND and OR | ||||
|   operators. | ||||
|  | ||||
| * In a ``filter()`` call, when :class:`F expressions <django.db.models.F>` | ||||
|   contained lookups spanning multi-valued relations, they didn't always reuse | ||||
|   the same relations as other lookups along the same chain. This was changed, | ||||
|   and now F() expressions will always use the same relations as other lookups | ||||
|   within the same ``filter()`` call. | ||||
|  | ||||
| * The :ttag:`csrf_token` template tag is no longer enclosed in a div. If you need | ||||
|   HTML validation against pre-HTML5 Strict DTDs, you should add a div around it | ||||
|   in your pages. | ||||
|  | ||||
| * The template tags library ``adminmedia``, which only contained the | ||||
|   deprecated template tag ``{% admin_media_prefix %}``, was removed. | ||||
|   Attempting to load it with ``{% load adminmedia %}`` will fail. If your | ||||
|   templates still contain that line you must remove it. | ||||
|  | ||||
| Features deprecated in 1.5 | ||||
| ========================== | ||||
|  | ||||
| .. _simplejson-deprecation-beta-1: | ||||
|  | ||||
| ``AUTH_PROFILE_MODULE`` | ||||
| ~~~~~~~~~~~~~~~~~~~~~~~ | ||||
|  | ||||
| With the introduction of :ref:`custom User models <auth-custom-user>`, there is | ||||
| no longer any need for a built-in mechanism to store user profile data. | ||||
|  | ||||
| You can still define user profiles models that have a one-to-one relation with | ||||
| the User model - in fact, for many applications needing to associate data with | ||||
| a User account, this will be an appropriate design pattern to follow. However, | ||||
| the ``AUTH_PROFILE_MODULE`` setting, and the | ||||
| ``django.contrib.auth.models.User.get_profile()`` method for accessing | ||||
| the user profile model, should not be used any longer. | ||||
|  | ||||
| Streaming behavior of :class:`~django.http.HttpResponse` | ||||
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ | ||||
|  | ||||
| Django 1.5 deprecates the ability to stream a response by passing an iterator | ||||
| to :class:`~django.http.HttpResponse`. If you rely on this behavior, switch to | ||||
| :class:`~django.http.StreamingHttpResponse`. See | ||||
| :ref:`explicit-streaming-responses-beta-1` above. | ||||
|  | ||||
| In Django 1.7 and above, the iterator will be consumed immediately by | ||||
| :class:`~django.http.HttpResponse`. | ||||
|  | ||||
| ``django.utils.simplejson`` | ||||
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~ | ||||
|  | ||||
| Since Django 1.5 drops support for Python 2.5, we can now rely on the | ||||
| :mod:`json` module being available in Python's standard library, so we've | ||||
| removed our own copy of :mod:`simplejson`. You should now import :mod:`json` | ||||
| instead of ``django.utils.simplejson``. | ||||
|  | ||||
| Unfortunately, this change might have unwanted side-effects, because of | ||||
| incompatibilities between versions of :mod:`simplejson` -- see the | ||||
| :ref:`backwards-incompatible changes <simplejson-incompatibilities-beta-1>` section. | ||||
| If you rely on features added to :mod:`simplejson` after it became Python's | ||||
| :mod:`json`, you should import :mod:`simplejson` explicitly. | ||||
|  | ||||
| ``django.utils.encoding.StrAndUnicode`` | ||||
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ | ||||
|  | ||||
| The ``django.utils.encoding.StrAndUnicode`` mix-in has been deprecated. | ||||
| Define a ``__str__`` method and apply the | ||||
| :func:`~django.utils.encoding.python_2_unicode_compatible` decorator instead. | ||||
|  | ||||
| ``django.utils.itercompat.product`` | ||||
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ | ||||
|  | ||||
| The ``django.utils.itercompat.product`` function has been deprecated. Use | ||||
| the built-in :func:`itertools.product` instead. | ||||
|  | ||||
| ``django.utils.markup`` | ||||
| ~~~~~~~~~~~~~~~~~~~~~~~ | ||||
|  | ||||
| The markup contrib module has been deprecated and will follow an accelerated | ||||
| deprecation schedule. Direct use of python markup libraries or 3rd party tag | ||||
| libraries is preferred to Django maintaining this functionality in the | ||||
| framework. | ||||
|  | ||||
| ``cleanup`` management command | ||||
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ | ||||
|  | ||||
| The ``cleanup`` management command has been deprecated and replaced by | ||||
| :djadmin:`clearsessions`. | ||||
|  | ||||
| ``daily_cleanup.py`` script | ||||
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~ | ||||
|  | ||||
| The undocumented ``daily_cleanup.py`` script has been deprecated. Use the | ||||
| :djadmin:`clearsessions` management command instead. | ||||
|  | ||||
| ``depth`` keyword argument in ``select_related`` | ||||
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ | ||||
|  | ||||
| The ``depth`` keyword argument in | ||||
| :meth:`~django.db.models.query.QuerySet.select_related` has been deprecated. | ||||
| You should use field names instead. | ||||
| @@ -156,30 +156,7 @@ added to all affected release series. | ||||
| Additionally, :doc:`an archive of disclosed security issues | ||||
| </releases/security>` is maintained. | ||||
|  | ||||
| Development releases | ||||
| ==================== | ||||
|  | ||||
| These notes are retained for historical purposes. If you are upgrading | ||||
| between formal Django releases, you don't need to worry about these | ||||
| notes. | ||||
|  | ||||
| .. toctree:: | ||||
|    :maxdepth: 1 | ||||
|    :hidden: | ||||
|  | ||||
|    security | ||||
|    1.5-beta-1 | ||||
|    1.5-alpha-1 | ||||
|    1.4-beta-1 | ||||
|    1.4-alpha-1 | ||||
|    1.3-beta-1 | ||||
|    1.3-alpha-1 | ||||
|    1.2-rc-1 | ||||
|    1.2-beta-1 | ||||
|    1.2-alpha-1 | ||||
|    1.1-rc-1 | ||||
|    1.1-beta-1 | ||||
|    1.1-alpha-1 | ||||
|    1.0-beta-2 | ||||
|    1.0-beta | ||||
|    1.0-alpha-2 | ||||
|    1.0-alpha-1 | ||||
|   | ||||
		Reference in New Issue
	
	Block a user