diff options
| author | Mark Hatle <mark.hatle@windriver.com> | 2015-09-10 17:02:10 -0500 |
|---|---|---|
| committer | Richard Purdie <richard.purdie@linuxfoundation.org> | 2015-09-18 09:05:34 +0100 |
| commit | 4c3d4eceb1811c4c17fb6649be86d8038a8daf4d (patch) | |
| tree | af1fbd9fff751a57c52fa0c55435aadaea256063 | |
| parent | 460e4c2c2c0411347442c30aedda6e0830fede16 (diff) | |
| download | poky-4c3d4eceb1811c4c17fb6649be86d8038a8daf4d.tar.gz | |
bitbake: fetch2/__init__.py: uri_replace regex handling
We should only substitute one time. If we do it without a max count, we can
end up matching over and over.
Before this change:
https://downloads.yoctoproject.org/releases/bitbake/bitbake-1.0.tar.gz
with a mirror of
https://.*/[^/]* http://AAAA/A/A/A/
would end up either recursing indefinitely or result in:
http://AAAA/A/A/A/A/A/A/A/A/A/bitbake-1.0.tar.gz
(Bitbake rev: 4d254e02e2867dd9a6663508c8ca9f2733af71a8)
Signed-off-by: Mark Hatle <mark.hatle@windriver.com>
Signed-off-by: Richard Purdie <richard.purdie@linuxfoundation.org>
| -rw-r--r-- | bitbake/lib/bb/fetch2/__init__.py | 2 | ||||
| -rw-r--r-- | bitbake/lib/bb/tests/fetch.py | 7 |
2 files changed, 8 insertions, 1 deletions
diff --git a/bitbake/lib/bb/fetch2/__init__.py b/bitbake/lib/bb/fetch2/__init__.py index 3d53b63b3e..569007fdb8 100644 --- a/bitbake/lib/bb/fetch2/__init__.py +++ b/bitbake/lib/bb/fetch2/__init__.py | |||
| @@ -464,7 +464,7 @@ def uri_replace(ud, uri_find, uri_replace, replacements, d): | |||
| 464 | for k in replacements: | 464 | for k in replacements: |
| 465 | uri_replace_decoded[loc] = uri_replace_decoded[loc].replace(k, replacements[k]) | 465 | uri_replace_decoded[loc] = uri_replace_decoded[loc].replace(k, replacements[k]) |
| 466 | #bb.note("%s %s %s" % (regexp, uri_replace_decoded[loc], uri_decoded[loc])) | 466 | #bb.note("%s %s %s" % (regexp, uri_replace_decoded[loc], uri_decoded[loc])) |
| 467 | result_decoded[loc] = re.sub(regexp, uri_replace_decoded[loc], uri_decoded[loc]) | 467 | result_decoded[loc] = re.sub(regexp, uri_replace_decoded[loc], uri_decoded[loc], 1) |
| 468 | if loc == 2: | 468 | if loc == 2: |
| 469 | # Handle path manipulations | 469 | # Handle path manipulations |
| 470 | basename = None | 470 | basename = None |
diff --git a/bitbake/lib/bb/tests/fetch.py b/bitbake/lib/bb/tests/fetch.py index 1e61f3a116..84862247e0 100644 --- a/bitbake/lib/bb/tests/fetch.py +++ b/bitbake/lib/bb/tests/fetch.py | |||
| @@ -405,6 +405,13 @@ class MirrorUriTest(FetcherTest): | |||
| 405 | 'http://otherdownloads.yoctoproject.org/downloads/bitbake-1.0.tar.gz', | 405 | 'http://otherdownloads.yoctoproject.org/downloads/bitbake-1.0.tar.gz', |
| 406 | 'http://downloads2.yoctoproject.org/downloads/bitbake-1.0.tar.gz']) | 406 | 'http://downloads2.yoctoproject.org/downloads/bitbake-1.0.tar.gz']) |
| 407 | 407 | ||
| 408 | recmirrorvar = "https://.*/[^/]* http://AAAA/A/A/A/ \n" | ||
| 409 | |||
| 410 | def test_recursive(self): | ||
| 411 | fetcher = bb.fetch.FetchData("https://downloads.yoctoproject.org/releases/bitbake/bitbake-1.0.tar.gz", self.d) | ||
| 412 | mirrors = bb.fetch2.mirror_from_string(self.recmirrorvar) | ||
| 413 | uris, uds = bb.fetch2.build_mirroruris(fetcher, mirrors, self.d) | ||
| 414 | self.assertEqual(uris, ['http://AAAA/A/A/A/bitbake/bitbake-1.0.tar.gz']) | ||
| 408 | 415 | ||
| 409 | class FetcherLocalTest(FetcherTest): | 416 | class FetcherLocalTest(FetcherTest): |
| 410 | def setUp(self): | 417 | def setUp(self): |
