Beispiel #1
0
    def test_check_circular_dependencies(self):
        uut = DependencyTracker()
        uut.add(0, 1)
        uut.add(1, 2)

        uut.check_circular_dependencies()

        uut.add(2, 0)

        with self.assertRaises(CircularDependencyError):
            uut.check_circular_dependencies()
    def test_check_circular_dependencies(self):
        uut = DependencyTracker()
        uut.add(0, 1)
        uut.add(1, 2)

        uut.check_circular_dependencies()

        uut.add(2, 0)

        with self.assertRaises(CircularDependencyError):
            uut.check_circular_dependencies()
Beispiel #3
0
    def test_get_dependants(self):
        uut = DependencyTracker()

        self.assertEqual(uut.get_dependants(0), set())

        uut.add(0, 1)
        uut.add(0, 2)
        uut.add(1, 3)

        self.assertEqual(uut.get_dependants(0), {1, 2})
        self.assertEqual(uut.get_dependants(1), {3})
        self.assertEqual(uut.get_dependants(2), set())

        uut.resolve(0)

        self.assertEqual(uut.get_dependants(0), set())
        self.assertEqual(uut.get_dependants(1), {3})
    def test_get_dependants(self):
        uut = DependencyTracker()

        self.assertEqual(uut.get_dependants(0), set())

        uut.add(0, 1)
        uut.add(0, 2)
        uut.add(1, 3)

        self.assertEqual(uut.get_dependants(0), {1, 2})
        self.assertEqual(uut.get_dependants(1), {3})
        self.assertEqual(uut.get_dependants(2), set())

        uut.resolve(0)

        self.assertEqual(uut.get_dependants(0), set())
        self.assertEqual(uut.get_dependants(1), {3})
    def test_get_dependencies(self):
        uut = DependencyTracker()

        self.assertEqual(uut.get_dependencies(0), set())

        uut.add(0, 1)
        uut.add(0, 2)
        uut.add(0, 3)
        uut.add(1, 3)

        self.assertEqual(uut.get_dependencies(0), set())
        self.assertEqual(uut.get_dependencies(1), {0})
        self.assertEqual(uut.get_dependencies(2), {0})
        self.assertEqual(uut.get_dependencies(3), {0, 1})

        uut.resolve(0)

        self.assertEqual(uut.get_dependencies(1), set())
        self.assertEqual(uut.get_dependencies(3), {1})
Beispiel #6
0
    def test_get_dependencies(self):
        uut = DependencyTracker()

        self.assertEqual(uut.get_dependencies(0), set())

        uut.add(0, 1)
        uut.add(0, 2)
        uut.add(0, 3)
        uut.add(1, 3)

        self.assertEqual(uut.get_dependencies(0), set())
        self.assertEqual(uut.get_dependencies(1), {0})
        self.assertEqual(uut.get_dependencies(2), {0})
        self.assertEqual(uut.get_dependencies(3), {0, 1})

        uut.resolve(0)

        self.assertEqual(uut.get_dependencies(1), set())
        self.assertEqual(uut.get_dependencies(3), {1})
