summaryrefslogtreecommitdiffstats
path: root/pym/portage/tests/resolver
diff options
context:
space:
mode:
authorSebastian Luther <SebastianLuther@gmx.de>2011-09-19 15:07:08 +0200
committerZac Medico <zmedico@gentoo.org>2011-09-20 09:47:34 -0700
commit6cea2091526659521d35be6c8dc7733f69f1a760 (patch)
tree3f3e2598d61469ce598b7b89bcf6b60ac0b8e5d9 /pym/portage/tests/resolver
parent72ef29a6adaa053cf2d538349a3a1555909ed697 (diff)
downloadportage-6cea2091526659521d35be6c8dc7733f69f1a760.tar.gz
portage-6cea2091526659521d35be6c8dc7733f69f1a760.tar.bz2
portage-6cea2091526659521d35be6c8dc7733f69f1a760.zip
Reject inconsistent backtrack parameters
If backtracking masks a package that caused another package to be masked, we declare this backtracking node as invalid. The backtracker should be able to find another node that gives a valid solution if one exists. This fixes bug 375573.
Diffstat (limited to 'pym/portage/tests/resolver')
-rw-r--r--pym/portage/tests/resolver/test_backtracking.py43
1 files changed, 43 insertions, 0 deletions
diff --git a/pym/portage/tests/resolver/test_backtracking.py b/pym/portage/tests/resolver/test_backtracking.py
index fc493062c..600f68216 100644
--- a/pym/portage/tests/resolver/test_backtracking.py
+++ b/pym/portage/tests/resolver/test_backtracking.py
@@ -167,3 +167,46 @@ class BacktrackingTestCase(TestCase):
self.assertEqual(test_case.test_success, True, test_case.fail_msg)
finally:
playground.cleanup()
+
+
+ def testBacktrackNoWrongRebuilds(self):
+ """
+ Ensure we remove backtrack masks if the reason for the mask gets masked itself.
+ """
+
+ ebuilds = {
+ "dev-libs/A-1": { },
+ "dev-libs/A-2": { },
+ "dev-libs/B-1": { "RDEPEND": "dev-libs/D"},
+ "dev-libs/C-1": { },
+ "dev-libs/C-2": { "RDEPEND": ">=dev-libs/A-2" },
+ "dev-libs/D-1": { "RDEPEND": "<dev-libs/A-2" },
+ }
+
+ installed = {
+ "dev-libs/A-1": { },
+ "dev-libs/B-1": { "RDEPEND": "dev-libs/D" },
+ "dev-libs/C-1": { },
+ "dev-libs/D-1": { "RDEPEND": "<dev-libs/A-2" },
+ }
+
+ world = [ "dev-libs/B", "dev-libs/C" ]
+
+ options = {'--update' : True, '--deep' : True, '--selective' : True}
+
+ test_cases = (
+ ResolverPlaygroundTestCase(
+ ["@world"],
+ options = options,
+ mergelist = [],
+ success = True),
+ )
+
+ playground = ResolverPlayground(ebuilds=ebuilds, installed=installed, world=world)
+
+ 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()