Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
S
setuptools
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Analytics
Analytics
CI / CD
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
Jérome Perrin
setuptools
Commits
7944b2b1
Commit
7944b2b1
authored
Sep 03, 2017
by
Jason R. Coombs
Committed by
GitHub
Sep 03, 2017
Browse files
Options
Browse Files
Download
Plain Diff
Merge branch 'master' into add_markdown_to_possible_readmes
parents
500bb9a1
f7e27cc0
Changes
10
Hide whitespace changes
Inline
Side-by-side
Showing
10 changed files
with
651 additions
and
60 deletions
+651
-60
CHANGES.rst
CHANGES.rst
+18
-2
docs/setuptools.txt
docs/setuptools.txt
+22
-21
pkg_resources/__init__.py
pkg_resources/__init__.py
+11
-3
pkg_resources/tests/test_working_set.py
pkg_resources/tests/test_working_set.py
+478
-0
setup.py
setup.py
+1
-0
setuptools/command/bdist_egg.py
setuptools/command/bdist_egg.py
+12
-4
setuptools/command/egg_info.py
setuptools/command/egg_info.py
+4
-0
setuptools/dist.py
setuptools/dist.py
+34
-30
setuptools/tests/test_dist.py
setuptools/tests/test_dist.py
+46
-0
setuptools/tests/test_egg_info.py
setuptools/tests/test_egg_info.py
+25
-0
No files found.
CHANGES.rst
View file @
7944b2b1
v36
.3.1
v36
.4.0
-------
*
#
1075
:
Add
new
``
Description
-
Content
-
Type
``
metadata
field
.
`
See
here
for
documentation
on
how
to
use
this
field
.
<
https
://
packaging
.
python
.
org
/
specifications
/#
description
-
content
-
type
>`
_
*
#
1068
:
Sort
files
and
directories
when
building
eggs
for
deterministic
order
.
*
#
196
:
Remove
caching
of
easy_install
command
in
fetch_build_egg
.
Fixes
issue
where
``
pytest
-
runner
-
N
.
N
``
would
satisfy
the
installation
of
``
pytest
``.
*
#
1129
:
Fix
working
set
dependencies
handling
when
replacing
conflicting
distributions
(
e
.
g
.
when
using
``
setup_requires
``
with
a
conflicting
transitive
dependency
,
fix
#
1124
).
*
Improved
handling
of
README
files
extensions
and
added
*
#
1133
:
Improved
handling
of
README
files
extensions
and
added
Markdown
to
the
list
of
searched
READMES
.
Markdown
to
the
list
of
searched
READMES
.
v36
.3.0
v36
.3.0
...
...
docs/setuptools.txt
View file @
7944b2b1
...
@@ -2394,27 +2394,28 @@ Metadata
...
@@ -2394,27 +2394,28 @@ Metadata
Aliases given below are supported for compatibility reasons,
Aliases given below are supported for compatibility reasons,
but not advised.
but not advised.
================= ================= =====
============================== ================= =====
Key Aliases Accepted value type
Key Aliases Accepted value type
================= ================= =====
============================== ================= =====
name str
name str
version attr:, str
version attr:, str
url home-page str
url home-page str
download_url download-url str
download_url download-url str
author str
author str
author_email author-email str
author_email author-email str
maintainer str
maintainer str
maintainer_email maintainer-email str
maintainer_email maintainer-email str
classifiers classifier file:, list-comma
classifiers classifier file:, list-comma
license file:, str
license file:, str
description summary file:, str
description summary file:, str
long_description long-description file:, str
long_description long-description file:, str
keywords list-comma
long_description_content_type str
platforms platform list-comma
keywords list-comma
provides list-comma
platforms platform list-comma
requires list-comma
provides list-comma
obsoletes list-comma
requires list-comma
================= ================= =====
obsoletes list-comma
============================== ================= =====
.. note::
.. note::
...
...
pkg_resources/__init__.py
View file @
7944b2b1
...
@@ -852,7 +852,10 @@ class WorkingSet(object):
...
@@ -852,7 +852,10 @@ class WorkingSet(object):
# distribution
# distribution
env = Environment([])
env = Environment([])
ws = WorkingSet([])
ws = WorkingSet([])
dist = best[req.key] = env.best_match(req, ws, installer)
dist = best[req.key] = env.best_match(
req, ws, installer,
replace_conflicting=replace_conflicting
)
if dist is None:
if dist is None:
requirers = required_by.get(req, None)
requirers = required_by.get(req, None)
raise DistributionNotFound(req, requirers)
raise DistributionNotFound(req, requirers)
...
@@ -1104,7 +1107,7 @@ class Environment(object):
...
@@ -1104,7 +1107,7 @@ class Environment(object):
dists.append(dist)
dists.append(dist)
dists.sort(key=operator.attrgetter('hashcmp'), reverse=True)
dists.sort(key=operator.attrgetter('hashcmp'), reverse=True)
def best_match(self, req, working_set, installer=None):
def best_match(self, req, working_set, installer=None
, replace_conflicting=False
):
"""
Find
distribution
best
matching
`req`
and
usable
on
`working_set`
"""
Find
distribution
best
matching
`req`
and
usable
on
`working_set`
This
calls
the
``
find
(
req
)
``
method
of
the
`working_set`
to
see
if
a
This
calls
the
``
find
(
req
)
``
method
of
the
`working_set`
to
see
if
a
...
@@ -1117,7 +1120,12 @@ class Environment(object):
...
@@ -1117,7 +1120,12 @@ class Environment(object):
calling the environment'
s
``
obtain
(
req
,
installer
)
``
method
will
be
calling the environment'
s
``
obtain
(
req
,
installer
)
``
method
will
be
returned
.
returned
.
"""
"""
dist = working_set.find(req)
try:
dist = working_set.find(req)
except VersionConflict:
if not replace_conflicting:
raise
dist = None
if dist is not None:
if dist is not None:
return dist
return dist
for dist in self[req.key]:
for dist in self[req.key]:
...
...
pkg_resources/tests/test_working_set.py
0 → 100644
View file @
7944b2b1
import
inspect
import
re
import
textwrap
import
pytest
import
pkg_resources
from
.test_resources
import
Metadata
def
strip_comments
(
s
):
return
'
\
n
'
.
join
(
l
for
l
in
s
.
split
(
'
\
n
'
)
if
l
.
strip
()
and
not
l
.
strip
().
startswith
(
'#'
)
)
def
parse_distributions
(
s
):
'''
Parse a series of distribution specs of the form:
{project_name}-{version}
[optional, indented requirements specification]
Example:
foo-0.2
bar-1.0
foo>=3.0
[feature]
baz
yield 2 distributions:
- project_name=foo, version=0.2
- project_name=bar, version=1.0, requires=['foo>=3.0', 'baz; extra=="feature"']
'''
s
=
s
.
strip
()
for
spec
in
re
.
split
(
'
\
n
(?=[^
\
s])
'
, s):
if not spec:
continue
fields = spec.split('
\
n
', 1)
assert 1 <= len(fields) <= 2
name, version = fields.pop(0).split('
-
')
if fields:
requires = textwrap.dedent(fields.pop(0))
metadata=Metadata(('
requires
.
txt
', requires))
else:
metadata = None
dist = pkg_resources.Distribution(project_name=name,
version=version,
metadata=metadata)
yield dist
class FakeInstaller(object):
def __init__(self, installable_dists):
self._installable_dists = installable_dists
def __call__(self, req):
return next(iter(filter(lambda dist: dist in req,
self._installable_dists)), None)
def parametrize_test_working_set_resolve(*test_list):
idlist = []
argvalues = []
for test in test_list:
(
name,
installed_dists,
installable_dists,
requirements,
expected1, expected2
) = [
strip_comments(s.lstrip()) for s in
textwrap.dedent(test).lstrip().split('
\
n
\
n
', 5)
]
installed_dists = list(parse_distributions(installed_dists))
installable_dists = list(parse_distributions(installable_dists))
requirements = list(pkg_resources.parse_requirements(requirements))
for id_, replace_conflicting, expected in (
(name, False, expected1),
(name + '
_replace_conflicting
', True, expected2),
):
idlist.append(id_)
expected = strip_comments(expected.strip())
if re.match('
\
w
+
$
', expected):
expected = getattr(pkg_resources, expected)
assert issubclass(expected, Exception)
else:
expected = list(parse_distributions(expected))
argvalues.append(pytest.param(installed_dists, installable_dists,
requirements, replace_conflicting,
expected))
return pytest.mark.parametrize('
installed_dists
,
installable_dists
,
'
'
requirements
,
replace_conflicting
,
'
'
resolved_dists_or_exception
',
argvalues, ids=idlist)
@parametrize_test_working_set_resolve(
'''
# id
noop
# installed
# installable
# wanted
# resolved
# resolved [replace conflicting]
''',
'''
# id
already_installed
# installed
foo-3.0
# installable
# wanted
foo>=2.1,!=3.1,<4
# resolved
foo-3.0
# resolved [replace conflicting]
foo-3.0
''',
'''
# id
installable_not_installed
# installed
# installable
foo-3.0
foo-4.0
# wanted
foo>=2.1,!=3.1,<4
# resolved
foo-3.0
# resolved [replace conflicting]
foo-3.0
''',
'''
# id
not_installable
# installed
# installable
# wanted
foo>=2.1,!=3.1,<4
# resolved
DistributionNotFound
# resolved [replace conflicting]
DistributionNotFound
''',
'''
# id
no_matching_version
# installed
# installable
foo-3.1
# wanted
foo>=2.1,!=3.1,<4
# resolved
DistributionNotFound
# resolved [replace conflicting]
DistributionNotFound
''',
'''
# id
installable_with_installed_conflict
# installed
foo-3.1
# installable
foo-3.5
# wanted
foo>=2.1,!=3.1,<4
# resolved
VersionConflict
# resolved [replace conflicting]
foo-3.5
''',
'''
# id
not_installable_with_installed_conflict
# installed
foo-3.1
# installable
# wanted
foo>=2.1,!=3.1,<4
# resolved
VersionConflict
# resolved [replace conflicting]
DistributionNotFound
''',
'''
# id
installed_with_installed_require
# installed
foo-3.9
baz-0.1
foo>=2.1,!=3.1,<4
# installable
# wanted
baz
# resolved
foo-3.9
baz-0.1
# resolved [replace conflicting]
foo-3.9
baz-0.1
''',
'''
# id
installed_with_conflicting_installed_require
# installed
foo-5
baz-0.1
foo>=2.1,!=3.1,<4
# installable
# wanted
baz
# resolved
VersionConflict
# resolved [replace conflicting]
DistributionNotFound
''',
'''
# id
installed_with_installable_conflicting_require
# installed
foo-5
baz-0.1
foo>=2.1,!=3.1,<4
# installable
foo-2.9
# wanted
baz
# resolved
VersionConflict
# resolved [replace conflicting]
baz-0.1
foo-2.9
''',
'''
# id
installed_with_installable_require
# installed
baz-0.1
foo>=2.1,!=3.1,<4
# installable
foo-3.9
# wanted
baz
# resolved
foo-3.9
baz-0.1
# resolved [replace conflicting]
foo-3.9
baz-0.1
''',
'''
# id
installable_with_installed_require
# installed
foo-3.9
# installable
baz-0.1
foo>=2.1,!=3.1,<4
# wanted
baz
# resolved
foo-3.9
baz-0.1
# resolved [replace conflicting]
foo-3.9
baz-0.1
''',
'''
# id
installable_with_installable_require
# installed
# installable
foo-3.9
baz-0.1
foo>=2.1,!=3.1,<4
# wanted
baz
# resolved
foo-3.9
baz-0.1
# resolved [replace conflicting]
foo-3.9
baz-0.1
''',
'''
# id
installable_with_conflicting_installable_require
# installed
foo-5
# installable
foo-2.9
baz-0.1
foo>=2.1,!=3.1,<4
# wanted
baz
# resolved
VersionConflict
# resolved [replace conflicting]
baz-0.1
foo-2.9
''',
'''
# id
conflicting_installables
# installed
# installable
foo-2.9
foo-5.0
# wanted
foo>=2.1,!=3.1,<4
foo>=4
# resolved
VersionConflict
# resolved [replace conflicting]
VersionConflict
''',
'''
# id
installables_with_conflicting_requires
# installed
# installable
foo-2.9
dep==1.0
baz-5.0
dep==2.0
dep-1.0
dep-2.0
# wanted
foo
baz
# resolved
VersionConflict
# resolved [replace conflicting]
VersionConflict
''',
'''
# id
installables_with_conflicting_nested_requires
# installed
# installable
foo-2.9
dep1
dep1-1.0
subdep<1.0
baz-5.0
dep2
dep2-1.0
subdep>1.0
subdep-0.9
subdep-1.1
# wanted
foo
baz
# resolved
VersionConflict
# resolved [replace conflicting]
VersionConflict
''',
)
def test_working_set_resolve(installed_dists, installable_dists, requirements,
replace_conflicting, resolved_dists_or_exception):
ws = pkg_resources.WorkingSet([])
list(map(ws.add, installed_dists))
resolve_call = lambda: ws.resolve(
requirements, installer=FakeInstaller(installable_dists),
replace_conflicting=replace_conflicting,
)
if inspect.isclass(resolved_dists_or_exception):
with pytest.raises(resolved_dists_or_exception):
resolve_call()
else:
assert sorted(resolve_call()) == sorted(resolved_dists_or_exception)
setup.py
View file @
7944b2b1
...
@@ -95,6 +95,7 @@ setup_params = dict(
...
@@ -95,6 +95,7 @@ setup_params = dict(
author
=
"Python Packaging Authority"
,
author
=
"Python Packaging Authority"
,
author_email
=
"distutils-sig@python.org"
,
author_email
=
"distutils-sig@python.org"
,
long_description
=
long_description
,
long_description
=
long_description
,
long_description_content_type
=
'text/x-rst; charset=UTF-8'
,
keywords
=
"CPAN PyPI distutils eggs package management"
,
keywords
=
"CPAN PyPI distutils eggs package management"
,
url
=
"https://github.com/pypa/setuptools"
,
url
=
"https://github.com/pypa/setuptools"
,
src_root
=
None
,
src_root
=
None
,
...
...
setuptools/command/bdist_egg.py
View file @
7944b2b1
...
@@ -38,6 +38,14 @@ def strip_module(filename):
...
@@ -38,6 +38,14 @@ def strip_module(filename):
filename
=
filename
[:
-
6
]
filename
=
filename
[:
-
6
]
return
filename
return
filename
def
sorted_walk
(
dir
):
"""Do os.walk in a reproducible way,
independent of indeterministic filesystem readdir order
"""
for
base
,
dirs
,
files
in
os
.
walk
(
dir
):
dirs
.
sort
()
files
.
sort
()
yield
base
,
dirs
,
files
def
write_stub
(
resource
,
pyfile
):
def
write_stub
(
resource
,
pyfile
):
_stub_template
=
textwrap
.
dedent
(
"""
_stub_template
=
textwrap
.
dedent
(
"""
...
@@ -302,7 +310,7 @@ class bdist_egg(Command):
...
@@ -302,7 +310,7 @@ class bdist_egg(Command):
ext_outputs
=
[]
ext_outputs
=
[]
paths
=
{
self
.
bdist_dir
:
''
}
paths
=
{
self
.
bdist_dir
:
''
}
for
base
,
dirs
,
files
in
os
.
walk
(
self
.
bdist_dir
):
for
base
,
dirs
,
files
in
sorted_
walk
(
self
.
bdist_dir
):
for
filename
in
files
:
for
filename
in
files
:
if
os
.
path
.
splitext
(
filename
)[
1
].
lower
()
in
NATIVE_EXTENSIONS
:
if
os
.
path
.
splitext
(
filename
)[
1
].
lower
()
in
NATIVE_EXTENSIONS
:
all_outputs
.
append
(
paths
[
base
]
+
filename
)
all_outputs
.
append
(
paths
[
base
]
+
filename
)
...
@@ -329,7 +337,7 @@ NATIVE_EXTENSIONS = dict.fromkeys('.dll .so .dylib .pyd'.split())
...
@@ -329,7 +337,7 @@ NATIVE_EXTENSIONS = dict.fromkeys('.dll .so .dylib .pyd'.split())
def
walk_egg
(
egg_dir
):
def
walk_egg
(
egg_dir
):
"""Walk an unpacked egg's contents, skipping the metadata directory"""
"""Walk an unpacked egg's contents, skipping the metadata directory"""
walker
=
os
.
walk
(
egg_dir
)
walker
=
sorted_
walk
(
egg_dir
)
base
,
dirs
,
files
=
next
(
walker
)
base
,
dirs
,
files
=
next
(
walker
)
if
'EGG-INFO'
in
dirs
:
if
'EGG-INFO'
in
dirs
:
dirs
.
remove
(
'EGG-INFO'
)
dirs
.
remove
(
'EGG-INFO'
)
...
@@ -463,10 +471,10 @@ def make_zipfile(zip_filename, base_dir, verbose=0, dry_run=0, compress=True,
...
@@ -463,10 +471,10 @@ def make_zipfile(zip_filename, base_dir, verbose=0, dry_run=0, compress=True,
compression
=
zipfile
.
ZIP_DEFLATED
if
compress
else
zipfile
.
ZIP_STORED
compression
=
zipfile
.
ZIP_DEFLATED
if
compress
else
zipfile
.
ZIP_STORED
if
not
dry_run
:
if
not
dry_run
:
z
=
zipfile
.
ZipFile
(
zip_filename
,
mode
,
compression
=
compression
)
z
=
zipfile
.
ZipFile
(
zip_filename
,
mode
,
compression
=
compression
)
for
dirname
,
dirs
,
files
in
os
.
walk
(
base_dir
):
for
dirname
,
dirs
,
files
in
sorted_
walk
(
base_dir
):
visit
(
z
,
dirname
,
files
)
visit
(
z
,
dirname
,
files
)
z
.
close
()
z
.
close
()
else
:
else
:
for
dirname
,
dirs
,
files
in
os
.
walk
(
base_dir
):
for
dirname
,
dirs
,
files
in
sorted_
walk
(
base_dir
):
visit
(
None
,
dirname
,
files
)
visit
(
None
,
dirname
,
files
)
return
zip_filename
return
zip_filename
setuptools/command/egg_info.py
View file @
7944b2b1
...
@@ -599,6 +599,10 @@ def write_pkg_info(cmd, basename, filename):
...
@@ -599,6 +599,10 @@ def write_pkg_info(cmd, basename, filename):
metadata
=
cmd
.
distribution
.
metadata
metadata
=
cmd
.
distribution
.
metadata
metadata
.
version
,
oldver
=
cmd
.
egg_version
,
metadata
.
version
metadata
.
version
,
oldver
=
cmd
.
egg_version
,
metadata
.
version
metadata
.
name
,
oldname
=
cmd
.
egg_name
,
metadata
.
name
metadata
.
name
,
oldname
=
cmd
.
egg_name
,
metadata
.
name
metadata
.
long_description_content_type
=
getattr
(
cmd
.
distribution
,
'long_description_content_type'
)
try
:
try
:
# write unescaped data to PKG-INFO, so older pkg_resources
# write unescaped data to PKG-INFO, so older pkg_resources
# can still parse it
# can still parse it
...
...
setuptools/dist.py
View file @
7944b2b1
...
@@ -58,6 +58,13 @@ def write_pkg_file(self, file):
...
@@ -58,6 +58,13 @@ def write_pkg_file(self, file):
if
self
.
download_url
:
if
self
.
download_url
:
file
.
write
(
'Download-URL: %s
\
n
'
%
self
.
download_url
)
file
.
write
(
'Download-URL: %s
\
n
'
%
self
.
download_url
)
long_desc_content_type
=
getattr
(
self
,
'long_description_content_type'
,
None
)
or
'UNKNOWN'
file
.
write
(
'Description-Content-Type: %s
\
n
'
%
long_desc_content_type
)
long_desc
=
rfc822_escape
(
self
.
get_long_description
())
long_desc
=
rfc822_escape
(
self
.
get_long_description
())
file
.
write
(
'Description: %s
\
n
'
%
long_desc
)
file
.
write
(
'Description: %s
\
n
'
%
long_desc
)
...
@@ -317,6 +324,9 @@ class Distribution(Distribution_parse_config_files, _Distribution):
...
@@ -317,6 +324,9 @@ class Distribution(Distribution_parse_config_files, _Distribution):
self.dist_files = []
self.dist_files = []
self.src_root = attrs and attrs.pop("src_root", None)
self.src_root = attrs and attrs.pop("src_root", None)
self.patch_missing_pkg_info(attrs)
self.patch_missing_pkg_info(attrs)
self.long_description_content_type = _attrs_dict.get(
'
long_description_content_type
'
)
# Make sure we have any eggs needed to interpret '
attrs
'
# Make sure we have any eggs needed to interpret '
attrs
'
if attrs is not None:
if attrs is not None:
self.dependency_links = attrs.pop('
dependency_links
', [])
self.dependency_links = attrs.pop('
dependency_links
', [])
...
@@ -485,36 +495,30 @@ class Distribution(Distribution_parse_config_files, _Distribution):
...
@@ -485,36 +495,30 @@ class Distribution(Distribution_parse_config_files, _Distribution):
def fetch_build_egg(self, req):
def fetch_build_egg(self, req):
"""Fetch an egg needed for building"""
"""Fetch an egg needed for building"""
from setuptools.command.easy_install import easy_install
try:
dist = self.__class__({'
script_args
': ['
easy_install
']})
cmd = self._egg_fetcher
dist.parse_config_files()
cmd.package_index.to_scan = []
opts = dist.get_option_dict('
easy_install
')
except AttributeError:
keep = (
from setuptools.command.easy_install import easy_install
'
find_links
', '
site_dirs
', '
index_url
', '
optimize
',
dist = self.__class__({'
script_args
': ['
easy_install
']})
'
site_dirs
', '
allow_hosts
'
dist.parse_config_files()
)
opts = dist.get_option_dict('
easy_install
')
for key in list(opts):
keep = (
if key not in keep:
'
find_links
', '
site_dirs
', '
index_url
', '
optimize
',
del opts[key] # don'
t
use
any
other
settings
'
site_dirs
', '
allow_hosts
'
if
self
.
dependency_links
:
)
links
=
self
.
dependency_links
[:]
for key in list(opts):
if
'find_links'
in
opts
:
if key not in keep:
links
=
opts
[
'find_links'
][
1
].
split
()
+
links
del opts[key] # don'
t
use
any
other
settings
opts
[
'find_links'
]
=
(
'setup'
,
links
)
if
self
.
dependency_links
:
install_dir
=
self
.
get_egg_cache_dir
()
links
=
self
.
dependency_links
[:]
cmd
=
easy_install
(
if
'find_links'
in
opts
:
dist
,
args
=
[
"x"
],
install_dir
=
install_dir
,
links
=
opts
[
'find_links'
][
1
].
split
()
+
links
exclude_scripts
=
True
,
opts
[
'find_links'
]
=
(
'setup'
,
links
)
always_copy
=
False
,
build_directory
=
None
,
editable
=
False
,
install_dir
=
self
.
get_egg_cache_dir
()
upgrade
=
False
,
multi_version
=
True
,
no_report
=
True
,
user
=
False
cmd
=
easy_install
(
)
dist
,
args
=
[
"x"
],
install_dir
=
install_dir
,
cmd
.
ensure_finalized
()
exclude_scripts
=
True
,
always_copy
=
False
,
build_directory
=
None
,
editable
=
False
,
upgrade
=
False
,
multi_version
=
True
,
no_report
=
True
,
user
=
False
)
cmd
.
ensure_finalized
()
self
.
_egg_fetcher
=
cmd
return
cmd
.
easy_install
(
req
)
return
cmd
.
easy_install
(
req
)
def
_set_global_opts_from_features
(
self
):
def
_set_global_opts_from_features
(
self
):
...
...
setuptools/tests/test_dist.py
0 → 100644
View file @
7944b2b1
from
setuptools
import
Distribution
from
setuptools.extern.six.moves.urllib.request
import
pathname2url
from
setuptools.extern.six.moves.urllib_parse
import
urljoin
from
.textwrap
import
DALS
from
.test_easy_install
import
make_nspkg_sdist
def
test_dist_fetch_build_egg
(
tmpdir
):
"""
Check multiple calls to `Distribution.fetch_build_egg` work as expected.
"""
index
=
tmpdir
.
mkdir
(
'index'
)
index_url
=
urljoin
(
'file://'
,
pathname2url
(
str
(
index
)))
def
sdist_with_index
(
distname
,
version
):
dist_dir
=
index
.
mkdir
(
distname
)
dist_sdist
=
'%s-%s.tar.gz'
%
(
distname
,
version
)
make_nspkg_sdist
(
str
(
dist_dir
.
join
(
dist_sdist
)),
distname
,
version
)
with
dist_dir
.
join
(
'index.html'
).
open
(
'w'
)
as
fp
:
fp
.
write
(
DALS
(
'''
<!DOCTYPE html><html><body>
<a href="{dist_sdist}" rel="internal">{dist_sdist}</a><br/>
</body></html>
'''
).
format
(
dist_sdist
=
dist_sdist
))
sdist_with_index
(
'barbazquux'
,
'3.2.0'
)
sdist_with_index
(
'barbazquux-runner'
,
'2.11.1'
)
with
tmpdir
.
join
(
'setup.cfg'
).
open
(
'w'
)
as
fp
:
fp
.
write
(
DALS
(
'''
[easy_install]
index_url = {index_url}
'''
).
format
(
index_url
=
index_url
))
reqs
=
'''
barbazquux-runner
barbazquux
'''
.
split
()
with
tmpdir
.
as_cwd
():
dist
=
Distribution
()
resolved_dists
=
[
dist
.
fetch_build_egg
(
r
)
for
r
in
reqs
]
assert
[
dist
.
key
for
dist
in
resolved_dists
if
dist
]
==
reqs
setuptools/tests/test_egg_info.py
View file @
7944b2b1
...
@@ -398,6 +398,31 @@ class TestEggInfo(object):
...
@@ -398,6 +398,31 @@ class TestEggInfo(object):
self
.
_run_install_command
(
tmpdir_cwd
,
env
)
self
.
_run_install_command
(
tmpdir_cwd
,
env
)
assert
glob
.
glob
(
os
.
path
.
join
(
env
.
paths
[
'lib'
],
'barbazquux*'
))
==
[]
assert
glob
.
glob
(
os
.
path
.
join
(
env
.
paths
[
'lib'
],
'barbazquux*'
))
==
[]
def
test_long_description_content_type
(
self
,
tmpdir_cwd
,
env
):
# Test that specifying a `long_description_content_type` keyword arg to
# the `setup` function results in writing a `Description-Content-Type`
# line to the `PKG-INFO` file in the `<distribution>.egg-info`
# directory.
# `Description-Content-Type` is described at
# https://github.com/pypa/python-packaging-user-guide/pull/258
self
.
_setup_script_with_requires
(
"""long_description_content_type='text/markdown',"""
)
environ
=
os
.
environ
.
copy
().
update
(
HOME
=
env
.
paths
[
'home'
],
)
code
,
data
=
environment
.
run_setup_py
(
cmd
=
[
'egg_info'
],
pypath
=
os
.
pathsep
.
join
([
env
.
paths
[
'lib'
],
str
(
tmpdir_cwd
)]),
data_stream
=
1
,
env
=
environ
,
)
egg_info_dir
=
os
.
path
.
join
(
'.'
,
'foo.egg-info'
)
with
open
(
os
.
path
.
join
(
egg_info_dir
,
'PKG-INFO'
))
as
pkginfo_file
:
pkg_info_lines
=
pkginfo_file
.
read
().
split
(
'
\
n
'
)
expected_line
=
'Description-Content-Type: text/markdown'
assert
expected_line
in
pkg_info_lines
def
test_python_requires_egg_info
(
self
,
tmpdir_cwd
,
env
):
def
test_python_requires_egg_info
(
self
,
tmpdir_cwd
,
env
):
self
.
_setup_script_with_requires
(
self
.
_setup_script_with_requires
(
"""python_requires='>=2.7.12',"""
)
"""python_requires='>=2.7.12',"""
)
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment