Fixed #17965 -- Definitely dropped support for Python 2.5. Thanks jonash for the initial patch and Aymeric Augustin for the review.
git-svn-id: http://code.djangoproject.com/svn/django/trunk@17834 bcc190cf-cafb-0310-a4f2-bffc1f526a37
This commit is contained in:
parent
27322df995
commit
23d3459761
|
@ -407,10 +407,7 @@ class SessionMiddlewareTests(unittest.TestCase):
|
||||||
|
|
||||||
# Handle the response through the middleware
|
# Handle the response through the middleware
|
||||||
response = middleware.process_response(request, response)
|
response = middleware.process_response(request, response)
|
||||||
# If it isn't in the cookie, that's fine (Python 2.5)
|
self.assertFalse(response.cookies[settings.SESSION_COOKIE_NAME]['httponly'])
|
||||||
if 'httponly' in settings.SESSION_COOKIE_NAME:
|
|
||||||
self.assertFalse(
|
|
||||||
response.cookies[settings.SESSION_COOKIE_NAME]['httponly'])
|
|
||||||
|
|
||||||
self.assertNotIn('httponly',
|
self.assertNotIn('httponly',
|
||||||
str(response.cookies[settings.SESSION_COOKIE_NAME]))
|
str(response.cookies[settings.SESSION_COOKIE_NAME]))
|
||||||
|
|
|
@ -25,12 +25,7 @@ try:
|
||||||
# The mod_python version is more efficient, so try importing it first.
|
# The mod_python version is more efficient, so try importing it first.
|
||||||
from mod_python.util import parse_qsl
|
from mod_python.util import parse_qsl
|
||||||
except ImportError:
|
except ImportError:
|
||||||
try:
|
from urlparse import parse_qsl
|
||||||
# Python 2.6 and greater
|
|
||||||
from urlparse import parse_qsl
|
|
||||||
except ImportError:
|
|
||||||
# Python 2.5. Works on Python 2.6 but raises PendingDeprecationWarning
|
|
||||||
from cgi import parse_qsl
|
|
||||||
|
|
||||||
__all__ = [
|
__all__ = [
|
||||||
'get_cache', 'cache', 'DEFAULT_CACHE_ALIAS'
|
'get_cache', 'cache', 'DEFAULT_CACHE_ALIAS'
|
||||||
|
|
|
@ -12,7 +12,7 @@ from django.core.management.color import no_style
|
||||||
from django.db import (connections, router, transaction, DEFAULT_DB_ALIAS,
|
from django.db import (connections, router, transaction, DEFAULT_DB_ALIAS,
|
||||||
IntegrityError, DatabaseError)
|
IntegrityError, DatabaseError)
|
||||||
from django.db.models import get_apps
|
from django.db.models import get_apps
|
||||||
from django.utils.itercompat import product
|
from itertools import product
|
||||||
|
|
||||||
try:
|
try:
|
||||||
import bz2
|
import bz2
|
||||||
|
|
|
@ -18,17 +18,9 @@ try:
|
||||||
# The mod_python version is more efficient, so try importing it first.
|
# The mod_python version is more efficient, so try importing it first.
|
||||||
from mod_python.util import parse_qsl
|
from mod_python.util import parse_qsl
|
||||||
except ImportError:
|
except ImportError:
|
||||||
try:
|
from urlparse import parse_qsl
|
||||||
# Python 2.6 and greater
|
|
||||||
from urlparse import parse_qsl
|
|
||||||
except ImportError:
|
|
||||||
# Python 2.5. Works on Python 2.6 but raises PendingDeprecationWarning
|
|
||||||
from cgi import parse_qsl
|
|
||||||
|
|
||||||
import Cookie
|
import Cookie
|
||||||
# httponly support exists in Python 2.6's Cookie library,
|
|
||||||
# but not in Python 2.5.
|
|
||||||
_morsel_supports_httponly = 'httponly' in Cookie.Morsel._reserved
|
|
||||||
# Some versions of Python 2.7 and later won't need this encoding bug fix:
|
# Some versions of Python 2.7 and later won't need this encoding bug fix:
|
||||||
_cookie_encodes_correctly = Cookie.SimpleCookie().value_encode(';') == (';', '"\\073"')
|
_cookie_encodes_correctly = Cookie.SimpleCookie().value_encode(';') == (';', '"\\073"')
|
||||||
# See ticket #13007, http://bugs.python.org/issue2193 and http://trac.edgewall.org/ticket/2256
|
# See ticket #13007, http://bugs.python.org/issue2193 and http://trac.edgewall.org/ticket/2256
|
||||||
|
@ -39,28 +31,10 @@ try:
|
||||||
except Cookie.CookieError:
|
except Cookie.CookieError:
|
||||||
_cookie_allows_colon_in_names = False
|
_cookie_allows_colon_in_names = False
|
||||||
|
|
||||||
if _morsel_supports_httponly and _cookie_encodes_correctly and _cookie_allows_colon_in_names:
|
if _cookie_encodes_correctly and _cookie_allows_colon_in_names:
|
||||||
SimpleCookie = Cookie.SimpleCookie
|
SimpleCookie = Cookie.SimpleCookie
|
||||||
else:
|
else:
|
||||||
if not _morsel_supports_httponly:
|
Morsel = Cookie.Morsel
|
||||||
class Morsel(Cookie.Morsel):
|
|
||||||
def __setitem__(self, K, V):
|
|
||||||
K = K.lower()
|
|
||||||
if K == "httponly":
|
|
||||||
if V:
|
|
||||||
# The superclass rejects httponly as a key,
|
|
||||||
# so we jump to the grandparent.
|
|
||||||
super(Cookie.Morsel, self).__setitem__(K, V)
|
|
||||||
else:
|
|
||||||
super(Morsel, self).__setitem__(K, V)
|
|
||||||
|
|
||||||
def OutputString(self, attrs=None):
|
|
||||||
output = super(Morsel, self).OutputString(attrs)
|
|
||||||
if "httponly" in self:
|
|
||||||
output += "; httponly"
|
|
||||||
return output
|
|
||||||
else:
|
|
||||||
Morsel = Cookie.Morsel
|
|
||||||
|
|
||||||
class SimpleCookie(Cookie.SimpleCookie):
|
class SimpleCookie(Cookie.SimpleCookie):
|
||||||
if not _cookie_encodes_correctly:
|
if not _cookie_encodes_correctly:
|
||||||
|
@ -88,7 +62,7 @@ else:
|
||||||
|
|
||||||
return val, encoded
|
return val, encoded
|
||||||
|
|
||||||
if not _cookie_allows_colon_in_names or not _morsel_supports_httponly:
|
if not _cookie_allows_colon_in_names:
|
||||||
def load(self, rawdata):
|
def load(self, rawdata):
|
||||||
self.bad_cookies = set()
|
self.bad_cookies = set()
|
||||||
super(SimpleCookie, self).load(rawdata)
|
super(SimpleCookie, self).load(rawdata)
|
||||||
|
|
|
@ -8,23 +8,6 @@ import __builtin__
|
||||||
import itertools
|
import itertools
|
||||||
import warnings
|
import warnings
|
||||||
|
|
||||||
# Fallback for Python 2.5
|
|
||||||
def product(*args, **kwds):
|
|
||||||
"""
|
|
||||||
Taken from http://docs.python.org/library/itertools.html#itertools.product
|
|
||||||
"""
|
|
||||||
# product('ABCD', 'xy') --> Ax Ay Bx By Cx Cy Dx Dy
|
|
||||||
# product(range(2), repeat=3) --> 000 001 010 011 100 101 110 111
|
|
||||||
pools = map(tuple, args) * kwds.get('repeat', 1)
|
|
||||||
result = [[]]
|
|
||||||
for pool in pools:
|
|
||||||
result = [x+[y] for x in result for y in pool]
|
|
||||||
for prod in result:
|
|
||||||
yield tuple(prod)
|
|
||||||
|
|
||||||
if hasattr(itertools, 'product'):
|
|
||||||
product = itertools.product
|
|
||||||
|
|
||||||
def is_iterable(x):
|
def is_iterable(x):
|
||||||
"A implementation independent way of checking for iterables"
|
"A implementation independent way of checking for iterables"
|
||||||
try:
|
try:
|
||||||
|
@ -34,6 +17,13 @@ def is_iterable(x):
|
||||||
else:
|
else:
|
||||||
return True
|
return True
|
||||||
|
|
||||||
|
def product(*args, **kwds):
|
||||||
|
# PendingDeprecationWarning in 1.5, remove this comment when the Deprecations
|
||||||
|
# will have been advanced for 1.5
|
||||||
|
warnings.warn("django.utils.itercompat.product is deprecated; use the native version instead",
|
||||||
|
PendingDeprecationWarning)
|
||||||
|
return itertools.product(*args, **kwds)
|
||||||
|
|
||||||
def all(iterable):
|
def all(iterable):
|
||||||
warnings.warn("django.utils.itercompat.all is deprecated; use the native version instead",
|
warnings.warn("django.utils.itercompat.all is deprecated; use the native version instead",
|
||||||
PendingDeprecationWarning)
|
PendingDeprecationWarning)
|
||||||
|
|
|
@ -16,9 +16,8 @@ How do I get started?
|
||||||
What are Django's prerequisites?
|
What are Django's prerequisites?
|
||||||
--------------------------------
|
--------------------------------
|
||||||
|
|
||||||
Django requires Python_, specifically any version of Python from 2.5
|
Django requires Python_, specifically Python 2.6 or 2.7.
|
||||||
through 2.7. No other Python libraries are required for basic Django
|
No other Python libraries are required for basic Django usage.
|
||||||
usage.
|
|
||||||
|
|
||||||
For a development environment -- if you just want to experiment with Django --
|
For a development environment -- if you just want to experiment with Django --
|
||||||
you don't need to have a separate Web server installed; Django comes with its
|
you don't need to have a separate Web server installed; Django comes with its
|
||||||
|
@ -39,15 +38,14 @@ PostgreSQL fans, and MySQL_, `SQLite 3`_, and Oracle_ are also supported.
|
||||||
.. _`SQLite 3`: http://www.sqlite.org/
|
.. _`SQLite 3`: http://www.sqlite.org/
|
||||||
.. _Oracle: http://www.oracle.com/
|
.. _Oracle: http://www.oracle.com/
|
||||||
|
|
||||||
Do I lose anything by using Python 2.5 versus newer Python versions, such as Python 2.6 or 2.7?
|
Do I lose anything by using Python 2.6 versus newer Python versions, such as Python 2.7?
|
||||||
-----------------------------------------------------------------------------------------------
|
----------------------------------------------------------------------------------------
|
||||||
|
|
||||||
Not in the core framework. Currently, Django itself officially supports any
|
Not in the core framework. Currently, Django itself officially supports
|
||||||
version of Python from 2.5 through 2.7, inclusive. However, newer versions of
|
Python 2.6 and 2.7. However, newer versions of
|
||||||
Python are often faster, have more features, and are better supported. If you
|
Python are often faster, have more features, and are better supported. If you
|
||||||
use a newer version of Python you will also have access to some APIs that
|
use a newer version of Python you will also have access to some APIs that
|
||||||
aren't available under older versions of Python. For example, since Python 2.6,
|
aren't available under older versions of Python.
|
||||||
you can use the advanced string formatting described in :pep:`3101`.
|
|
||||||
|
|
||||||
Third-party applications for use with Django are, of course, free to set their
|
Third-party applications for use with Django are, of course, free to set their
|
||||||
own version requirements.
|
own version requirements.
|
||||||
|
@ -58,7 +56,7 @@ versions as part of a migration which will end with Django running on Python 3
|
||||||
|
|
||||||
All else being equal, we recommend that you use the latest 2.x release
|
All else being equal, we recommend that you use the latest 2.x release
|
||||||
(currently Python 2.7). This will let you take advantage of the numerous
|
(currently Python 2.7). This will let you take advantage of the numerous
|
||||||
improvements and optimizations to the Python language since version 2.5, and
|
improvements and optimizations to the Python language since version 2.6, and
|
||||||
will help ease the process of dropping support for older Python versions on
|
will help ease the process of dropping support for older Python versions on
|
||||||
the road to Python 3.
|
the road to Python 3.
|
||||||
|
|
||||||
|
|
|
@ -4,6 +4,12 @@ Running Django on Jython
|
||||||
|
|
||||||
.. index:: Jython, Java, JVM
|
.. index:: Jython, Java, JVM
|
||||||
|
|
||||||
|
.. admonition::
|
||||||
|
|
||||||
|
Django 1.5 has dropped support for Python 2.5. Until Jython provides a new
|
||||||
|
version that supports 2.6, Django 1.5 is no more compatible with Jython.
|
||||||
|
Please use Django 1.4 if you want to use Django over Jython.
|
||||||
|
|
||||||
Jython_ is an implementation of Python that runs on the Java platform (JVM).
|
Jython_ is an implementation of Python that runs on the Java platform (JVM).
|
||||||
Django runs cleanly on Jython version 2.5 or later, which means you can deploy
|
Django runs cleanly on Jython version 2.5 or later, which means you can deploy
|
||||||
Django on any Java platform.
|
Django on any Java platform.
|
||||||
|
|
|
@ -7,20 +7,6 @@ in a backward incompatible way, following their deprecation, as per the
|
||||||
:ref:`deprecation policy <internal-release-deprecation-policy>`. More details
|
:ref:`deprecation policy <internal-release-deprecation-policy>`. More details
|
||||||
about each item can often be found in the release notes of two versions prior.
|
about each item can often be found in the release notes of two versions prior.
|
||||||
|
|
||||||
1.3
|
|
||||||
---
|
|
||||||
|
|
||||||
See the :doc:`Django 1.1 release notes</releases/1.1>` for more details on
|
|
||||||
these changes.
|
|
||||||
|
|
||||||
* ``AdminSite.root()``. This method of hooking up the admin URLs will be
|
|
||||||
removed in favor of including ``admin.site.urls``.
|
|
||||||
|
|
||||||
* Authentication backends need to define the boolean attributes
|
|
||||||
``supports_object_permissions`` and ``supports_anonymous_user`` until
|
|
||||||
version 1.4, at which point it will be assumed that all backends will
|
|
||||||
support these options.
|
|
||||||
|
|
||||||
1.4
|
1.4
|
||||||
---
|
---
|
||||||
|
|
||||||
|
@ -276,6 +262,15 @@ these changes.
|
||||||
in 1.4. The backward compatibility will be removed --
|
in 1.4. The backward compatibility will be removed --
|
||||||
``HttpRequest.raw_post_data`` will no longer work.
|
``HttpRequest.raw_post_data`` will no longer work.
|
||||||
|
|
||||||
|
1.7
|
||||||
|
---
|
||||||
|
|
||||||
|
See the :doc:`Django 1.5 release notes</releases/1.5>` for more details on
|
||||||
|
these changes.
|
||||||
|
|
||||||
|
* The function ``django.utils.itercompat.product`` will be removed. The Python
|
||||||
|
builtin version should be used instead.
|
||||||
|
|
||||||
2.0
|
2.0
|
||||||
---
|
---
|
||||||
|
|
||||||
|
|
|
@ -10,7 +10,7 @@ Install Python
|
||||||
--------------
|
--------------
|
||||||
|
|
||||||
Being a Python Web framework, Django requires Python. It works with any Python
|
Being a Python Web framework, Django requires Python. It works with any Python
|
||||||
version from 2.5 to 2.7 (due to backwards incompatibilities in Python 3.0,
|
version from 2.6 to 2.7 (due to backwards incompatibilities in Python 3.0,
|
||||||
Django does not currently work with Python 3.0; see :doc:`the Django FAQ
|
Django does not currently work with Python 3.0; see :doc:`the Django FAQ
|
||||||
</faq/install>` for more information on supported Python versions and the 3.0
|
</faq/install>` for more information on supported Python versions and the 3.0
|
||||||
transition), these versions of Python include a lightweight database called
|
transition), these versions of Python include a lightweight database called
|
||||||
|
@ -31,15 +31,15 @@ probably already have it installed.
|
||||||
You can verify that Python is installed by typing ``python`` from your shell;
|
You can verify that Python is installed by typing ``python`` from your shell;
|
||||||
you should see something like::
|
you should see something like::
|
||||||
|
|
||||||
Python 2.5.1 (r251:54863, Jan 17 2008, 19:35:17)
|
Python 2.6.6 (r266:84292, Dec 26 2010, 22:31:48)
|
||||||
[GCC 4.0.1 (Apple Inc. build 5465)] on darwin
|
[GCC 4.4.5] on linux2
|
||||||
Type "help", "copyright", "credits" or "license" for more information.
|
Type "help", "copyright", "credits" or "license" for more information.
|
||||||
>>>
|
>>>
|
||||||
|
|
||||||
Set up a database
|
Set up a database
|
||||||
-----------------
|
-----------------
|
||||||
|
|
||||||
If you installed Python 2.5 or later, you can skip this step for now.
|
If you installed Python 2.6 or later, you can skip this step for now.
|
||||||
|
|
||||||
If not, or if you'd like to work with a "large" database engine like PostgreSQL,
|
If not, or if you'd like to work with a "large" database engine like PostgreSQL,
|
||||||
MySQL, or Oracle, consult the :ref:`database installation information
|
MySQL, or Oracle, consult the :ref:`database installation information
|
||||||
|
|
|
@ -221,9 +221,8 @@ your database connection settings.
|
||||||
|
|
||||||
If you're new to databases, we recommend simply using SQLite by setting
|
If you're new to databases, we recommend simply using SQLite by setting
|
||||||
:setting:`ENGINE` to ``'django.db.backends.sqlite3'`` and :setting:`NAME` to
|
:setting:`ENGINE` to ``'django.db.backends.sqlite3'`` and :setting:`NAME` to
|
||||||
the place where you'd like to store the database. SQLite is included as part
|
the place where you'd like to store the database. SQLite is included in Python,
|
||||||
of Python 2.5 and later, so you won't need to install anything else to support
|
so you won't need to install anything else to support your database.
|
||||||
your database.
|
|
||||||
|
|
||||||
.. note::
|
.. note::
|
||||||
|
|
||||||
|
|
|
@ -37,8 +37,8 @@ Example::
|
||||||
WSGIProcessGroup geodjango
|
WSGIProcessGroup geodjango
|
||||||
WSGIScriptAlias / /home/geo/geodjango/world.wsgi
|
WSGIScriptAlias / /home/geo/geodjango/world.wsgi
|
||||||
|
|
||||||
Alias /media/ "/usr/lib/python2.5/site-packages/django/contrib/admin/media/"
|
Alias /media/ "/usr/lib/python2.6/site-packages/django/contrib/admin/media/"
|
||||||
<Directory "/usr/lib/python2.5/site-packages/django/contrib/admin/media/">
|
<Directory "/usr/lib/python2.6/site-packages/django/contrib/admin/media/">
|
||||||
Order allow,deny
|
Order allow,deny
|
||||||
Options Indexes
|
Options Indexes
|
||||||
Allow from all
|
Allow from all
|
||||||
|
@ -77,7 +77,7 @@ Example::
|
||||||
PythonPath "['/var/www/apps'] + sys.path"
|
PythonPath "['/var/www/apps'] + sys.path"
|
||||||
</Location>
|
</Location>
|
||||||
|
|
||||||
Alias /media/ "/usr/lib/python2.5/site-packages/django/contrib/admin/media/"
|
Alias /media/ "/usr/lib/python2.6/site-packages/django/contrib/admin/media/"
|
||||||
<Location "/media">
|
<Location "/media">
|
||||||
SetHandler None
|
SetHandler None
|
||||||
</Location>
|
</Location>
|
||||||
|
|
|
@ -461,17 +461,6 @@ SQLite 3.3.6 was released in April 2006, so most current binary distributions
|
||||||
for different platforms include newer version of SQLite usable from Python
|
for different platforms include newer version of SQLite usable from Python
|
||||||
through either the ``pysqlite2`` or the ``sqlite3`` modules.
|
through either the ``pysqlite2`` or the ``sqlite3`` modules.
|
||||||
|
|
||||||
However, some platform/Python version combinations include older versions of
|
|
||||||
SQLite (e.g. the official binary distribution of Python 2.5 for Windows, 2.5.4
|
|
||||||
as of this writing, includes SQLite 3.3.4). There are (as of Django 1.1) even
|
|
||||||
some tests in the Django test suite that will fail when run under this setup.
|
|
||||||
|
|
||||||
As described :ref:`below<using-newer-versions-of-pysqlite>`, this can be solved
|
|
||||||
by downloading and installing a newer version of ``pysqlite2``
|
|
||||||
(``pysqlite-2.x.x.win32-py2.5.exe`` in the described case) that includes and
|
|
||||||
uses a newer version of SQLite. Python 2.6 for Windows ships with a version of
|
|
||||||
SQLite that is not affected by these issues.
|
|
||||||
|
|
||||||
Version 3.5.9
|
Version 3.5.9
|
||||||
-------------
|
-------------
|
||||||
|
|
||||||
|
|
|
@ -39,3 +39,8 @@ Backwards incompatible changes in 1.5
|
||||||
Features deprecated in 1.5
|
Features deprecated in 1.5
|
||||||
==========================
|
==========================
|
||||||
|
|
||||||
|
itercompat.product
|
||||||
|
~~~~~~~~~~~~~~~~~~
|
||||||
|
|
||||||
|
The :func:`~django.utils.itercompat.product` function has been deprecated. Use
|
||||||
|
the builtin `itertools.product` instead.
|
||||||
|
|
|
@ -93,9 +93,7 @@ These functions, described in detail below, can be used in two different ways:
|
||||||
# this code executes inside a transaction
|
# this code executes inside a transaction
|
||||||
# ...
|
# ...
|
||||||
|
|
||||||
Both techniques work with all supported version of Python. However, in Python
|
Both techniques work with all supported version of Python.
|
||||||
2.5, you must add ``from __future__ import with_statement`` at the beginning
|
|
||||||
of your module if you are using the ``with`` statement.
|
|
||||||
|
|
||||||
.. _decorator: http://docs.python.org/glossary.html#term-decorator
|
.. _decorator: http://docs.python.org/glossary.html#term-decorator
|
||||||
.. _context manager: http://docs.python.org/glossary.html#term-context-manager
|
.. _context manager: http://docs.python.org/glossary.html#term-context-manager
|
||||||
|
|
|
@ -9,7 +9,7 @@ Install Python
|
||||||
|
|
||||||
Being a Python Web framework, Django requires Python.
|
Being a Python Web framework, Django requires Python.
|
||||||
|
|
||||||
It works with any Python version from 2.5 to 2.7 (due to backwards
|
It works with any Python version from 2.6 to 2.7 (due to backwards
|
||||||
incompatibilities in Python 3.0, Django does not currently work with
|
incompatibilities in Python 3.0, Django does not currently work with
|
||||||
Python 3.0; see :doc:`the Django FAQ </faq/install>` for more
|
Python 3.0; see :doc:`the Django FAQ </faq/install>` for more
|
||||||
information on supported Python versions and the 3.0 transition).
|
information on supported Python versions and the 3.0 transition).
|
||||||
|
|
|
@ -1591,10 +1591,6 @@ your test suite.
|
||||||
|
|
||||||
You can use this as a context manager, like this::
|
You can use this as a context manager, like this::
|
||||||
|
|
||||||
# This is necessary in Python 2.5 to enable the with statement.
|
|
||||||
# In 2.6 and up, it's not necessary.
|
|
||||||
from __future__ import with_statement
|
|
||||||
|
|
||||||
with self.assertTemplateUsed('index.html'):
|
with self.assertTemplateUsed('index.html'):
|
||||||
render_to_string('index.html')
|
render_to_string('index.html')
|
||||||
with self.assertTemplateUsed(template_name='index.html'):
|
with self.assertTemplateUsed(template_name='index.html'):
|
||||||
|
@ -1656,12 +1652,7 @@ your test suite.
|
||||||
|
|
||||||
self.assertNumQueries(7, lambda: my_function(using=7))
|
self.assertNumQueries(7, lambda: my_function(using=7))
|
||||||
|
|
||||||
If you're using Python 2.5 or greater you can also use this as a context
|
You can also use this as a context manager::
|
||||||
manager::
|
|
||||||
|
|
||||||
# This is necessary in Python 2.5 to enable the with statement, in 2.6
|
|
||||||
# and up it is no longer necessary.
|
|
||||||
from __future__ import with_statement
|
|
||||||
|
|
||||||
with self.assertNumQueries(2):
|
with self.assertNumQueries(2):
|
||||||
Person.objects.create(name="Aaron")
|
Person.objects.create(name="Aaron")
|
||||||
|
|
1
setup.py
1
setup.py
|
@ -88,7 +88,6 @@ setup(
|
||||||
'License :: OSI Approved :: BSD License',
|
'License :: OSI Approved :: BSD License',
|
||||||
'Operating System :: OS Independent',
|
'Operating System :: OS Independent',
|
||||||
'Programming Language :: Python',
|
'Programming Language :: Python',
|
||||||
'Programming Language :: Python :: 2.5',
|
|
||||||
'Programming Language :: Python :: 2.6',
|
'Programming Language :: Python :: 2.6',
|
||||||
'Programming Language :: Python :: 2.7',
|
'Programming Language :: Python :: 2.7',
|
||||||
'Topic :: Internet :: WWW/HTTP',
|
'Topic :: Internet :: WWW/HTTP',
|
||||||
|
|
|
@ -25,8 +25,6 @@ class FormsWidgetTestCase(TestCase):
|
||||||
self.assertHTMLEqual(w.render('email', 'some "quoted" & ampersanded value'), u'<input type="text" name="email" value="some "quoted" & ampersanded value" />')
|
self.assertHTMLEqual(w.render('email', 'some "quoted" & ampersanded value'), u'<input type="text" name="email" value="some "quoted" & ampersanded value" />')
|
||||||
self.assertHTMLEqual(w.render('email', 'test@example.com', attrs={'class': 'fun'}), u'<input type="text" name="email" value="test@example.com" class="fun" />')
|
self.assertHTMLEqual(w.render('email', 'test@example.com', attrs={'class': 'fun'}), u'<input type="text" name="email" value="test@example.com" class="fun" />')
|
||||||
|
|
||||||
# Note that doctest in Python 2.4 (and maybe 2.5?) doesn't support non-ascii
|
|
||||||
# characters in output, so we're displaying the repr() here.
|
|
||||||
self.assertHTMLEqual(w.render('email', 'ŠĐĆŽćžšđ', attrs={'class': 'fun'}), u'<input type="text" name="email" value="\u0160\u0110\u0106\u017d\u0107\u017e\u0161\u0111" class="fun" />')
|
self.assertHTMLEqual(w.render('email', 'ŠĐĆŽćžšđ', attrs={'class': 'fun'}), u'<input type="text" name="email" value="\u0160\u0110\u0106\u017d\u0107\u017e\u0161\u0111" class="fun" />')
|
||||||
|
|
||||||
# You can also pass 'attrs' to the constructor:
|
# You can also pass 'attrs' to the constructor:
|
||||||
|
|
Loading…
Reference in New Issue