diff options
| author | Paul Eggleton <paul.eggleton@linux.intel.com> | 2015-10-14 19:19:23 +0100 | 
|---|---|---|
| committer | Richard Purdie <richard.purdie@linuxfoundation.org> | 2015-10-21 22:49:12 +0100 | 
| commit | 1f7752282ffb47d2621030ddb2fa42a5e491d6d2 (patch) | |
| tree | c7f0e799c12f51a00779d7afe94a1b90bb13d43e /meta/lib | |
| parent | 80e2dfbfef2d40c3ab074142deac73317f89e3a2 (diff) | |
| download | openembedded-core-1f7752282ffb47d2621030ddb2fa42a5e491d6d2.tar.gz openembedded-core-1f7752282ffb47d2621030ddb2fa42a5e491d6d2.tar.bz2 openembedded-core-1f7752282ffb47d2621030ddb2fa42a5e491d6d2.zip | |
devtool: handle virtual providers
For modify / extract / upgrade, if the specified "recipe" is not
actually a recipe but a virtual target such as virtual/kernel, map it
correctly to the actual recipe and make sure we use that name within the
workspace. Thanks to Chris Larson for reminding me this was still broken
and for a hint on how to fix it.
Signed-off-by: Paul Eggleton <paul.eggleton@linux.intel.com>
Signed-off-by: Ross Burton <ross.burton@intel.com>
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):      import bb.providers      if pn in cooker.recipecache.pkg_pn: -        filenames = cooker.recipecache.pkg_pn[pn]          best = bb.providers.findBestProvider(pn, cooker.data, cooker.recipecache, cooker.recipecache.pkg_pn)          return best[3] +    elif pn in cooker.recipecache.providers: +        filenames = cooker.recipecache.providers[pn] +        eligible, foundUnique = bb.providers.filterProviders(filenames, pn, cooker.expanded_data, cooker.recipecache) +        filename = eligible[0] +        return filename      else:          return None 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):          # Try building          bitbake(testrecipe) +    def test_devtool_modify_virtual(self): +        # Try modifying a virtual recipe +        virtrecipe = 'virtual/libx11' +        realrecipe = 'libx11' +        tempdir = tempfile.mkdtemp(prefix='devtoolqa') +        self.track_for_cleanup(tempdir) +        self.track_for_cleanup(self.workspacedir) +        self.add_command_to_tearDown('bitbake-layers remove-layer */workspace') +        result = runCmd('devtool modify %s -x %s' % (virtrecipe, tempdir)) +        self.assertTrue(os.path.exists(os.path.join(tempdir, 'Makefile.am')), 'Extracted source could not be found') +        self.assertTrue(os.path.exists(os.path.join(self.workspacedir, 'conf', 'layer.conf')), 'Workspace directory not created') +        matches = glob.glob(os.path.join(self.workspacedir, 'appends', '%s_*.bbappend' % realrecipe)) +        self.assertTrue(matches, 'bbappend not created %s' % result.output) +        # Test devtool status +        result = runCmd('devtool status') +        self.assertNotIn(virtrecipe, result.output) +        self.assertIn(realrecipe, result.output) +        # Check git repo +        self._check_src_repo(tempdir) +        # This is probably sufficient + +      @testcase(1169)      def test_devtool_update_recipe(self):          # Check preconditions @@ -805,6 +827,16 @@ class DevtoolTests(DevtoolBase):          self.assertTrue(os.path.exists(os.path.join(tempdir, 'Makefile.am')), 'Extracted source could not be found')          self._check_src_repo(tempdir) +    def test_devtool_extract_virtual(self): +        tempdir = tempfile.mkdtemp(prefix='devtoolqa') +        # Try devtool extract +        self.track_for_cleanup(tempdir) +        self.track_for_cleanup(self.workspacedir) +        self.add_command_to_tearDown('bitbake-layers remove-layer */workspace') +        result = runCmd('devtool extract virtual/libx11 %s' % tempdir) +        self.assertTrue(os.path.exists(os.path.join(tempdir, 'Makefile.am')), 'Extracted source could not be found') +        self._check_src_repo(tempdir) +      @testcase(1168)      def test_devtool_reset_all(self):          tempdir = tempfile.mkdtemp(prefix='devtoolqa') | 
