[requirements] Update requirements

* delete upper limits
* upgrades sync_requirements file:
  - write constant values of versions in case of min == max versions
  - ignore update version in case of [do-not-touch] tag

Change-Id: I8b28761b6c365eb3ecbaabf4142edacf36a1a213
This commit is contained in:
Andrey Kurilin 2016-09-07 16:26:17 +03:00
parent 2e6f4083ce
commit 43da28e867
3 changed files with 109 additions and 89 deletions

View File

@ -1,45 +1,41 @@
# The order of packages is significant, because pip processes them in the order # The order of packages is significant, because pip processes them in the order
# of appearance. Changing the order has an impact on the overall integration # of appearance. Changing the order has an impact on the overall integration
# process, which may cause wedges in the gate later. # process, which may cause wedges in the gate later.
alembic>=0.8.4,<=0.8.7 # MIT alembic>=0.8.4 # MIT
boto>=2.32.1,<=2.42.0 # MIT boto>=2.32.1 # MIT
decorator>=3.4.0,<=4.0.10 # new BSD License decorator>=3.4.0 # new BSD License
Jinja2>=2.8,<=2.8 # BSD Jinja2>=2.8 # BSD
# [constant-upper-limit] jsonschema>=2.0.0,!=2.5.0,<3.0.0 # MIT
jsonschema!=2.5.0,>=2.0.0,<3.0.0 # MIT netaddr>=0.7.12,!=0.7.16 # BSD
netaddr!=0.7.16,>=0.7.12,<=0.7.18 # BSD oslo.config>=3.14.0 # Apache Software License
oslo.config>=3.14.0,<=3.17.0 # Apache Software License oslo.db>=4.10.0 # Apache Software License
oslo.db>=4.10.0,<=4.13.1 # Apache Software License oslo.i18n>=2.1.0 # Apache Software License
oslo.i18n>=2.1.0,<=3.9.0 # Apache Software License oslo.log>=1.14.0 # Apache Software License
oslo.log>=1.14.0,<=3.16.0 # Apache Software License oslo.serialization>=1.10.0 # Apache Software License
oslo.serialization>=1.10.0,<=2.13.0 # Apache Software License oslo.utils>=3.16.0 # Apache Software License
oslo.utils>=3.16.0,<=3.16.0 # Apache Software License paramiko>=2.0 # LGPL
paramiko>=2.0,<=2.0.2 # LGPL pbr>=1.6 # Apache Software License
pbr>=1.6,<=1.10.0 # Apache Software License
# [constant-upper-limit]
PrettyTable>=0.7,<0.8 # BSD PrettyTable>=0.7,<0.8 # BSD
PyYAML>=3.1.0,<=3.12 # MIT PyYAML>=3.1.0 # MIT
python-designateclient>=1.5.0,<=2.3.0 # Apache License, Version 2.0 python-designateclient>=1.5.0 # Apache License, Version 2.0
python-glanceclient!=2.4.0,>=2.3.0,<=2.5.0 # Apache License, Version 2.0 python-glanceclient>=2.3.0,!=2.4.0 # Apache License, Version 2.0
python-keystoneclient!=2.1.0,>=2.0.0,<=3.5.0 # Apache Software License python-keystoneclient>=2.0.0,!=2.1.0 # Apache Software License
keystoneauth1>=2.10.0,<=2.12.1 # Apache Software License keystoneauth1>=2.10.0 # Apache Software License
python-novaclient!=2.33.0,>=2.29.0,<=6.0.0 # Apache License, Version 2.0 python-novaclient>=2.29.0,!=2.33.0 # Apache License, Version 2.0
python-neutronclient>=5.1.0,<=6.0.0 # Apache Software License python-neutronclient>=5.1.0 # Apache Software License
python-cinderclient!=1.7.0,!=1.7.1,>=1.6.0,<=1.9.0 # Apache Software License python-cinderclient>=1.6.0,!=1.7.0,!=1.7.1 # Apache Software License
python-manilaclient>=1.10.0,<=1.11.0 # Apache Software License python-manilaclient>=1.10.0 # Apache Software License
python-monascaclient>=1.1.0,<=1.2.0 # Apache Software License python-monascaclient>=1.1.0 # Apache Software License
python-heatclient>=1.4.0,<=1.4.0 # Apache Software License python-heatclient>=1.4.0 # Apache Software License
python-ceilometerclient>=2.5.0,<=2.6.0 # Apache Software License python-ceilometerclient>=2.5.0 # Apache Software License
python-ironicclient>=1.6.0,<=1.7.0 # Apache Software License python-ironicclient>=1.6.0 # Apache Software License
python-saharaclient>=0.18.0,<=0.18.0 # Apache License, Version 2.0 python-saharaclient>=0.18.0 # Apache License, Version 2.0
python-troveclient>=2.2.0,<=2.5.0 # Apache Software License python-troveclient>=2.2.0 # Apache Software License
python-zaqarclient>=1.0.0,<=1.2.0 # Apache Software License python-zaqarclient>=1.0.0 # Apache Software License
python-swiftclient>=2.2.0,<=3.1.0 # Apache Software License python-swiftclient>=2.2.0 # Apache Software License
python-watcherclient>=0.23.0,<=0.25.0 # Apache Software License python-watcherclient>=0.23.0 # Apache Software License
python-subunit>=0.0.18,<=1.2.0 python-subunit>=0.0.18
requests>=2.10.0,<=2.11.1 # Apache License, Version 2.0 requests>=2.10.0 # Apache License, Version 2.0
# [constant-upper-limit]
SQLAlchemy>=1.0.10,<1.1.0 # MIT SQLAlchemy>=1.0.10,<1.1.0 # MIT
# [constant-upper-limit] sphinx>=1.2.1,!=1.3b1,<1.3 # BSD
sphinx!=1.3b1,>=1.2.1,<1.3 # BSD six>=1.9.0 # MIT
six>=1.9.0,<=1.10.0 # MIT

