remove optimization for values unchanged from the branch

When a requirement setting is changed, require that all requirements
follow the rules.

Without this change, it is possible to partially update the dependency
list for a project in a way that leaves some of the dependencies out
of compliance. With this change, all dependencies must be compliant in
order to update any of them.

Change-Id: I154245339a36618ac2e9a5922bc37121d44bca29
Signed-off-by: Doug Hellmann <doug@doughellmann.com>
This commit is contained in:
Doug Hellmann 2018-04-10 11:18:16 -04:00
parent 3375d70b1f
commit 4bff2d214d
3 changed files with 4 additions and 89 deletions

View File

@ -131,12 +131,8 @@ def get_global_reqs(content):
return global_reqs return global_reqs
def _validate_one(name, reqs, branch_reqs, blacklist, global_reqs): def _validate_one(name, reqs, blacklist, global_reqs):
"Returns True if there is a failure." "Returns True if there is a failure."
if (name in branch_reqs.reqs and
reqs == branch_reqs.reqs[name]):
# Unchanged [or a change that preserves a current value]
return False
if name in blacklist: if name in blacklist:
# Blacklisted items are not synced and are managed # Blacklisted items are not synced and are managed
# by project teams as they see fit, so no further # by project teams as they see fit, so no further
@ -171,7 +167,7 @@ def _validate_one(name, reqs, branch_reqs, blacklist, global_reqs):
return False return False
def validate(head_reqs, branch_reqs, blacklist, global_reqs): def validate(head_reqs, blacklist, global_reqs):
failed = False failed = False
# iterate through the changing entries and see if they match the global # iterate through the changing entries and see if they match the global
# equivalents we want enforced # equivalents we want enforced
@ -182,7 +178,6 @@ def validate(head_reqs, branch_reqs, blacklist, global_reqs):
_validate_one( _validate_one(
name, name,
reqs, reqs,
branch_reqs,
blacklist, blacklist,
global_reqs, global_reqs,
) )

View File

@ -131,17 +131,11 @@ class TestValidateOne(testtools.TestCase):
r r
for r, line in requirement.parse('name>=1.2,!=1.4')['name'] for r, line in requirement.parse('name>=1.2,!=1.4')['name']
] ]
branch_reqs = check.RequirementsList(
'testproj',
{'requirements': {'requirements.txt': 'name>=1.2,!=1.4'}},
)
branch_reqs.process(False)
global_reqs = check.get_global_reqs('name>=1.2,!=1.4') global_reqs = check.get_global_reqs('name>=1.2,!=1.4')
self.assertFalse( self.assertFalse(
check._validate_one( check._validate_one(
'name', 'name',
reqs=reqs, reqs=reqs,
branch_reqs=branch_reqs,
blacklist=requirement.parse(''), blacklist=requirement.parse(''),
global_reqs=global_reqs, global_reqs=global_reqs,
) )
@ -153,17 +147,11 @@ class TestValidateOne(testtools.TestCase):
r r
for r, line in requirement.parse('name>=1.2,!=1.4')['name'] for r, line in requirement.parse('name>=1.2,!=1.4')['name']
] ]
branch_reqs = check.RequirementsList(
'testproj',
{'requirements': {'requirements.txt': 'name>=1.2,!=1.4'}},
)
branch_reqs.process(False)
global_reqs = check.get_global_reqs('name>=1.2,!=1.4') global_reqs = check.get_global_reqs('name>=1.2,!=1.4')
self.assertFalse( self.assertFalse(
check._validate_one( check._validate_one(
'name', 'name',
reqs=reqs, reqs=reqs,
branch_reqs=branch_reqs,
blacklist=requirement.parse('name'), blacklist=requirement.parse('name'),
global_reqs=global_reqs, global_reqs=global_reqs,
) )
@ -176,17 +164,11 @@ class TestValidateOne(testtools.TestCase):
r r
for r, line in requirement.parse('name>=1.5')['name'] for r, line in requirement.parse('name>=1.5')['name']
] ]
branch_reqs = check.RequirementsList(
'testproj',
{'requirements': {'requirements.txt': 'name>=1.2,!=1.4'}},
)
branch_reqs.process(False)
global_reqs = check.get_global_reqs('name>=1.2,!=1.4') global_reqs = check.get_global_reqs('name>=1.2,!=1.4')
self.assertFalse( self.assertFalse(
check._validate_one( check._validate_one(
'name', 'name',
reqs=reqs, reqs=reqs,
branch_reqs=branch_reqs,
blacklist=requirement.parse('name'), blacklist=requirement.parse('name'),
global_reqs=global_reqs, global_reqs=global_reqs,
) )
@ -198,17 +180,11 @@ class TestValidateOne(testtools.TestCase):
r r
for r, line in requirement.parse('name>=1.2,!=1.4')['name'] for r, line in requirement.parse('name>=1.2,!=1.4')['name']
] ]
branch_reqs = check.RequirementsList(
'testproj',
{'requirements': {'requirements.txt': 'name>=1.2,!=1.4'}},
)
branch_reqs.process(False)
global_reqs = check.get_global_reqs('') global_reqs = check.get_global_reqs('')
self.assertTrue( self.assertTrue(
check._validate_one( check._validate_one(
'name', 'name',
reqs=reqs, reqs=reqs,
branch_reqs=branch_reqs,
blacklist=requirement.parse(''), blacklist=requirement.parse(''),
global_reqs=global_reqs, global_reqs=global_reqs,
) )
@ -220,17 +196,11 @@ class TestValidateOne(testtools.TestCase):
r r
for r, line in requirement.parse('name>=1.2,!=1.4')['name'] for r, line in requirement.parse('name>=1.2,!=1.4')['name']
] ]
branch_reqs = check.RequirementsList(
'testproj',
{'requirements': {'requirements.txt': ''}},
)
branch_reqs.process(False)
global_reqs = check.get_global_reqs('name>=1.2,!=1.4') global_reqs = check.get_global_reqs('name>=1.2,!=1.4')
self.assertFalse( self.assertFalse(
check._validate_one( check._validate_one(
'name', 'name',
reqs=reqs, reqs=reqs,
branch_reqs=branch_reqs,
blacklist=requirement.parse(''), blacklist=requirement.parse(''),
global_reqs=global_reqs, global_reqs=global_reqs,
) )
@ -243,17 +213,11 @@ class TestValidateOne(testtools.TestCase):
r r
for r, line in requirement.parse('name>=1.1,!=1.4')['name'] for r, line in requirement.parse('name>=1.1,!=1.4')['name']
] ]
branch_reqs = check.RequirementsList(
'testproj',
{'requirements': {'requirements.txt': ''}},
)
branch_reqs.process(False)
global_reqs = check.get_global_reqs('name>=1.2,!=1.4') global_reqs = check.get_global_reqs('name>=1.2,!=1.4')
self.assertFalse( self.assertFalse(
check._validate_one( check._validate_one(
'name', 'name',
reqs=reqs, reqs=reqs,
branch_reqs=branch_reqs,
blacklist=requirement.parse(''), blacklist=requirement.parse(''),
global_reqs=global_reqs, global_reqs=global_reqs,
) )
@ -266,17 +230,11 @@ class TestValidateOne(testtools.TestCase):
r r
for r, line in requirement.parse('name>=1.2,!=1.4,!=1.5')['name'] for r, line in requirement.parse('name>=1.2,!=1.4,!=1.5')['name']
] ]
branch_reqs = check.RequirementsList(
'testproj',
{'requirements': {'requirements.txt': ''}},
)
branch_reqs.process(False)
global_reqs = check.get_global_reqs('name>=1.2,!=1.4') global_reqs = check.get_global_reqs('name>=1.2,!=1.4')
self.assertTrue( self.assertTrue(
check._validate_one( check._validate_one(
'name', 'name',
reqs=reqs, reqs=reqs,
branch_reqs=branch_reqs,
blacklist=requirement.parse(''), blacklist=requirement.parse(''),
global_reqs=global_reqs, global_reqs=global_reqs,
) )
@ -289,17 +247,11 @@ class TestValidateOne(testtools.TestCase):
r r
for r, line in requirement.parse('name>=1.2')['name'] for r, line in requirement.parse('name>=1.2')['name']
] ]
branch_reqs = check.RequirementsList(
'testproj',
{'requirements': {'requirements.txt': ''}},
)
branch_reqs.process(False)
global_reqs = check.get_global_reqs('name>=1.2,!=1.4') global_reqs = check.get_global_reqs('name>=1.2,!=1.4')
self.assertFalse( self.assertFalse(
check._validate_one( check._validate_one(
'name', 'name',
reqs=reqs, reqs=reqs,
branch_reqs=branch_reqs,
blacklist=requirement.parse(''), blacklist=requirement.parse(''),
global_reqs=global_reqs, global_reqs=global_reqs,
) )
@ -317,11 +269,6 @@ class TestValidateOne(testtools.TestCase):
r r
for r, line in requirement.parse(r_content)['name'] for r, line in requirement.parse(r_content)['name']
] ]
branch_reqs = check.RequirementsList(
'testproj',
{'requirements': {'requirements.txt': ''}},
)
branch_reqs.process(False)
global_reqs = check.get_global_reqs(textwrap.dedent(""" global_reqs = check.get_global_reqs(textwrap.dedent("""
name>=1.5;python_version=='3.5' name>=1.5;python_version=='3.5'
name>=1.2,!=1.4;python_version=='2.6' name>=1.2,!=1.4;python_version=='2.6'
@ -330,7 +277,6 @@ class TestValidateOne(testtools.TestCase):
check._validate_one( check._validate_one(
'name', 'name',
reqs=reqs, reqs=reqs,
branch_reqs=branch_reqs,
blacklist=requirement.parse(''), blacklist=requirement.parse(''),
global_reqs=global_reqs, global_reqs=global_reqs,
) )
@ -347,11 +293,6 @@ class TestValidateOne(testtools.TestCase):
r r
for r, line in requirement.parse(r_content)['name'] for r, line in requirement.parse(r_content)['name']
] ]
branch_reqs = check.RequirementsList(
'testproj',
{'requirements': {'requirements.txt': ''}},
)
branch_reqs.process(False)
global_reqs = check.get_global_reqs(textwrap.dedent(""" global_reqs = check.get_global_reqs(textwrap.dedent("""
name>=1.5;python_version=='3.5' name>=1.5;python_version=='3.5'
name>=1.2,!=1.4;python_version=='2.6' name>=1.2,!=1.4;python_version=='2.6'
@ -360,7 +301,6 @@ class TestValidateOne(testtools.TestCase):
check._validate_one( check._validate_one(
'name', 'name',
reqs=reqs, reqs=reqs,
branch_reqs=branch_reqs,
blacklist=requirement.parse(''), blacklist=requirement.parse(''),
global_reqs=global_reqs, global_reqs=global_reqs,
) )
@ -378,11 +318,6 @@ class TestValidateOne(testtools.TestCase):
r r
for r, line in requirement.parse(r_content)['name'] for r, line in requirement.parse(r_content)['name']
] ]
branch_reqs = check.RequirementsList(
'testproj',
{'requirements': {'requirements.txt': ''}},
)
branch_reqs.process(False)
global_reqs = check.get_global_reqs(textwrap.dedent(""" global_reqs = check.get_global_reqs(textwrap.dedent("""
name>=1.5;python_version=='3.5' name>=1.5;python_version=='3.5'
name>=1.2,!=1.4;python_version=='2.6' name>=1.2,!=1.4;python_version=='2.6'
@ -391,7 +326,6 @@ class TestValidateOne(testtools.TestCase):
check._validate_one( check._validate_one(
'name', 'name',
reqs=reqs, reqs=reqs,
branch_reqs=branch_reqs,
blacklist=requirement.parse(''), blacklist=requirement.parse(''),
global_reqs=global_reqs, global_reqs=global_reqs,
) )

View File

@ -136,21 +136,7 @@ def main():
head_strict = not branch.startswith('stable/') head_strict = not branch.startswith('stable/')
head_reqs.process(strict=head_strict) head_reqs.process(strict=head_strict)
if not args.local: failed = check.validate(head_reqs, blacklist, global_reqs)
# build a list of requirements already in the target branch,
# so that we can create a diff and identify what's being changed
run_command("git checkout HEAD^1")
branch_proj = project.read(cwd)
# switch back to the proposed change now
run_command("git checkout %s" % branch)
else:
branch_proj = {'root': cwd}
branch_reqs = check.RequirementsList(branch, branch_proj)
# Don't error on the target branch being broken.
branch_reqs.process(strict=False)
failed = check.validate(head_reqs, branch_reqs, blacklist, global_reqs)
failed = ( failed = (
check.validate_lower_constraints( check.validate_lower_constraints(
@ -162,7 +148,7 @@ def main():
) )
# report the results # report the results
if failed or head_reqs.failed or branch_reqs.failed: if failed or head_reqs.failed:
print("*** Incompatible requirement found!") print("*** Incompatible requirement found!")
print("*** See http://docs.openstack.org/developer/requirements") print("*** See http://docs.openstack.org/developer/requirements")
sys.exit(1) sys.exit(1)