mirror of
https://github.com/django/django.git
synced 2025-10-24 14:16:09 +00:00
Fixed #10506, #13793, #14891, #25201 -- Introduced new APIs to specify models' default and base managers.
This deprecates use_for_related_fields.
Old API:
class CustomManager(models.Model):
use_for_related_fields = True
class Model(models.Model):
custom_manager = CustomManager()
New API:
class Model(models.Model):
custom_manager = CustomManager()
class Meta:
base_manager_name = 'custom_manager'
Refs #20932, #25897.
Thanks Carl Meyer for the guidance throughout this work.
Thanks Tim Graham for writing the docs.
This commit is contained in:
@@ -1,7 +1,8 @@
|
||||
from __future__ import unicode_literals
|
||||
|
||||
from django.db import IntegrityError, connection, transaction
|
||||
from django.test import TestCase
|
||||
from django.test import TestCase, ignore_warnings
|
||||
from django.utils.deprecation import RemovedInDjango20Warning
|
||||
|
||||
from .models import (
|
||||
Bar, Director, Favorites, HiddenPointer, ManualPrimaryKey, MultiModel,
|
||||
@@ -422,6 +423,7 @@ class OneToOneTests(TestCase):
|
||||
hasattr(Target, HiddenPointer._meta.get_field('target').remote_field.get_accessor_name())
|
||||
)
|
||||
|
||||
@ignore_warnings(category=RemovedInDjango20Warning) # for use_for_related_fields deprecation
|
||||
def test_related_object(self):
|
||||
public_school = School.objects.create(is_public=True)
|
||||
public_director = Director.objects.create(school=public_school, is_temp=False)
|
||||
@@ -473,6 +475,26 @@ class OneToOneTests(TestCase):
|
||||
finally:
|
||||
Director._default_manager.use_for_related_fields = False
|
||||
|
||||
School._meta.base_manager_name = 'objects'
|
||||
School._meta._expire_cache()
|
||||
try:
|
||||
private_director = Director._base_manager.get(pk=private_director.pk)
|
||||
with self.assertRaises(School.DoesNotExist):
|
||||
private_director.school
|
||||
finally:
|
||||
School._meta.base_manager_name = None
|
||||
School._meta._expire_cache()
|
||||
|
||||
Director._meta.base_manager_name = 'objects'
|
||||
Director._meta._expire_cache()
|
||||
try:
|
||||
private_school = School._base_manager.get(pk=private_school.pk)
|
||||
with self.assertRaises(Director.DoesNotExist):
|
||||
private_school.director
|
||||
finally:
|
||||
Director._meta.base_manager_name = None
|
||||
Director._meta._expire_cache()
|
||||
|
||||
def test_hasattr_related_object(self):
|
||||
# The exception raised on attribute access when a related object
|
||||
# doesn't exist should be an instance of a subclass of `AttributeError`
|
||||
|
||||
Reference in New Issue
Block a user