mirror of
https://github.com/servo/servo.git
synced 2025-06-17 12:54:28 +00:00
msiextract corrupts files :( Try lessmsi instead
https://gitlab.gnome.org/GNOME/msitools/issues/6
This commit is contained in:
parent
3b2076fdc3
commit
a7fc7629ff
2 changed files with 23 additions and 95 deletions
|
@ -97,20 +97,19 @@ def android_arm32():
|
||||||
|
|
||||||
|
|
||||||
def windows_dev():
|
def windows_dev():
|
||||||
python27_task = extract_msi(
|
def extract_msi(*names):
|
||||||
"https://www.python.org/ftp/python/2.7.15/python-2.7.15.amd64.msi",
|
return "".join(
|
||||||
sha256="5e85f3c4c209de98480acbf2ba2e71a907fd5567a838ad4b6748c76deb286ad7",
|
"lessmsi x %HOMEDRIVE%%HOMEPATH%\\{name}.msi %HOMEDRIVE%%HOMEPATH%\\{name}\\\n"
|
||||||
)
|
.format(name=name)
|
||||||
|
for name in names
|
||||||
|
)
|
||||||
|
|
||||||
return decision.create_task(
|
return decision.create_task(
|
||||||
task_name="Windows x86_64: clone only (for now)",
|
task_name="Windows x86_64: clone only (for now)",
|
||||||
worker_type="servo-win2016",
|
worker_type="servo-win2016",
|
||||||
# script="""
|
script=extract_msi("python2") + """
|
||||||
# python mach --help
|
python -c "import os; print(os.listdir('.'))"
|
||||||
# """,
|
|
||||||
script="""
|
|
||||||
python -c "import sys; print(sys.path)"
|
|
||||||
""",
|
""",
|
||||||
with_repo=False,
|
|
||||||
mounts=[
|
mounts=[
|
||||||
{
|
{
|
||||||
"directory": "git",
|
"directory": "git",
|
||||||
|
@ -122,19 +121,27 @@ def windows_dev():
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"directory": "python2",
|
"file": "python2.msi",
|
||||||
"format": "tar.gz",
|
|
||||||
"content": {
|
"content": {
|
||||||
"artifact": "public/extracted.tar.gz",
|
"url": "https://www.python.org/ftp/python/2.7.15/python-2.7.15.amd64.msi",
|
||||||
"taskId": python27_task,
|
"sha256": "5e85f3c4c209de98480acbf2ba2e71a907fd5567a838ad4b6748c76deb286ad7",
|
||||||
|
}
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"directory": "lessmsi",
|
||||||
|
"format": "zip",
|
||||||
|
"content": {
|
||||||
|
"url": "https://github.com/activescott/lessmsi/releases/download/" +
|
||||||
|
"v1.6.1/lessmsi-v1.6.1.zip",
|
||||||
|
"sha256": "540b8801e08ec39ba26a100c855898f455410cecbae4991afae7bb2b4df026c7",
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
],
|
],
|
||||||
homedir_path=[
|
homedir_path=[
|
||||||
"git\\cmd",
|
"git\\cmd",
|
||||||
"python2",
|
"lessmsi",
|
||||||
|
"python2\\SourceDir",
|
||||||
],
|
],
|
||||||
dependencies=[python27_task],
|
|
||||||
sparse_checkout_exclude=["tests/wpt"],
|
sparse_checkout_exclude=["tests/wpt"],
|
||||||
**build_kwargs
|
**build_kwargs
|
||||||
)
|
)
|
||||||
|
@ -258,38 +265,6 @@ def daily_tasks_setup():
|
||||||
decision.task_name_template = "Servo daily: %s. On failure, ping: " + ping_on_daily_task_failure
|
decision.task_name_template = "Servo daily: %s. On failure, ping: " + ping_on_daily_task_failure
|
||||||
|
|
||||||
|
|
||||||
def extract_msi(url, sha256):
|
|
||||||
return decision.find_or_create_task(
|
|
||||||
index_bucket="extract-msi.v4",
|
|
||||||
index_key=sha256,
|
|
||||||
index_expiry=build_dependencies_artifacts_expiry,
|
|
||||||
|
|
||||||
task_name="Extracting MSI file " + url,
|
|
||||||
dockerfile=dockerfile_path("msiextract"),
|
|
||||||
script="""
|
|
||||||
curl --retry 5 --connect-timeout 10 --location --fail "$MSI_URL" -o input.msi
|
|
||||||
echo "$EXPECTED_SHA256 input.msi" | sha256sum --check
|
|
||||||
msiextract input.msi -C output
|
|
||||||
|
|
||||||
# May contains directories with names too long for Windows to even create:
|
|
||||||
# https://gitlab.gnome.org/GNOME/msitools/issues/5
|
|
||||||
rm -rf output/Windows/winsxs
|
|
||||||
|
|
||||||
ls output/
|
|
||||||
tar -czf /extracted.tar.gz -C output .
|
|
||||||
""",
|
|
||||||
env={
|
|
||||||
"MSI_URL": url,
|
|
||||||
"EXPECTED_SHA256": sha256,
|
|
||||||
},
|
|
||||||
artifacts=[
|
|
||||||
"/extracted.tar.gz"
|
|
||||||
],
|
|
||||||
max_run_time_minutes=20,
|
|
||||||
with_repo=False,
|
|
||||||
)
|
|
||||||
|
|
||||||
|
|
||||||
def dockerfile_path(name):
|
def dockerfile_path(name):
|
||||||
return os.path.join(os.path.dirname(__file__), "docker", name + ".dockerfile")
|
return os.path.join(os.path.dirname(__file__), "docker", name + ".dockerfile")
|
||||||
|
|
||||||
|
|
|
@ -1,47 +0,0 @@
|
||||||
# Build a version of libgcal that includes commit
|
|
||||||
# https://gitlab.gnome.org/GNOME/gcab/commit/3365b4bd58dd7f13e786caf3c7234cf8116263d9
|
|
||||||
# which fixes "Invalid cabinet chunk" errors:
|
|
||||||
# https://gitlab.gnome.org/GNOME/msitools/issues/4#note_336695
|
|
||||||
FROM ubuntu:bionic-20180821
|
|
||||||
RUN \
|
|
||||||
apt-get update -q && \
|
|
||||||
apt-get install -qy --no-install-recommends \
|
|
||||||
curl \
|
|
||||||
ca-certificates \
|
|
||||||
#
|
|
||||||
# Build dependencies for libgcab
|
|
||||||
meson \
|
|
||||||
git \
|
|
||||||
pkg-config \
|
|
||||||
libc6-dev \
|
|
||||||
libglib2.0-dev \
|
|
||||||
libgirepository1.0-dev \
|
|
||||||
gobject-introspection \
|
|
||||||
valac \
|
|
||||||
intltool \
|
|
||||||
&& \
|
|
||||||
export REV=3365b4bd58dd7f13e786caf3c7234cf8116263d9 && \
|
|
||||||
curl -L https://gitlab.gnome.org/GNOME/gcab/-/archive/$REV/gcab-$REV.tar.gz | tar -xz && \
|
|
||||||
mv gcab-$REV gcab && \
|
|
||||||
cd gcab && \
|
|
||||||
meson build && \
|
|
||||||
cd build && \
|
|
||||||
# UTF-8 locale to work around https://bugs.debian.org/cgi-bin/bugreport.cgi?bug=870310
|
|
||||||
export LANG=C.UTF-8 && \
|
|
||||||
ninja && \
|
|
||||||
cp -v libgcab/libgcab* /usr/local/lib
|
|
||||||
|
|
||||||
|
|
||||||
# FIXME: uncomment this after we upgrade docker-worker
|
|
||||||
# to a version of Docker that supports multi-stage builds:
|
|
||||||
|
|
||||||
# # Start a new image without the build dependencies, only the compiled library
|
|
||||||
# FROM ubuntu:bionic-20180821
|
|
||||||
# COPY --from=0 /usr/local/lib/libgcab* /usr/local/lib/
|
|
||||||
|
|
||||||
RUN \
|
|
||||||
apt-get update -q && \
|
|
||||||
apt-get install -qy --no-install-recommends \
|
|
||||||
curl \
|
|
||||||
ca-certificates \
|
|
||||||
msitools
|
|
Loading…
Add table
Add a link
Reference in a new issue