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:
parent
e8c6d7a8db
commit
6ec9c4f911
5
osc.py
5
osc.py
@ -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
112
osclib.py
@ -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
|
|
||||||
|
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user