1
0
mirror of https://github.com/django/django.git synced 2025-01-03 15:06:09 +00:00

Refs #23919 -- Removed unneeded force_str calls

This commit is contained in:
Claude Paroz 2017-01-11 23:17:25 +01:00
parent bf1c957027
commit dc8834cad4
44 changed files with 100 additions and 167 deletions

View File

@ -11,7 +11,7 @@ from django.db.models.sql.constants import QUERY_TERMS
from django.forms.utils import pretty_name from django.forms.utils import pretty_name
from django.urls import NoReverseMatch, reverse from django.urls import NoReverseMatch, reverse
from django.utils import formats, timezone from django.utils import formats, timezone
from django.utils.encoding import force_str, force_text, smart_text from django.utils.encoding import force_text, smart_text
from django.utils.html import format_html from django.utils.html import format_html
from django.utils.text import capfirst from django.utils.text import capfirst
from django.utils.translation import ( from django.utils.translation import (
@ -340,12 +340,9 @@ def label_for_field(name, model, model_admin=None, return_attr=False):
# field is likely a ForeignObjectRel # field is likely a ForeignObjectRel
label = field.related_model._meta.verbose_name label = field.related_model._meta.verbose_name
except FieldDoesNotExist: except FieldDoesNotExist:
if name == "__unicode__": if name == "__str__":
label = force_text(model._meta.verbose_name) label = force_text(model._meta.verbose_name)
attr = str attr = str
elif name == "__str__":
label = force_str(model._meta.verbose_name)
attr = bytes
else: else:
if callable(name): if callable(name):
attr = name attr = name

View File

@ -13,7 +13,7 @@ from django.dispatch import receiver
from django.utils.crypto import ( from django.utils.crypto import (
constant_time_compare, get_random_string, pbkdf2, constant_time_compare, get_random_string, pbkdf2,
) )
from django.utils.encoding import force_bytes, force_str, force_text from django.utils.encoding import force_bytes, force_text
from django.utils.module_loading import import_string from django.utils.module_loading import import_string
from django.utils.translation import ugettext_noop as _ from django.utils.translation import ugettext_noop as _
@ -627,7 +627,7 @@ class CryptPasswordHasher(BasePasswordHasher):
def encode(self, password, salt): def encode(self, password, salt):
crypt = self._load_library() crypt = self._load_library()
assert len(salt) == 2 assert len(salt) == 2
data = crypt.crypt(force_str(password), salt) data = crypt.crypt(password, salt)
assert data is not None # A platform like OpenBSD with a dummy crypt module. assert data is not None # A platform like OpenBSD with a dummy crypt module.
# we don't need to store the salt, but Django used to do this # we don't need to store the salt, but Django used to do this
return "%s$%s$%s" % (self.algorithm, '', data) return "%s$%s$%s" % (self.algorithm, '', data)
@ -636,7 +636,7 @@ class CryptPasswordHasher(BasePasswordHasher):
crypt = self._load_library() crypt = self._load_library()
algorithm, salt, data = encoded.split('$', 2) algorithm, salt, data = encoded.split('$', 2)
assert algorithm == self.algorithm assert algorithm == self.algorithm
return constant_time_compare(data, crypt.crypt(force_str(password), data)) return constant_time_compare(data, crypt.crypt(password, data))
def safe_summary(self, encoded): def safe_summary(self, encoded):
algorithm, salt, data = encoded.split('$', 2) algorithm, salt, data = encoded.split('$', 2)

View File

@ -5,7 +5,6 @@ from django.contrib.auth.password_validation import validate_password
from django.core.exceptions import ValidationError from django.core.exceptions import ValidationError
from django.core.management.base import BaseCommand, CommandError from django.core.management.base import BaseCommand, CommandError
from django.db import DEFAULT_DB_ALIAS from django.db import DEFAULT_DB_ALIAS
from django.utils.encoding import force_str
UserModel = get_user_model() UserModel = get_user_model()
@ -16,7 +15,7 @@ class Command(BaseCommand):
requires_system_checks = False requires_system_checks = False
def _get_pass(self, prompt="Password: "): def _get_pass(self, prompt="Password: "):
p = getpass.getpass(prompt=force_str(prompt)) p = getpass.getpass(prompt=prompt)
if not p: if not p:
raise CommandError("aborted") raise CommandError("aborted")
return p return p

View File

@ -10,7 +10,6 @@ from django.contrib.auth.password_validation import validate_password
from django.core import exceptions from django.core import exceptions
from django.core.management.base import BaseCommand, CommandError from django.core.management.base import BaseCommand, CommandError
from django.db import DEFAULT_DB_ALIAS from django.db import DEFAULT_DB_ALIAS
from django.utils.encoding import force_str
from django.utils.text import capfirst from django.utils.text import capfirst
@ -103,12 +102,12 @@ class Command(BaseCommand):
if default_username: if default_username:
input_msg += " (leave blank to use '%s')" % default_username input_msg += " (leave blank to use '%s')" % default_username
username_rel = self.username_field.remote_field username_rel = self.username_field.remote_field
input_msg = force_str('%s%s: ' % ( input_msg = '%s%s: ' % (
input_msg, input_msg,
' (%s.%s)' % ( ' (%s.%s)' % (
username_rel.model._meta.object_name, username_rel.model._meta.object_name,
username_rel.field_name username_rel.field_name
) if username_rel else '') ) if username_rel else ''
) )
username = self.get_input_data(self.username_field, input_msg, default_username) username = self.get_input_data(self.username_field, input_msg, default_username)
if not username: if not username:
@ -126,13 +125,13 @@ class Command(BaseCommand):
field = self.UserModel._meta.get_field(field_name) field = self.UserModel._meta.get_field(field_name)
user_data[field_name] = options[field_name] user_data[field_name] = options[field_name]
while user_data[field_name] is None: while user_data[field_name] is None:
message = force_str('%s%s: ' % ( message = '%s%s: ' % (
capfirst(field.verbose_name), capfirst(field.verbose_name),
' (%s.%s)' % ( ' (%s.%s)' % (
field.remote_field.model._meta.object_name, field.remote_field.model._meta.object_name,
field.remote_field.field_name, field.remote_field.field_name,
) if field.remote_field else '', ) if field.remote_field else '',
)) )
input_value = self.get_input_data(field, message) input_value = self.get_input_data(field, message)
user_data[field_name] = input_value user_data[field_name] = input_value
fake_user_data[field_name] = input_value fake_user_data[field_name] = input_value
@ -144,7 +143,7 @@ class Command(BaseCommand):
# Get a password # Get a password
while password is None: while password is None:
password = getpass.getpass() password = getpass.getpass()
password2 = getpass.getpass(force_str('Password (again): ')) password2 = getpass.getpass('Password (again): ')
if password != password2: if password != password2:
self.stderr.write("Error: Your passwords didn't match.") self.stderr.write("Error: Your passwords didn't match.")
password = None password = None

View File

@ -7,7 +7,6 @@ import warnings
from django.core.cache.backends.base import DEFAULT_TIMEOUT, BaseCache from django.core.cache.backends.base import DEFAULT_TIMEOUT, BaseCache
from django.utils.deprecation import RemovedInDjango21Warning from django.utils.deprecation import RemovedInDjango21Warning
from django.utils.encoding import force_str
from django.utils.functional import cached_property from django.utils.functional import cached_property
@ -65,10 +64,6 @@ class BaseMemcachedCache(BaseCache):
timeout += int(time.time()) timeout += int(time.time())
return int(timeout) return int(timeout)
def make_key(self, key, version=None):
# Python 2 memcache requires the key to be a byte string.
return force_str(super(BaseMemcachedCache, self).make_key(key, version))
def add(self, key, value, timeout=DEFAULT_TIMEOUT, version=None): def add(self, key, value, timeout=DEFAULT_TIMEOUT, version=None):
key = self.make_key(key, version=version) key = self.make_key(key, version=version)
return self._cache.add(key, value, self.get_backend_timeout(timeout)) return self._cache.add(key, value, self.get_backend_timeout(timeout))

View File

@ -1,4 +1,4 @@
from django.utils.encoding import force_str from django.utils.encoding import force_text
# Levels # Levels
DEBUG = 10 DEBUG = 10
@ -35,7 +35,7 @@ class CheckMessage:
# method doesn't return "applabel.modellabel" and cannot be changed. # method doesn't return "applabel.modellabel" and cannot be changed.
obj = self.obj._meta.label obj = self.obj._meta.label
else: else:
obj = force_str(self.obj) obj = force_text(self.obj)
id = "(%s) " % self.id if self.id else "" id = "(%s) " % self.id if self.id else ""
hint = "\n\tHINT: %s" % self.hint if self.hint else '' hint = "\n\tHINT: %s" % self.hint if self.hint else ''
return "%s: %s%s%s" % (obj, id, self.msg, hint) return "%s: %s%s%s" % (obj, id, self.msg, hint)

View File

@ -2,7 +2,7 @@ import os
from io import BytesIO, StringIO, UnsupportedOperation from io import BytesIO, StringIO, UnsupportedOperation
from django.core.files.utils import FileProxyMixin from django.core.files.utils import FileProxyMixin
from django.utils.encoding import force_str, force_text from django.utils.encoding import force_text
class File(FileProxyMixin): class File(FileProxyMixin):
@ -20,7 +20,7 @@ class File(FileProxyMixin):
return force_text(self.name or '') return force_text(self.name or '')
def __repr__(self): def __repr__(self):
return force_str("<%s: %s>" % (self.__class__.__name__, self or "None")) return "<%s: %s>" % (self.__class__.__name__, self or "None")
def __bool__(self): def __bool__(self):
return bool(self.name) return bool(self.name)

View File

@ -9,7 +9,6 @@ from io import BytesIO
from django.conf import settings from django.conf import settings
from django.core.files import temp as tempfile from django.core.files import temp as tempfile
from django.core.files.base import File from django.core.files.base import File
from django.utils.encoding import force_str
__all__ = ('UploadedFile', 'TemporaryUploadedFile', 'InMemoryUploadedFile', __all__ = ('UploadedFile', 'TemporaryUploadedFile', 'InMemoryUploadedFile',
'SimpleUploadedFile') 'SimpleUploadedFile')
@ -33,8 +32,7 @@ class UploadedFile(File):
self.content_type_extra = content_type_extra self.content_type_extra = content_type_extra
def __repr__(self): def __repr__(self):
return force_str("<%s: %s (%s)>" % ( return "<%s: %s (%s)>" % (self.__class__.__name__, self.name, self.content_type)
self.__class__.__name__, self.name, self.content_type))
def _get_name(self): def _get_name(self):
return self._name return self._name

View File

@ -8,13 +8,10 @@ from django.conf import settings
from django.core import signals from django.core import signals
from django.core.handlers import base from django.core.handlers import base
from django.urls import set_script_prefix from django.urls import set_script_prefix
from django.utils.encoding import ( from django.utils.encoding import force_text, repercent_broken_unicode
force_str, force_text, repercent_broken_unicode,
)
from django.utils.functional import cached_property from django.utils.functional import cached_property
# encode() and decode() expect the charset to be a native string. ISO_8859_1, UTF_8 = 'iso-8859-1', 'utf-8'
ISO_8859_1, UTF_8 = str('iso-8859-1'), str('utf-8')
_slashes_re = re.compile(br'/+') _slashes_re = re.compile(br'/+')
@ -159,7 +156,7 @@ class WSGIHandler(base.BaseHandler):
response_headers = [(str(k), str(v)) for k, v in response.items()] response_headers = [(str(k), str(v)) for k, v in response.items()]
for c in response.cookies.values(): for c in response.cookies.values():
response_headers.append((str('Set-Cookie'), str(c.output(header='')))) response_headers.append((str('Set-Cookie'), str(c.output(header=''))))
start_response(force_str(status), response_headers) start_response(status, response_headers)
if getattr(response, 'file_to_stream', None) is not None and environ.get('wsgi.file_wrapper'): if getattr(response, 'file_to_stream', None) is not None and environ.get('wsgi.file_wrapper'):
response = environ['wsgi.file_wrapper'](response.file_to_stream) response = environ['wsgi.file_wrapper'](response.file_to_stream)
return response return response

View File

@ -8,7 +8,6 @@ from django.conf import settings
from django.core.mail.backends.base import BaseEmailBackend from django.core.mail.backends.base import BaseEmailBackend
from django.core.mail.message import sanitize_address from django.core.mail.message import sanitize_address
from django.core.mail.utils import DNS_NAME from django.core.mail.utils import DNS_NAME
from django.utils.encoding import force_str
class EmailBackend(BaseEmailBackend): class EmailBackend(BaseEmailBackend):
@ -68,7 +67,7 @@ class EmailBackend(BaseEmailBackend):
if not self.use_ssl and self.use_tls: if not self.use_ssl and self.use_tls:
self.connection.starttls(keyfile=self.ssl_keyfile, certfile=self.ssl_certfile) self.connection.starttls(keyfile=self.ssl_keyfile, certfile=self.ssl_certfile)
if self.username and self.password: if self.username and self.password:
self.connection.login(force_str(self.username), force_str(self.password)) self.connection.login(self.username, self.password)
return True return True
except (smtplib.SMTPException, socket.error): except (smtplib.SMTPException, socket.error):
if not self.fail_silently: if not self.fail_silently:

View File

@ -5,6 +5,7 @@ be executed through ``django-admin`` or ``manage.py``).
import os import os
import sys import sys
from argparse import ArgumentParser from argparse import ArgumentParser
from io import TextIOBase
import django import django
from django.core import checks from django.core import checks
@ -12,7 +13,6 @@ from django.core.exceptions import ImproperlyConfigured
from django.core.management.color import color_style, no_style from django.core.management.color import color_style, no_style
from django.db import DEFAULT_DB_ALIAS, connections from django.db import DEFAULT_DB_ALIAS, connections
from django.db.migrations.exceptions import MigrationSchemaMissing from django.db.migrations.exceptions import MigrationSchemaMissing
from django.utils.encoding import force_str
class CommandError(Exception): class CommandError(Exception):
@ -73,7 +73,7 @@ def handle_default_options(options):
sys.path.insert(0, options.pythonpath) sys.path.insert(0, options.pythonpath)
class OutputWrapper: class OutputWrapper(TextIOBase):
""" """
Wrapper around stdout/stderr Wrapper around stdout/stderr
""" """
@ -104,7 +104,7 @@ class OutputWrapper:
if ending and not msg.endswith(ending): if ending and not msg.endswith(ending):
msg += ending msg += ending
style_func = style_func or self.style_func style_func = style_func or self.style_func
self._out.write(force_str(style_func(msg))) self._out.write(style_func(msg))
class BaseCommand: class BaseCommand:
@ -377,9 +377,9 @@ class BaseCommand:
if issues: if issues:
visible_issue_count += len(issues) visible_issue_count += len(issues)
formatted = ( formatted = (
self.style.ERROR(force_str(e)) self.style.ERROR(str(e))
if e.is_serious() if e.is_serious()
else self.style.WARNING(force_str(e)) else self.style.WARNING(str(e))
for e in issues) for e in issues)
formatted = "\n".join(sorted(formatted)) formatted = "\n".join(sorted(formatted))
body += '\n%s:\n%s\n' % (group_name, formatted) body += '\n%s:\n%s\n' % (group_name, formatted)

View File

@ -15,7 +15,7 @@ from django.core.management.utils import (
find_command, handle_extensions, popen_wrapper, find_command, handle_extensions, popen_wrapper,
) )
from django.utils._os import upath from django.utils._os import upath
from django.utils.encoding import DEFAULT_LOCALE_ENCODING, force_str from django.utils.encoding import DEFAULT_LOCALE_ENCODING
from django.utils.functional import cached_property from django.utils.functional import cached_property
from django.utils.jslex import prepare_js_for_gettext from django.utils.jslex import prepare_js_for_gettext
from django.utils.text import get_text_list from django.utils.text import get_text_list
@ -557,7 +557,7 @@ class Command(BaseCommand):
input_files = [bf.work_path for bf in build_files] input_files = [bf.work_path for bf in build_files]
with NamedTemporaryFile(mode='w+') as input_files_list: with NamedTemporaryFile(mode='w+') as input_files_list:
input_files_list.write(force_str('\n'.join(input_files), encoding=DEFAULT_LOCALE_ENCODING)) input_files_list.write(('\n'.join(input_files)))
input_files_list.flush() input_files_list.flush()
args.extend(['--files-from', input_files_list.name]) args.extend(['--files-from', input_files_list.name])
args.extend(self.xgettext_options) args.extend(self.xgettext_options)
@ -649,7 +649,7 @@ class Command(BaseCommand):
with open(django_po, 'r', encoding='utf-8') as fp: with open(django_po, 'r', encoding='utf-8') as fp:
m = plural_forms_re.search(fp.read()) m = plural_forms_re.search(fp.read())
if m: if m:
plural_form_line = force_str(m.group('value')) plural_form_line = m.group('value')
if self.verbosity > 1: if self.verbosity > 1:
self.stdout.write("copying plural forms: %s\n" % plural_form_line) self.stdout.write("copying plural forms: %s\n" % plural_form_line)
lines = [] lines = []

