diff options
| author | Aníbal Limón <anibal.limon@linux.intel.com> | 2015-07-14 19:30:57 -0500 |
|---|---|---|
| committer | Richard Purdie <richard.purdie@linuxfoundation.org> | 2015-07-22 08:23:49 +0100 |
| commit | bd5167d154ac04dbecbda3a157ae8ef6304e0b4e (patch) | |
| tree | cd5928ca4f7f3f460836f07806c5fbe6a83a12dc | |
| parent | 4bbc5dd6e7454cc35c263707453a6725bc0d54a5 (diff) | |
| download | poky-bd5167d154ac04dbecbda3a157ae8ef6304e0b4e.tar.gz | |
bitbake: fetch2/git.py: latest_versionstring now returns (version, revision)
We need to know the revision associated with the upstream version in
SCM like git, this change broke return convention, oe-core recipeutils
get_recipe_upstream_version need to be updated.
tests/fetch.py: Updated git latest_versionstring test for comply new
convention.
[YOCTO #7605]
(Bitbake rev: fd175dc90024c503134c11cbd83e77d88c406ac8)
Signed-off-by: Aníbal Limón <anibal.limon@linux.intel.com>
Signed-off-by: Richard Purdie <richard.purdie@linuxfoundation.org>
| -rw-r--r-- | bitbake/lib/bb/fetch2/git.py | 18 | ||||
| -rw-r--r-- | bitbake/lib/bb/tests/fetch.py | 3 |
2 files changed, 14 insertions, 7 deletions
diff --git a/bitbake/lib/bb/fetch2/git.py b/bitbake/lib/bb/fetch2/git.py index 706fff5691..374d846798 100644 --- a/bitbake/lib/bb/fetch2/git.py +++ b/bitbake/lib/bb/fetch2/git.py | |||
| @@ -371,25 +371,28 @@ class Git(FetchMethod): | |||
| 371 | by searching through the tags output of ls-remote, comparing | 371 | by searching through the tags output of ls-remote, comparing |
| 372 | versions and returning the highest match. | 372 | versions and returning the highest match. |
| 373 | """ | 373 | """ |
| 374 | verstring = "" | 374 | pupver = ('', '') |
| 375 | |||
| 375 | tagregex = re.compile(d.getVar('GITTAGREGEX', True) or "(?P<pver>([0-9][\.|_]?)+)") | 376 | tagregex = re.compile(d.getVar('GITTAGREGEX', True) or "(?P<pver>([0-9][\.|_]?)+)") |
| 376 | try: | 377 | try: |
| 377 | output = self._lsremote(ud, d, "refs/tags/*") | 378 | output = self._lsremote(ud, d, "refs/tags/*") |
| 378 | except bb.fetch2.FetchError or bb.fetch2.NetworkAccess: | 379 | except bb.fetch2.FetchError or bb.fetch2.NetworkAccess: |
| 379 | return "" | 380 | return pupver |
| 380 | 381 | ||
| 382 | verstring = "" | ||
| 383 | revision = "" | ||
| 381 | for line in output.split("\n"): | 384 | for line in output.split("\n"): |
| 382 | if not line: | 385 | if not line: |
| 383 | break | 386 | break |
| 384 | 387 | ||
| 385 | line = line.split("/")[-1] | 388 | tag_head = line.split("/")[-1] |
| 386 | # Ignore non-released branches | 389 | # Ignore non-released branches |
| 387 | m = re.search("(alpha|beta|rc|final)+", line) | 390 | m = re.search("(alpha|beta|rc|final)+", tag_head) |
| 388 | if m: | 391 | if m: |
| 389 | continue | 392 | continue |
| 390 | 393 | ||
| 391 | # search for version in the line | 394 | # search for version in the line |
| 392 | tag = tagregex.search(line) | 395 | tag = tagregex.search(tag_head) |
| 393 | if tag == None: | 396 | if tag == None: |
| 394 | continue | 397 | continue |
| 395 | 398 | ||
| @@ -398,9 +401,12 @@ class Git(FetchMethod): | |||
| 398 | 401 | ||
| 399 | if verstring and bb.utils.vercmp(("0", tag, ""), ("0", verstring, "")) < 0: | 402 | if verstring and bb.utils.vercmp(("0", tag, ""), ("0", verstring, "")) < 0: |
| 400 | continue | 403 | continue |
| 404 | |||
| 401 | verstring = tag | 405 | verstring = tag |
| 406 | revision = line.split()[0] | ||
| 407 | pupver = (verstring, revision) | ||
| 402 | 408 | ||
| 403 | return verstring | 409 | return pupver |
| 404 | 410 | ||
| 405 | def _build_revision(self, ud, d, name): | 411 | def _build_revision(self, ud, d, name): |
| 406 | return ud.revisions[name] | 412 | return ud.revisions[name] |
diff --git a/bitbake/lib/bb/tests/fetch.py b/bitbake/lib/bb/tests/fetch.py index 13555bd677..8dd8ddb071 100644 --- a/bitbake/lib/bb/tests/fetch.py +++ b/bitbake/lib/bb/tests/fetch.py | |||
| @@ -697,7 +697,8 @@ class FetchMethodTest(FetcherTest): | |||
| 697 | self.d.setVar("SRCREV", k[2]) | 697 | self.d.setVar("SRCREV", k[2]) |
| 698 | self.d.setVar("GITTAGREGEX", k[3]) | 698 | self.d.setVar("GITTAGREGEX", k[3]) |
| 699 | ud = bb.fetch2.FetchData(k[1], self.d) | 699 | ud = bb.fetch2.FetchData(k[1], self.d) |
| 700 | verstring = ud.method.latest_versionstring(ud, self.d) | 700 | pupver= ud.method.latest_versionstring(ud, self.d) |
| 701 | verstring = pupver[0] | ||
| 701 | r = bb.utils.vercmp_string(v, verstring) | 702 | r = bb.utils.vercmp_string(v, verstring) |
| 702 | self.assertTrue(r == -1 or r == 0, msg="Package %s, version: %s <= %s" % (k[0], v, verstring)) | 703 | self.assertTrue(r == -1 or r == 0, msg="Package %s, version: %s <= %s" % (k[0], v, verstring)) |
| 703 | 704 | ||
