diff --git a/django/contrib/admin/templatetags/admin_list.py b/django/contrib/admin/templatetags/admin_list.py
index 534f4c4681..777bfbac81 100644
--- a/django/contrib/admin/templatetags/admin_list.py
+++ b/django/contrib/admin/templatetags/admin_list.py
@@ -34,12 +34,12 @@ def paginator_number(cl, i):
if i == DOT:
return '... '
elif i == cl.page_num:
- return format_html('{0} ', i+1)
+ return format_html('{0} ', i + 1)
else:
return format_html('{2} ',
cl.get_query_string({PAGE_VAR: i}),
- mark_safe(' class="end"' if i == cl.paginator.num_pages-1 else ''),
- i+1)
+ mark_safe(' class="end"' if i == cl.paginator.num_pages - 1 else ''),
+ i + 1)
@register.inclusion_tag('admin/pagination.html')
diff --git a/django/contrib/admin/utils.py b/django/contrib/admin/utils.py
index ed3668907a..82f6c42721 100644
--- a/django/contrib/admin/utils.py
+++ b/django/contrib/admin/utils.py
@@ -412,7 +412,7 @@ def reverse_field_path(model, path):
for piece in pieces:
field, model, direct, m2m = parent._meta.get_field_by_name(piece)
# skip trailing data field if extant:
- if len(reversed_path) == len(pieces)-1: # final iteration
+ if len(reversed_path) == len(pieces) - 1: # final iteration
try:
get_model_from_relation(field)
except NotRelationField:
diff --git a/django/contrib/admin/views/main.py b/django/contrib/admin/views/main.py
index a0ffef90f4..4b0da928a2 100644
--- a/django/contrib/admin/views/main.py
+++ b/django/contrib/admin/views/main.py
@@ -236,7 +236,7 @@ class ChangeList(six.with_metaclass(RenameChangeListMethods)):
result_list = self.queryset._clone()
else:
try:
- result_list = paginator.page(self.page_num+1).object_list
+ result_list = paginator.page(self.page_num + 1).object_list
except InvalidPage:
raise IncorrectLookupParameters
diff --git a/django/contrib/gis/geos/mutable_list.py b/django/contrib/gis/geos/mutable_list.py
index 08ebb0a8e7..d9108d6c58 100644
--- a/django/contrib/gis/geos/mutable_list.py
+++ b/django/contrib/gis/geos/mutable_list.py
@@ -145,7 +145,7 @@ class ListMixin(object):
del self[:]
else:
cache = list(self)
- for i in range(n-1):
+ for i in range(n - 1):
self.extend(cache)
return self
diff --git a/django/contrib/gis/geos/polygon.py b/django/contrib/gis/geos/polygon.py
index ef8eb27de5..f617f1fe76 100644
--- a/django/contrib/gis/geos/polygon.py
+++ b/django/contrib/gis/geos/polygon.py
@@ -134,7 +134,7 @@ class Polygon(GEOSGeometry):
return capi.get_extring(self.ptr)
else:
# Getting the interior ring, have to subtract 1 from the index.
- return capi.get_intring(self.ptr, index-1)
+ return capi.get_intring(self.ptr, index - 1)
def _get_single_external(self, index):
return GEOSGeometry(capi.geom_clone(self._get_single_internal(index)), srid=self.srid)
@@ -170,6 +170,6 @@ class Polygon(GEOSGeometry):
@property
def kml(self):
"Returns the KML representation of this Polygon."
- inner_kml = ''.join("%s" % self[i+1].kml
+ inner_kml = ''.join("%s" % self[i + 1].kml
for i in xrange(self.num_interior_rings))
return "%s%s" % (self[0].kml, inner_kml)
diff --git a/django/contrib/gis/geos/tests/test_geos.py b/django/contrib/gis/geos/tests/test_geos.py
index 59cd9a32cc..3f0ce0652b 100644
--- a/django/contrib/gis/geos/tests/test_geos.py
+++ b/django/contrib/gis/geos/tests/test_geos.py
@@ -1081,11 +1081,11 @@ class GEOSTest(unittest.TestCase, TestDataMixin):
self.assertEqual(ls.project(Point(0, 20)), 10.0)
self.assertEqual(ls.project(Point(7, 6)), 24)
- self.assertEqual(ls.project_normalized(Point(0, 20)), 1.0/3)
+ self.assertEqual(ls.project_normalized(Point(0, 20)), 1.0 / 3)
self.assertEqual(ls.interpolate(10), Point(0, 10))
self.assertEqual(ls.interpolate(24), Point(10, 6))
- self.assertEqual(ls.interpolate_normalized(1.0/3), Point(0, 10))
+ self.assertEqual(ls.interpolate_normalized(1.0 / 3), Point(0, 10))
self.assertEqual(mls.project(Point(0, 20)), 10)
self.assertEqual(mls.project(Point(7, 6)), 16)
diff --git a/django/contrib/gis/geos/tests/test_mutable_list.py b/django/contrib/gis/geos/tests/test_mutable_list.py
index 5340dac99d..9cdd80bc17 100644
--- a/django/contrib/gis/geos/tests/test_mutable_list.py
+++ b/django/contrib/gis/geos/tests/test_mutable_list.py
@@ -349,8 +349,8 @@ class ListMixinTest(unittest.TestCase):
ul.sort()
self.assertEqual(pl[:], ul[:], 'sort')
mid = pl[len(pl) // 2]
- pl.sort(key=lambda x: (mid-x)**2)
- ul.sort(key=lambda x: (mid-x)**2)
+ pl.sort(key=lambda x: (mid - x) ** 2)
+ ul.sort(key=lambda x: (mid - x) ** 2)
self.assertEqual(pl[:], ul[:], 'sort w/ key')
pl.insert(0, pl.pop())
@@ -359,8 +359,8 @@ class ListMixinTest(unittest.TestCase):
ul.sort(reverse=True)
self.assertEqual(pl[:], ul[:], 'sort w/ reverse')
mid = pl[len(pl) // 2]
- pl.sort(key=lambda x: (mid-x)**2)
- ul.sort(key=lambda x: (mid-x)**2)
+ pl.sort(key=lambda x: (mid - x) ** 2)
+ ul.sort(key=lambda x: (mid - x) ** 2)
self.assertEqual(pl[:], ul[:], 'sort w/ key')
def test_12_arithmetic(self):
diff --git a/django/contrib/gis/maps/google/zoom.py b/django/contrib/gis/maps/google/zoom.py
index 22b3ceac1d..e6e5d9217e 100644
--- a/django/contrib/gis/maps/google/zoom.py
+++ b/django/contrib/gis/maps/google/zoom.py
@@ -79,7 +79,7 @@ class GoogleZoom(object):
fac = min(max(sin(DTOR * lat), -0.9999), 0.9999)
# Calculating the pixel y coordinate.
- px_y = round(npix + (0.5 * log((1 + fac)/(1 - fac)) * (-1.0 * self._radpp[zoom])))
+ px_y = round(npix + (0.5 * log((1 + fac) / (1 - fac)) * (-1.0 * self._radpp[zoom])))
# Returning the pixel x, y to the caller of the function.
return (px_x, px_y)
@@ -116,8 +116,8 @@ class GoogleZoom(object):
# Getting the lower-left and upper-right lat/lon coordinates
# for the bounding box of the tile.
- ll = self.pixel_to_lonlat((px[0]-delta, px[1]-delta), zoom)
- ur = self.pixel_to_lonlat((px[0]+delta, px[1]+delta), zoom)
+ ll = self.pixel_to_lonlat((px[0] - delta, px[1] - delta), zoom)
+ ur = self.pixel_to_lonlat((px[0] + delta, px[1] + delta), zoom)
# Constructing the Polygon, representing the tile and returning.
return Polygon(LinearRing(ll, (ll[0], ur[1]), ur, (ur[0], ll[1]), ll), srid=4326)
@@ -143,10 +143,10 @@ class GoogleZoom(object):
if (env_w > tile_w) or (env_h > tile_h):
if z == 0:
raise GoogleMapException('Geometry width and height should not exceed that of the Earth.')
- return z-1
+ return z - 1
# Otherwise, we've zoomed in to the max.
- return self._nzoom-1
+ return self._nzoom - 1
def get_width_height(self, extent):
"""
diff --git a/django/contrib/gis/sitemaps/views.py b/django/contrib/gis/sitemaps/views.py
index 8dad5c505c..c4c08de8f5 100644
--- a/django/contrib/gis/sitemaps/views.py
+++ b/django/contrib/gis/sitemaps/views.py
@@ -32,7 +32,7 @@ def index(request, sitemaps):
sites.append('%s://%s%s' % (protocol, current_site.domain, sitemap_url))
if pages > 1:
- for page in range(2, pages+1):
+ for page in range(2, pages + 1):
sites.append('%s://%s%s?p=%s' % (protocol, current_site.domain, sitemap_url, page))
xml = loader.render_to_string('sitemap_index.xml', {'sitemaps': sites})
return HttpResponse(xml, content_type='application/xml')
diff --git a/django/contrib/gis/tests/test_measure.py b/django/contrib/gis/tests/test_measure.py
index 1c4fa448d2..37a0d51dbb 100644
--- a/django/contrib/gis/tests/test_measure.py
+++ b/django/contrib/gis/tests/test_measure.py
@@ -94,7 +94,7 @@ class DistanceTest(unittest.TestCase):
a5 = d1 * D(m=10)
self.assertTrue(isinstance(a5, Area))
- self.assertEqual(a5.sq_m, 100*10)
+ self.assertEqual(a5.sq_m, 100 * 10)
with self.assertRaises(TypeError):
d1 *= D(m=1)
diff --git a/django/contrib/gis/utils/layermapping.py b/django/contrib/gis/utils/layermapping.py
index 5f57bc1749..3ba087b967 100644
--- a/django/contrib/gis/utils/layermapping.py
+++ b/django/contrib/gis/utils/layermapping.py
@@ -600,7 +600,7 @@ class LayerMapping(object):
for i, end in enumerate(indices):
# Constructing the slice to use for this step; the last slice is
# special (e.g, [100:] instead of [90:100]).
- if i+1 == n_i:
+ if i + 1 == n_i:
step_slice = slice(beg, None)
else:
step_slice = slice(beg, end)
diff --git a/django/contrib/humanize/templatetags/humanize.py b/django/contrib/humanize/templatetags/humanize.py
index 9b5524da31..e33631a15d 100644
--- a/django/contrib/humanize/templatetags/humanize.py
+++ b/django/contrib/humanize/templatetags/humanize.py
@@ -148,7 +148,7 @@ def apnumber(value):
return value
if not 0 < value < 10:
return value
- return (_('one'), _('two'), _('three'), _('four'), _('five'), _('six'), _('seven'), _('eight'), _('nine'))[value-1]
+ return (_('one'), _('two'), _('three'), _('four'), _('five'), _('six'), _('seven'), _('eight'), _('nine'))[value - 1]
# Perform the comparison in the default time zone when USE_TZ = True
diff --git a/django/core/cache/backends/base.py b/django/core/cache/backends/base.py
index 13c34ea697..2c3151369a 100644
--- a/django/core/cache/backends/base.py
+++ b/django/core/cache/backends/base.py
@@ -233,9 +233,9 @@ class BaseCache(object):
if value is None:
raise ValueError("Key '%s' not found" % key)
- self.set(key, value, version=version+delta)
+ self.set(key, value, version=version + delta)
self.delete(key, version=version)
- return version+delta
+ return version + delta
def decr_version(self, key, delta=1, version=None):
"""Substracts delta from the cache version for the supplied key. Returns
diff --git a/django/core/files/base.py b/django/core/files/base.py
index 7abb94b1f2..b1325291c6 100644
--- a/django/core/files/base.py
+++ b/django/core/files/base.py
@@ -11,7 +11,7 @@ from django.utils.encoding import force_bytes, python_2_unicode_compatible
@python_2_unicode_compatible
class File(FileProxyMixin):
- DEFAULT_CHUNK_SIZE = 64 * 2**10
+ DEFAULT_CHUNK_SIZE = 64 * 2 ** 10
def __init__(self, file, name=None):
self.file = file
diff --git a/django/core/files/images.py b/django/core/files/images.py
index e1d6091658..b289d789ad 100644
--- a/django/core/files/images.py
+++ b/django/core/files/images.py
@@ -65,7 +65,7 @@ def get_image_dimensions(file_or_path, close=False):
raise
if p.image:
return p.image.size
- chunk_size = chunk_size*2
+ chunk_size *= 2
return None
finally:
if close:
diff --git a/django/core/files/move.py b/django/core/files/move.py
index fddee565b4..8aee5afaa6 100644
--- a/django/core/files/move.py
+++ b/django/core/files/move.py
@@ -38,7 +38,7 @@ def _samefile(src, dst):
os.path.normcase(os.path.abspath(dst)))
-def file_move_safe(old_file_name, new_file_name, chunk_size=1024*64, allow_overwrite=False):
+def file_move_safe(old_file_name, new_file_name, chunk_size=1024 * 64, allow_overwrite=False):
"""
Moves a file from one location to another in the safest way possible.
diff --git a/django/core/files/uploadedfile.py b/django/core/files/uploadedfile.py
index b53a502068..aa076a8559 100644
--- a/django/core/files/uploadedfile.py
+++ b/django/core/files/uploadedfile.py
@@ -23,7 +23,7 @@ class UploadedFile(File):
An ``UploadedFile`` object behaves somewhat like a file object and
represents some file data that the user submitted with a form.
"""
- DEFAULT_CHUNK_SIZE = 64 * 2**10
+ DEFAULT_CHUNK_SIZE = 64 * 2 ** 10
def __init__(self, file=None, name=None, content_type=None, size=None, charset=None, content_type_extra=None):
super(UploadedFile, self).__init__(file, name)
diff --git a/django/core/management/__init__.py b/django/core/management/__init__.py
index de49f5e241..e24193c52b 100644
--- a/django/core/management/__init__.py
+++ b/django/core/management/__init__.py
@@ -317,7 +317,7 @@ class ManagementUtility(object):
cword = int(os.environ['COMP_CWORD'])
try:
- curr = cwords[cword-1]
+ curr = cwords[cword - 1]
except IndexError:
curr = ''
@@ -350,7 +350,7 @@ class ManagementUtility(object):
options += [(s_opt.get_opt_string(), s_opt.nargs) for s_opt in
subcommand_cls.option_list]
# filter out previously specified options from available options
- prev_opts = [x.split('=')[0] for x in cwords[1:cword-1]]
+ prev_opts = [x.split('=')[0] for x in cwords[1:cword - 1]]
options = [opt for opt in options if opt[0] not in prev_opts]
# filter options by current input
diff --git a/django/core/management/commands/createcachetable.py b/django/core/management/commands/createcachetable.py
index c375fc2b17..be6da1dbf0 100644
--- a/django/core/management/commands/createcachetable.py
+++ b/django/core/management/commands/createcachetable.py
@@ -69,7 +69,7 @@ class Command(BaseCommand):
table_output.append(" ".join(field_output))
full_statement = ["CREATE TABLE %s (" % qn(tablename)]
for i, line in enumerate(table_output):
- full_statement.append(' %s%s' % (line, ',' if i < len(table_output)-1 else ''))
+ full_statement.append(' %s%s' % (line, ',' if i < len(table_output) - 1 else ''))
full_statement.append(');')
with transaction.commit_on_success_unless_managed():
curs = connection.cursor()
diff --git a/django/core/urlresolvers.py b/django/core/urlresolvers.py
index 76b50916e0..13919144e5 100644
--- a/django/core/urlresolvers.py
+++ b/django/core/urlresolvers.py
@@ -147,7 +147,7 @@ def get_mod_func(callback):
dot = callback.rindex('.')
except ValueError:
return callback, ''
- return callback[:dot], callback[dot+1:]
+ return callback[:dot], callback[dot + 1:]
class LocaleRegexProvider(object):
diff --git a/django/db/migrations/operations/special.py b/django/db/migrations/operations/special.py
index ef3f7169a5..f48d8cab05 100644
--- a/django/db/migrations/operations/special.py
+++ b/django/db/migrations/operations/special.py
@@ -33,7 +33,7 @@ class SeparateDatabaseAndState(Operation):
base_state = to_state
for pos, database_operation in enumerate(reversed(self.database_operations)):
to_state = base_state.clone()
- for dbop in self.database_operations[:-(pos+1)]:
+ for dbop in self.database_operations[:-(pos + 1)]:
dbop.state_forwards(app_label, to_state)
from_state = base_state.clone()
database_operation.state_forwards(app_label, from_state)
diff --git a/django/db/migrations/optimizer.py b/django/db/migrations/optimizer.py
index 980eedddf7..fe527a5c3e 100644
--- a/django/db/migrations/optimizer.py
+++ b/django/db/migrations/optimizer.py
@@ -48,13 +48,13 @@ class MigrationOptimizer(object):
new_operations = []
for i, operation in enumerate(operations):
# Compare it to each operation after it
- for j, other in enumerate(operations[i+1:]):
+ for j, other in enumerate(operations[i + 1:]):
result = self.reduce(operation, other)
if result is not None:
# Optimize! Add result, then remaining others, then return
new_operations.extend(result)
- new_operations.extend(operations[i+1:i+1+j])
- new_operations.extend(operations[i+j+2:])
+ new_operations.extend(operations[i + 1:i + 1 + j])
+ new_operations.extend(operations[i + j + 2:])
return new_operations
if not self.can_optimize_through(operation, other, app_label):
new_operations.append(operation)
diff --git a/django/db/models/query.py b/django/db/models/query.py
index 5bfa68b071..1289e14755 100644
--- a/django/db/models/query.py
+++ b/django/db/models/query.py
@@ -1359,7 +1359,7 @@ def get_klass_info(klass, max_depth=0, cur_depth=0, requested=None,
next = requested[f.name]
else:
next = None
- klass_info = get_klass_info(f.rel.to, max_depth=max_depth, cur_depth=cur_depth+1,
+ klass_info = get_klass_info(f.rel.to, max_depth=max_depth, cur_depth=cur_depth + 1,
requested=next, only_load=only_load)
related_fields.append((f, klass_info))
diff --git a/django/forms/extras/widgets.py b/django/forms/extras/widgets.py
index 95831679b8..7fd209f397 100644
--- a/django/forms/extras/widgets.py
+++ b/django/forms/extras/widgets.py
@@ -62,7 +62,7 @@ class SelectDateWidget(Widget):
self.years = years
else:
this_year = datetime.date.today().year
- self.years = range(this_year, this_year+10)
+ self.years = range(this_year, this_year + 10)
# Optional dict of months to use in the "month" select box.
if months:
diff --git a/django/forms/formsets.py b/django/forms/formsets.py
index 9c8b790d59..625f597117 100644
--- a/django/forms/formsets.py
+++ b/django/forms/formsets.py
@@ -363,7 +363,7 @@ class BaseFormSet(object):
if self.can_order:
# Only pre-fill the ordering field for initial forms.
if index is not None and index < self.initial_form_count():
- form.fields[ORDERING_FIELD_NAME] = IntegerField(label=_('Order'), initial=index+1, required=False)
+ form.fields[ORDERING_FIELD_NAME] = IntegerField(label=_('Order'), initial=index + 1, required=False)
else:
form.fields[ORDERING_FIELD_NAME] = IntegerField(label=_('Order'), required=False)
if self.can_delete:
diff --git a/django/forms/models.py b/django/forms/models.py
index 32f0f043ae..6d9a567926 100644
--- a/django/forms/models.py
+++ b/django/forms/models.py
@@ -572,7 +572,7 @@ class BaseModelFormSet(BaseFormSet):
if i >= self.initial_form_count() and self.initial_extra:
# Set initial values for extra forms
try:
- kwargs['initial'] = self.initial_extra[i-self.initial_form_count()]
+ kwargs['initial'] = self.initial_extra[i - self.initial_form_count()]
except IndexError:
pass
return super(BaseModelFormSet, self)._construct_form(i, **kwargs)
diff --git a/django/http/multipartparser.py b/django/http/multipartparser.py
index 21617255a8..1c64195f25 100644
--- a/django/http/multipartparser.py
+++ b/django/http/multipartparser.py
@@ -94,7 +94,7 @@ class MultiPartParser(object):
# For compatibility with low-level network APIs (with 32-bit integers),
# the chunk size should be < 2^31, but still divisible by 4.
possible_sizes = [x.chunk_size for x in upload_handlers if x.chunk_size]
- self._chunk_size = min([2**31-4] + possible_sizes)
+ self._chunk_size = min([2 ** 31 - 4] + possible_sizes)
self._meta = META
self._encoding = encoding or settings.DEFAULT_CHARSET
@@ -267,7 +267,7 @@ class MultiPartParser(object):
def IE_sanitize(self, filename):
"""Cleanup filename from Internet Explorer full paths."""
- return filename and filename[filename.rfind("\\")+1:].strip()
+ return filename and filename[filename.rfind("\\") + 1:].strip()
class LazyStream(six.Iterator):
@@ -512,11 +512,11 @@ class BoundaryIter(six.Iterator):
end = index
next = index + len(self._boundary)
# backup over CRLF
- last = max(0, end-1)
- if data[last:last+1] == b'\n':
+ last = max(0, end - 1)
+ if data[last:last + 1] == b'\n':
end -= 1
- last = max(0, end-1)
- if data[last:last+1] == b'\r':
+ last = max(0, end - 1)
+ if data[last:last + 1] == b'\r':
end -= 1
return end, next
@@ -623,7 +623,7 @@ def parse_header(line):
i = p.find(b'=')
if i >= 0:
name = p[:i].strip().lower().decode('ascii')
- value = p[i+1:].strip()
+ value = p[i + 1:].strip()
if len(value) >= 2 and value[:1] == value[-1:] == b'"':
value = value[1:-1]
value = value.replace(b'\\\\', b'\\').replace(b'\\"', b'"')
diff --git a/django/template/defaultfilters.py b/django/template/defaultfilters.py
index a4f0a89554..1bd54404b3 100644
--- a/django/template/defaultfilters.py
+++ b/django/template/defaultfilters.py
@@ -680,14 +680,14 @@ def unordered_list(value, autoescape=None):
sublist_item = title
title = ''
elif i < list_length - 1:
- next_item = list_[i+1]
+ next_item = list_[i + 1]
if next_item and isinstance(next_item, (list, tuple)):
# The next item is a sub-list.
sublist_item = next_item
# We've processed the next item now too.
i += 1
if sublist_item:
- sublist = _helper(sublist_item, tabs+1)
+ sublist = _helper(sublist_item, tabs + 1)
sublist = '\n%s
\n%s' % (indent, sublist,
indent, indent)
output.append('%s%s%s' % (indent,
diff --git a/django/template/defaulttags.py b/django/template/defaulttags.py
index 77d63ab256..011d15ea65 100644
--- a/django/template/defaulttags.py
+++ b/django/template/defaulttags.py
@@ -171,7 +171,7 @@ class ForNode(Node):
for i, item in enumerate(values):
# Shortcuts for current loop iteration number.
loop_dict['counter0'] = i
- loop_dict['counter'] = i+1
+ loop_dict['counter'] = i + 1
# Reverse counter iteration numbers.
loop_dict['revcounter'] = len_values - i
loop_dict['revcounter0'] = len_values - i - 1
@@ -832,7 +832,7 @@ def do_for(parser, token):
raise TemplateSyntaxError("'for' tag received an invalid argument:"
" %s" % token.contents)
- sequence = parser.compile_filter(bits[in_index+1])
+ sequence = parser.compile_filter(bits[in_index + 1])
nodelist_loop = parser.parse(('empty', 'endfor',))
token = parser.next_token()
if token.contents == 'empty':
diff --git a/django/template/smartif.py b/django/template/smartif.py
index 4a9e2ef541..554a214cb6 100644
--- a/django/template/smartif.py
+++ b/django/template/smartif.py
@@ -158,7 +158,7 @@ class IfParser(object):
i = 0
while i < l:
token = tokens[i]
- if token == "not" and i + 1 < l and tokens[i+1] == "in":
+ if token == "not" and i + 1 < l and tokens[i + 1] == "in":
token = "not in"
i += 1 # skip 'in'
mapped_tokens.append(self.translate_token(token))
diff --git a/django/test/runner.py b/django/test/runner.py
index 148f6a3e17..44adaab141 100644
--- a/django/test/runner.py
+++ b/django/test/runner.py
@@ -203,10 +203,10 @@ def reorder_suite(suite, classes):
"""
class_count = len(classes)
suite_class = type(suite)
- bins = [suite_class() for i in range(class_count+1)]
+ bins = [suite_class() for i in range(class_count + 1)]
partition_suite(suite, classes, bins)
for i in range(class_count):
- bins[0].addTests(bins[i+1])
+ bins[0].addTests(bins[i + 1])
return bins[0]
diff --git a/django/utils/dateformat.py b/django/utils/dateformat.py
index 78483f2d4c..1640f9ae5a 100644
--- a/django/utils/dateformat.py
+++ b/django/utils/dateformat.py
@@ -303,7 +303,7 @@ class DateFormat(TimeFormat):
weekday = self.data.weekday() + 1
day_of_year = self.z()
if day_of_year <= (8 - jan1_weekday) and jan1_weekday > 4:
- if jan1_weekday == 5 or (jan1_weekday == 6 and calendar.isleap(self.data.year-1)):
+ if jan1_weekday == 5 or (jan1_weekday == 6 and calendar.isleap(self.data.year - 1)):
week_number = 53
else:
week_number = 52
diff --git a/django/utils/datetime_safe.py b/django/utils/datetime_safe.py
index a584011db5..6cd0bf1cdd 100644
--- a/django/utils/datetime_safe.py
+++ b/django/utils/datetime_safe.py
@@ -83,8 +83,8 @@ def strftime(dt, fmt):
s1 = time.strftime(fmt, (year,) + timetuple[1:])
sites1 = _findall(s1, str(year))
- s2 = time.strftime(fmt, (year+28,) + timetuple[1:])
- sites2 = _findall(s2, str(year+28))
+ s2 = time.strftime(fmt, (year + 28,) + timetuple[1:])
+ sites2 = _findall(s2, str(year + 28))
sites = []
for site in sites1:
@@ -94,5 +94,5 @@ def strftime(dt, fmt):
s = s1
syear = "%04d" % (dt.year,)
for site in sites:
- s = s[:site] + syear + s[site+4:]
+ s = s[:site] + syear + s[site + 4:]
return s
diff --git a/django/utils/jslex.py b/django/utils/jslex.py
index 8c481fd1d8..1b47230b6d 100644
--- a/django/utils/jslex.py
+++ b/django/utils/jslex.py
@@ -25,7 +25,7 @@ def literals(choices, prefix="", suffix=""):
individually.
"""
- return "|".join(prefix+re.escape(c)+suffix for c in choices.split())
+ return "|".join(prefix + re.escape(c) + suffix for c in choices.split())
class Lexer(object):
diff --git a/django/utils/translation/trans_null.py b/django/utils/translation/trans_null.py
index 9e3beb0f7d..69f32bc243 100644
--- a/django/utils/translation/trans_null.py
+++ b/django/utils/translation/trans_null.py
@@ -59,7 +59,7 @@ gettext_noop = gettext_lazy = _ = gettext
def to_locale(language):
p = language.find('-')
if p >= 0:
- return language[:p].lower()+'_'+language[p+1:].upper()
+ return language[:p].lower() + '_' + language[p + 1:].upper()
else:
return language.lower()
diff --git a/django/utils/translation/trans_real.py b/django/utils/translation/trans_real.py
index d78b6d6412..0f08056778 100644
--- a/django/utils/translation/trans_real.py
+++ b/django/utils/translation/trans_real.py
@@ -55,12 +55,12 @@ def to_locale(language, to_lower=False):
p = language.find('-')
if p >= 0:
if to_lower:
- return language[:p].lower()+'_'+language[p+1:].lower()
+ return language[:p].lower() + '_' + language[p + 1:].lower()
else:
# Get correct locale for sr-latn
- if len(language[p+1:]) > 2:
- return language[:p].lower()+'_'+language[p+1].upper()+language[p+2:].lower()
- return language[:p].lower()+'_'+language[p+1:].upper()
+ if len(language[p + 1:]) > 2:
+ return language[:p].lower() + '_' + language[p + 1].upper() + language[p + 2:].lower()
+ return language[:p].lower() + '_' + language[p + 1:].upper()
else:
return language.lower()
@@ -69,7 +69,7 @@ def to_language(locale):
"""Turns a locale name (en_US) into a language name (en-us)."""
p = locale.find('_')
if p >= 0:
- return locale[:p].lower()+'-'+locale[p+1:].lower()
+ return locale[:p].lower() + '-' + locale[p + 1:].lower()
else:
return locale.lower()
diff --git a/django/views/debug.py b/django/views/debug.py
index 0ee5d588c7..2706da6268 100644
--- a/django/views/debug.py
+++ b/django/views/debug.py
@@ -26,8 +26,8 @@ def linebreak_iter(template_source):
yield 0
p = template_source.find('\n')
while p >= 0:
- yield p+1
- p = template_source.find('\n', p+1)
+ yield p + 1
+ p = template_source.find('\n', p + 1)
yield len(template_source) + 1
@@ -302,7 +302,7 @@ class ExceptionReporter(object):
end = getattr(self.exc_value, 'end', None)
if start is not None and end is not None:
unicode_str = self.exc_value.args[1]
- unicode_hint = smart_text(unicode_str[max(start-5, 0):min(end+5, len(unicode_str))], 'ascii', errors='replace')
+ unicode_hint = smart_text(unicode_str[max(start - 5, 0):min(end + 5, len(unicode_str))], 'ascii', errors='replace')
from django import get_version
c = {
'is_email': self.is_email,
@@ -419,7 +419,7 @@ class ExceptionReporter(object):
pre_context = source[lower_bound:lineno]
context_line = source[lineno]
- post_context = source[lineno+1:upper_bound]
+ post_context = source[lineno + 1:upper_bound]
return lower_bound, pre_context, context_line, post_context
diff --git a/docs/_ext/literals_to_xrefs.py b/docs/_ext/literals_to_xrefs.py
index 268d084d42..41ae811292 100644
--- a/docs/_ext/literals_to_xrefs.py
+++ b/docs/_ext/literals_to_xrefs.py
@@ -68,8 +68,8 @@ def fixliterals(fname):
new.append(m.group(0))
continue
- sys.stdout.write("\n"+"-"*80+"\n")
- sys.stdout.write(data[prev_start+1:m.start()])
+ sys.stdout.write("\n" + "-" * 80 + "\n")
+ sys.stdout.write(data[prev_start + 1:m.start()])
sys.stdout.write(colorize(m.group(0), fg="red"))
sys.stdout.write(data[m.end():next_end])
sys.stdout.write("\n\n")
diff --git a/extras/csrf_migration_helper.py b/extras/csrf_migration_helper.py
index 818c1263b7..38dee93735 100755
--- a/extras/csrf_migration_helper.py
+++ b/extras/csrf_migration_helper.py
@@ -161,7 +161,7 @@ def make_template_info(filename, root_dirs):
relative_filenames from the supplied filename and root template directories
"""
return Template(filename,
- [filename[len(d)+1:] for d in root_dirs if filename.startswith(d)])
+ [filename[len(d) + 1:] for d in root_dirs if filename.startswith(d)])
class Template(object):
diff --git a/setup.cfg b/setup.cfg
index 994c4e5431..f2191511d9 100644
--- a/setup.cfg
+++ b/setup.cfg
@@ -4,7 +4,7 @@ install-script = scripts/rpm-install.sh
[flake8]
exclude=./django/utils/dictconfig.py,./django/contrib/comments/*,./django/utils/unittest.py,./tests/comment_tests/*,./django/test/_doctest.py,./django/utils/six.py,./django/conf/app_template/*
-ignore=E124,E125,E127,E128,E226,E251,E501,W601
+ignore=E124,E125,E127,E128,E251,E501,W601
[metadata]
license-file = LICENSE
diff --git a/tests/admin_filters/tests.py b/tests/admin_filters/tests.py
index bbec124d4d..8f379245a6 100644
--- a/tests/admin_filters/tests.py
+++ b/tests/admin_filters/tests.py
@@ -61,7 +61,7 @@ class DecadeListFilterWithNoneReturningLookups(DecadeListFilterWithTitleAndParam
class DecadeListFilterWithFailingQueryset(DecadeListFilterWithTitleAndParameter):
def queryset(self, request, queryset):
- raise 1/0
+ raise 1 / 0
class DecadeListFilterWithQuerysetBasedLookups(DecadeListFilterWithTitleAndParameter):
diff --git a/tests/aggregation_regress/tests.py b/tests/aggregation_regress/tests.py
index be42a13181..dc3d3e2e46 100644
--- a/tests/aggregation_regress/tests.py
+++ b/tests/aggregation_regress/tests.py
@@ -346,7 +346,7 @@ class AggregationTests(TestCase):
def test_aggregate_fexpr(self):
# Aggregates can be used with F() expressions
# ... where the F() is pushed into the HAVING clause
- qs = Publisher.objects.annotate(num_books=Count('book')).filter(num_books__lt=F('num_awards')/2).order_by('name').values('name', 'num_books', 'num_awards')
+ qs = Publisher.objects.annotate(num_books=Count('book')).filter(num_books__lt=F('num_awards') / 2).order_by('name').values('name', 'num_books', 'num_awards')
self.assertQuerysetEqual(
qs, [
{'num_books': 1, 'name': 'Morgan Kaufmann', 'num_awards': 9},
@@ -355,7 +355,7 @@ class AggregationTests(TestCase):
lambda p: p,
)
- qs = Publisher.objects.annotate(num_books=Count('book')).exclude(num_books__lt=F('num_awards')/2).order_by('name').values('name', 'num_books', 'num_awards')
+ qs = Publisher.objects.annotate(num_books=Count('book')).exclude(num_books__lt=F('num_awards') / 2).order_by('name').values('name', 'num_books', 'num_awards')
self.assertQuerysetEqual(
qs, [
{'num_books': 2, 'name': 'Apress', 'num_awards': 3},
@@ -366,7 +366,7 @@ class AggregationTests(TestCase):
)
# ... and where the F() references an aggregate
- qs = Publisher.objects.annotate(num_books=Count('book')).filter(num_awards__gt=2*F('num_books')).order_by('name').values('name', 'num_books', 'num_awards')
+ qs = Publisher.objects.annotate(num_books=Count('book')).filter(num_awards__gt=2 * F('num_books')).order_by('name').values('name', 'num_books', 'num_awards')
self.assertQuerysetEqual(
qs, [
{'num_books': 1, 'name': 'Morgan Kaufmann', 'num_awards': 9},
@@ -375,7 +375,7 @@ class AggregationTests(TestCase):
lambda p: p,
)
- qs = Publisher.objects.annotate(num_books=Count('book')).exclude(num_books__lt=F('num_awards')/2).order_by('name').values('name', 'num_books', 'num_awards')
+ qs = Publisher.objects.annotate(num_books=Count('book')).exclude(num_books__lt=F('num_awards') / 2).order_by('name').values('name', 'num_books', 'num_awards')
self.assertQuerysetEqual(
qs, [
{'num_books': 2, 'name': 'Apress', 'num_awards': 3},
diff --git a/tests/bulk_create/tests.py b/tests/bulk_create/tests.py
index dada5326c9..9bb95acb72 100644
--- a/tests/bulk_create/tests.py
+++ b/tests/bulk_create/tests.py
@@ -94,7 +94,7 @@ class BulkCreateTests(TestCase):
with override_settings(DEBUG=True):
connection.queries = []
TwoFields.objects.bulk_create([
- TwoFields(f1=i, f2=i+1) for i in range(0, 1001)
+ TwoFields(f1=i, f2=i + 1) for i in range(0, 1001)
])
self.assertEqual(TwoFields.objects.count(), 1001)
self.assertEqual(
@@ -115,7 +115,7 @@ class BulkCreateTests(TestCase):
with override_settings(DEBUG=True):
connection.queries = []
TwoFields.objects.bulk_create([
- TwoFields(f1=i, f2=i+1) for i in range(0, 1001)
+ TwoFields(f1=i, f2=i + 1) for i in range(0, 1001)
])
self.assertTrue(len(connection.queries) < 10)
@@ -127,7 +127,7 @@ class BulkCreateTests(TestCase):
with override_settings(DEBUG=True):
connection.queries = []
TwoFields.objects.bulk_create([
- TwoFields(id=i if i % 2 == 0 else None, f1=i, f2=i+1)
+ TwoFields(id=i if i % 2 == 0 else None, f1=i, f2=i + 1)
for i in range(100000, 101000)])
self.assertEqual(TwoFields.objects.count(), 1000)
# We can't assume much about the ID's created, except that the above
@@ -145,7 +145,7 @@ class BulkCreateTests(TestCase):
with override_settings(DEBUG=True):
connection.queries = []
TwoFields.objects.bulk_create([
- TwoFields(id=i if i % 2 == 0 else None, f1=i, f2=i+1)
+ TwoFields(id=i if i % 2 == 0 else None, f1=i, f2=i + 1)
for i in range(100000, 101000)])
self.assertTrue(len(connection.queries) < 10)
diff --git a/tests/cache/tests.py b/tests/cache/tests.py
index a93ed4418a..053ee14a58 100644
--- a/tests/cache/tests.py
+++ b/tests/cache/tests.py
@@ -436,13 +436,13 @@ class BaseCacheTests(object):
it is an absolute expiration timestamp instead of a relative
offset. Test that we honour this convention. Refs #12399.
'''
- self.cache.set('key1', 'eggs', 60*60*24*30 + 1) # 30 days + 1 second
+ self.cache.set('key1', 'eggs', 60 * 60 * 24 * 30 + 1) # 30 days + 1 second
self.assertEqual(self.cache.get('key1'), 'eggs')
- self.cache.add('key2', 'ham', 60*60*24*30 + 1)
+ self.cache.add('key2', 'ham', 60 * 60 * 24 * 30 + 1)
self.assertEqual(self.cache.get('key2'), 'ham')
- self.cache.set_many({'key3': 'sausage', 'key4': 'lobster bisque'}, 60*60*24*30 + 1)
+ self.cache.set_many({'key3': 'sausage', 'key4': 'lobster bisque'}, 60 * 60 * 24 * 30 + 1)
self.assertEqual(self.cache.get('key3'), 'sausage')
self.assertEqual(self.cache.get('key4'), 'lobster bisque')
@@ -1000,7 +1000,7 @@ class LocMemCacheTests(unittest.TestCase, BaseCacheTests):
"""incr/decr does not modify expiry time (matches memcached behavior)"""
key = 'value'
_key = self.cache.make_key(key)
- self.cache.set(key, 1, timeout=self.cache.default_timeout*10)
+ self.cache.set(key, 1, timeout=self.cache.default_timeout * 10)
expire = self.cache._expire_info[_key]
self.cache.incr(key)
self.assertEqual(expire, self.cache._expire_info[_key])
diff --git a/tests/defaultfilters/tests.py b/tests/defaultfilters/tests.py
index 3e785a8c70..52a61a1ac7 100644
--- a/tests/defaultfilters/tests.py
+++ b/tests/defaultfilters/tests.py
@@ -613,15 +613,15 @@ class DefaultFiltersTests(TestCase):
# NOTE: \xa0 avoids wrapping between value and unit
self.assertEqual(filesizeformat(1023), '1023\xa0bytes')
self.assertEqual(filesizeformat(1024), '1.0\xa0KB')
- self.assertEqual(filesizeformat(10*1024), '10.0\xa0KB')
- self.assertEqual(filesizeformat(1024*1024-1), '1024.0\xa0KB')
- self.assertEqual(filesizeformat(1024*1024), '1.0\xa0MB')
- self.assertEqual(filesizeformat(1024*1024*50), '50.0\xa0MB')
- self.assertEqual(filesizeformat(1024*1024*1024-1), '1024.0\xa0MB')
- self.assertEqual(filesizeformat(1024*1024*1024), '1.0\xa0GB')
- self.assertEqual(filesizeformat(1024*1024*1024*1024), '1.0\xa0TB')
- self.assertEqual(filesizeformat(1024*1024*1024*1024*1024), '1.0\xa0PB')
- self.assertEqual(filesizeformat(1024*1024*1024*1024*1024*2000),
+ self.assertEqual(filesizeformat(10 * 1024), '10.0\xa0KB')
+ self.assertEqual(filesizeformat(1024 * 1024 - 1), '1024.0\xa0KB')
+ self.assertEqual(filesizeformat(1024 * 1024), '1.0\xa0MB')
+ self.assertEqual(filesizeformat(1024 * 1024 * 50), '50.0\xa0MB')
+ self.assertEqual(filesizeformat(1024 * 1024 * 1024 - 1), '1024.0\xa0MB')
+ self.assertEqual(filesizeformat(1024 * 1024 * 1024), '1.0\xa0GB')
+ self.assertEqual(filesizeformat(1024 * 1024 * 1024 * 1024), '1.0\xa0TB')
+ self.assertEqual(filesizeformat(1024 * 1024 * 1024 * 1024 * 1024), '1.0\xa0PB')
+ self.assertEqual(filesizeformat(1024 * 1024 * 1024 * 1024 * 1024 * 2000),
'2000.0\xa0PB')
self.assertEqual(filesizeformat(complex(1, -1)), '0\xa0bytes')
self.assertEqual(filesizeformat(""), '0\xa0bytes')
@@ -680,16 +680,16 @@ class DefaultFiltersI18NTests(TransRealMixin, TestCase):
with self.settings(USE_L10N=True), translation.override('de', deactivate=True):
self.assertEqual(filesizeformat(1023), '1023\xa0Bytes')
self.assertEqual(filesizeformat(1024), '1,0\xa0KB')
- self.assertEqual(filesizeformat(10*1024), '10,0\xa0KB')
- self.assertEqual(filesizeformat(1024*1024-1), '1024,0\xa0KB')
- self.assertEqual(filesizeformat(1024*1024), '1,0\xa0MB')
- self.assertEqual(filesizeformat(1024*1024*50), '50,0\xa0MB')
- self.assertEqual(filesizeformat(1024*1024*1024-1), '1024,0\xa0MB')
- self.assertEqual(filesizeformat(1024*1024*1024), '1,0\xa0GB')
- self.assertEqual(filesizeformat(1024*1024*1024*1024), '1,0\xa0TB')
- self.assertEqual(filesizeformat(1024*1024*1024*1024*1024),
+ self.assertEqual(filesizeformat(10 * 1024), '10,0\xa0KB')
+ self.assertEqual(filesizeformat(1024 * 1024 - 1), '1024,0\xa0KB')
+ self.assertEqual(filesizeformat(1024 * 1024), '1,0\xa0MB')
+ self.assertEqual(filesizeformat(1024 * 1024 * 50), '50,0\xa0MB')
+ self.assertEqual(filesizeformat(1024 * 1024 * 1024 - 1), '1024,0\xa0MB')
+ self.assertEqual(filesizeformat(1024 * 1024 * 1024), '1,0\xa0GB')
+ self.assertEqual(filesizeformat(1024 * 1024 * 1024 * 1024), '1,0\xa0TB')
+ self.assertEqual(filesizeformat(1024 * 1024 * 1024 * 1024 * 1024),
'1,0\xa0PB')
- self.assertEqual(filesizeformat(1024*1024*1024*1024*1024*2000),
+ self.assertEqual(filesizeformat(1024 * 1024 * 1024 * 1024 * 1024 * 2000),
'2000,0\xa0PB')
self.assertEqual(filesizeformat(complex(1, -1)), '0\xa0Bytes')
self.assertEqual(filesizeformat(""), '0\xa0Bytes')
diff --git a/tests/expressions/tests.py b/tests/expressions/tests.py
index 23d729ffee..99f41024f8 100644
--- a/tests/expressions/tests.py
+++ b/tests/expressions/tests.py
@@ -74,7 +74,7 @@ class ExpressionsTests(TestCase):
# We can perform arithmetic operations in expressions
# Make sure we have 2 spare chairs
- company_query.update(num_chairs=F("num_employees")+2)
+ company_query.update(num_chairs=F("num_employees") + 2)
self.assertQuerysetEqual(
company_query, [
{
diff --git a/tests/forms_tests/tests/test_fields.py b/tests/forms_tests/tests/test_fields.py
index e7412b81d7..d7eb86f399 100644
--- a/tests/forms_tests/tests/test_fields.py
+++ b/tests/forms_tests/tests/test_fields.py
@@ -760,11 +760,11 @@ class FieldsTests(SimpleTestCase):
def test_url_regex_ticket11198(self):
f = URLField()
# hangs "forever" if catastrophic backtracking in ticket:#11198 not fixed
- self.assertRaisesMessage(ValidationError, "'Enter a valid URL.'", f.clean, 'http://%s' % ("X"*200,))
+ self.assertRaisesMessage(ValidationError, "'Enter a valid URL.'", f.clean, 'http://%s' % ("X" * 200,))
# a second test, to make sure the problem is really addressed, even on
# domains that don't fail the domain label length check in the regex
- self.assertRaisesMessage(ValidationError, "'Enter a valid URL.'", f.clean, 'http://%s' % ("X"*60,))
+ self.assertRaisesMessage(ValidationError, "'Enter a valid URL.'", f.clean, 'http://%s' % ("X" * 60,))
def test_urlfield_2(self):
f = URLField(required=False)
diff --git a/tests/lookup/tests.py b/tests/lookup/tests.py
index 0e23933c52..f5e0b744de 100644
--- a/tests/lookup/tests.py
+++ b/tests/lookup/tests.py
@@ -283,26 +283,26 @@ class LookupTests(TestCase):
Article.objects.extra(select={'id_plus_one': 'id+1'})
.order_by('id').values_list('id_plus_one', 'id'),
[
- (self.a1.id+1, self.a1.id),
- (self.a2.id+1, self.a2.id),
- (self.a3.id+1, self.a3.id),
- (self.a4.id+1, self.a4.id),
- (self.a5.id+1, self.a5.id),
- (self.a6.id+1, self.a6.id),
- (self.a7.id+1, self.a7.id)
+ (self.a1.id + 1, self.a1.id),
+ (self.a2.id + 1, self.a2.id),
+ (self.a3.id + 1, self.a3.id),
+ (self.a4.id + 1, self.a4.id),
+ (self.a5.id + 1, self.a5.id),
+ (self.a6.id + 1, self.a6.id),
+ (self.a7.id + 1, self.a7.id)
],
transform=identity)
self.assertQuerysetEqual(
Article.objects.extra(select={'id_plus_one': 'id+1'})
.order_by('id').values_list('id', 'id_plus_one'),
[
- (self.a1.id, self.a1.id+1),
- (self.a2.id, self.a2.id+1),
- (self.a3.id, self.a3.id+1),
- (self.a4.id, self.a4.id+1),
- (self.a5.id, self.a5.id+1),
- (self.a6.id, self.a6.id+1),
- (self.a7.id, self.a7.id+1)
+ (self.a1.id, self.a1.id + 1),
+ (self.a2.id, self.a2.id + 1),
+ (self.a3.id, self.a3.id + 1),
+ (self.a4.id, self.a4.id + 1),
+ (self.a5.id, self.a5.id + 1),
+ (self.a6.id, self.a6.id + 1),
+ (self.a7.id, self.a7.id + 1)
],
transform=identity)
self.assertQuerysetEqual(
diff --git a/tests/requests/tests.py b/tests/requests/tests.py
index c00f5bb5e0..2a69638260 100644
--- a/tests/requests/tests.py
+++ b/tests/requests/tests.py
@@ -162,7 +162,7 @@ class RequestsTests(SimpleTestCase):
response.set_cookie('max_age', max_age=10)
max_age_cookie = response.cookies['max_age']
self.assertEqual(max_age_cookie['max-age'], 10)
- self.assertEqual(max_age_cookie['expires'], cookie_date(time.time()+10))
+ self.assertEqual(max_age_cookie['expires'], cookie_date(time.time() + 10))
def test_httponly_cookie(self):
response = HttpResponse()
diff --git a/tests/sites_framework/tests.py b/tests/sites_framework/tests.py
index ee25036aae..fb62c28c14 100644
--- a/tests/sites_framework/tests.py
+++ b/tests/sites_framework/tests.py
@@ -9,7 +9,7 @@ from .models import (SyndicatedArticle, ExclusiveArticle, CustomArticle,
class SitesFrameworkTestCase(TestCase):
def setUp(self):
Site.objects.get_or_create(id=settings.SITE_ID, domain="example.com", name="example.com")
- Site.objects.create(id=settings.SITE_ID+1, domain="example2.com", name="example2.com")
+ Site.objects.create(id=settings.SITE_ID + 1, domain="example2.com", name="example2.com")
def test_site_fk(self):
article = ExclusiveArticle.objects.create(title="Breaking News!", site_id=settings.SITE_ID)
@@ -18,9 +18,9 @@ class SitesFrameworkTestCase(TestCase):
def test_sites_m2m(self):
article = SyndicatedArticle.objects.create(title="Fresh News!")
article.sites.add(Site.objects.get(id=settings.SITE_ID))
- article.sites.add(Site.objects.get(id=settings.SITE_ID+1))
+ article.sites.add(Site.objects.get(id=settings.SITE_ID + 1))
article2 = SyndicatedArticle.objects.create(title="More News!")
- article2.sites.add(Site.objects.get(id=settings.SITE_ID+1))
+ article2.sites.add(Site.objects.get(id=settings.SITE_ID + 1))
self.assertEqual(SyndicatedArticle.on_site.all().get(), article)
def test_custom_named_field(self):
diff --git a/tests/utils_tests/test_timesince.py b/tests/utils_tests/test_timesince.py
index 5814a7cb90..376e425a88 100644
--- a/tests/utils_tests/test_timesince.py
+++ b/tests/utils_tests/test_timesince.py
@@ -28,28 +28,28 @@ class TimesinceTests(unittest.TestCase):
def test_ignore_microseconds_and_seconds(self):
""" Microseconds and seconds are ignored. """
- self.assertEqual(timesince(self.t, self.t+self.onemicrosecond),
+ self.assertEqual(timesince(self.t, self.t + self.onemicrosecond),
'0\xa0minutes')
- self.assertEqual(timesince(self.t, self.t+self.onesecond),
+ self.assertEqual(timesince(self.t, self.t + self.onesecond),
'0\xa0minutes')
def test_other_units(self):
""" Test other units. """
- self.assertEqual(timesince(self.t, self.t+self.oneminute),
+ self.assertEqual(timesince(self.t, self.t + self.oneminute),
'1\xa0minute')
- self.assertEqual(timesince(self.t, self.t+self.onehour), '1\xa0hour')
- self.assertEqual(timesince(self.t, self.t+self.oneday), '1\xa0day')
- self.assertEqual(timesince(self.t, self.t+self.oneweek), '1\xa0week')
- self.assertEqual(timesince(self.t, self.t+self.onemonth),
+ self.assertEqual(timesince(self.t, self.t + self.onehour), '1\xa0hour')
+ self.assertEqual(timesince(self.t, self.t + self.oneday), '1\xa0day')
+ self.assertEqual(timesince(self.t, self.t + self.oneweek), '1\xa0week')
+ self.assertEqual(timesince(self.t, self.t + self.onemonth),
'1\xa0month')
- self.assertEqual(timesince(self.t, self.t+self.oneyear), '1\xa0year')
+ self.assertEqual(timesince(self.t, self.t + self.oneyear), '1\xa0year')
def test_multiple_units(self):
""" Test multiple units. """
self.assertEqual(timesince(self.t,
- self.t+2*self.oneday+6*self.onehour), '2\xa0days, 6\xa0hours')
+ self.t + 2 * self.oneday + 6 * self.onehour), '2\xa0days, 6\xa0hours')
self.assertEqual(timesince(self.t,
- self.t+2*self.oneweek+2*self.oneday), '2\xa0weeks, 2\xa0days')
+ self.t + 2 * self.oneweek + 2 * self.oneday), '2\xa0weeks, 2\xa0days')
def test_display_first_unit(self):
"""
@@ -57,42 +57,42 @@ class TimesinceTests(unittest.TestCase):
displayed.
"""
self.assertEqual(timesince(self.t,
- self.t+2*self.oneweek+3*self.onehour+4*self.oneminute),
+ self.t + 2 * self.oneweek + 3 * self.onehour + 4 * self.oneminute),
'2\xa0weeks')
self.assertEqual(timesince(self.t,
- self.t+4*self.oneday+5*self.oneminute), '4\xa0days')
+ self.t + 4 * self.oneday + 5 * self.oneminute), '4\xa0days')
def test_display_second_before_first(self):
"""
When the second date occurs before the first, we should always
get 0 minutes.
"""
- self.assertEqual(timesince(self.t, self.t-self.onemicrosecond),
+ self.assertEqual(timesince(self.t, self.t - self.onemicrosecond),
'0\xa0minutes')
- self.assertEqual(timesince(self.t, self.t-self.onesecond),
+ self.assertEqual(timesince(self.t, self.t - self.onesecond),
'0\xa0minutes')
- self.assertEqual(timesince(self.t, self.t-self.oneminute),
+ self.assertEqual(timesince(self.t, self.t - self.oneminute),
'0\xa0minutes')
- self.assertEqual(timesince(self.t, self.t-self.onehour),
+ self.assertEqual(timesince(self.t, self.t - self.onehour),
'0\xa0minutes')
- self.assertEqual(timesince(self.t, self.t-self.oneday),
+ self.assertEqual(timesince(self.t, self.t - self.oneday),
'0\xa0minutes')
- self.assertEqual(timesince(self.t, self.t-self.oneweek),
+ self.assertEqual(timesince(self.t, self.t - self.oneweek),
'0\xa0minutes')
- self.assertEqual(timesince(self.t, self.t-self.onemonth),
+ self.assertEqual(timesince(self.t, self.t - self.onemonth),
'0\xa0minutes')
- self.assertEqual(timesince(self.t, self.t-self.oneyear),
+ self.assertEqual(timesince(self.t, self.t - self.oneyear),
'0\xa0minutes')
self.assertEqual(timesince(self.t,
- self.t-2*self.oneday-6*self.onehour), '0\xa0minutes')
+ self.t - 2 * self.oneday - 6 * self.onehour), '0\xa0minutes')
self.assertEqual(timesince(self.t,
- self.t-2*self.oneweek-2*self.oneday), '0\xa0minutes')
+ self.t - 2 * self.oneweek - 2 * self.oneday), '0\xa0minutes')
self.assertEqual(timesince(self.t,
- self.t-2*self.oneweek-3*self.onehour-4*self.oneminute),
+ self.t - 2 * self.oneweek - 3 * self.onehour - 4 * self.oneminute),
'0\xa0minutes')
self.assertEqual(timesince(self.t,
- self.t-4*self.oneday-5*self.oneminute), '0\xa0minutes')
+ self.t - 4 * self.oneday - 5 * self.oneminute), '0\xa0minutes')
@requires_tz_support
def test_different_timezones(self):