updated test and also vlaidate that the correct manager is used

This commit is contained in:
Hans de Jong 2020-02-13 09:14:48 +01:00
parent 061ddca19e
commit 0df9e5129d
3 changed files with 43 additions and 23 deletions

View file

@ -5,6 +5,9 @@ from django.core import validators
from django.db import models
from django.utils.translation import ugettext_lazy
# from modeltranslation.manager import MultilingualManager
from modeltranslation.manager import MultilingualManager
class TestModel(models.Model):
title = models.CharField(ugettext_lazy('title'), max_length=255)
@ -100,9 +103,9 @@ class OtherFieldsModel(models.Model):
boolean = models.BooleanField(default=False)
nullboolean = models.NullBooleanField()
csi = models.CommaSeparatedIntegerField(max_length=255)
ip = models.IPAddressField(blank=True, null=True)
float = models.FloatField(blank=True, null=True)
decimal = models.DecimalField(max_digits=5, decimal_places=2, blank=True, null=True)
ip = models.IPAddressField(blank=True, null=True)
date = models.DateField(blank=True, null=True)
datetime = models.DateTimeField(blank=True, null=True)
time = models.TimeField(blank=True, null=True)
@ -264,6 +267,23 @@ class ThirdPartyRegisteredModel(models.Model):
# ######### Manager testing
class FilteredManager(MultilingualManager):
def get_queryset(self):
# always return empty queryset
return super(FilteredManager, self).get_queryset().filter(pk=None)
class FilteredTestModel(models.Model):
title = models.CharField(ugettext_lazy('title'), max_length=255)
objects = FilteredManager()
class ForeignKeyFilteredModel(models.Model):
title = models.CharField(ugettext_lazy('title'), max_length=255)
test = models.ForeignKey(
FilteredTestModel, null=True, related_name="test_fks", on_delete=models.CASCADE,
)
class ManagerTestModel(models.Model):
title = models.CharField(ugettext_lazy('title'), max_length=255)

View file

@ -41,7 +41,7 @@ models = translation = None
request = None
# How many models are registered for tests.
TEST_MODELS = 33 + (1 if MIGRATIONS else 0)
TEST_MODELS = 35 + (1 if MIGRATIONS else 0)
class reload_override_settings(override_settings):
@ -997,33 +997,24 @@ class ForeignKeyFieldsTest(ModeltranslationTestBase):
Make sure base_manager does not get same queryset filter as TestModel in reverse lookup
https://docs.djangoproject.com/en/3.0/topics/db/managers/#base-managers
"""
from modeltranslation.tests.models import FilteredManager
class FilteredManager(MultilingualManager):
def get_queryset(self):
# always return empty queryset
return super(FilteredManager, self).get_queryset().filter(pk=None)
# save old to set back, not used to these tests
objects = models.TestModel.objects
filter_manager = FilteredManager()
filter_manager.model = models.TestModel
filter_manager.name = 'objects'
filter_manager.auto_created = True
models.TestModel.objects = filter_manager
test_inst = models.TestModel(title_en='title_en', title_de='title_de')
test_inst = models.FilteredTestModel(title_en='title_en', title_de='title_de')
test_inst.save()
# create objects with relations to test_inst
fk_inst = self.model(test=test_inst, title_en='f_title_en', title_de='f_title_de')
self.assertFalse(models.FilteredTestModel.objects.all().exists())
self.assertEqual(models.FilteredTestModel.objects.__class__, FilteredManager)
self.assertEqual(models.FilteredTestModel._meta.base_manager.__class__, MultilingualManager)
manager = test_inst.objects # for good measure
self.assertFalse(manager.all().exists())
# # create objects with relations to test_inst
fk_inst = models.ForeignKeyFilteredModel(test=test_inst, title_en='f_title_en', title_de='f_title_de')
fk_inst.save()
fk_inst.refresh_from_db() # force to reset cached values
self.assertEqual(models.ForeignKeyFilteredModel.objects.__class__, MultilingualManager)
self.assertEqual(models.ForeignKeyFilteredModel._meta.base_manager.__class__, MultilingualManager)
self.assertEqual(fk_inst.test, test_inst)
# set objects back for further tests
models.TestModel.objects = objects
def test_non_translated_relation(self):
non_de = models.NonTranslated.objects.create(title='title_de')
non_en = models.NonTranslated.objects.create(title='title_en')

View file

@ -58,6 +58,15 @@ class OneToOneFieldModelTranslationOptions(TranslationOptions):
fields = ('title', 'test', 'optional', 'non',)
@register(models.FilteredTestModel)
class FilteredTestModelTranslationOptions(TranslationOptions):
fields = ('title', )
@register(models.ForeignKeyFilteredModel)
class ForeignKeyFilteredModelTranslationOptions(TranslationOptions):
fields = ('title', )
# ######### Custom fields testing
@register(models.OtherFieldsModel)