View File

@ -1,18 +1,21 @@
# The order of packages is significant, because pip processes them in the order # The order of packages is significant, because pip processes them in the order
# of appearance. Changing the order has an impact on the overall integration # of appearance. Changing the order has an impact on the overall integration
# process, which may cause wedges in the gate later. # process, which may cause wedges in the gate later.
# [constant-upper-limit]
# [do-not-touch] we need to modify our code to support latest release of this
# lib
hacking>=0.9.2,<0.10 # Apache Software License hacking>=0.9.2,<0.10 # Apache Software License
pytest>=2.7,<=3.0.2 # MIT
pytest-cov>=2.2.1,<=2.3.1 # MIT pytest>=2.7 # MIT
pytest-html>=1.10.0,<=1.10.0 # Mozilla Public License 2.0 (MPL 2.0) pytest-cov>=2.2.1 # MIT
pytest-html>=1.10.0 # Mozilla Public License 2.0 (MPL 2.0)
pytest-xdist # MIT pytest-xdist # MIT
coverage>=3.6,<=4.2 # Apache License, Version 2.0 coverage>=3.6 # Apache License, Version 2.0
ddt>=1.0.1,<=1.1.0 ddt>=1.0.1
mock>=2.0,<=2.0.0 mock>=2.0
python-dateutil>=2.4.2,<=2.5.3 # Simplified BSD python-dateutil>=2.4.2 # Simplified BSD
testtools>=1.4.0,<=2.2.0 testtools>=1.4.0
oslosphinx!=3.4.0,>=2.5.0,<=4.7.0 # Apache Software License oslosphinx>=2.5.0,!=3.4.0 # Apache Software License
oslotest>=1.10.0,<=2.10.0 # Apache Software License oslotest>=1.10.0 # Apache Software License

View File

@ -43,13 +43,13 @@ RALLY_REQUIREMENTS_FILES = (
"test-requirements.txt", "test-requirements.txt",
"optional-requirements.txt" "optional-requirements.txt"
) )
UPPER_LIMIT_TAG = "[constant-upper-limit]" DO_NOT_TOUCH_TAG = "[do-not-touch]"
class Comment(object): class Comment(object):
def __init__(self, s=None): def __init__(self, s=None, finished=False):
self._comments = [] self._comments = []
self.is_finished = False self.is_finished = finished
if s: if s:
self.append(s) self.append(s)
@ -82,7 +82,7 @@ class Requirement(object):
self.version = version self.version = version
self._license = None self._license = None
self._pypy_info = None self._pypy_info = None
self.upper_limit_flag = False self.do_not_touch = False
def sync_max_version_with_pypy(self): def sync_max_version_with_pypy(self):
if isinstance(self.version, dict) and not self.upper_limit_flag: if isinstance(self.version, dict) and not self.upper_limit_flag:
@ -151,26 +151,41 @@ class Requirement(object):
def __str__(self): def __str__(self):
if isinstance(self.version, dict): if isinstance(self.version, dict):
version = "" version = []
if self.version["ne"]:
version += ",".join(self.version["ne"]) min_equal_to_max = False
if self.version["min"]: if self.version["min"] and self.version["max"]:
if version: if (self.version["min"].startswith(">=") and
version += "," self.version["max"].startswith("<=") and
version += self.version["min"] self.version["min"][2:] == self.version["max"][2:]):
if self.version["max"]: # min and max versions are equal there is no need to write
if version: # both of them
version += "," min_equal_to_max = True
version += self.version["max"] version.append("==%s" % self.version["min"][2:])
if not min_equal_to_max and self.version["min"]:
version.append(self.version["min"])
if not min_equal_to_max and self.version["ne"]:
version.extend(self.version["ne"])
if not min_equal_to_max and self.version["max"]:
version.append(self.version["max"])
version = ",".join(version)
else: else:
if self.do_not_touch:
version = self.version version = self.version
else:
# remove const version
version = ">=%s" % self.version[2:]
string = "%s%s" % (self.package_name, version) string = "%s%s" % (self.package_name, version)
if self.license: if self.license:
# NOTE(andreykurilin): When I start implementation of this script, # NOTE(andreykurilin): When I start implementation of this script,
# python-keystoneclient dependency took around ~45-55, so let's # python-keystoneclient dependency string took around ~45-55
# use this length as indent. Feel free to modify it to lower or # chars, so let's use this length as indent. Feel free to modify
# greater value. # it to lower or greater value.
magic_number = 55 magic_number = 55
if len(string) < magic_number: if len(string) < magic_number:
indent = magic_number - len(string) indent = magic_number - len(string)
@ -192,30 +207,33 @@ def parse_data(raw_data, include_comments=True):
if not include_comments: if not include_comments:
continue continue
if (isinstance(requirements[-1], Comment) and
UPPER_LIMIT_TAG in line):
requirements[-1].is_finished = True
if getattr(requirements[-1], "is_finished", True): if getattr(requirements[-1], "is_finished", True):
requirements.append(Comment()) requirements.append(Comment())
requirements[-1].append(line) requirements[-1].append(line)
elif line == "":
# just empty line
if isinstance(requirements[-1], Comment):
requirements[-1].finish_him()
requirements.append(Comment(finished=True))
else: else:
if (isinstance(requirements[-1], Comment) and if (isinstance(requirements[-1], Comment) and
not requirements[-1].is_finished): not requirements[-1].is_finished):
requirements[-1].finish_him() requirements[-1].finish_him()
if line == "":
requirements.append("")
else:
# parse_line # parse_line
req = Requirement.parse_line(line) req = Requirement.parse_line(line)
if req: if req:
if (isinstance(requirements[-1], Comment) and if (isinstance(requirements[-1], Comment) and
str(requirements[-1]).endswith(UPPER_LIMIT_TAG)): DO_NOT_TOUCH_TAG in str(requirements[-1])):
req.upper_limit_flag = True req.do_not_touch = True
requirements.append(req) requirements.append(req)
if not requirements[-1]: for i in range(len(requirements) - 1, 0, -1):
requirements.pop() # remove empty lines at the end of file
if isinstance(requirements[i], Comment):
if str(requirements[i]) == "":
requirements.pop(i)
else:
break
return requirements[1:] return requirements[1:]
@ -261,12 +279,14 @@ def _sync():
gr = parse_data(raw_gr, include_comments=False) gr = parse_data(raw_gr, include_comments=False)
for filename, requirements in _read_requirements(): for filename, requirements in _read_requirements():
for i in range(0, len(requirements)): for i in range(0, len(requirements)):
if isinstance(requirements[i], Requirement): if (isinstance(requirements[i], Requirement) and
not requirements[i].do_not_touch):
try: try:
gr_item = gr[gr.index(requirements[i])] gr_item = gr[gr.index(requirements[i])]
except ValueError: except ValueError:
# it not g-r requirements # it not g-r requirements
pass if isinstance(requirements[i].version, dict):
requirements[i].version["max"] = None
else: else:
requirements[i].version = gr_item.version requirements[i].version = gr_item.version
yield filename, requirements yield filename, requirements
@ -290,6 +310,7 @@ def add_uppers():
LOG.info("Obtaining latest versions of packages from %s." % filename) LOG.info("Obtaining latest versions of packages from %s." % filename)
for req in requirements: for req in requirements:
if isinstance(req, Requirement): if isinstance(req, Requirement):
if isinstance(req.version, dict) and not req.version["max"]:
req.sync_max_version_with_pypy() req.sync_max_version_with_pypy()
_write_requirements(filename, requirements) _write_requirements(filename, requirements)