Tests: Add resolver/test_eapi (2 tests disabled)
authorSebastian Luther <SebastianLuther@gmx.de>
Thu, 5 Aug 2010 14:29:31 +0000 (16:29 +0200)
committerZac Medico <zmedico@gentoo.org>
Thu, 5 Aug 2010 20:37:33 +0000 (13:37 -0700)
The resolver accepts EAPI-0 ebuilds with IUSE defaults and slot dependencies.

pym/portage/tests/resolver/ResolverPlayground.py
pym/portage/tests/resolver/test_eapi.py [new file with mode: 0644]
pym/portage/tests/resolver/test_simple.py

index 56cdb5f417e36022a7b4cbfd52d52078e050c394..643a3b6112d6ed2c9f17624283c677a40a7a6947 100644 (file)
@@ -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 (file)
index 0000000..f2eff44
--- /dev/null
@@ -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))
index d178e7fb0a2cf99135ccf940cb08c999386d98ce..c092129b7879db9a4893a95a9428417ebae40f04 100644 (file)
@@ -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))