deprecations: Deprecate support for '-py{N}' requirements
This has been marked as deprecated for a long time in the docs but we've done nothing to indicate this from a code perspective. Fix this. Change-Id: I916bf16773a2a2cffa3c352d5dba52e3fbc298c2 Fixes-Bug: #431529
This commit is contained in:
parent
f4a1a7dec0
commit
9be181e8e6
@ -46,6 +46,8 @@ from pbr import testr_command
|
|||||||
from pbr import version
|
from pbr import version
|
||||||
|
|
||||||
REQUIREMENTS_FILES = ('requirements.txt', 'tools/pip-requires')
|
REQUIREMENTS_FILES = ('requirements.txt', 'tools/pip-requires')
|
||||||
|
PY_REQUIREMENTS_FILES = [x % sys.version_info[0] for x in (
|
||||||
|
'requirements-py%d.txt', 'tools/pip-requires-py%d')]
|
||||||
TEST_REQUIREMENTS_FILES = ('test-requirements.txt', 'tools/test-requires')
|
TEST_REQUIREMENTS_FILES = ('test-requirements.txt', 'tools/test-requires')
|
||||||
|
|
||||||
|
|
||||||
@ -57,9 +59,8 @@ def get_requirements_files():
|
|||||||
# - REQUIREMENTS_FILES with -py2 or -py3 in the name
|
# - REQUIREMENTS_FILES with -py2 or -py3 in the name
|
||||||
# (e.g. requirements-py3.txt)
|
# (e.g. requirements-py3.txt)
|
||||||
# - REQUIREMENTS_FILES
|
# - REQUIREMENTS_FILES
|
||||||
return (list(map(('-py' + str(sys.version_info[0])).join,
|
|
||||||
map(os.path.splitext, REQUIREMENTS_FILES)))
|
return PY_REQUIREMENTS_FILES + list(REQUIREMENTS_FILES)
|
||||||
+ list(REQUIREMENTS_FILES))
|
|
||||||
|
|
||||||
|
|
||||||
def append_text_list(config, key, text_list):
|
def append_text_list(config, key, text_list):
|
||||||
@ -78,9 +79,20 @@ def _any_existing(file_list):
|
|||||||
|
|
||||||
# Get requirements from the first file that exists
|
# Get requirements from the first file that exists
|
||||||
def get_reqs_from_files(requirements_files):
|
def get_reqs_from_files(requirements_files):
|
||||||
for requirements_file in _any_existing(requirements_files):
|
existing = _any_existing(requirements_files)
|
||||||
|
|
||||||
|
deprecated = [f for f in existing if f in PY_REQUIREMENTS_FILES]
|
||||||
|
if deprecated:
|
||||||
|
warnings.warn('Support for \'-pyN\'-suffixed requirements files is '
|
||||||
|
'deprecated in pbr 4.0 and will be removed in 5.0. '
|
||||||
|
'Use environment markers instead. Conflicting files: '
|
||||||
|
'%r' % deprecated,
|
||||||
|
DeprecationWarning)
|
||||||
|
|
||||||
|
for requirements_file in existing:
|
||||||
with open(requirements_file, 'r') as fil:
|
with open(requirements_file, 'r') as fil:
|
||||||
return fil.read().split('\n')
|
return fil.read().split('\n')
|
||||||
|
|
||||||
return []
|
return []
|
||||||
|
|
||||||
|
|
||||||
|
@ -549,14 +549,17 @@ class ParseRequirementsTest(base.BaseTestCase):
|
|||||||
result = packaging.parse_requirements([requirements])
|
result = packaging.parse_requirements([requirements])
|
||||||
self.assertEqual(['pbr'], result)
|
self.assertEqual(['pbr'], result)
|
||||||
|
|
||||||
def test_python_version(self):
|
@mock.patch('warnings.warn')
|
||||||
|
def test_python_version(self, mock_warn):
|
||||||
with open("requirements-py%d.txt" % sys.version_info[0],
|
with open("requirements-py%d.txt" % sys.version_info[0],
|
||||||
"w") as fh:
|
"w") as fh:
|
||||||
fh.write("# this is a comment\nfoobar\n# and another one\nfoobaz")
|
fh.write("# this is a comment\nfoobar\n# and another one\nfoobaz")
|
||||||
self.assertEqual(['foobar', 'foobaz'],
|
self.assertEqual(['foobar', 'foobaz'],
|
||||||
packaging.parse_requirements())
|
packaging.parse_requirements())
|
||||||
|
mock_warn.assert_called_once_with(mock.ANY, DeprecationWarning)
|
||||||
|
|
||||||
def test_python_version_multiple_options(self):
|
@mock.patch('warnings.warn')
|
||||||
|
def test_python_version_multiple_options(self, mock_warn):
|
||||||
with open("requirements-py1.txt", "w") as fh:
|
with open("requirements-py1.txt", "w") as fh:
|
||||||
fh.write("thisisatrap")
|
fh.write("thisisatrap")
|
||||||
with open("requirements-py%d.txt" % sys.version_info[0],
|
with open("requirements-py%d.txt" % sys.version_info[0],
|
||||||
@ -564,6 +567,9 @@ class ParseRequirementsTest(base.BaseTestCase):
|
|||||||
fh.write("# this is a comment\nfoobar\n# and another one\nfoobaz")
|
fh.write("# this is a comment\nfoobar\n# and another one\nfoobaz")
|
||||||
self.assertEqual(['foobar', 'foobaz'],
|
self.assertEqual(['foobar', 'foobaz'],
|
||||||
packaging.parse_requirements())
|
packaging.parse_requirements())
|
||||||
|
# even though we have multiple offending files, this should only be
|
||||||
|
# called once
|
||||||
|
mock_warn.assert_called_once_with(mock.ANY, DeprecationWarning)
|
||||||
|
|
||||||
|
|
||||||
class ParseRequirementsTestScenarios(base.BaseTestCase):
|
class ParseRequirementsTestScenarios(base.BaseTestCase):
|
||||||
|
@ -0,0 +1,5 @@
|
|||||||
|
---
|
||||||
|
deprecations:
|
||||||
|
- |
|
||||||
|
Support for ``pyN``-suffixed requirement files has been deprecated:
|
||||||
|
environment markers should be used instead.
|
Loading…
Reference in New Issue
Block a user