mirror of
https://github.com/pypa/pip
synced 2023-12-13 21:30:23 +01:00
Merge pull request #4208 from frame-technology/relative-file-paths
Support relative paths for file links.
This commit is contained in:
commit
4ee868553c
3
news/4208.bugfix
Normal file
3
news/4208.bugfix
Normal file
|
@ -0,0 +1,3 @@
|
|||
Fix a bug where `SETUPTOOLS_SHIM` got called incorrectly for relative path
|
||||
requirements by converting relative paths to absolute paths prior to calling
|
||||
the shim.
|
|
@ -77,7 +77,10 @@ class InstallRequirement(object):
|
|||
self.req = req
|
||||
self.comes_from = comes_from
|
||||
self.constraint = constraint
|
||||
self.source_dir = source_dir
|
||||
if source_dir is not None:
|
||||
self.source_dir = os.path.normpath(os.path.abspath(source_dir))
|
||||
else:
|
||||
self.source_dir = None
|
||||
self.editable = editable
|
||||
|
||||
self._wheel_cache = wheel_cache
|
||||
|
@ -388,7 +391,7 @@ class InstallRequirement(object):
|
|||
shutil.move(old_location, new_location)
|
||||
self._temp_build_dir = new_location
|
||||
self._ideal_build_dir = None
|
||||
self.source_dir = new_location
|
||||
self.source_dir = os.path.normpath(os.path.abspath(new_location))
|
||||
self._egg_info_path = None
|
||||
|
||||
@property
|
||||
|
|
|
@ -271,6 +271,41 @@ def test_install_from_local_directory(script, data):
|
|||
assert egg_info_folder in result.files_created, str(result)
|
||||
|
||||
|
||||
def test_install_relative_directory(script, data):
|
||||
"""
|
||||
Test installing a requirement using a relative path.
|
||||
"""
|
||||
egg_info_file = (
|
||||
script.site_packages / 'FSPkg-0.1.dev0-py%s.egg-info' % pyversion
|
||||
)
|
||||
egg_link_file = (
|
||||
script.site_packages / 'FSPkg.egg-link'
|
||||
)
|
||||
package_folder = script.site_packages / 'fspkg'
|
||||
|
||||
# Compute relative install path to FSPkg from scratch path.
|
||||
full_rel_path = data.packages.join('FSPkg') - script.scratch_path
|
||||
embedded_rel_path = script.scratch_path.join(full_rel_path)
|
||||
|
||||
# For each relative path, install as either editable or not using either
|
||||
# URLs with egg links or not.
|
||||
for req_path in (full_rel_path,
|
||||
'file:' + full_rel_path + '#egg=FSPkg',
|
||||
embedded_rel_path):
|
||||
# Regular install.
|
||||
result = script.pip('install', req_path,
|
||||
cwd=script.scratch_path)
|
||||
assert egg_info_file in result.files_created, str(result)
|
||||
assert package_folder in result.files_created, str(result)
|
||||
script.pip('uninstall', '-y', 'fspkg')
|
||||
|
||||
# Editable install.
|
||||
result = script.pip('install', '-e' + req_path,
|
||||
cwd=script.scratch_path)
|
||||
assert egg_link_file in result.files_created, str(result)
|
||||
script.pip('uninstall', '-y', 'fspkg')
|
||||
|
||||
|
||||
def test_install_quiet(script, data):
|
||||
"""
|
||||
Test that install -q is actually quiet.
|
||||
|
|
|
@ -3,7 +3,7 @@ import textwrap
|
|||
|
||||
import pytest
|
||||
|
||||
from tests.lib import (pyversion, path_to_url, requirements_file,
|
||||
from tests.lib import (pyversion, requirements_file,
|
||||
_create_test_package_with_subdirectory)
|
||||
from tests.lib.local_repos import local_checkout
|
||||
|
||||
|
@ -53,25 +53,43 @@ def test_schema_check_in_requirements_file(script):
|
|||
|
||||
def test_relative_requirements_file(script, data):
|
||||
"""
|
||||
Test installing from a requirements file with a relative path with an
|
||||
egg= definition..
|
||||
Test installing from a requirements file with a relative path. For path
|
||||
URLs, use an egg= definition.
|
||||
|
||||
"""
|
||||
url = path_to_url(
|
||||
os.path.join(data.root, "packages", "..", "packages", "FSPkg")
|
||||
) + '#egg=FSPkg'
|
||||
script.scratch_path.join("file-egg-req.txt").write(textwrap.dedent("""\
|
||||
%s
|
||||
""" % url))
|
||||
result = script.pip(
|
||||
'install', '-vvv', '-r', script.scratch_path / 'file-egg-req.txt'
|
||||
)
|
||||
assert (
|
||||
egg_info_file = (
|
||||
script.site_packages / 'FSPkg-0.1.dev0-py%s.egg-info' % pyversion
|
||||
) in result.files_created, str(result)
|
||||
assert (script.site_packages / 'fspkg') in result.files_created, (
|
||||
str(result.stdout)
|
||||
)
|
||||
egg_link_file = (
|
||||
script.site_packages / 'FSPkg.egg-link'
|
||||
)
|
||||
package_folder = script.site_packages / 'fspkg'
|
||||
|
||||
# Compute relative install path to FSPkg from scratch path.
|
||||
full_rel_path = data.packages.join('FSPkg') - script.scratch_path
|
||||
embedded_rel_path = script.scratch_path.join(full_rel_path)
|
||||
|
||||
# For each relative path, install as either editable or not using either
|
||||
# URLs with egg links or not.
|
||||
for req_path in (full_rel_path,
|
||||
'file:' + full_rel_path + '#egg=FSPkg',
|
||||
embedded_rel_path):
|
||||
# Regular install.
|
||||
with requirements_file(req_path + '\n',
|
||||
script.scratch_path) as reqs_file:
|
||||
result = script.pip('install', '-vvv', '-r', reqs_file.name,
|
||||
cwd=script.scratch_path)
|
||||
assert egg_info_file in result.files_created, str(result)
|
||||
assert package_folder in result.files_created, str(result)
|
||||
script.pip('uninstall', '-y', 'fspkg')
|
||||
|
||||
# Editable install.
|
||||
with requirements_file('-e ' + req_path + '\n',
|
||||
script.scratch_path) as reqs_file:
|
||||
result = script.pip('install', '-vvv', '-r', reqs_file.name,
|
||||
cwd=script.scratch_path)
|
||||
assert egg_link_file in result.files_created, str(result)
|
||||
script.pip('uninstall', '-y', 'fspkg')
|
||||
|
||||
|
||||
@pytest.mark.network
|
||||
|
|
Loading…
Reference in a new issue