1
0
mirror of https://github.com/openSUSE/osc.git synced 2025-01-24 22:06:14 +01:00

- use cElementTree for XML parsing, since it is faster and easier to use, ditch

qp_xml (but still use xml.dom.ext for writing, maybe we can get rid of that
  later)
- fix display of build results, which was showing only one arch per repository
- fix listing of repositories of a project
This commit is contained in:
Dr. Peter Poeml 2006-05-02 08:17:45 +00:00
parent e8c6d7a8db
commit 6ec9c4f911
2 changed files with 57 additions and 60 deletions

5
osc.py
View File

@ -314,7 +314,8 @@ def main():
print ''.join(get_user_id(sys.argv[2])) print ''.join(get_user_id(sys.argv[2]))
elif cmd == 'platforms': elif cmd == 'platforms':
if project: if len(sys.argv) > 2:
project = sys.argv[2]
print '\n'.join(get_platforms_of_project(project)) print '\n'.join(get_platforms_of_project(project))
else: else:
print '\n'.join(get_platforms()) print '\n'.join(get_platforms())
@ -345,7 +346,7 @@ def main():
project = store_read_project(wd) project = store_read_project(wd)
for platform in get_platforms_of_project(project): for platform in get_platforms_of_project(project):
print ''.join(get_results(project, package, platform)) print '\n'.join(get_results(project, package, platform))
elif cmd == 'log': elif cmd == 'log':

112
osclib.py
View File