View File

@ -43,7 +43,7 @@ import zlib
from django.conf import settings from django.conf import settings
from django.utils import baseconv from django.utils import baseconv
from django.utils.crypto import constant_time_compare, salted_hmac from django.utils.crypto import constant_time_compare, salted_hmac
from django.utils.encoding import force_bytes, force_str, force_text from django.utils.encoding import force_bytes, force_text
from django.utils.module_loading import import_string from django.utils.module_loading import import_string
_SEP_UNSAFE = re.compile(r'^[A-z0-9-_=]*$') _SEP_UNSAFE = re.compile(r'^[A-z0-9-_=]*$')
@ -152,25 +152,21 @@ class Signer:
def __init__(self, key=None, sep=':', salt=None): def __init__(self, key=None, sep=':', salt=None):
# Use of native strings in all versions of Python # Use of native strings in all versions of Python
self.key = key or settings.SECRET_KEY self.key = key or settings.SECRET_KEY
self.sep = force_str(sep) self.sep = sep
if _SEP_UNSAFE.match(self.sep): if _SEP_UNSAFE.match(self.sep):
raise ValueError( raise ValueError(
'Unsafe Signer separator: %r (cannot be empty or consist of ' 'Unsafe Signer separator: %r (cannot be empty or consist of '
'only A-z0-9-_=)' % sep, 'only A-z0-9-_=)' % sep,
) )
self.salt = force_str(salt or '%s.%s' % (self.__class__.__module__, self.__class__.__name__)) self.salt = salt or '%s.%s' % (self.__class__.__module__, self.__class__.__name__)
def signature(self, value): def signature(self, value):
signature = base64_hmac(self.salt + 'signer', value, self.key) return force_text(base64_hmac(self.salt + 'signer', value, self.key))
# Convert the signature from bytes to str only on Python 3
return force_str(signature)
def sign(self, value): def sign(self, value):
value = force_str(value) return '%s%s%s' % (value, self.sep, self.signature(value))
return str('%s%s%s') % (value, self.sep, self.signature(value))
def unsign(self, signed_value): def unsign(self, signed_value):
signed_value = force_str(signed_value)
if self.sep not in signed_value: if self.sep not in signed_value:
raise BadSignature('No "%s" found in value' % self.sep) raise BadSignature('No "%s" found in value' % self.sep)
value, sig = signed_value.rsplit(self.sep, 1) value, sig = signed_value.rsplit(self.sep, 1)
@ -185,8 +181,7 @@ class TimestampSigner(Signer):
return baseconv.base62.encode(int(time.time())) return baseconv.base62.encode(int(time.time()))
def sign(self, value): def sign(self, value):
value = force_str(value) value = '%s%s%s' % (force_text(value), self.sep, self.timestamp())
value = str('%s%s%s') % (value, self.sep, self.timestamp())
return super(TimestampSigner, self).sign(value) return super(TimestampSigner, self).sign(value)
def unsign(self, value, max_age=None): def unsign(self, value, max_age=None):

