tests.py 3.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899
  1. from __future__ import unicode_literals
  2. from django.core.exceptions import FieldError
  3. from django.test import TestCase
  4. from django.utils import six
  5. from .models import (SelfRefer, Tag, TagCollection, Entry, SelfReferChild,
  6. SelfReferChildSibling, Worksheet, RegressionModelSplit)
  7. class M2MRegressionTests(TestCase):
  8. def test_multiple_m2m(self):
  9. # Multiple m2m references to model must be distinguished when
  10. # accessing the relations through an instance attribute.
  11. s1 = SelfRefer.objects.create(name='s1')
  12. s2 = SelfRefer.objects.create(name='s2')
  13. s3 = SelfRefer.objects.create(name='s3')
  14. s1.references.add(s2)
  15. s1.related.add(s3)
  16. e1 = Entry.objects.create(name='e1')
  17. t1 = Tag.objects.create(name='t1')
  18. t2 = Tag.objects.create(name='t2')
  19. e1.topics.add(t1)
  20. e1.related.add(t2)
  21. self.assertQuerysetEqual(s1.references.all(), ["<SelfRefer: s2>"])
  22. self.assertQuerysetEqual(s1.related.all(), ["<SelfRefer: s3>"])
  23. self.assertQuerysetEqual(e1.topics.all(), ["<Tag: t1>"])
  24. self.assertQuerysetEqual(e1.related.all(), ["<Tag: t2>"])
  25. def test_internal_related_name_not_in_error_msg(self):
  26. # The secret internal related names for self-referential many-to-many
  27. # fields shouldn't appear in the list when an error is made.
  28. six.assertRaisesRegex(
  29. self, FieldError,
  30. "Choices are: id, name, references, related, selfreferchild, selfreferchildsibling$",
  31. lambda: SelfRefer.objects.filter(porcupine='fred')
  32. )
  33. def test_m2m_inheritance_symmetry(self):
  34. # Test to ensure that the relationship between two inherited models
  35. # with a self-referential m2m field maintains symmetry
  36. sr_child = SelfReferChild(name="Hanna")
  37. sr_child.save()
  38. sr_sibling = SelfReferChildSibling(name="Beth")
  39. sr_sibling.save()
  40. sr_child.related.add(sr_sibling)
  41. self.assertQuerysetEqual(sr_child.related.all(), ["<SelfRefer: Beth>"])
  42. self.assertQuerysetEqual(sr_sibling.related.all(), ["<SelfRefer: Hanna>"])
  43. def test_m2m_pk_field_type(self):
  44. # Regression for #11311 - The primary key for models in a m2m relation
  45. # doesn't have to be an AutoField
  46. w = Worksheet(id='abc')
  47. w.save()
  48. w.delete()
  49. def test_add_m2m_with_base_class(self):
  50. # Regression for #11956 -- You can add an object to a m2m with the
  51. # base class without causing integrity errors
  52. t1 = Tag.objects.create(name='t1')
  53. t2 = Tag.objects.create(name='t2')
  54. c1 = TagCollection.objects.create(name='c1')
  55. c1.tags = [t1, t2]
  56. c1 = TagCollection.objects.get(name='c1')
  57. self.assertQuerysetEqual(c1.tags.all(), ["<Tag: t1>", "<Tag: t2>"], ordered=False)
  58. self.assertQuerysetEqual(t1.tag_collections.all(), ["<TagCollection: c1>"])
  59. def test_manager_class_caching(self):
  60. e1 = Entry.objects.create()
  61. e2 = Entry.objects.create()
  62. t1 = Tag.objects.create()
  63. t2 = Tag.objects.create()
  64. # Get same manager twice in a row:
  65. self.assertTrue(t1.entry_set.__class__ is t1.entry_set.__class__)
  66. self.assertTrue(e1.topics.__class__ is e1.topics.__class__)
  67. # Get same manager for different instances
  68. self.assertTrue(e1.topics.__class__ is e2.topics.__class__)
  69. self.assertTrue(t1.entry_set.__class__ is t2.entry_set.__class__)
  70. def test_m2m_abstract_split(self):
  71. # Regression for #19236 - an abstract class with a 'split' method
  72. # causes a TypeError in add_lazy_relation
  73. m1 = RegressionModelSplit(name='1')
  74. m1.save()