2013-03-08 09:15:23 -05:00
|
|
|
import warnings
|
|
|
|
|
2015-01-09 15:08:16 -05:00
|
|
|
from django.test import SimpleTestCase
|
2014-12-05 18:14:20 -02:00
|
|
|
from django.test.utils import reset_warning_registry
|
2015-09-26 13:38:04 -04:00
|
|
|
from django.utils.deprecation import (
|
|
|
|
DeprecationInstanceCheck, RemovedInNextVersionWarning, RenameMethodsBase,
|
|
|
|
)
|
2013-03-08 09:15:23 -05:00
|
|
|
|
|
|
|
|
|
|
|
class RenameManagerMethods(RenameMethodsBase):
|
|
|
|
renamed_methods = (
|
2013-06-29 18:34:41 +02:00
|
|
|
('old', 'new', DeprecationWarning),
|
2013-03-08 09:15:23 -05:00
|
|
|
)
|
|
|
|
|
|
|
|
|
|
|
|
class RenameMethodsTests(SimpleTestCase):
|
|
|
|
"""
|
|
|
|
Tests the `RenameMethodsBase` type introduced to rename `get_query_set`
|
|
|
|
to `get_queryset` across the code base following #15363.
|
|
|
|
"""
|
|
|
|
|
|
|
|
def test_class_definition_warnings(self):
|
|
|
|
"""
|
|
|
|
Ensure a warning is raised upon class definition to suggest renaming
|
|
|
|
the faulty method.
|
|
|
|
"""
|
2014-12-05 18:14:20 -02:00
|
|
|
reset_warning_registry()
|
2013-03-08 09:15:23 -05:00
|
|
|
with warnings.catch_warnings(record=True) as recorded:
|
|
|
|
warnings.simplefilter('always')
|
2013-10-22 11:21:07 +01:00
|
|
|
|
2017-01-07 12:11:46 +01:00
|
|
|
class Manager(metaclass=RenameManagerMethods):
|
2013-03-08 09:15:23 -05:00
|
|
|
def old(self):
|
|
|
|
pass
|
|
|
|
self.assertEqual(len(recorded), 1)
|
|
|
|
msg = str(recorded[0].message)
|
2016-04-07 22:04:45 -04:00
|
|
|
self.assertEqual(msg, '`Manager.old` method should be renamed `new`.')
|
2013-03-08 09:15:23 -05:00
|
|
|
|
|
|
|
def test_get_new_defined(self):
|
|
|
|
"""
|
|
|
|
Ensure `old` complains and not `new` when only `new` is defined.
|
|
|
|
"""
|
|
|
|
with warnings.catch_warnings(record=True) as recorded:
|
|
|
|
warnings.simplefilter('ignore')
|
2013-10-22 11:21:07 +01:00
|
|
|
|
2017-01-07 12:11:46 +01:00
|
|
|
class Manager(metaclass=RenameManagerMethods):
|
2013-03-08 09:15:23 -05:00
|
|
|
def new(self):
|
|
|
|
pass
|
|
|
|
warnings.simplefilter('always')
|
|
|
|
manager = Manager()
|
|
|
|
manager.new()
|
|
|
|
self.assertEqual(len(recorded), 0)
|
|
|
|
manager.old()
|
|
|
|
self.assertEqual(len(recorded), 1)
|
|
|
|
msg = str(recorded.pop().message)
|
2016-04-07 22:04:45 -04:00
|
|
|
self.assertEqual(msg, '`Manager.old` is deprecated, use `new` instead.')
|
2013-03-08 09:15:23 -05:00
|
|
|
|
|
|
|
def test_get_old_defined(self):
|
|
|
|
"""
|
|
|
|
Ensure `old` complains when only `old` is defined.
|
|
|
|
"""
|
|
|
|
with warnings.catch_warnings(record=True) as recorded:
|
|
|
|
warnings.simplefilter('ignore')
|
2013-10-22 11:21:07 +01:00
|
|
|
|
2017-01-07 12:11:46 +01:00
|
|
|
class Manager(metaclass=RenameManagerMethods):
|
2013-03-08 09:15:23 -05:00
|
|
|
def old(self):
|
|
|
|
pass
|
|
|
|
warnings.simplefilter('always')
|
|
|
|
manager = Manager()
|
|
|
|
manager.new()
|
|
|
|
self.assertEqual(len(recorded), 0)
|
|
|
|
manager.old()
|
|
|
|
self.assertEqual(len(recorded), 1)
|
|
|
|
msg = str(recorded.pop().message)
|
2016-04-07 22:04:45 -04:00
|
|
|
self.assertEqual(msg, '`Manager.old` is deprecated, use `new` instead.')
|
2013-03-08 09:15:23 -05:00
|
|
|
|
|
|
|
def test_deprecated_subclass_renamed(self):
|
|
|
|
"""
|
|
|
|
Ensure the correct warnings are raised when a class that didn't rename
|
|
|
|
`old` subclass one that did.
|
|
|
|
"""
|
|
|
|
with warnings.catch_warnings(record=True) as recorded:
|
|
|
|
warnings.simplefilter('ignore')
|
2013-10-22 11:21:07 +01:00
|
|
|
|
2017-01-07 12:11:46 +01:00
|
|
|
class Renamed(metaclass=RenameManagerMethods):
|
2013-03-08 09:15:23 -05:00
|
|
|
def new(self):
|
|
|
|
pass
|
2013-10-22 11:21:07 +01:00
|
|
|
|
2013-03-08 09:15:23 -05:00
|
|
|
class Deprecated(Renamed):
|
|
|
|
def old(self):
|
|
|
|
super(Deprecated, self).old()
|
|
|
|
warnings.simplefilter('always')
|
|
|
|
deprecated = Deprecated()
|
|
|
|
deprecated.new()
|
|
|
|
self.assertEqual(len(recorded), 1)
|
|
|
|
msg = str(recorded.pop().message)
|
2016-04-07 22:04:45 -04:00
|
|
|
self.assertEqual(msg, '`Renamed.old` is deprecated, use `new` instead.')
|
2013-03-08 09:15:23 -05:00
|
|
|
recorded[:] = []
|
|
|
|
deprecated.old()
|
|
|
|
self.assertEqual(len(recorded), 2)
|
|
|
|
msgs = [str(warning.message) for warning in recorded]
|
|
|
|
self.assertEqual(msgs, [
|
|
|
|
'`Deprecated.old` is deprecated, use `new` instead.',
|
|
|
|
'`Renamed.old` is deprecated, use `new` instead.',
|
|
|
|
])
|
|
|
|
|
|
|
|
def test_renamed_subclass_deprecated(self):
|
|
|
|
"""
|
|
|
|
Ensure the correct warnings are raised when a class that renamed
|
|
|
|
`old` subclass one that didn't.
|
|
|
|
"""
|
|
|
|
with warnings.catch_warnings(record=True) as recorded:
|
|
|
|
warnings.simplefilter('ignore')
|
2013-10-22 11:21:07 +01:00
|
|
|
|
2017-01-07 12:11:46 +01:00
|
|
|
class Deprecated(metaclass=RenameManagerMethods):
|
2013-03-08 09:15:23 -05:00
|
|
|
def old(self):
|
|
|
|
pass
|
2013-10-22 11:21:07 +01:00
|
|
|
|
2013-03-08 09:15:23 -05:00
|
|
|
class Renamed(Deprecated):
|
|
|
|
def new(self):
|
|
|
|
super(Renamed, self).new()
|
|
|
|
warnings.simplefilter('always')
|
|
|
|
renamed = Renamed()
|
|
|
|
renamed.new()
|
|
|
|
self.assertEqual(len(recorded), 0)
|
|
|
|
renamed.old()
|
|
|
|
self.assertEqual(len(recorded), 1)
|
|
|
|
msg = str(recorded.pop().message)
|
2016-04-07 22:04:45 -04:00
|
|
|
self.assertEqual(msg, '`Renamed.old` is deprecated, use `new` instead.')
|
2013-03-08 09:15:23 -05:00
|
|
|
|
|
|
|
def test_deprecated_subclass_renamed_and_mixins(self):
|
|
|
|
"""
|
|
|
|
Ensure the correct warnings are raised when a subclass inherit from a
|
|
|
|
class that renamed `old` and mixins that may or may not have renamed
|
|
|
|
`new`.
|
|
|
|
"""
|
|
|
|
with warnings.catch_warnings(record=True) as recorded:
|
|
|
|
warnings.simplefilter('ignore')
|
2013-10-22 11:21:07 +01:00
|
|
|
|
2017-01-07 12:11:46 +01:00
|
|
|
class Renamed(metaclass=RenameManagerMethods):
|
2013-03-08 09:15:23 -05:00
|
|
|
def new(self):
|
|
|
|
pass
|
2013-10-22 11:21:07 +01:00
|
|
|
|
2017-01-19 02:39:46 -05:00
|
|
|
class RenamedMixin:
|
2013-03-08 09:15:23 -05:00
|
|
|
def new(self):
|
|
|
|
super(RenamedMixin, self).new()
|
2013-10-22 11:21:07 +01:00
|
|
|
|
2017-01-19 02:39:46 -05:00
|
|
|
class DeprecatedMixin:
|
2013-03-08 09:15:23 -05:00
|
|
|
def old(self):
|
|
|
|
super(DeprecatedMixin, self).old()
|
2013-10-22 11:21:07 +01:00
|
|
|
|
2013-03-08 09:15:23 -05:00
|
|
|
class Deprecated(DeprecatedMixin, RenamedMixin, Renamed):
|
|
|
|
pass
|
|
|
|
warnings.simplefilter('always')
|
|
|
|
deprecated = Deprecated()
|
|
|
|
deprecated.new()
|
|
|
|
self.assertEqual(len(recorded), 1)
|
|
|
|
msg = str(recorded.pop().message)
|
2016-04-07 22:04:45 -04:00
|
|
|
self.assertEqual(msg, '`RenamedMixin.old` is deprecated, use `new` instead.')
|
2013-03-08 09:15:23 -05:00
|
|
|
deprecated.old()
|
|
|
|
self.assertEqual(len(recorded), 2)
|
|
|
|
msgs = [str(warning.message) for warning in recorded]
|
|
|
|
self.assertEqual(msgs, [
|
|
|
|
'`DeprecatedMixin.old` is deprecated, use `new` instead.',
|
|
|
|
'`RenamedMixin.old` is deprecated, use `new` instead.',
|
|
|
|
])
|
2015-09-26 13:38:04 -04:00
|
|
|
|
|
|
|
|
|
|
|
class DeprecationInstanceCheckTest(SimpleTestCase):
|
|
|
|
def test_warning(self):
|
2017-01-07 12:11:46 +01:00
|
|
|
class Manager(metaclass=DeprecationInstanceCheck):
|
2015-09-26 13:38:04 -04:00
|
|
|
alternative = 'fake.path.Foo'
|
|
|
|
deprecation_warning = RemovedInNextVersionWarning
|
|
|
|
|
|
|
|
msg = '`Manager` is deprecated, use `fake.path.Foo` instead.'
|
|
|
|
with warnings.catch_warnings():
|
|
|
|
warnings.simplefilter('error', category=RemovedInNextVersionWarning)
|
|
|
|
with self.assertRaisesMessage(RemovedInNextVersionWarning, msg):
|
|
|
|
isinstance(object, Manager)
|