View File

@ -12,7 +12,6 @@ from django.db import utils
from django.db.backends import utils as backend_utils from django.db.backends import utils as backend_utils
from django.db.backends.base.base import BaseDatabaseWrapper from django.db.backends.base.base import BaseDatabaseWrapper
from django.utils import six from django.utils import six
from django.utils.encoding import force_str
from django.utils.functional import cached_property from django.utils.functional import cached_property
from django.utils.safestring import SafeBytes, SafeText from django.utils.safestring import SafeBytes, SafeText
@ -225,7 +224,7 @@ class DatabaseWrapper(BaseDatabaseWrapper):
if settings_dict['NAME']: if settings_dict['NAME']:
kwargs['db'] = settings_dict['NAME'] kwargs['db'] = settings_dict['NAME']
if settings_dict['PASSWORD']: if settings_dict['PASSWORD']:
kwargs['passwd'] = force_str(settings_dict['PASSWORD']) kwargs['passwd'] = settings_dict['PASSWORD']
if settings_dict['HOST'].startswith('/'): if settings_dict['HOST'].startswith('/'):
kwargs['unix_socket'] = settings_dict['HOST'] kwargs['unix_socket'] = settings_dict['HOST']
elif settings_dict['HOST']: elif settings_dict['HOST']:

View File

@ -12,7 +12,6 @@ from django.core.exceptions import ImproperlyConfigured
from django.db import DEFAULT_DB_ALIAS from django.db import DEFAULT_DB_ALIAS
from django.db.backends.base.base import BaseDatabaseWrapper from django.db.backends.base.base import BaseDatabaseWrapper
from django.db.utils import DatabaseError as WrappedDatabaseError from django.db.utils import DatabaseError as WrappedDatabaseError
from django.utils.encoding import force_str
from django.utils.functional import cached_property from django.utils.functional import cached_property
from django.utils.safestring import SafeBytes, SafeText from django.utils.safestring import SafeBytes, SafeText
@ -160,7 +159,7 @@ class DatabaseWrapper(BaseDatabaseWrapper):
if settings_dict['USER']: if settings_dict['USER']:
conn_params['user'] = settings_dict['USER'] conn_params['user'] = settings_dict['USER']
if settings_dict['PASSWORD']: if settings_dict['PASSWORD']:
conn_params['password'] = force_str(settings_dict['PASSWORD']) conn_params['password'] = settings_dict['PASSWORD']
if settings_dict['HOST']: if settings_dict['HOST']:
conn_params['host'] = settings_dict['HOST'] conn_params['host'] = settings_dict['HOST']
if settings_dict['PORT']: if settings_dict['PORT']:

