diff options
Diffstat (limited to 'meta/lib')
-rw-r--r-- | meta/lib/oe/recipeutils.py | 6 | ||||
-rw-r--r-- | meta/lib/oeqa/selftest/devtool.py | 32 |
2 files changed, 37 insertions, 1 deletions
diff --git a/meta/lib/oe/recipeutils.py b/meta/lib/oe/recipeutils.py index 207c300667..119a68821b 100644 --- a/meta/lib/oe/recipeutils.py +++ b/meta/lib/oe/recipeutils.py | |||
@@ -31,9 +31,13 @@ def pn_to_recipe(cooker, pn): | |||
31 | import bb.providers | 31 | import bb.providers |
32 | 32 | ||
33 | if pn in cooker.recipecache.pkg_pn: | 33 | if pn in cooker.recipecache.pkg_pn: |
34 | filenames = cooker.recipecache.pkg_pn[pn] | ||
35 | best = bb.providers.findBestProvider(pn, cooker.data, cooker.recipecache, cooker.recipecache.pkg_pn) | 34 | best = bb.providers.findBestProvider(pn, cooker.data, cooker.recipecache, cooker.recipecache.pkg_pn) |
36 | return best[3] | 35 | return best[3] |
36 | elif pn in cooker.recipecache.providers: | ||
37 | filenames = cooker.recipecache.providers[pn] | ||
38 | eligible, foundUnique = bb.providers.filterProviders(filenames, pn, cooker.expanded_data, cooker.recipecache) | ||
39 | filename = eligible[0] | ||
40 | return filename | ||
37 | else: | 41 | else: |
38 | return None | 42 | return None |
39 | 43 | ||
diff --git a/meta/lib/oeqa/selftest/devtool.py b/meta/lib/oeqa/selftest/devtool.py index baa56d6dc1..e4de309e72 100644 --- a/meta/lib/oeqa/selftest/devtool.py +++ b/meta/lib/oeqa/selftest/devtool.py | |||
@@ -466,6 +466,28 @@ class DevtoolTests(DevtoolBase): | |||
466 | # Try building | 466 | # Try building |
467 | bitbake(testrecipe) | 467 | bitbake(testrecipe) |
468 | 468 | ||
469 | def test_devtool_modify_virtual(self): | ||
470 | # Try modifying a virtual recipe | ||
471 | virtrecipe = 'virtual/libx11' | ||
472 | realrecipe = 'libx11' | ||
473 | tempdir = tempfile.mkdtemp(prefix='devtoolqa') | ||
474 | self.track_for_cleanup(tempdir) | ||
475 | self.track_for_cleanup(self.workspacedir) | ||
476 | self.add_command_to_tearDown('bitbake-layers remove-layer */workspace') | ||
477 | result = runCmd('devtool modify %s -x %s' % (virtrecipe, tempdir)) | ||
478 | self.assertTrue(os.path.exists(os.path.join(tempdir, 'Makefile.am')), 'Extracted source could not be found') | ||
479 | self.assertTrue(os.path.exists(os.path.join(self.workspacedir, 'conf', 'layer.conf')), 'Workspace directory not created') | ||
480 | matches = glob.glob(os.path.join(self.workspacedir, 'appends', '%s_*.bbappend' % realrecipe)) | ||
481 | self.assertTrue(matches, 'bbappend not created %s' % result.output) | ||
482 | # Test devtool status | ||
483 | result = runCmd('devtool status') | ||
484 | self.assertNotIn(virtrecipe, result.output) | ||
485 | self.assertIn(realrecipe, result.output) | ||
486 | # Check git repo | ||
487 | self._check_src_repo(tempdir) | ||
488 | # This is probably sufficient | ||
489 | |||
490 | |||
469 | @testcase(1169) | 491 | @testcase(1169) |
470 | def test_devtool_update_recipe(self): | 492 | def test_devtool_update_recipe(self): |
471 | # Check preconditions | 493 | # Check preconditions |
@@ -805,6 +827,16 @@ class DevtoolTests(DevtoolBase): | |||
805 | self.assertTrue(os.path.exists(os.path.join(tempdir, 'Makefile.am')), 'Extracted source could not be found') | 827 | self.assertTrue(os.path.exists(os.path.join(tempdir, 'Makefile.am')), 'Extracted source could not be found') |
806 | self._check_src_repo(tempdir) | 828 | self._check_src_repo(tempdir) |
807 | 829 | ||
830 | def test_devtool_extract_virtual(self): | ||
831 | tempdir = tempfile.mkdtemp(prefix='devtoolqa') | ||
832 | # Try devtool extract | ||
833 | self.track_for_cleanup(tempdir) | ||
834 | self.track_for_cleanup(self.workspacedir) | ||
835 | self.add_command_to_tearDown('bitbake-layers remove-layer */workspace') | ||
836 | result = runCmd('devtool extract virtual/libx11 %s' % tempdir) | ||
837 | self.assertTrue(os.path.exists(os.path.join(tempdir, 'Makefile.am')), 'Extracted source could not be found') | ||
838 | self._check_src_repo(tempdir) | ||
839 | |||
808 | @testcase(1168) | 840 | @testcase(1168) |
809 | def test_devtool_reset_all(self): | 841 | def test_devtool_reset_all(self): |
810 | tempdir = tempfile.mkdtemp(prefix='devtoolqa') | 842 | tempdir = tempfile.mkdtemp(prefix='devtoolqa') |