Commit 183a306e authored by Jason R. Coombs's avatar Jason R. Coombs

Remove bootstrap and tox-pip and instead rely on pep517.

parent 8222d6f7
"""
If setuptools is not already installed in the environment, it's not possible
to invoke setuptools' own commands. This routine will bootstrap this local
environment by creating a minimal egg-info directory and then invoking the
egg-info command to flesh out the egg-info directory.
"""
import os
import sys
import textwrap
import subprocess
import io
minimal_egg_info = textwrap.dedent("""
[distutils.commands]
egg_info = setuptools.command.egg_info:egg_info
[distutils.setup_keywords]
include_package_data = setuptools.dist:assert_bool
install_requires = setuptools.dist:check_requirements
extras_require = setuptools.dist:check_extras
entry_points = setuptools.dist:check_entry_points
[egg_info.writers]
PKG-INFO = setuptools.command.egg_info:write_pkg_info
dependency_links.txt = setuptools.command.egg_info:overwrite_arg
entry_points.txt = setuptools.command.egg_info:write_entries
requires.txt = setuptools.command.egg_info:write_requirements
""")
def ensure_egg_info():
if os.path.exists('setuptools.egg-info'):
return
print("adding minimal entry_points")
add_minimal_info()
run_egg_info()
def add_minimal_info():
"""
Build a minimal egg-info, enough to invoke egg_info
"""
os.mkdir('setuptools.egg-info')
with io.open('setuptools.egg-info/entry_points.txt', 'w') as ep:
ep.write(minimal_egg_info)
def run_egg_info():
cmd = [sys.executable, 'setup.py', 'egg_info']
print("Regenerating egg_info")
subprocess.check_call(cmd)
__name__ == '__main__' and ensure_egg_info()
[build-system] [build-system]
requires = [ requires = [
# avoid self install on Python 2; ref #1996
"setuptools >= 40.8; python_version > '3'", "setuptools >= 40.8; python_version > '3'",
"wheel", "wheel",
] ]
......
...@@ -10,17 +10,6 @@ from setuptools.command.install import install ...@@ -10,17 +10,6 @@ from setuptools.command.install import install
here = os.path.dirname(__file__) here = os.path.dirname(__file__)
def require_metadata():
"Prevent improper installs without necessary metadata. See #659"
egg_info_dir = os.path.join(here, 'setuptools.egg-info')
if not os.path.exists(egg_info_dir):
msg = (
"Cannot build setuptools without metadata. "
"Run `bootstrap.py`."
)
raise RuntimeError(msg)
def read_commands(): def read_commands():
command_ns = {} command_ns = {}
cmd_module_path = 'setuptools/command/__init__.py' cmd_module_path = 'setuptools/command/__init__.py'
...@@ -189,5 +178,4 @@ setup_params = dict( ...@@ -189,5 +178,4 @@ setup_params = dict(
if __name__ == '__main__': if __name__ == '__main__':
# allow setup.py to run from another directory # allow setup.py to run from another directory
here and os.chdir(here) here and os.chdir(here)
require_metadata()
dist = setuptools.setup(**setup_params) dist = setuptools.setup(**setup_params)
import os
import subprocess
import sys
import re
def remove_setuptools():
"""
Remove setuptools from the current environment.
"""
print("Removing setuptools")
cmd = [sys.executable, '-m', 'pip', 'uninstall', '-y', 'setuptools']
# set cwd to something other than '.' to avoid detecting
# '.' as the installed package.
subprocess.check_call(cmd, cwd=os.environ['TOX_WORK_DIR'])
def bootstrap():
print("Running bootstrap")
cmd = [sys.executable, '-m', 'bootstrap']
subprocess.check_call(cmd)
def is_install_self(args):
"""
Do the args represent an install of .?
"""
def strip_extras(arg):
match = re.match(r'(.*)?\[.*\]$', arg)
return match.group(1) if match else arg
return (
'install' in args
and any(
arg in ['.', os.getcwd()]
for arg in map(strip_extras, args)
)
)
def pip(*args):
cmd = [sys.executable, '-m', 'pip'] + list(args)
return subprocess.check_call(cmd)
def test_dependencies():
from ConfigParser import ConfigParser
def clean(dep):
spec, _, _ = dep.partition('#')
return spec.strip()
parser = ConfigParser()
parser.read('setup.cfg')
raw = parser.get('options.extras_require', 'tests').split('\n')
return filter(None, map(clean, raw))
def run(args):
os.environ['PIP_USE_PEP517'] = 'true'
if is_install_self(args):
remove_setuptools()
bootstrap()
pip(*args)
if __name__ == '__main__':
run(sys.argv[1:])
...@@ -11,8 +11,6 @@ commands = ...@@ -11,8 +11,6 @@ commands =
pytest {posargs} pytest {posargs}
usedevelop = True usedevelop = True
extras = testing extras = testing
install_command = {[helpers]pip} install {opts} {packages}
list_dependencies_command = {[helpers]pip} freeze --all
setenv = setenv =
COVERAGE_FILE={toxworkdir}/.coverage.{envname} COVERAGE_FILE={toxworkdir}/.coverage.{envname}
passenv = passenv =
...@@ -74,7 +72,3 @@ commands = ...@@ -74,7 +72,3 @@ commands =
python -m twine upload dist/* python -m twine upload dist/*
python -m jaraco.develop.create-github-release python -m jaraco.develop.create-github-release
python -m jaraco.tidelift.publish-release-notes python -m jaraco.tidelift.publish-release-notes
[helpers]
# Custom pip behavior
pip = python {toxinidir}/tools/tox_pip.py
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment