2020-04-30 00:41:12 +02:00
|
|
|
from django.test import TestCase
|
2021-11-07 10:25:34 +01:00
|
|
|
import treenode.treelib as tl
|
2020-04-30 00:41:12 +02:00
|
|
|
import seminar.models as m
|
|
|
|
|
|
|
|
class SimpleTreeLibTests(TestCase):
|
|
|
|
def setUp(self):
|
|
|
|
# Vyrobíme pár nějakých Nodů
|
|
|
|
self.root = m.CastNode(root=None, first_child=None, succ=None, nadpis="Root")
|
|
|
|
self.root.save()
|
|
|
|
self.some_node = m.CastNode(root=self.root, first_child=None, succ=None, nadpis="Přetržené")
|
|
|
|
self.other_node = m.CastNode(root=self.root, first_child=None, succ=None, nadpis="Dítě")
|
|
|
|
self.some_orphan = m.CastNode(root=None, first_child=None, succ=None, nadpis="Ošklivé")
|
|
|
|
self.other_orphan = m.CastNode(root=None, first_child=None, succ=None, nadpis="Káčátko")
|
|
|
|
|
|
|
|
# Trochu je pospojujeme
|
|
|
|
self.root.first_child = self.some_node
|
|
|
|
self.some_node.succ = self.other_node
|
|
|
|
self.some_orphan.first_child = self.other_orphan
|
|
|
|
|
|
|
|
# Všechno uložíme
|
|
|
|
self.other_node.save()
|
|
|
|
self.some_node.save()
|
|
|
|
self.other_orphan.save()
|
|
|
|
self.some_orphan.save()
|
|
|
|
self.root.save()
|
|
|
|
|
|
|
|
def test_safe_functions(self):
|
2020-04-30 01:27:24 +02:00
|
|
|
# safe_pred
|
2020-04-30 00:41:12 +02:00
|
|
|
self.assertEqual(tl.safe_pred(self.other_node), self.some_node)
|
|
|
|
self.assertIsNone(tl.safe_pred(self.root))
|
|
|
|
self.assertIsNone(tl.safe_pred(self.some_node))
|
|
|
|
self.assertIsNone(tl.safe_pred(self.some_orphan))
|
|
|
|
self.assertIsNone(tl.safe_pred(self.other_orphan))
|
2020-04-30 01:27:24 +02:00
|
|
|
|
|
|
|
# safe_father_of_first
|
|
|
|
self.assertIsNone(tl.safe_father_of_first(self.root))
|
|
|
|
self.assertEqual(tl.safe_father_of_first(self.some_node), self.root)
|
|
|
|
self.assertEqual(tl.safe_father_of_first(self.other_node), self.root)
|
|
|
|
self.assertIsNone(tl.safe_father_of_first(self.some_orphan))
|
|
|
|
self.assertEqual(tl.safe_father_of_first(self.other_orphan), self.some_orphan)
|