fix(dev-infra): browser archive rule should handle `.dmg` files (#42992)
We recently reworked our browser archive extraction to happen at analysis time for better caching. This resulted in us breaking the extraction of macOS dmg files so that Firefox is currently not usable for local testing on macOS. We implement a similar special logic for `.dmg` files to what has been done within the Bazel webtesting rules. PR Close #42992
This commit is contained in:
parent
f31436da3c
commit
bfd48391d7
|
@ -1,11 +1,27 @@
|
||||||
"""Implementation of the `browser_archive` rule."""
|
"""Implementation of the `browser_archive` rule."""
|
||||||
|
|
||||||
def _browser_archive_impl(ctx):
|
def _browser_archive_impl(ctx):
|
||||||
ctx.report_progress("Downloading browser archive from: %s" % ctx.attr.url)
|
url = ctx.attr.url
|
||||||
ctx.download_and_extract(
|
sha256 = ctx.attr.sha256
|
||||||
url = ctx.attr.url,
|
|
||||||
sha256 = ctx.attr.sha256,
|
# If the URL resolves to a `.dmg` file, then we need to convert the file
|
||||||
)
|
# to a zip so that we can extract the actual binaries. We use the `convert_dmg`
|
||||||
|
# script provided by the webtesting Bazel rules.
|
||||||
|
if url.endswith(".dmg"):
|
||||||
|
download_file_name = "_download_file_%s.dmg" % ctx.attr.name
|
||||||
|
result_zip_name = "_converted_file_%s.zip" % ctx.attr.name
|
||||||
|
|
||||||
|
ctx.download(url, download_file_name, sha256)
|
||||||
|
ctx.execute([ctx.path(Label("@io_bazel_rules_webtesting//web/internal:convert_dmg.sh")), download_file_name, result_zip_name])
|
||||||
|
ctx.extract(result_zip_name)
|
||||||
|
|
||||||
|
ctx.delete(result_zip_name)
|
||||||
|
ctx.delete(download_file_name)
|
||||||
|
else:
|
||||||
|
ctx.download_and_extract(
|
||||||
|
url = url,
|
||||||
|
sha256 = sha256,
|
||||||
|
)
|
||||||
|
|
||||||
# The browser archive has been downloaded and extracted. We now generate a repository
|
# The browser archive has been downloaded and extracted. We now generate a repository
|
||||||
# `BUILD.bazel` file that exposes the archive files, together with the specified
|
# `BUILD.bazel` file that exposes the archive files, together with the specified
|
||||||
|
|
Loading…
Reference in New Issue