Tests: add resolver/test_backtracking
authorSebastian Luther <SebastianLuther@gmx.de>
Sun, 8 Aug 2010 17:52:59 +0000 (19:52 +0200)
committerZac Medico <zmedico@gentoo.org>
Wed, 11 Aug 2010 11:04:11 +0000 (04:04 -0700)
pym/portage/tests/resolver/test_backtracking.py [new file with mode: 0644]

diff --git a/pym/portage/tests/resolver/test_backtracking.py b/pym/portage/tests/resolver/test_backtracking.py
new file mode 100644 (file)
index 0000000..d219c6b
--- /dev/null
@@ -0,0 +1,31 @@
+# Copyright 2010 Gentoo Foundation
+# Distributed under the terms of the GNU General Public License v2
+
+from portage.tests import TestCase
+from portage.tests.resolver.ResolverPlayground import ResolverPlayground, ResolverPlaygroundTestCase
+
+class BacktrackingTestCase(TestCase):
+
+       def testBacktracking(self):
+               ebuilds = {
+                       "dev-libs/A-1": {},
+                       "dev-libs/A-2": {},
+                       "dev-libs/B-1": { "DEPEND": "dev-libs/A" },
+                       }
+
+               test_cases = (
+                               ResolverPlaygroundTestCase(
+                                       ["=dev-libs/A-1", "dev-libs/B"],
+                                       all_permutations = True,
+                                       mergelist = ["dev-libs/A-1", "dev-libs/B-1"],
+                                       success = True),
+                       )
+
+               playground = ResolverPlayground(ebuilds=ebuilds)
+
+               try:
+                       for test_case in test_cases:
+                               playground.run_TestCase(test_case)
+                               self.assertEqual(test_case.test_success, True, test_case.fail_msg)
+               finally:
+                       playground.cleanup()