openSUSE-release-tools/osclib/check_command.py

102 lines
3.7 KiB
Python
Raw Normal View History

2014-03-06 18:50:59 +01:00
class CheckCommand(object):
def __init__(self, api):
self.api = api
def _report(self, project, verbose):
"""Print a single report for a project.
:param project: dict object, converted from JSON.
:param verbose: do verbose check or not
"""
report = []
# Check for superseded requests
for r in project.findall('obsolete_requests/*'):
if r.get('state') == 'superseded':
2024-05-07 17:55:17 +02:00
report.extend(f" - Request {r.get('id')} is superseded by {r.get('superseded_by')}")
# Untracked requests
for r in project.findall('untracked_requests/*'):
2024-05-07 17:55:17 +02:00
report.extend(f" - Request {r.get('id')} is no tracked but is open for the project")
# Status of obsolete requests
for r in project.findall('obsolete_requests/*'):
if r.get('state') == 'superseded':
2014-07-08 17:25:29 +02:00
continue
2024-05-07 17:55:17 +02:00
report.append(f" - {r.get('package')}: {r.get('state')}")
if not verbose:
break
# Missing reviews
2019-11-19 15:33:09 +01:00
for r in project.findall('missing_reviews/review'):
2024-05-07 17:55:17 +02:00
report.append(f" - {r.get('package')}: Missing reviews: {self.api.format_review(r)}")
if not verbose:
break
# Building repositories
2019-11-19 15:33:09 +01:00
if project.find('building_repositories/repo') is not None:
report.append(' - At least following repositories are still building:')
for r in project.findall('building_repositories/*'):
2024-05-07 17:55:17 +02:00
report.append(f" {r.get('repository')}/{r.get('arch')}: {r.get('state')}")
if not verbose:
break
# Broken packages
2019-11-19 15:33:09 +01:00
if project.find('broken_packages/package') is not None:
report.append(' - Following packages are broken:')
2019-11-19 15:33:09 +01:00
for r in project.findall('broken_packages/package'):
2024-05-07 17:55:17 +02:00
report.append(f" {r.get('package')} ({r.get('repository')}): {r.get('state')}")
if not verbose:
break
# openQA results
for check in project.findall('missing_checks/*'):
2019-10-10 15:17:57 +02:00
report.append(' - Missing check: ' + check.get('name'))
for check in project.findall('checks/*'):
2019-11-08 10:22:43 +01:00
state = check.find('state').text
if state != 'success':
2024-05-07 17:55:17 +02:00
info = f" - {state} check: {check.get('name')}"
2019-11-08 10:22:43 +01:00
url = check.find('url')
if url is not None:
info += " " + url.text
report.append(info)
break
if project.get('state') == 'acceptable':
2024-05-07 17:55:17 +02:00
report.insert(0, f" ++ Acceptable staging project {project.get('name')}")
elif project.get('state') != 'empty':
report.insert(0, ' -- %s Project %s still needs attention' % (project.get('state').upper(),
project.get('name')))
return report
def _check_project(self, project):
"""
Check state of one specified staging project
:param project: project to check
"""
info = self.api.project_status(project)
if info.get('state') == 'empty':
return []
return self._report(info, False) + ['']
def perform(self, project):
2014-03-06 18:50:59 +01:00
"""
Check one staging project verbosibly or all of them at once
:param project: project to check, None for all
"""
if project:
2019-11-08 10:22:43 +01:00
report = self._check_project(project)
2014-03-06 18:50:59 +01:00
else:
2019-11-08 10:22:43 +01:00
report = []
for project in self.api.get_staging_projects():
report.extend(self._check_project(project))
print('\n'.join(report))
2014-03-06 18:50:59 +01:00
return True