summaryrefslogtreecommitdiff
path: root/tests/m2m_recursive
diff options
context:
space:
mode:
authorMariusz Felisiak <felisiak.mariusz@gmail.com>2019-05-31 16:19:11 +0200
committerGitHub <noreply@github.com>2019-05-31 16:19:11 +0200
commitea6e684f344e5c2ed5a2be1cf2420725c2f88405 (patch)
tree631435bde720f125e0ef650179aef76687c5e956 /tests/m2m_recursive
parent85436473066aae5d793caeced010ea4f45da4e79 (diff)
downloaddjango-ea6e684f344e5c2ed5a2be1cf2420725c2f88405.tar.gz
Simplified m2m_recursive.tests.
Diffstat (limited to 'tests/m2m_recursive')
-rw-r--r--tests/m2m_recursive/tests.py175
1 files changed, 27 insertions, 148 deletions
diff --git a/tests/m2m_recursive/tests.py b/tests/m2m_recursive/tests.py
index ea0de1a329..0d992070a2 100644
--- a/tests/m2m_recursive/tests.py
+++ b/tests/m2m_recursive/tests.py
@@ -1,5 +1,3 @@
-from operator import attrgetter
-
from django.test import TestCase
from .models import Person
@@ -10,173 +8,54 @@ class RecursiveM2MTests(TestCase):
def setUpTestData(cls):
cls.a, cls.b, cls.c, cls.d = [
Person.objects.create(name=name)
- for name in ["Anne", "Bill", "Chuck", "David"]
+ for name in ['Anne', 'Bill', 'Chuck', 'David']
]
-
- # Anne is friends with Bill and Chuck
cls.a.friends.add(cls.b, cls.c)
-
- # David is friends with Anne and Chuck - add in reverse direction
+ # Add m2m for Anne and Chuck in reverse direction.
cls.d.friends.add(cls.a, cls.c)
def test_recursive_m2m_all(self):
- # Who is friends with Anne?
- self.assertQuerysetEqual(
- self.a.friends.all(), [
- "Bill",
- "Chuck",
- "David"
- ],
- attrgetter("name"),
- ordered=False
- )
- # Who is friends with Bill?
- self.assertQuerysetEqual(
- self.b.friends.all(), [
- "Anne",
- ],
- attrgetter("name")
- )
- # Who is friends with Chuck?
- self.assertQuerysetEqual(
- self.c.friends.all(), [
- "Anne",
- "David"
- ],
- attrgetter("name"),
- ordered=False
- )
- # Who is friends with David?
- self.assertQuerysetEqual(
- self.d.friends.all(), [
- "Anne",
- "Chuck",
- ],
- attrgetter("name"),
- ordered=False
- )
+ for person, friends in (
+ (self.a, [self.b, self.c, self.d]),
+ (self.b, [self.a]),
+ (self.c, [self.a, self.d]),
+ (self.d, [self.a, self.c]),
+ ):
+ with self.subTest(person=person):
+ self.assertSequenceEqual(person.friends.all(), friends)
def test_recursive_m2m_reverse_add(self):
- # Bill is already friends with Anne - add Anne again, but in the
- # reverse direction
+ # Add m2m for Anne in reverse direction.
self.b.friends.add(self.a)
-
- # Who is friends with Anne?
- self.assertQuerysetEqual(
- self.a.friends.all(), [
- "Bill",
- "Chuck",
- "David",
- ],
- attrgetter("name"),
- ordered=False
- )
- # Who is friends with Bill?
- self.assertQuerysetEqual(
- self.b.friends.all(), [
- "Anne",
- ],
- attrgetter("name")
- )
+ self.assertSequenceEqual(self.a.friends.all(), [self.b, self.c, self.d])
+ self.assertSequenceEqual(self.b.friends.all(), [self.a])
def test_recursive_m2m_remove(self):
- # Remove Anne from Bill's friends
self.b.friends.remove(self.a)
-
- # Who is friends with Anne?
- self.assertQuerysetEqual(
- self.a.friends.all(), [
- "Chuck",
- "David",
- ],
- attrgetter("name"),
- ordered=False
- )
- # Who is friends with Bill?
- self.assertQuerysetEqual(
- self.b.friends.all(), []
- )
+ self.assertSequenceEqual(self.a.friends.all(), [self.c, self.d])
+ self.assertSequenceEqual(self.b.friends.all(), [])
def test_recursive_m2m_clear(self):
- # Clear Anne's group of friends
+ # Clear m2m for Anne.
self.a.friends.clear()
-
- # Who is friends with Anne?
- self.assertQuerysetEqual(
- self.a.friends.all(), []
- )
-
- # Reverse relationships should also be gone
- # Who is friends with Chuck?
- self.assertQuerysetEqual(
- self.c.friends.all(), [
- "David",
- ],
- attrgetter("name")
- )
-
- # Who is friends with David?
- self.assertQuerysetEqual(
- self.d.friends.all(), [
- "Chuck",
- ],
- attrgetter("name")
- )
+ self.assertSequenceEqual(self.a.friends.all(), [])
+ # Reverse m2m relationships should be removed.
+ self.assertSequenceEqual(self.c.friends.all(), [self.d])
+ self.assertSequenceEqual(self.d.friends.all(), [self.c])
def test_recursive_m2m_add_via_related_name(self):
- # David is idolized by Anne and Chuck - add in reverse direction
+ # Add m2m with custom related name for Anne in reverse direction.
self.d.stalkers.add(self.a)
-
- # Who are Anne's idols?
- self.assertQuerysetEqual(
- self.a.idols.all(), [
- "David",
- ],
- attrgetter("name"),
- ordered=False
- )
- # Who is stalking Anne?
- self.assertQuerysetEqual(
- self.a.stalkers.all(), [],
- attrgetter("name")
- )
+ self.assertSequenceEqual(self.a.idols.all(), [self.d])
+ self.assertSequenceEqual(self.a.stalkers.all(), [])
def test_recursive_m2m_add_in_both_directions(self):
- """Adding the same relation twice results in a single relation."""
- # Ann idolizes David
+ # Adding the same relation twice results in a single relation.
self.a.idols.add(self.d)
-
- # David is idolized by Anne
self.d.stalkers.add(self.a)
-
- # Who are Anne's idols?
- self.assertQuerysetEqual(
- self.a.idols.all(), [
- "David",
- ],
- attrgetter("name"),
- ordered=False
- )
- # As the assertQuerysetEqual uses a set for comparison,
- # check we've only got David listed once
- self.assertEqual(self.a.idols.all().count(), 1)
+ self.assertSequenceEqual(self.a.idols.all(), [self.d])
def test_recursive_m2m_related_to_self(self):
- # Ann idolizes herself
self.a.idols.add(self.a)
-
- # Who are Anne's idols?
- self.assertQuerysetEqual(
- self.a.idols.all(), [
- "Anne",
- ],
- attrgetter("name"),
- ordered=False
- )
- # Who is stalking Anne?
- self.assertQuerysetEqual(
- self.a.stalkers.all(), [
- "Anne",
- ],
- attrgetter("name")
- )
+ self.assertSequenceEqual(self.a.idols.all(), [self.a])
+ self.assertSequenceEqual(self.a.stalkers.all(), [self.a])