diff options
author | Zac Medico <zmedico@gentoo.org> | 2013-02-11 17:35:48 -0800 |
---|---|---|
committer | Zac Medico <zmedico@gentoo.org> | 2013-02-11 17:35:48 -0800 |
commit | a1fc6a8b692ea76a118b298a868d4811c4793628 (patch) | |
tree | 28083b7a8d79408b62f244b8e6cc8d9ac94d754c | |
parent | _slot_operator_update_probe: detect insignificant (diff) | |
download | portage-a1fc6a8b692ea76a118b298a868d4811c4793628.tar.gz portage-a1fc6a8b692ea76a118b298a868d4811c4793628.tar.bz2 portage-a1fc6a8b692ea76a118b298a868d4811c4793628.zip |
Add test case for bug #456340.
The problem here results from poor handling of the unsatisfied built
slot operator dep inside _add_dep, where it aborts the graph and tries
to backtrack immediately. We really want it to queue a rebuild here,
and continue filling out the graph.
-rw-r--r-- | pym/portage/tests/resolver/test_slot_operator_unsolved.py | 73 |
1 files changed, 73 insertions, 0 deletions
diff --git a/pym/portage/tests/resolver/test_slot_operator_unsolved.py b/pym/portage/tests/resolver/test_slot_operator_unsolved.py new file mode 100644 index 000000000..a4962523f --- /dev/null +++ b/pym/portage/tests/resolver/test_slot_operator_unsolved.py @@ -0,0 +1,73 @@ +# Copyright 2013 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 SlotOperatorUnsolvedTestCase(TestCase): + """ + Demonstrate bug #456340, where an unsolved circular dependency + interacts with an unsatisfied built slot-operator dep. + + The problem here results from poor handling of the unsatisfied built + slot operator dep inside _add_dep, where it aborts the graph and tries + to backtrack immediately. We really want it to queue a rebuild here, + and continue filling out the graph. + """ + def __init__(self, *args, **kwargs): + super(SlotOperatorUnsolvedTestCase, self).__init__(*args, **kwargs) + + def testSlotOperatorUnsolved(self): + ebuilds = { + "dev-libs/icu-50.1.2" : { + "EAPI": "5", + "SLOT": "0/50.1.2" + }, + "net-libs/webkit-gtk-1.10.2-r300" : { + "EAPI": "5", + "DEPEND": ">=dev-libs/icu-3.8.1-r1:=", + "RDEPEND": ">=dev-libs/icu-3.8.1-r1:=" + }, + "dev-ruby/rdoc-3.12.1" : { + "EAPI": "5", + "DEPEND": ">=dev-ruby/hoe-2.7.0", + }, + "dev-ruby/hoe-2.13.0" : { + "EAPI": "5", + "DEPEND": ">=dev-ruby/rdoc-3.10", + "RDEPEND": ">=dev-ruby/rdoc-3.10", + }, + } + + installed = { + "dev-libs/icu-50.1.2" : { + "EAPI": "5", + "SLOT": "0/50.1.2" + }, + "net-libs/webkit-gtk-1.10.2-r300" : { + "EAPI": "5", + "DEPEND": ">=dev-libs/icu-3.8.1-r1:0/50=", + "RDEPEND": ">=dev-libs/icu-3.8.1-r1:0/50=" + }, + } + + world = ["net-libs/webkit-gtk", "dev-ruby/hoe"] + + test_cases = ( + + ResolverPlaygroundTestCase( + ["@world"], + options = {"--update": True, "--deep": True}, + success = False), + + ) + + playground = ResolverPlayground(ebuilds=ebuilds, + installed=installed, world=world, debug=False) + 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() |