Handle -/_ ambiguity in package names
Some openstack packages show up in the requirements list under a hyphenated name while their package metadata name contains only underscores. (For example, the glance_store library is listed in requirements as 'glance-store'.) This is causing problems for the tox_install_sibling_packages task run by zuul. Pip is able to handle this situation [0]; add code so the ansible task can handle it too. [0] http://paste.openstack.org/show/722298/ Change-Id: I89ad9926647a011174815761e79372f2d7d43609 Needed-by: https://review.openstack.org/#/c/569225/ Closes-bug: #1774030
This commit is contained in:
parent
0a673aa13b
commit
4d7d23d7c5
@ -52,6 +52,7 @@ try:
|
|||||||
except ImportError:
|
except ImportError:
|
||||||
import ConfigParser as configparser
|
import ConfigParser as configparser
|
||||||
|
|
||||||
|
import pkg_resources as prAPI
|
||||||
import os
|
import os
|
||||||
import subprocess
|
import subprocess
|
||||||
import tempfile
|
import tempfile
|
||||||
@ -120,6 +121,26 @@ def write_new_constraints_file(constraints, packages):
|
|||||||
return constraints_file.name
|
return constraints_file.name
|
||||||
|
|
||||||
|
|
||||||
|
def _get_package_root(name, sibling_packages):
|
||||||
|
'''
|
||||||
|
Returns a package root from the sibling packages dict.
|
||||||
|
|
||||||
|
If name is not found in sibling_packages, tries again using the 'filename'
|
||||||
|
form of the name returned by the setuptools package resource API.
|
||||||
|
|
||||||
|
:param name: package name
|
||||||
|
:param sibling_packages: dict of python packages that zuul has cloned
|
||||||
|
:returns: the package root (str)
|
||||||
|
:raises: KeyError
|
||||||
|
'''
|
||||||
|
try:
|
||||||
|
pkg_root = sibling_packages[name]
|
||||||
|
except KeyError:
|
||||||
|
pkg_root = sibling_packages[prAPI.to_filename(name)]
|
||||||
|
|
||||||
|
return pkg_root
|
||||||
|
|
||||||
|
|
||||||
def main():
|
def main():
|
||||||
module = AnsibleModule(
|
module = AnsibleModule(
|
||||||
argument_spec=dict(
|
argument_spec=dict(
|
||||||
@ -179,7 +200,8 @@ def main():
|
|||||||
log.append(
|
log.append(
|
||||||
"Found {name} python package installed".format(
|
"Found {name} python package installed".format(
|
||||||
name=dep_name))
|
name=dep_name))
|
||||||
if dep_name == package_name:
|
if (dep_name == package_name or
|
||||||
|
prAPI.to_filename(dep_name) == package_name):
|
||||||
# We don't need to re-process ourself. We've filtered ourselves
|
# We don't need to re-process ourself. We've filtered ourselves
|
||||||
# from the source dir list, but let's be sure nothing is weird.
|
# from the source dir list, but let's be sure nothing is weird.
|
||||||
log.append(
|
log.append(
|
||||||
@ -192,7 +214,16 @@ def main():
|
|||||||
name=dep_name,
|
name=dep_name,
|
||||||
root=sibling_python_packages[dep_name]))
|
root=sibling_python_packages[dep_name]))
|
||||||
changed = True
|
changed = True
|
||||||
|
found_sibling_packages.append(dep_name)
|
||||||
|
elif prAPI.to_filename(dep_name) in sibling_python_packages:
|
||||||
|
real_name = prAPI.to_filename(dep_name)
|
||||||
|
log.append(
|
||||||
|
"Package {name} ({pkg_name}) on system in {root}".format(
|
||||||
|
name=dep_name,
|
||||||
|
pkg_name=real_name,
|
||||||
|
root=sibling_python_packages[real_name]))
|
||||||
|
changed = True
|
||||||
|
# need to use dep_name here for later constraint file rewrite
|
||||||
found_sibling_packages.append(dep_name)
|
found_sibling_packages.append(dep_name)
|
||||||
|
|
||||||
if constraints:
|
if constraints:
|
||||||
@ -210,24 +241,29 @@ def main():
|
|||||||
args = [tox_python, '-m', 'pip', 'install']
|
args = [tox_python, '-m', 'pip', 'install']
|
||||||
if constraints:
|
if constraints:
|
||||||
args.extend(['-c', constraints_file])
|
args.extend(['-c', constraints_file])
|
||||||
|
|
||||||
|
pkg_root = _get_package_root(sibling_package,
|
||||||
|
sibling_python_packages)
|
||||||
log.append(
|
log.append(
|
||||||
"Installing {name} from {root} for deps".format(
|
"Installing {name} from {root} for deps".format(
|
||||||
name=sibling_package,
|
name=sibling_package,
|
||||||
root=sibling_python_packages[sibling_package]))
|
root=pkg_root))
|
||||||
args.append(sibling_python_packages[sibling_package])
|
args.append(pkg_root)
|
||||||
|
|
||||||
install_output = subprocess.check_output(args)
|
install_output = subprocess.check_output(args)
|
||||||
log.extend(install_output.decode('utf-8').split('\n'))
|
log.extend(install_output.decode('utf-8').split('\n'))
|
||||||
|
|
||||||
for sibling_package in found_sibling_packages:
|
for sibling_package in found_sibling_packages:
|
||||||
|
pkg_root = _get_package_root(sibling_package,
|
||||||
|
sibling_python_packages)
|
||||||
log.append(
|
log.append(
|
||||||
"Installing {name} from {root}".format(
|
"Installing {name} from {root}".format(
|
||||||
name=sibling_package,
|
name=sibling_package,
|
||||||
root=sibling_python_packages[sibling_package]))
|
root=pkg_root))
|
||||||
|
|
||||||
install_output = subprocess.check_output(
|
install_output = subprocess.check_output(
|
||||||
[tox_python, '-m', 'pip', 'install', '--no-deps',
|
[tox_python, '-m', 'pip', 'install', '--no-deps',
|
||||||
sibling_python_packages[sibling_package]])
|
pkg_root])
|
||||||
log.extend(install_output.decode('utf-8').split('\n'))
|
log.extend(install_output.decode('utf-8').split('\n'))
|
||||||
except Exception as e:
|
except Exception as e:
|
||||||
tb = traceback.format_exc()
|
tb = traceback.format_exc()
|
||||||
|
Loading…
Reference in New Issue
Block a user