From: Zac Medico Date: Sat, 21 May 2011 00:51:09 +0000 (-0700) Subject: ResolverPlayground: support ambigous_merge_order X-Git-Tag: v2.1.9.50~66 X-Git-Url: http://git.tremily.us/?a=commitdiff_plain;h=05796ead3c2a1536929de9dba22d0c700baa19a3;p=portage.git ResolverPlayground: support ambigous_merge_order --- diff --git a/pym/portage/tests/resolver/ResolverPlayground.py b/pym/portage/tests/resolver/ResolverPlayground.py index 073e3a601..bc2f80010 100644 --- a/pym/portage/tests/resolver/ResolverPlayground.py +++ b/pym/portage/tests/resolver/ResolverPlayground.py @@ -3,6 +3,7 @@ from itertools import permutations import shutil +import sys import tempfile import portage from portage import os @@ -24,6 +25,9 @@ from _emerge.create_depgraph_params import create_depgraph_params from _emerge.depgraph import backtrack_depgraph from _emerge.RootConfig import RootConfig +if sys.hexversion >= 0x3000000: + basestring = str + class ResolverPlayground(object): """ This class helps to create the necessary files on disk and @@ -463,6 +467,7 @@ class ResolverPlaygroundTestCase(object): def __init__(self, request, **kwargs): self.all_permutations = kwargs.pop("all_permutations", False) self.ignore_mergelist_order = kwargs.pop("ignore_mergelist_order", False) + self.ambigous_merge_order = kwargs.pop("ambigous_merge_order", False) self.check_repo_names = kwargs.pop("check_repo_names", False) if self.all_permutations: @@ -502,13 +507,51 @@ class ResolverPlaygroundTestCase(object): got = new_got if expected: new_expected = [] - for cpv in expected: - a = Atom("="+cpv, allow_repo=True) - new_expected.append(a.cpv) + for obj in expected: + if isinstance(obj, basestring): + a = Atom("="+obj, allow_repo=True) + new_expected.append(a.cpv) + continue + new_expected.append(set()) + for cpv in obj: + a = Atom("="+cpv, allow_repo=True) + new_expected[-1].add(a.cpv) expected = new_expected if self.ignore_mergelist_order and got is not None: got = set(got) expected = set(expected) + + if self.ambigous_merge_order and got: + expected_stack = list(reversed(expected)) + got_stack = list(reversed(got)) + new_expected = [] + while got_stack and expected_stack: + got_token = got_stack.pop() + expected_obj = expected_stack.pop() + if isinstance(expected_obj, basestring): + new_expected.append(got_token) + continue + expected_obj = set(expected_obj) + try: + expected_obj.remove(got_token) + except KeyError: + # result doesn't match, so stop early + break + new_expected.append(got_token) + match = True + while got_stack and expected_obj: + got_token = got_stack.pop() + try: + expected_obj.remove(got_token) + except KeyError: + match = False + break + new_expected.append(got_token) + if not match: + # result doesn't match, so stop early + break + expected = new_expected + elif key == "unstable_keywords" and expected is not None: expected = set(expected) diff --git a/pym/portage/tests/resolver/test_merge_order.py b/pym/portage/tests/resolver/test_merge_order.py new file mode 100644 index 000000000..ada9e73fd --- /dev/null +++ b/pym/portage/tests/resolver/test_merge_order.py @@ -0,0 +1,45 @@ +# Copyright 2011 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 MergeOrderTestCase(TestCase): + + def testMergeOrder(self): + ebuilds = { + "app-misc/circ-runtime-a-1": { + "RDEPEND": "app-misc/circ-runtime-b", + }, + "app-misc/circ-runtime-b-1": { + "RDEPEND": "app-misc/circ-runtime-a", + }, + "app-misc/some-app-a-1": { + "RDEPEND": "app-misc/circ-runtime-a app-misc/circ-runtime-b", + }, + } + + installed = { + } + + test_cases = ( + ResolverPlaygroundTestCase( + ["app-misc/some-app-a"], + success = True, + ambigous_merge_order = True, + mergelist = [("app-misc/circ-runtime-a-1", "app-misc/circ-runtime-b-1"), "app-misc/some-app-a-1"]), + ResolverPlaygroundTestCase( + ["app-misc/some-app-a"], + success = True, + ambigous_merge_order = True, + mergelist = [("app-misc/circ-runtime-b-1", "app-misc/circ-runtime-a-1"), "app-misc/some-app-a-1"]), + ) + + playground = ResolverPlayground(ebuilds=ebuilds, installed=installed) + 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()