View File

@ -26,7 +26,7 @@ from django.db.models.signals import (
class_prepared, post_init, post_save, pre_init, pre_save, class_prepared, post_init, post_save, pre_init, pre_save,
) )
from django.db.models.utils import make_model_tuple from django.db.models.utils import make_model_tuple
from django.utils.encoding import force_str, force_text from django.utils.encoding import force_text
from django.utils.functional import curry from django.utils.functional import curry
from django.utils.text import capfirst, get_text_list from django.utils.text import capfirst, get_text_list
from django.utils.translation import ugettext_lazy as _ from django.utils.translation import ugettext_lazy as _
@ -505,7 +505,7 @@ class Model(metaclass=ModelBase):
u = str(self) u = str(self)
except (UnicodeEncodeError, UnicodeDecodeError): except (UnicodeEncodeError, UnicodeDecodeError):
u = '[Bad Unicode data]' u = '[Bad Unicode data]'
return force_str('<%s: %s>' % (self.__class__.__name__, u)) return '<%s: %s>' % (self.__class__.__name__, u)
def __str__(self): def __str__(self):
return '%s object' % self.__class__.__name__ return '%s object' % self.__class__.__name__

View File

@ -9,7 +9,7 @@ from django.core.files.storage import default_storage
from django.core.validators import validate_image_file_extension from django.core.validators import validate_image_file_extension
from django.db.models import signals from django.db.models import signals
from django.db.models.fields import Field from django.db.models.fields import Field
from django.utils.encoding import force_str, force_text from django.utils.encoding import force_text
from django.utils.translation import ugettext_lazy as _ from django.utils.translation import ugettext_lazy as _
@ -304,7 +304,7 @@ class FileField(Field):
if callable(self.upload_to): if callable(self.upload_to):
filename = self.upload_to(instance, filename) filename = self.upload_to(instance, filename)
else: else:
dirname = force_text(datetime.datetime.now().strftime(force_str(self.upload_to))) dirname = force_text(datetime.datetime.now().strftime(self.upload_to))
filename = posixpath.join(dirname, filename) filename = posixpath.join(dirname, filename)
return self.storage.generate_filename(filename) return self.storage.generate_filename(filename)

View File

@ -29,7 +29,7 @@ from django.forms.widgets import (
from django.utils import formats, six from django.utils import formats, six
from django.utils.dateparse import parse_duration from django.utils.dateparse import parse_duration
from django.utils.duration import duration_string from django.utils.duration import duration_string
from django.utils.encoding import force_str, force_text from django.utils.encoding import force_text
from django.utils.ipv6 import clean_ipv6_address from django.utils.ipv6 import clean_ipv6_address
from django.utils.translation import ugettext_lazy as _, ungettext_lazy from django.utils.translation import ugettext_lazy as _, ungettext_lazy
@ -429,7 +429,7 @@ class DateField(BaseTemporalField):
return super(DateField, self).to_python(value) return super(DateField, self).to_python(value)
def strptime(self, value, format): def strptime(self, value, format):
return datetime.datetime.strptime(force_str(value), format).date() return datetime.datetime.strptime(value, format).date()
class TimeField(BaseTemporalField): class TimeField(BaseTemporalField):
@ -451,7 +451,7 @@ class TimeField(BaseTemporalField):
return super(TimeField, self).to_python(value) return super(TimeField, self).to_python(value)
def strptime(self, value, format): def strptime(self, value, format):
return datetime.datetime.strptime(force_str(value), format).time() return datetime.datetime.strptime(value, format).time()
class DateTimeField(BaseTemporalField): class DateTimeField(BaseTemporalField):
@ -482,7 +482,7 @@ class DateTimeField(BaseTemporalField):
return from_current_timezone(result) return from_current_timezone(result)
def strptime(self, value, format): def strptime(self, value, format):
return datetime.datetime.strptime(force_str(value), format) return datetime.datetime.strptime(value, format)
class DurationField(Field): class DurationField(Field):

View File

@ -13,7 +13,7 @@ from django.forms.utils import to_current_timezone
from django.templatetags.static import static from django.templatetags.static import static
from django.utils import datetime_safe, formats from django.utils import datetime_safe, formats
from django.utils.dates import MONTHS from django.utils.dates import MONTHS
from django.utils.encoding import force_str, force_text from django.utils.encoding import force_text
from django.utils.formats import get_format from django.utils.formats import get_format
from django.utils.html import format_html, html_safe from django.utils.html import format_html, html_safe
from django.utils.safestring import mark_safe from django.utils.safestring import mark_safe
@ -986,7 +986,7 @@ class SelectDateWidget(Widget):
if settings.USE_L10N: if settings.USE_L10N:
try: try:
input_format = get_format('DATE_INPUT_FORMATS')[0] input_format = get_format('DATE_INPUT_FORMATS')[0]
d = datetime.datetime.strptime(force_str(value), input_format) d = datetime.datetime.strptime(value, input_format)
year, month, day = d.year, d.month, d.day year, month, day = d.year, d.month, d.day
except ValueError: except ValueError:
pass pass

View File

@ -14,9 +14,7 @@ from django.core.files import uploadhandler
from django.http.multipartparser import MultiPartParser, MultiPartParserError from django.http.multipartparser import MultiPartParser, MultiPartParserError
from django.utils import six from django.utils import six
from django.utils.datastructures import ImmutableList, MultiValueDict from django.utils.datastructures import ImmutableList, MultiValueDict
from django.utils.encoding import ( from django.utils.encoding import escape_uri_path, force_bytes, iri_to_uri
escape_uri_path, force_bytes, force_str, iri_to_uri,
)
from django.utils.http import is_same_domain, limited_parse_qsl from django.utils.http import is_same_domain, limited_parse_qsl
RAISE_ERROR = object() RAISE_ERROR = object()
@ -64,10 +62,8 @@ class HttpRequest:
def __repr__(self): def __repr__(self):
if self.method is None or not self.get_full_path(): if self.method is None or not self.get_full_path():
return force_str('<%s>' % self.__class__.__name__) return '<%s>' % self.__class__.__name__
return force_str( return '<%s: %s %r>' % (self.__class__.__name__, self.method, self.get_full_path())
'<%s: %s %r>' % (self.__class__.__name__, self.method, force_str(self.get_full_path()))
)
def _get_raw_host(self): def _get_raw_host(self):
""" """

View File

@ -13,9 +13,7 @@ from django.core.exceptions import DisallowedRedirect
from django.core.serializers.json import DjangoJSONEncoder from django.core.serializers.json import DjangoJSONEncoder
from django.http.cookie import SimpleCookie from django.http.cookie import SimpleCookie
from django.utils import timezone from django.utils import timezone
from django.utils.encoding import ( from django.utils.encoding import force_bytes, force_text, iri_to_uri
force_bytes, force_str, force_text, iri_to_uri,
)
from django.utils.http import cookie_date from django.utils.http import cookie_date
_charset_from_content_type_re = re.compile(r';\s*charset=(?P<charset>[^\s;]+)', re.I) _charset_from_content_type_re = re.compile(r';\s*charset=(?P<charset>[^\s;]+)', re.I)
@ -170,7 +168,6 @@ class HttpResponseBase:
- an aware ``datetime.datetime`` object in any time zone. - an aware ``datetime.datetime`` object in any time zone.
If it is a ``datetime.datetime`` object then ``max_age`` will be calculated. If it is a ``datetime.datetime`` object then ``max_age`` will be calculated.
""" """
value = force_str(value)
self.cookies[key] = value self.cookies[key] = value
if expires is not None: if expires is not None:
if isinstance(expires, datetime.datetime): if isinstance(expires, datetime.datetime):

View File

@ -56,7 +56,7 @@ import re
from django.template.context import ( # NOQA: imported for backwards compatibility from django.template.context import ( # NOQA: imported for backwards compatibility
BaseContext, Context, ContextPopException, RequestContext, BaseContext, Context, ContextPopException, RequestContext,
) )
from django.utils.encoding import force_str, force_text from django.utils.encoding import force_text
from django.utils.formats import localize from django.utils.formats import localize
from django.utils.html import conditional_escape, escape from django.utils.html import conditional_escape, escape
from django.utils.inspect import getargspec from django.utils.inspect import getargspec
@ -971,8 +971,7 @@ class TextNode(Node):
self.s = s self.s = s
def __repr__(self): def __repr__(self):
rep = "<%s: %r>" % (self.__class__.__name__, self.s[:25]) return "<%s: %r>" % (self.__class__.__name__, self.s[:25])
return force_str(rep, 'ascii', errors='replace')
def render(self, context): def render(self, context):
return self.s return self.s

