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):      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') | 
