Skip to content

Commit

Permalink
Fix SetuptoolsDeprecationWarning issued by 'python -m build'
Browse files Browse the repository at this point in the history
Fix 'extras_require' in setup.py to fix the warning. This requires fixes
for the parsing of dependencies in test_dependencies_in_sync.py: Use the
'packaging' module which simplifies the code.
  • Loading branch information
rear1019 committed Jan 2, 2025
1 parent 9e6df6b commit 4e785fd
Show file tree
Hide file tree
Showing 2 changed files with 28 additions and 43 deletions.
2 changes: 1 addition & 1 deletion setup.py
Original file line number Diff line number Diff line change
Expand Up @@ -328,7 +328,6 @@ def run(self):
install_requires.append('qtconsole>=5.5.1,<5.7.0')

extras_require = {
'test:platform_system == "Windows"': ['pywin32'],
'test': [
'coverage',
'cython',
Expand All @@ -343,6 +342,7 @@ def run(self):
'pytest-order',
'pytest-qt',
'pytest-timeout',
'pywin32;platform_system=="Windows"',
'pyyaml',
'scipy',
'sympy',
Expand Down
69 changes: 27 additions & 42 deletions spyder/tests/test_dependencies_in_sync.py
Original file line number Diff line number Diff line change
Expand Up @@ -9,6 +9,8 @@
import os.path as osp

# Third party imports
from packaging.requirements import Requirement
from packaging.specifiers import SpecifierSet
import pytest
import yaml

Expand Down Expand Up @@ -42,15 +44,11 @@ def parse_environment_yaml(fpath):
elif dep == 'websockify':
continue
else:
parts = dep.split(' ')
if len(parts) > 1:
ver = parts[-1]
if ver[0] == '=':
ver = '=' + ver

deps[parts[0]] = ver
req = Requirement(dep)
if req.specifier:
deps[req.name] = str(req.specifier)
else:
deps[parts[0]] = None
deps[req.name] = None

return deps

Expand All @@ -66,10 +64,7 @@ def parse_spyder_dependencies():

ver = dep['required_version']
if ver:
if ';' in ver:
ver = ver.replace(';', ',')
elif ver[0] == '=':
ver = '=' + ver
ver = str(SpecifierSet(ver))

deps[dep['package_name'].lower()] = ver

Expand Down Expand Up @@ -105,21 +100,16 @@ def parse_setup_install_requires(fpath):
# Process dependencies
deps = {}
for dep in deps_list:
dep = dep.split(';')[0]
name, ver = None, None

for sep in ['>=', '==', '<=', '<', '>']:
if sep in dep:
name, ver = dep.split(sep)
name = name.split('[')[0] # Discard e.g. [all]
ver = sep + ver # Include comparator
break
req = Requirement(dep)

# Transform pypi to conda name
if name == 'pyqt5':
name = 'pyqt'
if req.name == 'pyqt5':
req.name = 'pyqt'

deps[name] = ver
if req.specifier:
deps[req.name] = str(req.specifier)
else:
deps[req.name] = None

return deps

Expand Down Expand Up @@ -147,27 +137,22 @@ def parse_setup_extra_requires(fpath):
dep_list = dep_dict.get('test')
dep_list = [item for item in dep_list if item[0] != '#']
for dep in dep_list:
dep = dep.split(';')[0]
name, ver = None, None

for sep in ['>=', '==', '<=', '<', '>']:
if sep in dep:
idx = dep.index(sep)
name = dep[:idx]
ver = dep[idx:]
break

if name is not None:
name = name.split('[')[0]
else:
name = dep.split('[')[0]
req = Requirement(dep)

# Transform pypi to conda name
if name == 'pyqt5':
name = 'pyqt'
if req.name == 'pyqt5':
req.name = 'pyqt'

if req.marker and not req.marker.evaluate():
# Skip dependencies which are not required for current environment
# (e.g. skip 'platform_system=="Windows"' on Linux)
continue

if req.specifier:
deps[req.name] = str(req.specifier)
else:
deps[req.name] = None

deps[name] = ver
print(deps)
return deps


Expand Down

0 comments on commit 4e785fd

Please sign in to comment.