View File

@ -21,7 +21,7 @@ from django.test import signals
from django.test.utils import ContextList from django.test.utils import ContextList
from django.urls import resolve from django.urls import resolve
from django.utils import six from django.utils import six
from django.utils.encoding import force_bytes, force_str, uri_to_iri from django.utils.encoding import force_bytes, uri_to_iri
from django.utils.functional import SimpleLazyObject, curry from django.utils.functional import SimpleLazyObject, curry
from django.utils.http import urlencode from django.utils.http import urlencode
from django.utils.itercompat import is_iterable from django.utils.itercompat import is_iterable
@ -317,10 +317,10 @@ class RequestFactory:
return force_bytes(data, encoding=charset) return force_bytes(data, encoding=charset)
def _get_path(self, parsed): def _get_path(self, parsed):
path = force_str(parsed[2]) path = parsed.path
# If there are parameters, add them # If there are parameters, add them
if parsed[3]: if parsed.params:
path += str(";") + force_str(parsed[3]) path += ";" + parsed.params
path = uri_to_iri(path).encode(UTF_8) path = uri_to_iri(path).encode(UTF_8)
# Replace the behavior where non-ASCII values in the WSGI environ are # Replace the behavior where non-ASCII values in the WSGI environ are
# arbitrarily decoded with ISO-8859-1. # arbitrarily decoded with ISO-8859-1.
@ -389,7 +389,7 @@ class RequestFactory:
content_type='application/octet-stream', secure=False, content_type='application/octet-stream', secure=False,
**extra): **extra):
"""Constructs an arbitrary HTTP request.""" """Constructs an arbitrary HTTP request."""
parsed = urlparse(force_str(path)) parsed = urlparse(str(path)) # path can be lazy
data = force_bytes(data, settings.DEFAULT_CHARSET) data = force_bytes(data, settings.DEFAULT_CHARSET)
r = { r = {
'PATH_INFO': self._get_path(parsed), 'PATH_INFO': self._get_path(parsed),

View File

@ -23,7 +23,6 @@ from django.template import Template
from django.test.signals import setting_changed, template_rendered from django.test.signals import setting_changed, template_rendered
from django.urls import get_script_prefix, set_script_prefix from django.urls import get_script_prefix, set_script_prefix
from django.utils.decorators import available_attrs from django.utils.decorators import available_attrs
from django.utils.encoding import force_str
from django.utils.translation import deactivate from django.utils.translation import deactivate
try: try:
@ -317,7 +316,7 @@ def get_runner(settings, test_runner_class=None):
test_module_name = '.'.join(test_path[:-1]) test_module_name = '.'.join(test_path[:-1])
else: else:
test_module_name = '.' test_module_name = '.'
test_module = __import__(test_module_name, {}, {}, force_str(test_path[-1])) test_module = __import__(test_module_name, {}, {}, test_path[-1])
test_runner = getattr(test_module, test_path[-1]) test_runner = getattr(test_module, test_path[-1])
return test_runner return test_runner

View File

@ -15,7 +15,7 @@ from django.core.checks import Warning
from django.core.checks.urls import check_resolver from django.core.checks.urls import check_resolver
from django.core.exceptions import ImproperlyConfigured from django.core.exceptions import ImproperlyConfigured
from django.utils.datastructures import MultiValueDict from django.utils.datastructures import MultiValueDict
from django.utils.encoding import force_str, force_text from django.utils.encoding import force_text
from django.utils.functional import cached_property from django.utils.functional import cached_property
from django.utils.http import RFC3986_SUBDELIMS, urlquote from django.utils.http import RFC3986_SUBDELIMS, urlquote
from django.utils.regex_helper import normalize from django.utils.regex_helper import normalize
@ -160,7 +160,7 @@ class RegexURLPattern(LocaleRegexProvider):
self.name = name self.name = name
def __repr__(self): def __repr__(self):
return force_str('<%s %s %s>' % (self.__class__.__name__, self.name, self.regex.pattern)) return '<%s %s %s>' % (self.__class__.__name__, self.name, self.regex.pattern)
def check(self): def check(self):
warnings = self._check_pattern_name() warnings = self._check_pattern_name()

View File

@ -5,7 +5,6 @@ from importlib import import_module
from django.conf import settings from django.conf import settings
from django.utils import dateformat, datetime_safe, numberformat from django.utils import dateformat, datetime_safe, numberformat
from django.utils.encoding import force_str
from django.utils.functional import lazy from django.utils.functional import lazy
from django.utils.safestring import mark_safe from django.utils.safestring import mark_safe
from django.utils.translation import ( from django.utils.translation import (
@ -111,7 +110,6 @@ def get_format(format_type, lang=None, use_l10n=None):
If use_l10n is provided and is not None, that will force the value to If use_l10n is provided and is not None, that will force the value to
be localized (or not), overriding the value of settings.USE_L10N. be localized (or not), overriding the value of settings.USE_L10N.
""" """
format_type = force_str(format_type)
use_l10n = use_l10n or (use_l10n is None and settings.USE_L10N) use_l10n = use_l10n or (use_l10n is None and settings.USE_L10N)
if use_l10n and lang is None: if use_l10n and lang is None:
lang = get_language() lang = get_language()
@ -229,14 +227,14 @@ def localize_input(value, default=None):
return number_format(value) return number_format(value)
elif isinstance(value, datetime.datetime): elif isinstance(value, datetime.datetime):
value = datetime_safe.new_datetime(value) value = datetime_safe.new_datetime(value)
format = force_str(default or get_format('DATETIME_INPUT_FORMATS')[0]) format = default or get_format('DATETIME_INPUT_FORMATS')[0]
return value.strftime(format) return value.strftime(format)
elif isinstance(value, datetime.date): elif isinstance(value, datetime.date):
value = datetime_safe.new_date(value) value = datetime_safe.new_date(value)
format = force_str(default or get_format('DATE_INPUT_FORMATS')[0]) format = default or get_format('DATE_INPUT_FORMATS')[0]
return value.strftime(format) return value.strftime(format)
elif isinstance(value, datetime.time): elif isinstance(value, datetime.time):
format = force_str(default or get_format('TIME_INPUT_FORMATS')[0]) format = default or get_format('TIME_INPUT_FORMATS')[0]
return value.strftime(format) return value.strftime(format)
return value return value

View File

@ -5,7 +5,7 @@ from urllib.parse import (
parse_qsl, quote, unquote, urlencode, urlsplit, urlunsplit, parse_qsl, quote, unquote, urlencode, urlsplit, urlunsplit,
) )
from django.utils.encoding import force_str, force_text from django.utils.encoding import force_text
from django.utils.functional import keep_lazy, keep_lazy_text from django.utils.functional import keep_lazy, keep_lazy_text
from django.utils.http import RFC3986_GENDELIMS, RFC3986_SUBDELIMS from django.utils.http import RFC3986_GENDELIMS, RFC3986_SUBDELIMS
from django.utils.safestring import SafeData, SafeText, mark_safe from django.utils.safestring import SafeData, SafeText, mark_safe
@ -189,7 +189,7 @@ def strip_spaces_between_tags(value):
def smart_urlquote(url): def smart_urlquote(url):
"Quotes a URL if it isn't already quoted." "Quotes a URL if it isn't already quoted."
def unquote_quote(segment): def unquote_quote(segment):
segment = unquote(force_str(segment)) segment = unquote(segment)
# Tilde is part of RFC3986 Unreserved Characters # Tilde is part of RFC3986 Unreserved Characters
# http://tools.ietf.org/html/rfc3986#section-2.3 # http://tools.ietf.org/html/rfc3986#section-2.3
# See also http://bugs.python.org/issue16285 # See also http://bugs.python.org/issue16285
@ -211,7 +211,7 @@ def smart_urlquote(url):
if query: if query:
# Separately unquoting key/value, so as to not mix querystring separators # Separately unquoting key/value, so as to not mix querystring separators
# included in query values. See #22267. # included in query values. See #22267.
query_parts = [(unquote(force_str(q[0])), unquote(force_str(q[1]))) query_parts = [(unquote(q[0]), unquote(q[1]))
for q in parse_qsl(query, keep_blank_values=True)] for q in parse_qsl(query, keep_blank_values=True)]
# urlencode will take care of quoting # urlencode will take care of quoting
query = urlencode(query_parts) query = urlencode(query_parts)

View File

@ -5,7 +5,7 @@ ORM.
import copy import copy
from django.utils.encoding import force_str, force_text from django.utils.encoding import force_text
class Node: class Node:
@ -45,10 +45,10 @@ class Node:
def __str__(self): def __str__(self):
template = '(NOT (%s: %s))' if self.negated else '(%s: %s)' template = '(NOT (%s: %s))' if self.negated else '(%s: %s)'
return force_str(template % (self.connector, ', '.join(force_text(c) for c in self.children))) return template % (self.connector, ', '.join(force_text(c) for c in self.children))
def __repr__(self): def __repr__(self):
return str("<%s: %s>") % (self.__class__.__name__, self) return "<%s: %s>" % (self.__class__.__name__, self)
def __deepcopy__(self, memodict): def __deepcopy__(self, memodict):
""" """

View File

@ -10,7 +10,7 @@ from django.template.defaultfilters import force_escape, pprint
from django.urls import Resolver404, resolve from django.urls import Resolver404, resolve
from django.utils import timezone from django.utils import timezone
from django.utils.datastructures import MultiValueDict from django.utils.datastructures import MultiValueDict
from django.utils.encoding import force_bytes, force_text from django.utils.encoding import force_text
from django.utils.module_loading import import_string from django.utils.module_loading import import_string
from django.utils.translation import ugettext as _ from django.utils.translation import ugettext as _
@ -505,7 +505,7 @@ def technical_404_response(request, exception):
'root_urlconf': settings.ROOT_URLCONF, 'root_urlconf': settings.ROOT_URLCONF,
'request_path': error_url, 'request_path': error_url,
'urlpatterns': tried, 'urlpatterns': tried,
'reason': force_bytes(exception, errors='replace'), 'reason': str(exception),
'request': request, 'request': request,
'settings': get_safe_settings(), 'settings': get_safe_settings(),
'raising_view_name': caller, 'raising_view_name': caller,

View File

@ -5,7 +5,7 @@ from django.core.exceptions import ImproperlyConfigured
from django.db import models from django.db import models
from django.http import Http404 from django.http import Http404
from django.utils import timezone from django.utils import timezone
from django.utils.encoding import force_str, force_text from django.utils.encoding import force_text
from django.utils.functional import cached_property from django.utils.functional import cached_property
from django.utils.translation import ugettext as _ from django.utils.translation import ugettext as _
from django.views.generic.base import View from django.views.generic.base import View
@ -687,7 +687,7 @@ def _date_from_string(year, year_format, month='', month_format='', day='', day_
format = delim.join((year_format, month_format, day_format)) format = delim.join((year_format, month_format, day_format))
datestr = delim.join((year, month, day)) datestr = delim.join((year, month, day))
try: try:
return datetime.datetime.strptime(force_str(datestr), format).date() return datetime.datetime.strptime(datestr, format).date()
except ValueError: except ValueError:
raise Http404(_("Invalid date string '%(datestr)s' given format '%(format)s'") % { raise Http404(_("Invalid date string '%(datestr)s' given format '%(format)s'") % {
'datestr': datestr, 'datestr': datestr,

View File

@ -1397,7 +1397,7 @@ class ManageRunserverEmptyAllowedHosts(AdminScriptTestCase):
class ManageTestserver(AdminScriptTestCase): class ManageTestserver(AdminScriptTestCase):
from django.core.management.commands.testserver import Command as TestserverCommand from django.core.management.commands.testserver import Command as TestserverCommand
@mock.patch.object(TestserverCommand, 'handle') @mock.patch.object(TestserverCommand, 'handle', return_value='')
def test_testserver_handle_params(self, mock_handle): def test_testserver_handle_params(self, mock_handle):
out = StringIO() out = StringIO()
call_command('testserver', 'blah.json', stdout=out) call_command('testserver', 'blah.json', stdout=out)

View File

@ -217,13 +217,9 @@ class UtilsTests(SimpleTestCase):
("History", None) ("History", None)
) )
self.assertEqual(
label_for_field("__unicode__", Article),
"article"
)
self.assertEqual( self.assertEqual(
label_for_field("__str__", Article), label_for_field("__str__", Article),
str("article") "article"
) )
with self.assertRaises(AttributeError): with self.assertRaises(AttributeError):

View File

@ -15,7 +15,6 @@ from django.core.management import call_command
from django.core.management.base import CommandError from django.core.management.base import CommandError
from django.db import migrations from django.db import migrations
from django.test import TestCase, mock, override_settings from django.test import TestCase, mock, override_settings
from django.utils.encoding import force_str
from django.utils.translation import ugettext_lazy as _ from django.utils.translation import ugettext_lazy as _
from .models import ( from .models import (
@ -44,7 +43,7 @@ def mock_inputs(inputs):
assert str('__proxy__') not in prompt assert str('__proxy__') not in prompt
response = '' response = ''
for key, val in inputs.items(): for key, val in inputs.items():
if force_str(key) in prompt.lower(): if key in prompt.lower():
response = val response = val
break break
return response return response

View File

@ -15,7 +15,7 @@ from django.test import (
SimpleTestCase, TestCase, TransactionTestCase, mock, override_settings, SimpleTestCase, TestCase, TransactionTestCase, mock, override_settings,
) )
from django.test.utils import captured_stdout, isolate_apps from django.test.utils import captured_stdout, isolate_apps
from django.utils.encoding import force_str, force_text from django.utils.encoding import force_text
from .models import ( from .models import (
Article, Author, ModelWithNullFKToSite, Post, SchemeIncludedURL, Article, Author, ModelWithNullFKToSite, Post, SchemeIncludedURL,
@ -144,7 +144,7 @@ class GenericForeignKeyTests(SimpleTestCase):
class Model(models.Model): class Model(models.Model):
field = GenericForeignKey() field = GenericForeignKey()
expected = "contenttypes_tests.Model.field" expected = "contenttypes_tests.Model.field"
actual = force_str(Model.field) actual = force_text(Model.field)
self.assertEqual(expected, actual) self.assertEqual(expected, actual)
def test_missing_content_type_field(self): def test_missing_content_type_field(self):

View File

@ -1,9 +1,7 @@
import locale
import os import os
from django.db.backends.postgresql.client import DatabaseClient from django.db.backends.postgresql.client import DatabaseClient
from django.test import SimpleTestCase, mock from django.test import SimpleTestCase, mock
from django.utils.encoding import force_bytes, force_str
class PostgreSqlDbshellCommandTestCase(SimpleTestCase): class PostgreSqlDbshellCommandTestCase(SimpleTestCase):
@ -13,13 +11,12 @@ class PostgreSqlDbshellCommandTestCase(SimpleTestCase):
That function invokes the runshell command, while mocking That function invokes the runshell command, while mocking
subprocess.call. It returns a 2-tuple with: subprocess.call. It returns a 2-tuple with:
- The command line list - The command line list
- The binary content of file pointed by environment PGPASSFILE, or - The content of the file pointed by environment PGPASSFILE, or None.
None.
""" """
def _mock_subprocess_call(*args): def _mock_subprocess_call(*args):
self.subprocess_args = list(*args) self.subprocess_args = list(*args)
if 'PGPASSFILE' in os.environ: if 'PGPASSFILE' in os.environ:
with open(os.environ['PGPASSFILE'], 'rb') as f: with open(os.environ['PGPASSFILE'], 'r') as f:
self.pgpass = f.read().strip() # ignore line endings self.pgpass = f.read().strip() # ignore line endings
else: else:
self.pgpass = None self.pgpass = None
@ -40,7 +37,7 @@ class PostgreSqlDbshellCommandTestCase(SimpleTestCase):
'port': '444', 'port': '444',
}), ( }), (
['psql', '-U', 'someuser', '-h', 'somehost', '-p', '444', 'dbname'], ['psql', '-U', 'someuser', '-h', 'somehost', '-p', '444', 'dbname'],
b'somehost:444:dbname:someuser:somepassword', 'somehost:444:dbname:someuser:somepassword',
) )
) )
@ -67,7 +64,7 @@ class PostgreSqlDbshellCommandTestCase(SimpleTestCase):
'port': '444', 'port': '444',
}), ( }), (
['psql', '-U', 'some:user', '-h', '::1', '-p', '444', 'dbname'], ['psql', '-U', 'some:user', '-h', '::1', '-p', '444', 'dbname'],
b'\\:\\:1:444:dbname:some\\:user:some\\:password', '\\:\\:1:444:dbname:some\\:user:some\\:password',
) )
) )
@ -81,30 +78,23 @@ class PostgreSqlDbshellCommandTestCase(SimpleTestCase):
'port': '444', 'port': '444',
}), ( }), (
['psql', '-U', 'some\\user', '-h', 'somehost', '-p', '444', 'dbname'], ['psql', '-U', 'some\\user', '-h', 'somehost', '-p', '444', 'dbname'],
b'somehost:444:dbname:some\\\\user:some\\\\password', 'somehost:444:dbname:some\\\\user:some\\\\password',
) )
) )
def test_accent(self): def test_accent(self):
# The pgpass temporary file needs to be encoded using the system locale.
encoding = locale.getpreferredencoding()
username = 'rôle' username = 'rôle'
password = 'sésame' password = 'sésame'
username_str = force_str(username, encoding) pgpass_string = 'somehost:444:dbname:%s:%s' % (username, password)
password_str = force_str(password, encoding)
pgpass_bytes = force_bytes(
'somehost:444:dbname:%s:%s' % (username, password),
encoding=encoding,
)
self.assertEqual( self.assertEqual(
self._run_it({ self._run_it({
'database': 'dbname', 'database': 'dbname',
'user': username_str, 'user': username,
'password': password_str, 'password': password,
'host': 'somehost', 'host': 'somehost',
'port': '444', 'port': '444',
}), ( }), (
['psql', '-U', username_str, '-h', 'somehost', '-p', '444', 'dbname'], ['psql', '-U', username, '-h', 'somehost', '-p', '444', 'dbname'],
pgpass_bytes, pgpass_string,
) )
) )