Beispiel #7
0
    def test_get_all_dependencies(self):
        uut = DependencyTracker()

        self.assertEqual(uut.get_all_dependencies(0), set())

        uut.add(0, 1)
        uut.add(0, 2)

        self.assertEqual(uut.get_all_dependencies(0), set())
        self.assertEqual(uut.get_all_dependencies(1), {0})
        self.assertEqual(uut.get_all_dependencies(2), {0})

        uut.add(1, 3)

        self.assertEqual(uut.get_all_dependencies(0), set())
        self.assertEqual(uut.get_all_dependencies(1), {0})
        self.assertEqual(uut.get_all_dependencies(2), {0})
        self.assertEqual(uut.get_all_dependencies(3), {0, 1})

        uut.add(2, 4)

        self.assertEqual(uut.get_all_dependencies(0), set())
        self.assertEqual(uut.get_all_dependencies(1), {0})
        self.assertEqual(uut.get_all_dependencies(2), {0})
        self.assertEqual(uut.get_all_dependencies(3), {0, 1})
        self.assertEqual(uut.get_all_dependencies(4), {0, 2})
    def test_get_all_dependencies(self):
        uut = DependencyTracker()

        self.assertEqual(uut.get_all_dependencies(0), set())

        uut.add(0, 1)
        uut.add(0, 2)

        self.assertEqual(uut.get_all_dependencies(0), set())
        self.assertEqual(uut.get_all_dependencies(1), {0})
        self.assertEqual(uut.get_all_dependencies(2), {0})

        uut.add(1, 3)

        self.assertEqual(uut.get_all_dependencies(0), set())
        self.assertEqual(uut.get_all_dependencies(1), {0})
        self.assertEqual(uut.get_all_dependencies(2), {0})
        self.assertEqual(uut.get_all_dependencies(3), {0, 1})

        uut.add(2, 4)

        self.assertEqual(uut.get_all_dependencies(0), set())
        self.assertEqual(uut.get_all_dependencies(1), {0})
        self.assertEqual(uut.get_all_dependencies(2), {0})
        self.assertEqual(uut.get_all_dependencies(3), {0, 1})
        self.assertEqual(uut.get_all_dependencies(4), {0, 2})
Beispiel #9
0
    def test_get_all_dependants(self):
        uut = DependencyTracker()

        self.assertEqual(uut.get_all_dependants(0), set())

        uut.add(0, 1)
        uut.add(0, 2)

        self.assertEqual(uut.get_all_dependants(0), {1, 2})
        self.assertEqual(uut.get_all_dependants(1), set())
        self.assertEqual(uut.get_all_dependants(2), set())

        uut.add(1, 3)

        self.assertEqual(uut.get_all_dependants(0), {1, 2, 3})
        self.assertEqual(uut.get_all_dependants(1), {3})
        self.assertEqual(uut.get_all_dependants(2), set())
        self.assertEqual(uut.get_all_dependants(3), set())

        uut.add(2, 4)

        self.assertEqual(uut.get_all_dependants(0), {1, 2, 3, 4})
        self.assertEqual(uut.get_all_dependants(1), {3})
        self.assertEqual(uut.get_all_dependants(2), {4})
        self.assertEqual(uut.get_all_dependants(3), set())
        self.assertEqual(uut.get_all_dependants(4), set())
    def test_get_all_dependants(self):
        uut = DependencyTracker()

        self.assertEqual(uut.get_all_dependants(0), set())

        uut.add(0, 1)
        uut.add(0, 2)

        self.assertEqual(uut.get_all_dependants(0), {1, 2})
        self.assertEqual(uut.get_all_dependants(1), set())
        self.assertEqual(uut.get_all_dependants(2), set())

        uut.add(1, 3)

        self.assertEqual(uut.get_all_dependants(0), {1, 2, 3})
        self.assertEqual(uut.get_all_dependants(1), {3})
        self.assertEqual(uut.get_all_dependants(2), set())
        self.assertEqual(uut.get_all_dependants(3), set())

        uut.add(2, 4)

        self.assertEqual(uut.get_all_dependants(0), {1, 2, 3, 4})
        self.assertEqual(uut.get_all_dependants(1), {3})
        self.assertEqual(uut.get_all_dependants(2), {4})
        self.assertEqual(uut.get_all_dependants(3), set())
        self.assertEqual(uut.get_all_dependants(4), set())
Beispiel #11
0
    def test_are_dependencies_resolved(self):
        uut = DependencyTracker()

        self.assertTrue(uut.are_dependencies_resolved)

        uut.add(0, 1)

        self.assertFalse(uut.are_dependencies_resolved)

        uut.resolve(0)

        self.assertTrue(uut.are_dependencies_resolved)

        # Test case when dependencies were forcefully resolved.
        uut.add(0, 1)
        uut.add(1, 2)

        self.assertFalse(uut.are_dependencies_resolved)

        uut.resolve(1)

        self.assertTrue(uut.are_dependencies_resolved)
    def test_are_dependencies_resolved(self):
        uut = DependencyTracker()

        self.assertTrue(uut.are_dependencies_resolved)

        uut.add(0, 1)

        self.assertFalse(uut.are_dependencies_resolved)

        uut.resolve(0)

        self.assertTrue(uut.are_dependencies_resolved)

        # Test case when dependencies were forcefully resolved.
        uut.add(0, 1)
        uut.add(1, 2)

        self.assertFalse(uut.are_dependencies_resolved)

        uut.resolve(1)

        self.assertTrue(uut.are_dependencies_resolved)
