Mercurial > public > pelican-blog
comparison content/Coding/027-upgrading-django1.6.rst @ 4:7ce6393e6d30
Adding converted blog posts from old blog.
author | Brian Neal <bgneal@gmail.com> |
---|---|
date | Thu, 30 Jan 2014 21:45:03 -0600 (2014-01-31) |
parents | |
children | 49bebfa6f9d3 |
comparison
equal
deleted
inserted
replaced
3:c3115da3ff73 | 4:7ce6393e6d30 |
---|---|
1 Upgrading to Django 1.6 | |
2 ####################### | |
3 | |
4 :date: 2013-12-29 18:00 | |
5 :tags: Django | |
6 :slug: upgrading-to-django-1.6 | |
7 :author: Brian Neal | |
8 | |
9 Getting started | |
10 =============== | |
11 | |
12 `Django`_ 1.6 came out recently, which was soon followed by 1.6.1, and it looks | |
13 like 1.6.2 is on the way. I finally got around to upgrading two of my largest | |
14 sites. I thought I would make a list of what I changed at a high level for my | |
15 own reference. Perhaps someone else may find it useful as well. | |
16 | |
17 In any event, I highly recommend you read the excellent `release notes`_ and | |
18 `deprecation timeline`_. The changes in 1.6 didn't seem groundbreaking, but | |
19 they were numerous. I spent a lot of time reading through the notes and trying | |
20 to decide if the issues affected me or not. | |
21 | |
22 I recommend you run with warnings turned on:: | |
23 | |
24 $ python -Wall manage.py runserver | |
25 | |
26 This will help you flag down issues in your code. If you aren't sure where | |
27 a warning is coming from, you can turn warnings into exceptions and get | |
28 a traceback (see the Python docs on the warnings_ library). Another trick is to | |
29 put a pdb_ breakpoint in the Django code before or after the warning, then you | |
30 can examine the call stack with the ``w`` command. | |
31 | |
32 Upgrade Issues | |
33 ============== | |
34 | |
35 Here are the issues that I ran into. Of course you may have a very different | |
36 experience depending on what features of Django you used and the details of | |
37 your site. | |
38 | |
39 #. The location of the ``XViewMiddleware`` changed. I had to update my | |
40 ``MIDDLEWARE_CLASSES`` setting as a result. | |
41 #. Various ``get_query_set`` to ``get_queryset`` changes. The Django developers | |
42 have ironed out some naming inconsistencies in method names on both model | |
43 managers and ``ModelAdmin`` classes. | |
44 #. In template / form processing, the ``label_tag`` now includes the | |
45 ``label_suffix``. I noticed this when I saw that I had two colons on a form | |
46 field's label. | |
47 #. One very nice change that I am please to see is that Django now does test | |
48 discovery just like the unittest_ module in the standard library. To take | |
49 advantage of this I renamed all my test modules from ``view_tests.py`` to | |
50 ``test_views.py``, for example. This also let me get rid of ``import`` | |
51 statements in various ``__init__.py`` files in test subdirectories. In other | |
52 words, you no longer have to have silly lines like | |
53 ``from view_tests import *`` in your test packages' ``__init__.py`` files. | |
54 #. Django now supports database connection persistence. To take advantage of | |
55 this you need to set the CONN_MAX_AGE_ setting to a non-zero value. | |
56 #. The ``CACHE_MIDDLEWARE_ANONYMOUS_ONLY`` setting is now deprecated and can be | |
57 removed. For various reasons explained in the notes this never really worked | |
58 right anyway. | |
59 #. Updated to version 1.0 of the django-debug-toolbar_. The version I was using | |
60 would not work in Django 1.6. It is so good to see that this project is | |
61 being actively maintained again. There are several new panels and neat | |
62 features, check it out! | |
63 #. You now get a warning if you have a ``ModelForm`` without an ``exclude`` or | |
64 ``fields`` meta option. This is rather nice as I have been bit by this in | |
65 the past when a form suddenly started showing a newly added field that it | |
66 should not have. I added a ``fields`` option to a ``ModelForm`` as a result. | |
67 Unfortunately some third party applications I am using have this problem as | |
68 well. | |
69 #. The ``cycle`` tag has new XSS_ protection. To make use of it now, you have | |
70 to add a ``{% load cycle from future %}`` tag into your templates. | |
71 #. The ``django.contrib.auth`` password reset function is now using base 64 encoding of the | |
72 ``User`` primary key. The details are `here <https://docs.djangoproject.com/en/1.6/releases/1.6/#django-contrib-auth-password-reset-uses-base-64-encoding-of-user-pk>`_. This affected me | |
73 because I am using a custom password reset URL, and thus I needed to update | |
74 my URL pattern for both the new parameter name and the regular expression | |
75 for base 64. I missed this originally and I started getting 404's on my | |
76 password reset confirmation URLs. And yes, this is something I should have a | |
77 test for! | |
78 | |
79 What I didn't do | |
80 ================ | |
81 | |
82 Many of the warnings that I got came from third party modules that I have not | |
83 updated in a long time, including Celery_ and Haystack_. I am going to have to | |
84 schedule some time to update to the latest versions of these apps. Hopefully | |
85 the warnings will be fixed in the newer versions, but if not I can write | |
86 tickets or possibly submit patches / pull requests. This is the price of | |
87 progress I suppose. | |
88 | |
89 I also use a couple of smaller third party applications that seem to be no | |
90 longer maintained. These apps are now generating some warnings. I'll have to | |
91 fork them and fix these myself. Luckily these projects are on GitHub so this | |
92 should not be a problem. | |
93 | |
94 Finally I am still facing the problem of what to do about the deprecation of | |
95 the ``AUTH_PROFILE_MODULE`` and the ``get_profile`` method. This will be | |
96 removed in Django 1.7. I've been doing some more reading about this and I'm | |
97 less scared about this than I used to. I'll probably just change my profile | |
98 model to have a one-to-one relationship with the provided ``User`` model. I'll | |
99 have to do some more researching and thinking about this before Django 1.7. | |
100 | |
101 | |
102 Conclusion | |
103 ========== | |
104 | |
105 Once again the upgrade process went smoother and quicker than I thought thanks | |
106 to the excellent release notes and the Django team's use of Python warnings to | |
107 flag deprecated features. | |
108 | |
109 | |
110 .. _Django: https://www.djangoproject.com/ | |
111 .. _release notes: https://docs.djangoproject.com/en/1.6/releases/1.6/ | |
112 .. _deprecation timeline: https://docs.djangoproject.com/en/1.6/internals/deprecation/ | |
113 .. _warnings: http://docs.python.org/library/warnings.html | |
114 .. _pdb: http://docs.python.org/library/pdb.html | |
115 .. _unittest: http://docs.python.org/2/library/unittest.html | |
116 .. _CONN_MAX_AGE: https://docs.djangoproject.com/en/1.6/ref/settings/#conn-max-age | |
117 .. _XSS: http://en.wikipedia.org/wiki/Cross-site_scripting | |
118 .. _configurable user model: https://docs.djangoproject.com/en/1.5/topics/auth/customizing/#auth-custom-user | |
119 .. _django-debug-toolbar: https://pypi.python.org/pypi/django-debug-toolbar | |
120 .. _Celery: http://www.celeryproject.org/ | |
121 .. _Haystack: http://haystacksearch.org/ |