diff options
| author | Pavel Zhukov <pavel.zhukov@huawei.com> | 2021-12-02 08:56:04 +0100 |
|---|---|---|
| committer | Richard Purdie <richard.purdie@linuxfoundation.org> | 2021-12-15 07:40:29 +0000 |
| commit | 65d0414bdb7019bc0eb54e328f336990881b2594 (patch) | |
| tree | b5411eb775241cd371c7c31edb2b3295ea65e92c /meta/lib/oeqa | |
| parent | 34be1b3bad7773ef088a0224b3b540b793dca249 (diff) | |
| download | poky-65d0414bdb7019bc0eb54e328f336990881b2594.tar.gz | |
patch.py: Initialize git repo before patching
If PATCHTOOL="git" has been specified but workdir is not git repo
bitbake fails to apply the patches with error message:
Command Error: 'git rev-parse --show-toplevel' exited with 0 Output:
fatal: not a git repository (or any of the parent directories): .git
Fix this by initializing the repo before patching.
This allows binary git patches to be applied.
(From OE-Core rev: c3e8317b15b1b78511a6f9aedfed54b59ab6972f)
Signed-off-by: Pavel Zhukov <pavel.zhukov@huawei.com>
Signed-off-by: Richard Purdie <richard.purdie@linuxfoundation.org>
(cherry picked from commit 6184b56a7a0fc6f5d19fdfb81e7453667f7da940)
Signed-off-by: Anuj Mittal <anuj.mittal@intel.com>
Signed-off-by: Richard Purdie <richard.purdie@linuxfoundation.org>
Diffstat (limited to 'meta/lib/oeqa')
| -rw-r--r-- | meta/lib/oeqa/selftest/cases/bbtests.py | 15 |
1 files changed, 15 insertions, 0 deletions
diff --git a/meta/lib/oeqa/selftest/cases/bbtests.py b/meta/lib/oeqa/selftest/cases/bbtests.py index b932d5276b..a8b6231d83 100644 --- a/meta/lib/oeqa/selftest/cases/bbtests.py +++ b/meta/lib/oeqa/selftest/cases/bbtests.py | |||
| @@ -300,3 +300,18 @@ INHERIT_remove = \"report-error\" | |||
| 300 | 300 | ||
| 301 | test_recipe_summary_after = get_bb_var('SUMMARY', test_recipe) | 301 | test_recipe_summary_after = get_bb_var('SUMMARY', test_recipe) |
| 302 | self.assertEqual(expected_recipe_summary, test_recipe_summary_after) | 302 | self.assertEqual(expected_recipe_summary, test_recipe_summary_after) |
| 303 | |||
| 304 | def test_git_patchtool(self): | ||
| 305 | """ PATCHTOOL=git should work with non-git sources like tarballs | ||
| 306 | test recipe for the test must NOT containt git:// repository in SRC_URI | ||
| 307 | """ | ||
| 308 | test_recipe = "man-db" | ||
| 309 | self.write_recipeinc(test_recipe, 'PATCHTOOL=\"git\"') | ||
| 310 | src = get_bb_var("SRC_URI",test_recipe) | ||
| 311 | gitscm = re.search("git://", src) | ||
| 312 | self.assertFalse(gitscm, "test_git_patchtool pre-condition failed: {} test recipe contains git repo!".format(test_recipe)) | ||
| 313 | result = bitbake('man-db -c patch', ignore_status=False) | ||
| 314 | fatal = re.search("fatal: not a git repository (or any of the parent directories)", result.output) | ||
| 315 | self.assertFalse(fatal, "Failed to patch using PATCHTOOL=\"git\"") | ||
| 316 | self.delete_recipeinc(test_recipe) | ||
| 317 | bitbake('-cclean man-db') | ||
