- 07 Jan, 2025 10 commits
-
-
Xavier Thompson authored
See merge request !33 - Fixup "Use pip install --editable in easy_install.develop"
-
Xavier Thompson authored
-
Xavier Thompson authored
Fix output renormalisation when the Python version string contains more than one digit in the minor version number, i.e for Python >= 3.10.
-
Xavier Thompson authored
Let zc.recipe.egg:develop reinstall if .egg-info or .dist-info is missing from the folder referenced by .egg-link.
-
Xavier Thompson authored
Store a part's installed paths in `self[part].installed_files` before calling `recipe.update()`, to allow the part's recipe to read them if needed by looking up `options.installed_files`. Delete this attribute just after the call to ensure this data remains private to the part. This will allow zc.recipe.egg:develop to remember in `update()` which .egg-link it installed in `install()`; inferring this would otherwise require essentially reinstalling the egg from the setup path, as that is all the recipe gets as input. Storing this under `__buildout_installed__` in the part's options was considered, but some recipes take all the recorded key/value pairs as input, so it would be a breaking change.
-
Xavier Thompson authored
Enable zc.buildout.easy_install.build, which builds a project manually from an unpacked sdist archive and is used by zc.recipe.egg:custom, to build a project which only has a pyproject.toml but no setup.py.
-
Xavier Thompson authored
Mark .dist-info eggs installed by buildout as develop to distinguish them from .dist-info eggs from the system and decide how to sign the egg accordingly (with directory hash or with version).
-
Xavier Thompson authored
-
Xavier Thompson authored
Adapt tests to ignore warning generated by setuptools not finding zc.recipe.egg on first index lookup, because it's indexed as zc-recipe-egg, because since PEP 625 the sdist filename is zc_recipe_egg-xyz.tar.gz.
-
Xavier Thompson authored
Buildout relies on setuptools to fetch dists from package indexes like PyPI. Setuptools infers the project name of source distributions found in the index from their filename, as derived from their download link. This works on the assumption the sdist filename corresponds losslessly to the project name, and in the way setuptools expects. Setuptools normalizes any occurrence of a non alphanumeric and non '.' character into a '-'. This is actually already lossy for project names that contain other characters; therefore the assumption should instead be that the sdist filename is lossless with regards to this normalized project name - in general project names should respect this normalized form. Since PEP 625, that assumption is definitely broken, i.e. the filename is lossy with regards to the normalized project name: - in the sdist filename, characters . and - must both be replaced by _ - in the sdist filename, all characters must be lowercased Internally, setuptools lowercases the normalized project name in order to compare dists. The possibles consequences of that broken assumption are thus: 1. the sdist is discarded from the search 2. the sdist is found but the project name may be cased differently For example, zc.buildout==3.0.1 yields zc_buildout-3.0.1.tar.gz, which results in setuptools interpreting the project name as zc-buildout and discarding it from the search. Workaround 1. by also looking up the name with . replaced by _. Workaround 2. by fixing the project names back to the looked-up name.
-
- 13 Dec, 2024 30 commits
-
-
Xavier Thompson authored
-
Xavier Thompson authored
This test is skipped for Python2 because pip and setuptools versions compatible with Python2 do not support PEP 660 (i.e. editable installs without setup.py).
-
Xavier Thompson authored
Prior to pip 21.1, pip install --editable --target fails because it results in wrong parameters being passed to setup.py develop by pip. Prior to setuptools 45.2.0, both pip install --editable --target and pip install --editable --prefix fail because the temporary install directory used internally by pip is not added to PYTHONPATH prior to pip calling setup.py develop. In later version setuptools emits a warning instead of an error. Temporarily override PYTHONUSERBASE to point to the target directory, so as to emulate --prefix=<dir> with PYTHONUSERBASE=<dir> and --user. This is needed for Python2 because pip 21.1 and setuptools 45.2.0 are both Python3 only.
-
Xavier Thompson authored
Instead of running python setup.py develop directly. This will allow using zc.buildout.easy_install.develop on recent projects that have only a pyproject.toml. It also fixes develop leaving build artifacts in the source directory that caused later runs to do nothing, e.g. preventing develop-eggs to be rebuilt when a build dependency passed in setup-eggs option of zc.recipe.egg:develop changed. A verbosity parameter to tune verbosity of pip is added, with adjusted values for the case of buildout:develop and of zc.recipe.egg:develop, so as to remain close to the previous behavior with regards to logs. Technical details: For packages using PEP-660-style editable installs, supported by more recent versions of pip, pip will not delegate to `setup.py develop` - enabling editable installs for pure pyproject.toml projects - and will instead generate a .dist-info metadata folder but not a .egg-link. Since buildout currently requires a .egg-link, as it does not support PEP 660's mechanism that relies on having a sites-packages directory, we need to create this .egg-link after the fact. The tricky part is finding out where the .egg-link should point: the path containing the pyproject.toml, or a subdirectory? For this we make use of *.dist-info/top_level.txt to first determine the list of top-level packages, and then importlib to extract info from the PEP-660-style install. If top_level.txt does not exist, is empty, or otherwise does not list any package that resolves to an import path, fallback to the path of the folder that contains the pyproject.toml as the .egg-link target. If it lists multiple packages that resolve to different import paths, arbitrarily use the first one and emit a warning. Support namespace packages where `spec.submodule_search_locations` is a `_NamespacePath` object instead of a simple `list` and also support cases where the layout of the source project does not follow the same structure as the package tree - meaning some custom magic might be involved in making editable imports work as intended.
-
Xavier Thompson authored
-
Xavier Thompson authored
Trigger uninstall + install of eggs installed with zc.recipe.egg:custom or :develop when pinned versions of setup-eggs have changed. To achieve this the versions of setup-eggs are included in the section: this makes them part of its signature so that when they change, buildout will call `uninstall` and `install` for this section instead of just `update`. Unlike other zc.recipe.egg entry points, :custom stores the path of the installed egg; thus `uninstall` will remove it fully, leaving `install` to reinstall it cleanly from scrach. In the case of :develop, `uninstall` matters little as only the path of the installed `.egg-link` is stored. Instead `install` must be fixed to actually rebuild the egg in-place in the source directory and `develop` should do nothing. The main issue lies in `zc.buildout.easy_install.develop`: depending on the build process, it may leave build artifacts in the source directory that cause future runs to do nothing.
-
Xavier Thompson authored
See merge request !31 Note: all changes with +slapos001 are tests-related. - Fixup "[test] Add tests for build dependencies" - Fixup "[feat] zc.recipe.egg: Improve on the fly patches." - Fixup "[fix] Fix working set sorting". - Fixup "[feat] Add dependencies in __buildout_signature__"
-
Xavier Thompson authored
Pinning zc.buildout = >.1 is now invalid, so use >0.1 instead.
-
Xavier Thompson authored
Adapt filter in tests for pip emitting Python2.7 deprecation warnings to pip >= 20.2.2 and < 21.0 - these versions seem to accidentally add a redundant bit of message to the warning.
-
Xavier Thompson authored
The testing framework, some individual tests and 'buildout:develop' call python setup.py <command> manually, which is deprecated by setuptools. Depending on the setuptools version, suppress the warning for now to avoid polluting the logs.
-
Xavier Thompson authored
-
Xavier Thompson authored
-
Xavier Thompson authored
INFO logs from setuptools which were previously not emitted because setuptool's ad-hoc legacy logger defaulted to WARNING and above may now be emitted because setuptools now logs to the root logger, thus the global root logger's level configuration applied. This caused undesired 'root: <some setuptools info>' messages to be emitted and caused many tests to fail due to unexpected outputs.
-
Xavier Thompson authored
See merge request !30
-
Julien Muchembled authored
-
Julien Muchembled authored
When specifying an alternate URL as fallback, the main URL is always used for both downloading & uploading from/to networkcache.
-
Xavier Thompson authored
If slapos.libnetworkcache is importable, install it in bootstrap and in buildout upgrade - the places where bin/buildout is (re)generated - as though it were a dependency of zc.buildout. This is a hack to propagate libnetworkcache as a soft dependency.
-
Julien Muchembled authored
Like for URL that contain credentials, we still skip auth challenge because it's faster and: - we only support one auth scheme (basic) - netrc provides no way to specify realms, which seem anyway to be less and less used (https://stackoverflow.com/q/69303610 reports that recent browsers don't display them anymore) See merge request !25
-
Julien Muchembled authored
This retries with the alternate URL in case of HTTPError with the main one. Used by slapos.recipe.build:download* and slapos.recipe.cmmi recipes.
-
Julien Muchembled authored
- Py3: stop using legacy API of urllib.request and fix download of http(s) URLs containing user:passwd@ - Py2: avoid OOM when downloading huge files This is implemented as a method in case we want to make it configurable via [buildout].
-
Julien Muchembled authored
An optimization is to avoid temporary file when possible: a rename (or hard link) is not always possible (different mount points). Another one is to not check md5sum twice when using cache file. Fall-back mode is ignored if an MD5 checksum is given. In case of checksum mismatch for a cached path, remove it and download again, mainly to cover the following cases: - the url content changes and the user updates the checksum - buildout killed while downloading directly to cache (see above optimization) - shutil.copyfile is interrupted
-
Jérome Perrin authored
We want two identical sections at different URL to be able to produce same signature. This feature is useful for slapos.recipe.cmmi's shared parts. This commit may fixup "Support ${:_profile_base_location_}." but is purposefuly kept separate because it concerns parts signatures which are an orthogonal feature.
-
Kazuhiko Shiozaki authored
-
Kazuhiko Shiozaki authored
-
Xavier Thompson authored
-
Xavier Thompson authored
-
Xavier Thompson authored
When there is no pinned version for zc.buildout itself, buildout adds a ">=<current-version>" requirement to prevent accidental downgrading. If the current version has a local version label, this produced an invalid version specifier. To fix this, only the public part of the current version is used.
-
Xavier Thompson authored
-
Xavier Thompson authored
Use a special .pydistutils.cfg in a temporary HOME directory for the duration of the pip wheel run to prevent build dependencies specified in a setup_requires from being installed on the fly without respecting pinned versions.
-
Xavier Thompson authored
By default pip installs build dependencies (e.g. setuptools, poetry) in a temporary folder and temporarily adds it to sys.path in order to proceed to build the distribution. But we want all distributions to be installed with buildout and respect pinned versions, so we aim to prevent pip from installing build dependencies. Instead, we will install the build dependencies first and pass them explicitly to zc.recipe.egg via the setup-eggs option. This commit prevents pip from installing the build dependencies listed by the `build-system.requires` key in the pyproject.toml file. It may prevent pip from installing PEP 517 dynamic build dependencies or setuptools' setup_requires dependencies. See https://peps.python.org/pep-0517/#get-requires-for-build-wheel
-