mirror of https://github.com/django/django.git
[1.5.x] Changed testing strategy used in 6b03179e
.
Avoid polluting the app cache as it causes unrelated test failures.
Refs #19688.
Backport of 7b49da1
from master.
This commit is contained in:
parent
f8b41da431
commit
455baa68eb
|
@ -1,5 +1,23 @@
|
|||
from django.db.models.base import ModelBase
|
||||
from __future__ import unicode_literals
|
||||
|
||||
from django.db import models
|
||||
from django.utils import six
|
||||
|
||||
|
||||
class CustomBaseModel(ModelBase):
|
||||
# The models definitions below used to crash. Generating models dynamically
|
||||
# at runtime is a bad idea because it pollutes the app cache. This doesn't
|
||||
# integrate well with the test suite but at least it prevents regressions.
|
||||
|
||||
|
||||
class CustomBaseModel(models.base.ModelBase):
|
||||
pass
|
||||
|
||||
|
||||
class MyModel(six.with_metaclass(CustomBaseModel, models.Model)):
|
||||
"""Model subclass with a custom base using six.with_metaclass."""
|
||||
|
||||
|
||||
if not six.PY3:
|
||||
class MyModel(models.Model):
|
||||
"""Model subclass with a custom base using __metaclass__."""
|
||||
__metaclass__ = CustomBaseModel
|
||||
|
|
|
@ -1,36 +0,0 @@
|
|||
from __future__ import unicode_literals
|
||||
|
||||
from django.db import models
|
||||
from django.test.testcases import SimpleTestCase
|
||||
from django.utils import six
|
||||
from django.utils.unittest import skipIf
|
||||
|
||||
from .models import CustomBaseModel
|
||||
|
||||
|
||||
class CustomBaseTest(SimpleTestCase):
|
||||
|
||||
@skipIf(six.PY3, 'test metaclass definition under Python 2')
|
||||
def test_py2_custom_base(self):
|
||||
"""
|
||||
Make sure models.Model can be subclassed with a valid custom base
|
||||
using __metaclass__
|
||||
"""
|
||||
try:
|
||||
class MyModel(models.Model):
|
||||
__metaclass__ = CustomBaseModel
|
||||
except Exception:
|
||||
self.fail("models.Model couldn't be subclassed with a valid "
|
||||
"custom base using __metaclass__.")
|
||||
|
||||
def test_six_custom_base(self):
|
||||
"""
|
||||
Make sure models.Model can be subclassed with a valid custom base
|
||||
using `six.with_metaclass`.
|
||||
"""
|
||||
try:
|
||||
class MyModel(six.with_metaclass(CustomBaseModel, models.Model)):
|
||||
pass
|
||||
except Exception:
|
||||
self.fail("models.Model couldn't be subclassed with a valid "
|
||||
"custom base using `six.with_metaclass`.")
|
Loading…
Reference in New Issue