View File

@ -4,7 +4,7 @@ import os
from django.core.files.uploadedfile import UploadedFile from django.core.files.uploadedfile import UploadedFile
from django.http import HttpResponse, HttpResponseServerError from django.http import HttpResponse, HttpResponseServerError
from django.utils.encoding import force_bytes, force_str from django.utils.encoding import force_bytes, force_text
from .models import FileModel from .models import FileModel
from .tests import UNICODE_FILENAME, UPLOAD_TO from .tests import UNICODE_FILENAME, UPLOAD_TO
@ -152,9 +152,7 @@ def file_upload_content_type_extra(request):
""" """
params = {} params = {}
for file_name, uploadedfile in request.FILES.items(): for file_name, uploadedfile in request.FILES.items():
params[file_name] = { params[file_name] = {k: force_text(v) for k, v in uploadedfile.content_type_extra.items()}
k: force_str(v) for k, v in uploadedfile.content_type_extra.items()
}
return HttpResponse(json.dumps(params)) return HttpResponse(json.dumps(params))

View File

@ -2,7 +2,6 @@ import datetime
from django.core.exceptions import ImproperlyConfigured from django.core.exceptions import ImproperlyConfigured
from django.test import TestCase, override_settings from django.test import TestCase, override_settings
from django.utils.encoding import force_str
from django.views.generic.base import View from django.views.generic.base import View
from .models import Artist, Author, Book, Page from .models import Artist, Author, Book, Page
@ -235,7 +234,7 @@ class ListViewTests(TestCase):
self._make_authors(1) self._make_authors(1)
res = self.client.get('/list/authors/paginated/2/') res = self.client.get('/list/authors/paginated/2/')
self.assertEqual(res.status_code, 404) self.assertEqual(res.status_code, 404)
self.assertEqual(force_str(res.context.get('reason')), "Invalid page (2): That page contains no results") self.assertEqual(res.context.get('reason'), "Invalid page (2): That page contains no results")
def _make_authors(self, n): def _make_authors(self, n):
Author.objects.all().delete() Author.objects.all().delete()