Beispiel #13
0
    def test_dependants(self):
        uut = DependencyTracker()

        self.assertEqual(uut.dependants, set())

        uut.add(0, 1)
        uut.add(0, 2)
        uut.add(1, 3)
        uut.add(1, 3)
        uut.add(4, 5)

        self.assertEqual(uut.dependants, {1, 2, 3, 5})
    def test_dependants(self):
        uut = DependencyTracker()

        self.assertEqual(uut.dependants, set())

        uut.add(0, 1)
        uut.add(0, 2)
        uut.add(1, 3)
        uut.add(1, 3)
        uut.add(4, 5)

        self.assertEqual(uut.dependants, {1, 2, 3, 5})
    def test_dependencies(self):
        uut = DependencyTracker()

        self.assertEqual(uut.dependencies, set())

        uut.add(1, 2)
        uut.add(2, 3)
        uut.add(3, 4)
        uut.add(3, 5)
        uut.add(2, 5)

        self.assertEqual(uut.dependencies, {1, 2, 3})
Beispiel #16
0
    def test_dependencies(self):
        uut = DependencyTracker()

        self.assertEqual(uut.dependencies, set())

        uut.add(1, 2)
        uut.add(2, 3)
        uut.add(3, 4)
        uut.add(3, 5)
        uut.add(2, 5)

        self.assertEqual(uut.dependencies, {1, 2, 3})
    def test_resolve(self):
        uut = DependencyTracker()
        uut.add(0, 1)
        uut.add(0, 2)
        uut.add(0, 3)
        uut.add(4, 5)
        uut.add(6, 0)

        self.assertEqual(uut.resolve(0), {1, 2, 3})

        # Dependants already resolved.
        self.assertEqual(uut.resolve(0), set())

        # Though 0 had a dependency, it was still forcefully resolved.
        self.assertEqual(uut.resolve(6), set())

        # Let's re-add a dependant for 0.
        uut.add(0, 1)
        self.assertEqual(uut.resolve(0), {1})

        # Test the case when we forcefully resolve a dependency, which is still
        # itself a dependant of another dependency together with another
        # dependant.
        uut.add(7, 8)
        uut.add(7, 9)
        uut.add(8, 10)

        self.assertEqual(uut.resolve(8), {10})

        # Test case when a dependant depends on multiple dependencies.
        uut.add(30, 20)
        uut.add(40, 20)

        self.assertEqual(uut.resolve(30), set())
        self.assertEqual(uut.resolve(40), {20})
Beispiel #18
0
    def test_resolve(self):
        uut = DependencyTracker()
        uut.add(0, 1)
        uut.add(0, 2)
        uut.add(0, 3)
        uut.add(4, 5)
        uut.add(6, 0)

        self.assertEqual(uut.resolve(0), {1, 2, 3})

        # Dependants already resolved.
        self.assertEqual(uut.resolve(0), set())

        # Though 0 had a dependency, it was still forcefully resolved.
        self.assertEqual(uut.resolve(6), set())

        # Let's re-add a dependant for 0.
        uut.add(0, 1)
        self.assertEqual(uut.resolve(0), {1})

        # Test the case when we forcefully resolve a dependency, which is still
        # itself a dependant of another dependency together with another
        # dependant.
        uut.add(7, 8)
        uut.add(7, 9)
        uut.add(8, 10)

        self.assertEqual(uut.resolve(8), {10})

        # Test case when a dependant depends on multiple dependencies.
        uut.add(30, 20)
        uut.add(40, 20)

        self.assertEqual(uut.resolve(30), set())
        self.assertEqual(uut.resolve(40), {20})