From 062ce508b0edcb3a2e801d7959e08207bd8d2a1e Mon Sep 17 00:00:00 2001 From: Tim Graham Date: Mon, 15 Jun 2015 10:37:14 -0400 Subject: [PATCH] [1.8.x] Fixed flake8 warnings on Python 3. Backport of 47fcbe506c04019a12e16221843e25a52249b1ab from master --- django/db/backends/oracle/operations.py | 2 +- django/db/utils.py | 2 +- django/utils/functional.py | 2 +- django/utils/html.py | 2 +- tests/i18n/tests.py | 7 +++++-- tests/model_fields/tests.py | 5 +++-- tests/queries/tests.py | 9 +++++---- 7 files changed, 17 insertions(+), 12 deletions(-) diff --git a/django/db/backends/oracle/operations.py b/django/db/backends/oracle/operations.py index 02fd6fcc7d..fe90ca894d 100644 --- a/django/db/backends/oracle/operations.py +++ b/django/db/backends/oracle/operations.py @@ -235,7 +235,7 @@ WHEN (new.%(col_name)s IS NULL) # http://cx-oracle.sourceforge.net/html/cursor.html#Cursor.statement # The DB API definition does not define this attribute. statement = cursor.statement - if statement and six.PY2 and not isinstance(statement, unicode): + if statement and six.PY2 and not isinstance(statement, unicode): # NOQA: unicode undefined on PY3 statement = statement.decode('utf-8') # Unlike Psycopg's `query` and MySQLdb`'s `_last_executed`, CxOracle's # `statement` doesn't contain the query parameters. refs #20010. diff --git a/django/db/utils.py b/django/db/utils.py index 4ce7030eb3..d8aa34d30f 100644 --- a/django/db/utils.py +++ b/django/db/utils.py @@ -19,7 +19,7 @@ DEFAULT_DB_ALIAS = 'default' DJANGO_VERSION_PICKLE_KEY = '_django_version' -class Error(Exception if six.PY3 else StandardError): +class Error(Exception if six.PY3 else StandardError): # NOQA: StandardError undefined on PY3 pass diff --git a/django/utils/functional.py b/django/utils/functional.py index e3875a2c51..81bcb17b97 100644 --- a/django/utils/functional.py +++ b/django/utils/functional.py @@ -310,7 +310,7 @@ class LazyObject(object): __bool__ = new_method_proxy(bool) else: __str__ = new_method_proxy(str) - __unicode__ = new_method_proxy(unicode) + __unicode__ = new_method_proxy(unicode) # NOQA: unicode undefined on PY3 __nonzero__ = new_method_proxy(bool) # Introspection support diff --git a/django/utils/html.py b/django/utils/html.py index eabbb16467..837a17f171 100644 --- a/django/utils/html.py +++ b/django/utils/html.py @@ -388,7 +388,7 @@ def html_safe(klass): ) klass_unicode = klass.__unicode__ klass.__unicode__ = lambda self: mark_safe(klass_unicode(self)) - klass.__html__ = lambda self: unicode(self) + klass.__html__ = lambda self: unicode(self) # NOQA: unicode undefined on PY3 else: if '__str__' not in klass.__dict__: raise ValueError( diff --git a/tests/i18n/tests.py b/tests/i18n/tests.py index dd84aa815f..470300ee93 100644 --- a/tests/i18n/tests.py +++ b/tests/i18n/tests.py @@ -206,7 +206,10 @@ class TranslationTests(TestCase): result = ungettext_lazy('%(name)s has %(num)d good result', '%(name)s has %(num)d good results', 4) self.assertEqual(result % {'name': 'Joe', 'num': 4}, "Joe has 4 good results") # Now with a long - result = ungettext_lazy('%(name)s has %(num)d good result', '%(name)s has %(num)d good results', long(4)) + result = ungettext_lazy( + '%(name)s has %(num)d good result', '%(name)s has %(num)d good results', + long(4) # NOQA: long undefined on PY3 + ) self.assertEqual(result % {'name': 'Joe', 'num': 4}, "Joe has 4 good results") @override_settings(LOCALE_PATHS=extended_locale_paths) @@ -472,7 +475,7 @@ class FormattingTests(TestCase): self.d = datetime.date(2009, 12, 31) self.dt = datetime.datetime(2009, 12, 31, 20, 50) self.t = datetime.time(10, 15, 48) - self.l = 10000 if PY3 else long(10000) + self.l = 10000 if PY3 else long(10000) # NOQA: long undefined on PY3 self.ctxt = Context({ 'n': self.n, 't': self.t, diff --git a/tests/model_fields/tests.py b/tests/model_fields/tests.py index e04c518a93..9fe905dfc1 100644 --- a/tests/model_fields/tests.py +++ b/tests/model_fields/tests.py @@ -711,10 +711,11 @@ class PromiseTest(test.TestCase): @unittest.skipIf(six.PY3, "Python 3 has no `long` type.") def test_BigIntegerField(self): - lazy_func = lazy(lambda: long(9999999999999999999), long) + # NOQA: long undefined on PY3 + lazy_func = lazy(lambda: long(9999999999999999999), long) # NOQA self.assertIsInstance( BigIntegerField().get_prep_value(lazy_func()), - long) + long) # NOQA def test_BinaryField(self): lazy_func = lazy(lambda: b'', bytes) diff --git a/tests/queries/tests.py b/tests/queries/tests.py index 2a62c8db90..6ba799d244 100644 --- a/tests/queries/tests.py +++ b/tests/queries/tests.py @@ -2246,17 +2246,18 @@ class QuerySetSupportsPythonIdioms(TestCase): @unittest.skipUnless(six.PY2, "Python 2 only -- Python 3 doesn't have longs.") def test_slicing_works_with_longs(self): - self.assertEqual(self.get_ordered_articles()[long(0)].name, 'Article 1') - self.assertQuerysetEqual(self.get_ordered_articles()[long(1):long(3)], + # NOQA: long undefined on PY3 + self.assertEqual(self.get_ordered_articles()[long(0)].name, 'Article 1') # NOQA + self.assertQuerysetEqual(self.get_ordered_articles()[long(1):long(3)], # NOQA ["", ""]) - self.assertQuerysetEqual(self.get_ordered_articles()[::long(2)], + self.assertQuerysetEqual(self.get_ordered_articles()[::long(2)], # NOQA ["", "", "", ""]) # And can be mixed with ints. - self.assertQuerysetEqual(self.get_ordered_articles()[1:long(3)], + self.assertQuerysetEqual(self.get_ordered_articles()[1:long(3)], # NOQA ["", ""]) def test_slicing_without_step_is_lazy(self):