View File

@ -7,7 +7,6 @@ from django.db import close_old_connections, connection
from django.test import ( from django.test import (
RequestFactory, SimpleTestCase, TransactionTestCase, override_settings, RequestFactory, SimpleTestCase, TransactionTestCase, override_settings,
) )
from django.utils.encoding import force_str
try: try:
from http import HTTPStatus from http import HTTPStatus
@ -65,10 +64,7 @@ class HandlerTests(SimpleTestCase):
raw_cookie = 'want="café"'.encode('utf-8').decode('iso-8859-1') raw_cookie = 'want="café"'.encode('utf-8').decode('iso-8859-1')
environ['HTTP_COOKIE'] = raw_cookie environ['HTTP_COOKIE'] = raw_cookie
request = WSGIRequest(environ) request = WSGIRequest(environ)
# If would be nicer if request.COOKIES returned unicode values. self.assertEqual(request.COOKIES['want'], "café")
# However the current cookie parser doesn't do this and fixing it is
# much more work than fixing #20557. Feel free to remove force_str()!
self.assertEqual(request.COOKIES['want'], force_str("café"))
def test_invalid_unicode_cookie(self): def test_invalid_unicode_cookie(self):
""" """

View File

@ -17,7 +17,6 @@ from django.http import (
) )
from django.test import SimpleTestCase from django.test import SimpleTestCase
from django.utils._os import upath from django.utils._os import upath
from django.utils.encoding import force_str
from django.utils.functional import lazystr from django.utils.functional import lazystr
@ -294,13 +293,8 @@ class HttpResponseTests(unittest.TestCase):
self.assertIsInstance(r['key'], str) self.assertIsInstance(r['key'], str)
self.assertIn(b'test', r.serialize_headers()) self.assertIn(b'test', r.serialize_headers())
# Latin-1 unicode or bytes values are also converted to native strings. # Non-ASCII values are serialized to Latin-1.
r['key'] = 'café' r['key'] = 'café'
self.assertEqual(r['key'], force_str('café', 'latin-1'))
self.assertIsInstance(r['key'], str)
r['key'] = 'café'.encode('latin-1')
self.assertEqual(r['key'], force_str('café', 'latin-1'))
self.assertIsInstance(r['key'], str)
self.assertIn('café'.encode('latin-1'), r.serialize_headers()) self.assertIn('café'.encode('latin-1'), r.serialize_headers())
# Other unicode values are MIME-encoded (there's no way to pass them as bytes). # Other unicode values are MIME-encoded (there's no way to pass them as bytes).
@ -759,7 +753,7 @@ class CookieTests(unittest.TestCase):
# More characters the spec forbids. # More characters the spec forbids.
self.assertEqual(parse_cookie('a b,c<>@:/[]?{}=d " =e,f g'), {'a b,c<>@:/[]?{}': 'd " =e,f g'}) self.assertEqual(parse_cookie('a b,c<>@:/[]?{}=d " =e,f g'), {'a b,c<>@:/[]?{}': 'd " =e,f g'})
# Unicode characters. The spec only allows ASCII. # Unicode characters. The spec only allows ASCII.
self.assertEqual(parse_cookie('saint=André Bessette'), {'saint': force_str('André Bessette')}) self.assertEqual(parse_cookie('saint=André Bessette'), {'saint': 'André Bessette'})
# Browsers don't send extra whitespace or semicolons in Cookie headers, # Browsers don't send extra whitespace or semicolons in Cookie headers,
# but parse_cookie() should parse whitespace the same way # but parse_cookie() should parse whitespace the same way
# document.cookie parses whitespace. # document.cookie parses whitespace.