@ -10,9 +10,10 @@ __version__ = '0.2'
import os import os
import sys import sys
import urllib2 import urllib2
from xml.utils import qp_xml
import netrc import netrc
from urlparse import urlunsplit from urlparse import urlunsplit
import cElementTree as ET
from cStringIO import StringIO
# the needed entry in .netrc looks like this: # the needed entry in .netrc looks like this:
# machine api.opensuse.org login your_login password your_pass # machine api.opensuse.org login your_login password your_pass
@ -107,27 +108,27 @@ def check_store_version():
def meta_get_packagelist(prj): def meta_get_packagelist(prj):
reader = Sax2.Reader()
u = makeurl(['source', prj, '_meta']) u = makeurl(['source', prj, '_meta'])
f = urllib2.urlopen(u) f = urllib2.urlopen(u)
doc = reader.fromStream(f)
tree = ET.parse(f)
root = tree.getroot()
r = [] r = []
for i in doc.getElementsByTagName('package'): for node in root.findall('package'):
r.append(i.getAttribute('name')) r.append(node.get('name'))
return r return r
def meta_get_filelist(prj, package): def meta_get_filelist(prj, package):
reader = Sax2.Reader()
u = makeurl(['source', prj, package]) u = makeurl(['source', prj, package])
f = urllib2.urlopen(u) f = urllib2.urlopen(u)
doc = reader.fromStream(f) tree = ET.parse(f)
r = [] r = []
for i in doc.getElementsByTagName('entry'): for node in tree.getroot():
r.append(i.getAttribute('name')) r.append(node.get('name'))
return r return r
@ -166,25 +167,23 @@ def localmeta_removefile(filename):
def localmeta_get_filelist(): def localmeta_get_filelist():
reader = Sax2.Reader() tree = ET.parse(os.path.join(store, '_files'))
f = open(os.path.join(store, '_files')).read() root = tree.getroot()
doc = reader.fromString(f)
r = [] r = []
for i in doc.getElementsByTagName('entry'): for node in root.findall('entry'):
r.append(i.getAttribute('name')) r.append(node.get('name'))
return r return r
def get_slash_source(): def get_slash_source():
u = makeurl(['source']) u = makeurl(['source'])
f = urllib2.urlopen(u) tree = ET.parse(urllib2.urlopen(u))
parser = qp_xml.Parser()
root = parser.parse(f)
r = [] r = []
for entry in root.children: for node in tree.getroot():
r.append(entry.attrs[('', 'name')]) r.append(node.get('name'))
r.sort()
return r return r
def show_project_meta(prj): def show_project_meta(prj):
@ -375,85 +374,82 @@ def checkout_package(project, package):
os.chdir(olddir) os.chdir(olddir)
def get_platforms(): def get_platforms():
f = urllib2.urlopen(makeurl(['platform'])) f = urllib2.urlopen(makeurl(['platform']))
tree = ET.parse(f)
parser = qp_xml.Parser()
root = parser.parse(f)
r = [] r = []
for entry in root.children: for node in tree.getroot():
r.append(entry.attrs[('', 'name')]) r.append(node.get('name'))
r.sort()
return r return r
def get_platforms_of_project(prj): def get_platforms_of_project(prj):
f = show_project_meta(prj) f = show_project_meta(prj)
tree = ET.parse(StringIO(''.join(f)))
parser = qp_xml.Parser()
root = parser.parse('\n'.join(f))
r = [] r = []
for entry in root.children: for node in tree.findall('repository'):
if entry.name == 'repository': r.append(node.get('name'))
r.append(entry.attrs[('', 'name')])
return r return r
def show_results_meta(prj, package, platform): def show_results_meta(prj, package, platform):
u = makeurl(['result', prj, platform, package, 'result']) u = makeurl(['result', prj, platform, package, 'result'])
f = urllib2.urlopen(u) f = urllib2.urlopen(u)
return f.readlines() return f.readlines()
def get_results(prj, package, platform): def get_results(prj, package, platform):
#print '----------------------------------------' #print '----------------------------------------'
f = show_results_meta(prj, package, platform)
reader = Sax2.Reader()
doc = reader.fromString(''.join(f))
r = [] r = []
#result_line_templ = '%(prj)-15s %(pac)-15s %(rep)-15s %(arch)-10s %(status)s' #result_line_templ = '%(prj)-15s %(pac)-15s %(rep)-15s %(arch)-10s %(status)s'
result_line_templ = '%(rep)-15s %(arch)-10s %(status)s %(hint)s' result_line_templ = '%(rep)-15s %(arch)-10s %(status)s %(hint)s'
for i in doc.getElementsByTagName('packageresult'): f = show_results_meta(prj, package, platform)
rmap = {} tree = ET.parse(StringIO(''.join(f)))
rmap['hint'] = ''
rmap['prj'] = i.getAttribute('project')
rmap['pac'] = i.getAttribute('package')
rmap['rep'] = i.getAttribute('repository')
for ii in i.getElementsByTagName('archresult'): root = tree.getroot()
rmap['arch'] = ii.getAttribute('arch')
for iii in ii.getElementsByTagName('status'): rmap = {}
rmap['status'] = iii.getAttribute('code') rmap['hint'] = ''
if rmap['status'] == 'expansion error': rmap['prj'] = root.get('project')
for iiii in iii.getElementsByTagName('summary'): rmap['pac'] = root.get('package')
rmap['status'] += ':' rmap['rep'] = root.get('repository')
rmap['hint'] = iiii.childNodes[0].data
if rmap['status'] == 'failed': for node in root.findall('archresult'):
rmap['status'] += ':' rmap['arch'] = node.get('arch')
rmap['hint'] = '\'osc log %(rep)s %(arch)s\' -> ' % rmap + \
'(%s://%s' % (scheme, netloc) + \ statusnode = node.find('status')
'/result/%(prj)s/%(rep)s/%(pac)s/%(arch)s/log)' % rmap rmap['status'] = statusnode.get('code')
if rmap['status'] == 'expansion error':
rmap['status'] += ': ' + statusnode.find('summary').text
if rmap['status'] == 'failed':
rmap['status'] += ':'
rmap['hint'] = '\'osc log %(rep)s %(arch)s\' -> ' % rmap + \
'(%s://%s' % (scheme, netloc) + \
'/result/%(prj)s/%(rep)s/%(pac)s/%(arch)s/log)' % rmap
r.append(result_line_templ % rmap) r.append(result_line_templ % rmap)
return r return r
def get_log(prj, package, platform, arch): def get_log(prj, package, platform, arch):
u = makeurl(['result', prj, platform, package, arch, 'log']) u = makeurl(['result', prj, platform, package, arch, 'log'])
f = urllib2.urlopen(u) f = urllib2.urlopen(u)
return f.readlines() return f.readlines()
def store_read_project(dir): def store_read_project(dir):
p = open(os.path.join(dir, store, '_project')).readlines()[0].strip() p = open(os.path.join(dir, store, '_project')).readlines()[0].strip()
return p return p
def store_read_package(dir): def store_read_package(dir):
p = open(os.path.join(dir, store, '_package')).readlines()[0].strip() p = open(os.path.join(dir, store, '_package')).readlines()[0].strip()
return p return p
#p = open(os.path.join(dir, store, '_meta')).readlines()[0]
#p = p.split('"')[1]
#return p