From cafa8cf69be8eaaccf51c7befab814f6fd8eb89a Mon Sep 17 00:00:00 2001 From: Sebastian Luther Date: Thu, 5 Aug 2010 16:29:31 +0200 Subject: Tests: Add resolver/test_eapi (2 tests disabled) The resolver accepts EAPI-0 ebuilds with IUSE defaults and slot dependencies. --- pym/portage/tests/resolver/ResolverPlayground.py | 4 + pym/portage/tests/resolver/test_eapi.py | 98 ++++++++++++++++++++++++ pym/portage/tests/resolver/test_simple.py | 4 +- 3 files changed, 103 insertions(+), 3 deletions(-) create mode 100644 pym/portage/tests/resolver/test_eapi.py (limited to 'pym') diff --git a/pym/portage/tests/resolver/ResolverPlayground.py b/pym/portage/tests/resolver/ResolverPlayground.py index 56cdb5f41..643a3b611 100644 --- a/pym/portage/tests/resolver/ResolverPlayground.py +++ b/pym/portage/tests/resolver/ResolverPlayground.py @@ -178,9 +178,13 @@ class ResolverPlayground(object): myopts["--quiet"] = True myopts["--root"] = self.root myopts["--config-root"] = self.root + myopts["--root-deps"] = "rdeps" + + portage.util.noiselimit = -2 myparams = create_depgraph_params(myopts, myaction) success, mydepgraph, favorites = backtrack_depgraph( self.settings, self.trees, myopts, myparams, myaction, myfiles, None) + portage.util.noiselimit = 0 if success: mergelist = [x.cpv for x in mydepgraph._dynamic_config._serialized_tasks_cache] diff --git a/pym/portage/tests/resolver/test_eapi.py b/pym/portage/tests/resolver/test_eapi.py new file mode 100644 index 000000000..f2eff44d4 --- /dev/null +++ b/pym/portage/tests/resolver/test_eapi.py @@ -0,0 +1,98 @@ +# 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 + +class SimpleResolverTestCase(TestCase): + + def testEAPI(self): + ebuilds = { + #EAPI-1: IUSE-defaults + "dev-libs/A-1.0": { "EAPI": 0, "IUSE": "+foo" }, + "dev-libs/A-1.1": { "EAPI": 1, "IUSE": "+foo" }, + "dev-libs/A-1.2": { "EAPI": 2, "IUSE": "+foo" }, + "dev-libs/A-1.3": { "EAPI": 3, "IUSE": "+foo" }, + #~ "dev-libs/A-1.4": { "EAPI": 4, "IUSE": "+foo" }, + + #EAPI-1: slot deps + "dev-libs/A-2.0": { "EAPI": 0, "DEPEND": "dev-libs/B:0" }, + "dev-libs/A-2.1": { "EAPI": 1, "DEPEND": "dev-libs/B:0" }, + "dev-libs/A-2.2": { "EAPI": 2, "DEPEND": "dev-libs/B:0" }, + "dev-libs/A-2.3": { "EAPI": 3, "DEPEND": "dev-libs/B:0" }, + #~ "dev-libs/A-2.4": { "EAPI": 4, "DEPEND": "dev-libs/B:0" }, + + #EAPI-2: use deps + "dev-libs/A-3.0": { "EAPI": 0, "DEPEND": "dev-libs/B[foo]" }, + "dev-libs/A-3.1": { "EAPI": 1, "DEPEND": "dev-libs/B[foo]" }, + "dev-libs/A-3.2": { "EAPI": 2, "DEPEND": "dev-libs/B[foo]" }, + "dev-libs/A-3.3": { "EAPI": 3, "DEPEND": "dev-libs/B[foo]" }, + #~ "dev-libs/A-3.4": { "EAPI": 4, "DEPEND": "dev-libs/B[foo]" }, + + #EAPI-2: strong blocks + "dev-libs/A-4.0": { "EAPI": 0, "DEPEND": "!!dev-libs/B" }, + "dev-libs/A-4.1": { "EAPI": 1, "DEPEND": "!!dev-libs/B" }, + "dev-libs/A-4.2": { "EAPI": 2, "DEPEND": "!!dev-libs/B" }, + "dev-libs/A-4.3": { "EAPI": 3, "DEPEND": "!!dev-libs/B" }, + #~ "dev-libs/A-4.4": { "EAPI": 4, "DEPEND": "!!dev-libs/B" }, + + #EAPI-4: slot operator deps + #~ "dev-libs/A-5.0": { "EAPI": 0, "DEPEND": "dev-libs/B:*" }, + #~ "dev-libs/A-5.1": { "EAPI": 1, "DEPEND": "dev-libs/B:*" }, + #~ "dev-libs/A-5.2": { "EAPI": 2, "DEPEND": "dev-libs/B:*" }, + #~ "dev-libs/A-5.3": { "EAPI": 3, "DEPEND": "dev-libs/B:*" }, + #~ "dev-libs/A-5.4": { "EAPI": 4, "DEPEND": "dev-libs/B:*" }, + + #EAPI-4: slot operator deps + #~ "dev-libs/A-6.0": { "EAPI": 0, "DEPEND": "dev-libs/B[bar(+)]" }, + #~ "dev-libs/A-6.1": { "EAPI": 1, "DEPEND": "dev-libs/B[bar(+)]" }, + #~ "dev-libs/A-6.2": { "EAPI": 2, "DEPEND": "dev-libs/B[bar(+)]" }, + #~ "dev-libs/A-6.3": { "EAPI": 3, "DEPEND": "dev-libs/B[bar(+)]" }, + #~ "dev-libs/A-6.4": { "EAPI": 4, "DEPEND": "dev-libs/B[bar(+)]" }, + + "dev-libs/B-1": {"EAPI": 1, "IUSE": "+foo"}, + } + + requests = ( + #~ (["=dev-libs/A-1.0"], {}, None, False, None), + (["=dev-libs/A-1.1"], {}, None, True, ["dev-libs/A-1.1"]), + (["=dev-libs/A-1.2"], {}, None, True, ["dev-libs/A-1.2"]), + (["=dev-libs/A-1.3"], {}, None, True, ["dev-libs/A-1.3"]), + #~ (["=dev-libs/A-1.4"], {}, None, True, ["dev-libs/A-1.4"]), + + #~ (["=dev-libs/A-2.0"], {}, None, False, None), + (["=dev-libs/A-2.1"], {}, None, True, ["dev-libs/B-1", "dev-libs/A-2.1"]), + (["=dev-libs/A-2.2"], {}, None, True, ["dev-libs/B-1", "dev-libs/A-2.2"]), + (["=dev-libs/A-2.3"], {}, None, True, ["dev-libs/B-1", "dev-libs/A-2.3"]), + #~ (["=dev-libs/A-2.4"], {}, None, True, ["dev-libs/B-1", "dev-libs/A-2.4"]), + + (["=dev-libs/A-3.0"], {}, None, False, None), + (["=dev-libs/A-3.1"], {}, None, False, None), + (["=dev-libs/A-3.2"], {}, None, True, ["dev-libs/B-1", "dev-libs/A-3.2"]), + (["=dev-libs/A-3.3"], {}, None, True, ["dev-libs/B-1", "dev-libs/A-3.3"]), + #~ (["=dev-libs/A-3.4"], {}, None, True, ["dev-libs/B-1", "dev-libs/A-3.4"]), + + (["=dev-libs/A-4.0"], {}, None, False, None), + (["=dev-libs/A-4.1"], {}, None, False, None), + (["=dev-libs/A-4.2"], {}, None, True, ["dev-libs/A-4.2"]), + (["=dev-libs/A-4.3"], {}, None, True, ["dev-libs/A-4.3"]), + #~ (["=dev-libs/A-4.4"], {}, None, True, ["dev-libs/A-4.4"]), + + #~ (["=dev-libs/A-5.0"], {}, None, False, None), + #~ (["=dev-libs/A-5.1"], {}, None, False, None), + #~ (["=dev-libs/A-5.2"], {}, None, False, None), + #~ (["=dev-libs/A-5.3"], {}, None, False, None), + #~ (["=dev-libs/A-5.4"], {}, None, True, ["dev-libs/B-1", "dev-libs/A-5.4"]), + + #~ (["=dev-libs/A-6.0"], {}, None, False, None), + #~ (["=dev-libs/A-6.1"], {}, None, False, None), + #~ (["=dev-libs/A-6.2"], {}, None, False, None), + #~ (["=dev-libs/A-6.3"], {}, None, False, None), + #~ (["=dev-libs/A-6.4"], {}, None, True, ["dev-libs/B-1", "dev-libs/A-6.4"]), + ) + + playground = ResolverPlayground(ebuilds=ebuilds) + + for atoms, options, action, expected_result, expected_mergelist in requests: + success, mergelist = playground.run(atoms, options, action) + self.assertEqual((success, mergelist), (expected_result, expected_mergelist)) diff --git a/pym/portage/tests/resolver/test_simple.py b/pym/portage/tests/resolver/test_simple.py index d178e7fb0..c092129b7 100644 --- a/pym/portage/tests/resolver/test_simple.py +++ b/pym/portage/tests/resolver/test_simple.py @@ -27,6 +27,4 @@ class SimpleResolverTestCase(TestCase): for atoms, options, action, expected_result, expected_mergelist in requests: success, mergelist = playground.run(atoms, options, action) - self.assertEqual(success, expected_result) - if success: - self.assertEqual(mergelist, expected_mergelist) + self.assertEqual((success, mergelist), (expected_result, expected_mergelist)) -- cgit v1.2.3-1-g7c22