tests.py 5.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147
  1. from __future__ import absolute_import
  2. from io import BytesIO
  3. from django.core import management
  4. from django.contrib.auth.models import User
  5. from django.test import TestCase
  6. from .models import (Person, Group, Membership, UserMembership, Car, Driver,
  7. CarDriver)
  8. class M2MThroughTestCase(TestCase):
  9. def test_everything(self):
  10. bob = Person.objects.create(name="Bob")
  11. jim = Person.objects.create(name="Jim")
  12. rock = Group.objects.create(name="Rock")
  13. roll = Group.objects.create(name="Roll")
  14. frank = User.objects.create_user("frank", "frank@example.com", "password")
  15. jane = User.objects.create_user("jane", "jane@example.com", "password")
  16. Membership.objects.create(person=bob, group=rock)
  17. Membership.objects.create(person=bob, group=roll)
  18. Membership.objects.create(person=jim, group=rock)
  19. self.assertQuerysetEqual(
  20. bob.group_set.all(), [
  21. "<Group: Rock>",
  22. "<Group: Roll>",
  23. ]
  24. )
  25. self.assertQuerysetEqual(
  26. roll.members.all(), [
  27. "<Person: Bob>",
  28. ]
  29. )
  30. self.assertRaises(AttributeError, setattr, bob, "group_set", [])
  31. self.assertRaises(AttributeError, setattr, roll, "members", [])
  32. self.assertRaises(AttributeError, rock.members.create, name="Anne")
  33. self.assertRaises(AttributeError, bob.group_set.create, name="Funk")
  34. UserMembership.objects.create(user=frank, group=rock)
  35. UserMembership.objects.create(user=frank, group=roll)
  36. UserMembership.objects.create(user=jane, group=rock)
  37. self.assertQuerysetEqual(
  38. frank.group_set.all(), [
  39. "<Group: Rock>",
  40. "<Group: Roll>",
  41. ]
  42. )
  43. self.assertQuerysetEqual(
  44. roll.user_members.all(), [
  45. "<User: frank>",
  46. ]
  47. )
  48. def test_serialization(self):
  49. "m2m-through models aren't serialized as m2m fields. Refs #8134"
  50. p = Person.objects.create(name="Bob")
  51. g = Group.objects.create(name="Roll")
  52. m =Membership.objects.create(person=p, group=g)
  53. pks = {"p_pk": p.pk, "g_pk": g.pk, "m_pk": m.pk}
  54. out = BytesIO()
  55. management.call_command("dumpdata", "m2m_through_regress", format="json", stdout=out)
  56. self.assertEqual(out.getvalue().strip(), """[{"pk": %(m_pk)s, "model": "m2m_through_regress.membership", "fields": {"person": %(p_pk)s, "price": 100, "group": %(g_pk)s}}, {"pk": %(p_pk)s, "model": "m2m_through_regress.person", "fields": {"name": "Bob"}}, {"pk": %(g_pk)s, "model": "m2m_through_regress.group", "fields": {"name": "Roll"}}]""" % pks)
  57. out = BytesIO()
  58. management.call_command("dumpdata", "m2m_through_regress", format="xml",
  59. indent=2, stdout=out)
  60. self.assertEqual(out.getvalue().strip(), """
  61. <?xml version="1.0" encoding="utf-8"?>
  62. <django-objects version="1.0">
  63. <object pk="%(m_pk)s" model="m2m_through_regress.membership">
  64. <field to="m2m_through_regress.person" name="person" rel="ManyToOneRel">%(p_pk)s</field>
  65. <field to="m2m_through_regress.group" name="group" rel="ManyToOneRel">%(g_pk)s</field>
  66. <field type="IntegerField" name="price">100</field>
  67. </object>
  68. <object pk="%(p_pk)s" model="m2m_through_regress.person">
  69. <field type="CharField" name="name">Bob</field>
  70. </object>
  71. <object pk="%(g_pk)s" model="m2m_through_regress.group">
  72. <field type="CharField" name="name">Roll</field>
  73. </object>
  74. </django-objects>
  75. """.strip() % pks)
  76. def test_join_trimming(self):
  77. "Check that we don't involve too many copies of the intermediate table when doing a join. Refs #8046, #8254"
  78. bob = Person.objects.create(name="Bob")
  79. jim = Person.objects.create(name="Jim")
  80. rock = Group.objects.create(name="Rock")
  81. roll = Group.objects.create(name="Roll")
  82. Membership.objects.create(person=bob, group=rock)
  83. Membership.objects.create(person=jim, group=rock, price=50)
  84. Membership.objects.create(person=bob, group=roll, price=50)
  85. self.assertQuerysetEqual(
  86. rock.members.filter(membership__price=50), [
  87. "<Person: Jim>",
  88. ]
  89. )
  90. self.assertQuerysetEqual(
  91. bob.group_set.filter(membership__price=50), [
  92. "<Group: Roll>",
  93. ]
  94. )
  95. class ToFieldThroughTests(TestCase):
  96. def setUp(self):
  97. self.car = Car.objects.create(make="Toyota")
  98. self.driver = Driver.objects.create(name="Ryan Briscoe")
  99. CarDriver.objects.create(car=self.car, driver=self.driver)
  100. def test_to_field(self):
  101. self.assertQuerysetEqual(
  102. self.car.drivers.all(),
  103. ["<Driver: Ryan Briscoe>"]
  104. )
  105. def test_to_field_reverse(self):
  106. self.assertQuerysetEqual(
  107. self.driver.car_set.all(),
  108. ["<Car: Toyota>"]
  109. )
  110. class ThroughLoadDataTestCase(TestCase):
  111. fixtures = ["m2m_through"]
  112. def test_sequence_creation(self):
  113. "Check that sequences on an m2m_through are created for the through model, not a phantom auto-generated m2m table. Refs #11107"
  114. out = BytesIO()
  115. management.call_command("dumpdata", "m2m_through_regress", format="json", stdout=out)
  116. self.assertEqual(out.getvalue().strip(), """[{"pk": 1, "model": "m2m_through_regress.usermembership", "fields": {"price": 100, "group": 1, "user": 1}}, {"pk": 1, "model": "m2m_through_regress.person", "fields": {"name": "Guido"}}, {"pk": 1, "model": "m2m_through_regress.group", "fields": {"name": "Python Core Group"}}]""")