View File

@ -22,7 +22,6 @@ from django.test import (
RequestFactory, SimpleTestCase, ignore_warnings, override_settings, RequestFactory, SimpleTestCase, ignore_warnings, override_settings,
) )
from django.utils.deprecation import RemovedInDjango21Warning from django.utils.deprecation import RemovedInDjango21Warning
from django.utils.encoding import force_str
int2byte = struct.Struct(">B").pack int2byte = struct.Struct(">B").pack
@ -350,7 +349,7 @@ class CommonMiddlewareTest(SimpleTestCase):
def test_non_ascii_query_string_does_not_crash(self): def test_non_ascii_query_string_does_not_crash(self):
"""Regression test for #15152""" """Regression test for #15152"""
request = self.rf.get('/slash') request = self.rf.get('/slash')
request.META['QUERY_STRING'] = force_str('drink=café') request.META['QUERY_STRING'] = 'drink=café'
r = CommonMiddleware().process_request(request) r = CommonMiddleware().process_request(request)
self.assertEqual(r.status_code, 301) self.assertEqual(r.status_code, 301)

View File

@ -24,7 +24,6 @@ from django.test import SimpleTestCase, ignore_warnings, mock
from django.utils import datetime_safe from django.utils import datetime_safe
from django.utils._os import upath from django.utils._os import upath
from django.utils.deconstruct import deconstructible from django.utils.deconstruct import deconstructible
from django.utils.encoding import force_str
from django.utils.functional import SimpleLazyObject from django.utils.functional import SimpleLazyObject
from django.utils.timezone import FixedOffset, get_default_timezone, utc from django.utils.timezone import FixedOffset, get_default_timezone, utc
from django.utils.translation import ugettext_lazy as _ from django.utils.translation import ugettext_lazy as _
@ -170,7 +169,7 @@ class WriterTests(SimpleTestCase):
def safe_exec(self, string, value=None): def safe_exec(self, string, value=None):
d = {} d = {}
try: try:
exec(force_str(string), globals(), d) exec(string, globals(), d)
except Exception as e: except Exception as e:
if value: if value:
self.fail("Could not exec %r (from value %r): %s" % (string.strip(), value, e)) self.fail("Could not exec %r (from value %r): %s" % (string.strip(), value, e))

View File

@ -3,7 +3,6 @@ from operator import attrgetter
from django.db.models import Q from django.db.models import Q
from django.test import TestCase from django.test import TestCase
from django.utils.encoding import force_str
from .models import Article from .models import Article
@ -124,9 +123,9 @@ class OrLookupsTests(TestCase):
def test_q_repr(self): def test_q_repr(self):
or_expr = Q(baz=Article(headline="Foö")) or_expr = Q(baz=Article(headline="Foö"))
self.assertEqual(repr(or_expr), force_str("<Q: (AND: ('baz', <Article: Foö>))>")) self.assertEqual(repr(or_expr), "<Q: (AND: ('baz', <Article: Foö>))>")
negated_or = ~Q(baz=Article(headline="Foö")) negated_or = ~Q(baz=Article(headline="Foö"))
self.assertEqual(repr(negated_or), force_str("<Q: (NOT (AND: ('baz', <Article: Foö>)))>")) self.assertEqual(repr(negated_or), "<Q: (NOT (AND: ('baz', <Article: Foö>)))>")
def test_q_negated(self): def test_q_negated(self):
# Q objects can be negated # Q objects can be negated

View File

@ -14,7 +14,6 @@ from django.http.request import split_domain_port
from django.test import RequestFactory, SimpleTestCase, override_settings from django.test import RequestFactory, SimpleTestCase, override_settings
from django.test.client import FakePayload from django.test.client import FakePayload
from django.test.utils import freeze_time, str_prefix from django.test.utils import freeze_time, str_prefix
from django.utils.encoding import force_str
from django.utils.http import cookie_date, urlencode from django.utils.http import cookie_date, urlencode
from django.utils.timezone import utc from django.utils.timezone import utc
@ -270,7 +269,7 @@ class RequestsTests(SimpleTestCase):
response = HttpResponse() response = HttpResponse()
cookie_value = '清風' cookie_value = '清風'
response.set_cookie('test', cookie_value) response.set_cookie('test', cookie_value)
self.assertEqual(force_str(cookie_value), response.cookies['test'].value) self.assertEqual(cookie_value, response.cookies['test'].value)
def test_limited_stream(self): def test_limited_stream(self):
# Read all of a limited stream # Read all of a limited stream

View File

@ -3,7 +3,6 @@ import datetime
from django.core import signing from django.core import signing
from django.test import SimpleTestCase from django.test import SimpleTestCase
from django.test.utils import freeze_time from django.test.utils import freeze_time
from django.utils.encoding import force_str
class TestSigner(SimpleTestCase): class TestSigner(SimpleTestCase):
@ -47,7 +46,7 @@ class TestSigner(SimpleTestCase):
for example in examples: for example in examples:
signed = signer.sign(example) signed = signer.sign(example)
self.assertIsInstance(signed, str) self.assertIsInstance(signed, str)
self.assertNotEqual(force_str(example), signed) self.assertNotEqual(example, signed)
self.assertEqual(example, signer.unsign(signed)) self.assertEqual(example, signer.unsign(signed))
def test_unsign_detects_tampering(self): def test_unsign_detects_tampering(self):