Backed out changeset d1dd480fd638 (bug 1666347) for causing mochitest timeouts.

This commit is contained in:
Mihai Alexandru Michis 2020-11-13 21:13:25 +02:00
parent 9275645bf0
commit 57a979f85c
5 changed files with 68 additions and 18 deletions

6
.gitignore vendored
View file

@ -90,6 +90,12 @@ parser/html/java/translator.jar
# Local Gradle configuration properties. # Local Gradle configuration properties.
/local.properties /local.properties
# Python virtualenv artifacts.
third_party/python/psutil/**/*.so
third_party/python/psutil/**/*.pyd
third_party/python/psutil/build/
third_party/python/psutil/tmp/
# Ignore chrome.manifest files from the devtools loader # Ignore chrome.manifest files from the devtools loader
devtools/client/chrome.manifest devtools/client/chrome.manifest
devtools/shared/chrome.manifest devtools/shared/chrome.manifest

View file

@ -87,6 +87,12 @@ _OPT\.OBJ/
# Local Gradle configuration properties. # Local Gradle configuration properties.
^local.properties$ ^local.properties$
# Python stuff installed at build time.
^third_party/python/psutil/.*\.so
^third_party/python/psutil/.*\.pyd
^third_party/python/psutil/build/
^third_party/python/psutil/tmp/
# Git repositories # Git repositories
.git/ .git/

View file

@ -9,7 +9,6 @@ import json
import math import math
import os import os
import platform import platform
import shutil
import subprocess import subprocess
import sys import sys
import uuid import uuid
@ -198,13 +197,6 @@ def bootstrap(topsrcdir, mozilla_dir=None):
print("You are running Python", platform.python_version()) print("You are running Python", platform.python_version())
sys.exit(1) sys.exit(1)
# This directory was deleted in bug 1666345, but there may be some ignored
# files here. We can safely just delete it for the user so they don't have
# to clean the repo themselves.
deleted_dir = os.path.join(topsrcdir, "third_party", "python", "psutil")
if os.path.exists(deleted_dir):
shutil.rmtree(deleted_dir)
# Global build system and mach state is stored in a central directory. By # Global build system and mach state is stored in a central directory. By
# default, this is ~/.mozbuild. However, it can be defined via an # default, this is ~/.mozbuild. However, it can be defined via an
# environment variable. We detect first run (by lack of this directory # environment variable. We detect first run (by lack of this directory
@ -511,8 +503,7 @@ def _finalize_telemetry_glean(telemetry, is_bootstrap, success):
has_psutil, logical_cores, physical_cores, memory_total = get_psutil_stats() has_psutil, logical_cores, physical_cores, memory_total = get_psutil_stats()
if has_psutil: if has_psutil:
# psutil may not be available (we allow `mach create-mach-environment` # psutil may not be available if a successful build hasn't occurred yet.
# to fail to install it).
system_metrics.logical_cores.add(logical_cores) system_metrics.logical_cores.add(logical_cores)
system_metrics.physical_cores.add(physical_cores) system_metrics.physical_cores.add(physical_cores)
if memory_total is not None: if memory_total is not None:

View file

@ -152,6 +152,12 @@ Please commit or stash these changes before vendoring, or re-run with `--ignore-
description="Vendor Python packages from pypi.org into third_party/python. " description="Vendor Python packages from pypi.org into third_party/python. "
"Some extra files like docs and tests will automatically be excluded.", "Some extra files like docs and tests will automatically be excluded.",
) )
@CommandArgument(
"--with-windows-wheel",
action="store_true",
help="Vendor a wheel for Windows along with the source package",
default=False,
)
@CommandArgument( @CommandArgument(
"--keep-extra-files", "--keep-extra-files",
action="store_true", action="store_true",

View file

@ -16,13 +16,17 @@ from mozpack.files import FileFinder
class VendorPython(MozbuildObject): class VendorPython(MozbuildObject):
def vendor(self, packages=None, keep_extra_files=False): def vendor(self, packages=None, with_windows_wheel=False, keep_extra_files=False):
self.populate_logger() self.populate_logger()
self.log_manager.enable_unstructured() self.log_manager.enable_unstructured()
vendor_dir = mozpath.join(self.topsrcdir, os.path.join("third_party", "python")) vendor_dir = mozpath.join(self.topsrcdir, os.path.join("third_party", "python"))
packages = packages or [] packages = packages or []
if with_windows_wheel and len(packages) != 1:
raise Exception(
"--with-windows-wheel is only supported for a single package!"
)
self.activate_virtualenv() self.activate_virtualenv()
pip_compile = os.path.join(self.virtualenv_manager.bin_path, "pip-compile") pip_compile = os.path.join(self.virtualenv_manager.bin_path, "pip-compile")
@ -71,6 +75,30 @@ class VendorPython(MozbuildObject):
"--disable-pip-version-check", "--disable-pip-version-check",
] ]
) )
if with_windows_wheel:
# This is hardcoded to CPython 2.7 for win64, which is good
# enough for what we need currently. If we need psutil for Python 3
# in the future that could be added here as well.
self.virtualenv_manager._run_pip(
[
"download",
"--dest",
tmp,
"--no-deps",
"--only-binary",
":all:",
"--platform",
"win_amd64",
"--implementation",
"cp",
"--python-version",
"27",
"--abi",
"none",
"--disable-pip-version-check",
packages[0],
]
)
self._extract(tmp, vendor_dir, keep_extra_files) self._extract(tmp, vendor_dir, keep_extra_files)
shutil.copyfile(tmpspec_absolute, spec) shutil.copyfile(tmpspec_absolute, spec)
@ -119,14 +147,27 @@ class VendorPython(MozbuildObject):
finder = FileFinder(src) finder = FileFinder(src)
for path, _ in finder.find("*"): for path, _ in finder.find("*"):
base, ext = os.path.splitext(path) base, ext = os.path.splitext(path)
if ext == ".whl":
# Wheels would extract into a directory with the name of the package, but
# we want the platform signifiers, minus the version number.
# Wheel filenames look like:
# {distribution}-{version}(-{build tag})?-{python tag}-{abi tag}-{platform tag}
bits = base.split("-")
# Remove the version number.
bits.pop(1)
target = os.path.join(dest, "-".join(bits))
mozfile.remove(target) # remove existing version of vendored package
os.mkdir(target)
mozfile.extract(os.path.join(finder.base, path), target, ignore=ignore)
else:
# packages extract into package-version directory name and we strip the version # packages extract into package-version directory name and we strip the version
tld = mozfile.extract(os.path.join(finder.base, path), dest, ignore=ignore)[ tld = mozfile.extract(
0 os.path.join(finder.base, path), dest, ignore=ignore
] )[0]
target = os.path.join(dest, tld.rpartition("-")[0]) target = os.path.join(dest, tld.rpartition("-")[0])
mozfile.remove(target) # remove existing version of vendored package mozfile.remove(target) # remove existing version of vendored package
mozfile.move(tld, target) mozfile.move(tld, target)
# If any files inside the vendored package were symlinks, turn them into normal files # If any files inside the vendored package were symlinks, turn them into normal files
# because hg.mozilla.org forbids symlinks in the repository. # because hg.mozilla.org forbids symlinks in the repository.
link_finder = FileFinder(target) link_finder = FileFinder(target)