Improve debuginfo lookup.

This commit is contained in:
Daniel Mach 2012-09-25 22:15:35 +02:00 committed by Dennis Gilmore
parent 5451453f6f
commit c047fe570b

View File

@ -33,6 +33,26 @@ from fnmatch import fnmatch
import arch as arch_module import arch as arch_module
def is_debug(po):
if "debuginfo" in po.name:
return True
return False
def is_source(po):
if po.arch in ("src", "nosrc"):
return True
return False
def is_package(po):
if is_debug(po):
return False
if is_source(po):
return False
return True
class MyConfigParser(ConfigParser.ConfigParser): class MyConfigParser(ConfigParser.ConfigParser):
"""A subclass of ConfigParser which does not lowercase options""" """A subclass of ConfigParser which does not lowercase options"""
@ -54,6 +74,11 @@ class PungiBase(object):
self.valid_arches.append("src") # throw source in there, filter it later self.valid_arches.append("src") # throw source in there, filter it later
self.valid_multilib_arches = arch_module.get_valid_multilib_arches(self.tree_arch) self.valid_multilib_arches = arch_module.get_valid_multilib_arches(self.tree_arch)
# arch: compatible arches
self.compatible_arches = {}
for i in self.valid_arches:
self.compatible_arches[i] = arch_module.get_compatible_arches(i)
self.doLoggerSetup() self.doLoggerSetup()
self.workdir = os.path.join(self.config.get('pungi', 'destdir'), self.workdir = os.path.join(self.config.get('pungi', 'destdir'),
'work', 'work',
@ -157,6 +182,7 @@ class Pungi(pypungi.PungiBase):
self.excluded_pkgs = {} # list the packages we've already excluded. self.excluded_pkgs = {} # list the packages we've already excluded.
self.seen_pkgs = {} # list the packages we've already seen so we can check all deps only once self.seen_pkgs = {} # list the packages we've already seen so we can check all deps only once
self.lookaside_repos = self.config.get('pungi', 'lookaside_repos').split(" ") self.lookaside_repos = self.config.get('pungi', 'lookaside_repos').split(" ")
self.sourcerpm_arch_map = {} # {sourcerpm: set[arches]} - used for gathering debuginfo
def _add_yum_repo(self, name, url, mirrorlist=False, groups=True, def _add_yum_repo(self, name, url, mirrorlist=False, groups=True,
cost=1000, includepkgs=[], excludepkgs=[], cost=1000, includepkgs=[], excludepkgs=[],
@ -283,6 +309,32 @@ class Pungi(pypungi.PungiBase):
return True return True
def add_package(self, po, msg=None):
if not is_package(po):
raise ValueError("Not a binary package: %s" % po)
if msg:
self.logger.info(msg)
if po not in self.polist:
self.polist.append(po)
self.ayum.install(po)
self.sourcerpm_arch_map.setdefault(po.sourcerpm, set()).add(po.arch)
def add_debuginfo(self, po, msg=None):
if not is_debug(po):
raise ValueError("Not a debuginfog package: %s" % po)
if msg:
self.logger.info(msg)
if po not in self.debuginfolist:
self.debuginfolist.append(po)
def add_source(self, po, msg=None):
if not is_source(po):
raise ValueError("Not a source package: %s" % po)
if msg:
self.logger.info(msg)
if po not in self.srpmpolist:
self.srpmpolist.append(po)
def verifyCachePkg(self, po, path): # Stolen from yum def verifyCachePkg(self, po, path): # Stolen from yum
"""check the package checksum vs the cache """check the package checksum vs the cache
return True if pkg is good, False if not""" return True if pkg is good, False if not"""
@ -358,8 +410,8 @@ class Pungi(pypungi.PungiBase):
for dep in depsack.returnNewestByNameArch(): for dep in depsack.returnNewestByNameArch():
if dep not in added: if dep not in added:
self.ayum.tsInfo.addInstall(dep) msg = 'Added %s.%s for %s.%s' % (dep.name, dep.arch, po.name, po.arch)
self.logger.info('Added %s.%s for %s.%s' % (dep.name, dep.arch, po.name, po.arch)) self.add_package(dep, msg)
added.append(dep) added.append(dep)
else: else:
# nogreedy # nogreedy
@ -372,8 +424,8 @@ class Pungi(pypungi.PungiBase):
match = self.ayum._bestPackageFromList(pkg_sack) match = self.ayum._bestPackageFromList(pkg_sack)
dep = match dep = match
if dep not in added: if dep not in added:
self.ayum.install(dep) msg = 'Added %s.%s for %s.%s' % (dep.name, dep.arch, po.name, po.arch)
self.logger.info('Added %s.%s for %s.%s' % (dep.name, dep.arch, po.name, po.arch)) self.add_package(dep, msg)
added.append(dep) added.append(dep)
except (yum.Errors.InstallError, yum.Errors.YumBaseError), ex: except (yum.Errors.InstallError, yum.Errors.YumBaseError), ex:
self.logger.warn("Unresolvable dependency %s in %s.%s" % (r, po.name, po.arch)) self.logger.warn("Unresolvable dependency %s in %s.%s" % (r, po.name, po.arch))
@ -405,9 +457,9 @@ class Pungi(pypungi.PungiBase):
for i, pkg_sack in packages_by_name.iteritems(): for i, pkg_sack in packages_by_name.iteritems():
pkg_sack = self.excludePackages(pkg_sack) pkg_sack = self.excludePackages(pkg_sack)
match = self.ayum._bestPackageFromList(pkg_sack) match = self.ayum._bestPackageFromList(pkg_sack)
self.ayum.tsInfo.addInstall(match) msg = 'Added langpack %s.%s for package %s (pattern: %s)' % (match.name, match.arch, po.name, pattern)
self.add_package(match, msg)
added.append(match) added.append(match)
self.logger.info('Added langpack %s.%s for package %s (pattern: %s)' % (match.name, match.arch, po.name, pattern))
return added return added
@ -535,8 +587,8 @@ class Pungi(pypungi.PungiBase):
# Get the newest results from the search # Get the newest results from the search
mysack = yum.packageSack.ListPackageSack(matches) mysack = yum.packageSack.ListPackageSack(matches)
for match in mysack.returnNewestByNameArch(): for match in mysack.returnNewestByNameArch():
self.ayum.tsInfo.addInstall(match) msg = 'Found %s.%s' % (match.name, match.arch)
self.logger.info('Found %s.%s' % (match.name, match.arch)) self.add_package(match, msg)
for pkg in unmatched: for pkg in unmatched:
if not pkg in matchdict.keys(): if not pkg in matchdict.keys():
@ -558,8 +610,8 @@ class Pungi(pypungi.PungiBase):
for i, pkg_sack in packages_by_name.iteritems(): for i, pkg_sack in packages_by_name.iteritems():
pkg_sack = self.excludePackages(pkg_sack) pkg_sack = self.excludePackages(pkg_sack)
match = self.ayum._bestPackageFromList(pkg_sack) match = self.ayum._bestPackageFromList(pkg_sack)
self.ayum.tsInfo.addInstall(match) msg = 'Found %s.%s' % (match.name, match.arch)
self.logger.info('Found %s.%s' % (match.name, match.arch)) self.add_package(match, msg)
if len(self.ayum.tsInfo) == 0: if len(self.ayum.tsInfo) == 0:
raise yum.Errors.MiscError, 'No packages found to download.' raise yum.Errors.MiscError, 'No packages found to download.'
@ -612,10 +664,10 @@ class Pungi(pypungi.PungiBase):
find the sourcerpm for them. Requires yum still find the sourcerpm for them. Requires yum still
configured and a list of package objects""" configured and a list of package objects"""
for po in self.polist[self.last_po:]: for po in self.polist[self.last_po:]:
srpmpo = self.src_by_bin[po] srpm_po = self.src_by_bin[po]
if not srpmpo in self.srpmpolist: if not srpm_po in self.srpmpolist:
self.logger.info("Adding source package %s.%s" % (srpmpo.name, srpmpo.arch)) msg = "Adding source package %s.%s" % (srpm_po.name, srpm_po.arch)
self.srpmpolist.append(srpmpo) self.add_source(srpm_po)
self.last_po = len(self.polist) self.last_po = len(self.polist)
def resolvePackageBuildDeps(self): def resolvePackageBuildDeps(self):
@ -666,51 +718,26 @@ class Pungi(pypungi.PungiBase):
break break
thepass = thepass + 1 thepass = thepass + 1
def getDebuginfoList(self): def getDebuginfoList(self):
"""Cycle through the list of package objects and find """Cycle through the list of package objects and find
debuginfo rpms for them. Requires yum still debuginfo rpms for them. Requires yum still
configured and a list of package objects""" configured and a list of package objects"""
for po in self.polist: for po in self.pkgs:
debugname = '%s-debuginfo' % po.name if not is_debug(po):
results = self.ayum.pkgSack.searchNevra(name=debugname, continue
epoch=po.epoch,
ver=po.version,
rel=po.release,
arch=po.arch)
if results:
if not results[0] in self.debuginfolist:
self.logger.debug('Added %s found by name' % results[0].name)
self.debuginfolist.append(results[0])
else:
srpm = po.sourcerpm.split('.src.rpm')[0]
sname, sver, srel = srpm.rsplit('-', 2)
debugname = '%s-debuginfo' % sname
srcresults = self.ayum.pkgSack.searchNevra(name=debugname,
ver=sver,
rel=srel,
arch=po.arch)
if srcresults:
if not srcresults[0] in self.debuginfolist:
self.logger.debug('Added %s found by srpm' % srcresults[0].name)
self.debuginfolist.append(srcresults[0])
if po.name == 'kernel' or po.name == 'glibc': if po.sourcerpm not in self.sourcerpm_arch_map:
# %name-debuginfo-common # TODO: print a warning / throw an error
debugcommon = '%s-debuginfo-common' % po.name continue
# %name-debuginfo-common-%arch
debugcommon_arch = "%s-%s" % (debugcommon, po.arch)
for name in (debugcommon, debugcommon_arch): if not set(self.compatible_arches[po.arch]) & set(self.sourcerpm_arch_map[po.sourcerpm]):
commonresults = self.ayum.pkgSack.searchNevra(name=name, # skip all incompatible arches
epoch=po.epoch, # this pulls i386 debuginfo for a i686 package for example
ver=po.version, continue
rel=po.release, msg = 'Added debuginfo %s.%s' % (po.name, po.arch)
arch=po.arch) self.add_debuginfo(po, msg)
if commonresults:
if not commonresults[0] in self.debuginfolist:
self.logger.debug('Added %s found by common' % commonresults[0].name)
self.debuginfolist.append(commonresults[0])
def _downloadPackageList(self, polist, relpkgdir): def _downloadPackageList(self, polist, relpkgdir):
"""Cycle through the list of package objects and """Cycle through the list of package objects and