diff options
-rw-r--r-- | meta/lib/oeqa/selftest/devtool.py | 33 | ||||
-rw-r--r-- | scripts/lib/devtool/standard.py | 7 |
2 files changed, 40 insertions, 0 deletions
diff --git a/meta/lib/oeqa/selftest/devtool.py b/meta/lib/oeqa/selftest/devtool.py index f147f248b3..932d6b9ec2 100644 --- a/meta/lib/oeqa/selftest/devtool.py +++ b/meta/lib/oeqa/selftest/devtool.py | |||
@@ -227,6 +227,39 @@ class DevtoolTests(oeSelfTest): | |||
227 | matches = glob.glob(stampprefix + '*') | 227 | matches = glob.glob(stampprefix + '*') |
228 | self.assertFalse(matches, 'Stamp files exist for recipe mdadm that should have been cleaned') | 228 | self.assertFalse(matches, 'Stamp files exist for recipe mdadm that should have been cleaned') |
229 | 229 | ||
230 | def test_devtool_modify_git(self): | ||
231 | # Check preconditions | ||
232 | workspacedir = os.path.join(self.builddir, 'workspace') | ||
233 | self.assertTrue(not os.path.exists(workspacedir), 'This test cannot be run with a workspace directory under the build directory') | ||
234 | testrecipe = 'mkelfimage' | ||
235 | src_uri = get_bb_var('SRC_URI', testrecipe) | ||
236 | self.assertIn('git://', src_uri, 'This test expects the %s recipe to be a git recipe' % testrecipe) | ||
237 | # Clean up anything in the workdir/sysroot/sstate cache | ||
238 | bitbake('%s -c cleansstate' % testrecipe) | ||
239 | # Try modifying a recipe | ||
240 | tempdir = tempfile.mkdtemp(prefix='devtoolqa') | ||
241 | self.track_for_cleanup(tempdir) | ||
242 | self.track_for_cleanup(workspacedir) | ||
243 | self.add_command_to_tearDown('bitbake-layers remove-layer */workspace') | ||
244 | self.add_command_to_tearDown('bitbake -c clean %s' % testrecipe) | ||
245 | result = runCmd('devtool modify %s -x %s' % (testrecipe, tempdir)) | ||
246 | self.assertTrue(os.path.exists(os.path.join(tempdir, 'Makefile')), 'Extracted source could not be found') | ||
247 | self.assertTrue(os.path.isdir(os.path.join(tempdir, '.git')), 'git repository for external source tree not found') | ||
248 | self.assertTrue(os.path.exists(os.path.join(workspacedir, 'conf', 'layer.conf')), 'Workspace directory not created') | ||
249 | matches = glob.glob(os.path.join(workspacedir, 'appends', 'mkelfimage_*.bbappend')) | ||
250 | self.assertTrue(matches, 'bbappend not created') | ||
251 | # Test devtool status | ||
252 | result = runCmd('devtool status') | ||
253 | self.assertIn(testrecipe, result.output) | ||
254 | self.assertIn(tempdir, result.output) | ||
255 | # Check git repo | ||
256 | result = runCmd('git status --porcelain', cwd=tempdir) | ||
257 | self.assertEqual(result.output.strip(), "", 'Created git repo is not clean') | ||
258 | result = runCmd('git symbolic-ref HEAD', cwd=tempdir) | ||
259 | self.assertEqual(result.output.strip(), "refs/heads/devtool", 'Wrong branch in git repo') | ||
260 | # Try building | ||
261 | bitbake(testrecipe) | ||
262 | |||
230 | def test_devtool_update_recipe(self): | 263 | def test_devtool_update_recipe(self): |
231 | # Check preconditions | 264 | # Check preconditions |
232 | workspacedir = os.path.join(self.builddir, 'workspace') | 265 | workspacedir = os.path.join(self.builddir, 'workspace') |
diff --git a/scripts/lib/devtool/standard.py b/scripts/lib/devtool/standard.py index bf18aae686..cabf3feaf3 100644 --- a/scripts/lib/devtool/standard.py +++ b/scripts/lib/devtool/standard.py | |||
@@ -202,6 +202,13 @@ def _extract_source(srctree, keep_temp, devbranch, d): | |||
202 | # Handle if S is set to a subdirectory of the source | 202 | # Handle if S is set to a subdirectory of the source |
203 | srcsubdir = os.path.join(workdir, os.path.relpath(srcsubdir, workdir).split(os.sep)[0]) | 203 | srcsubdir = os.path.join(workdir, os.path.relpath(srcsubdir, workdir).split(os.sep)[0]) |
204 | 204 | ||
205 | if os.path.exists(os.path.join(srcsubdir, '.git')): | ||
206 | alternatesfile = os.path.join(srcsubdir, '.git', 'objects', 'info', 'alternates') | ||
207 | if os.path.exists(alternatesfile): | ||
208 | # This will have been cloned with -s, so we need to convert it to a full clone | ||
209 | bb.process.run('git repack -a', cwd=srcsubdir) | ||
210 | os.remove(alternatesfile) | ||
211 | |||
205 | patchdir = os.path.join(srcsubdir, 'patches') | 212 | patchdir = os.path.join(srcsubdir, 'patches') |
206 | haspatches = False | 213 | haspatches = False |
207 | if os.path.exists(patchdir): | 214 | if os.path.exists(patchdir): |