Merge pull request #244 from openSUSE/coolo_requests

Coolo requests
This commit is contained in:
Alberto Planas 2014-09-22 14:12:54 +02:00
commit 97a7a0b3bb
2 changed files with 29 additions and 21 deletions

View File

@ -12,6 +12,7 @@ import re
#initialize osc config
osc.conf.get_config()
osc.conf.config['debug'] = True
srcmd5s = dict()
revs = dict()
@ -39,6 +40,8 @@ def parse_prj(prj):
# POSIX system. Create and return a getch that manipulates the tty.
import termios, sys, tty
def _getch():
return 'n'
fd = sys.stdin.fileno()
old_settings = termios.tcgetattr(fd)
try:
@ -47,11 +50,33 @@ def _getch():
finally:
termios.tcsetattr(fd, termios.TCSADRAIN, old_settings)
return ch
def get_devel_project(package):
url = osc.core.makeurl(osc.conf.config['apiurl'], ['source', 'openSUSE:Factory', package, '_meta'])
f = osc.core.http_GET(url)
root = ET.parse(f)
for dp in root.findall('./devel'):
return dp.attrib['project']
raise 'NOW WHAT?'
def create_submit(project=None, package=None, rev=None, md5=None):
text = "<request type='submit'>\n"
text += " <submit>\n"
text += " <source project='" + project + "' package='" + package + "' rev='" + md5 + "'/>\n"
text += " <target project='openSUSE:13.2'/>\n"
text += " </submit>\n"
text += " <description>Submit revision " + rev + " of openSUSE:Factory</description>\n"
text += "</request>"
url = osc.core.makeurl(osc.conf.config['apiurl'], [ 'request' ], { 'cmd': 'create' })
print osc.core.http_POST(url, data=text).read()
factory = parse_prj('openSUSE:Factory')
d132 = parse_prj('openSUSE:13.2')
NOS = ('graphviz-1a63c5430695678e333d14020602b84e', 'java-1_7_0-openjdk-59f27f7560ea2c583520b06cbe11a9e4')
NOS = ()
for package in sorted(set(factory) | set(d132)):
prompt = None
@ -84,15 +109,8 @@ for package in sorted(set(factory) | set(d132)):
md5 = srcmd5s[factory[package]]
rev = revs[factory[package]]
url = osc.core.makeurl(osc.conf.config['apiurl'], ['source', 'openSUSE:13.2', package],
{ 'cmd': 'copy', 'opackage': package, 'oproject': 'openSUSE:Factory', 'orev': md5,
'noservice': 1, 'comment': 'Copy from Factory revision {}'.format(rev) } )
print prompt
likes = _getch()
if likes == 'y':
print url
osc.core.http_POST(url)
create_submit(project=get_devel_project(package), package=package, rev=rev, md5=md5)
exit(0)
else: # the 13.2 must have it
print "delete package 13.2/%s-%s" % ( package, d132[package] )
@ -103,6 +121,3 @@ for package in sorted(set(factory) | set(d132)):
print url
osc.core.http_DELETE(url)

View File

@ -125,10 +125,6 @@ def _checker_add_review(self, opts, id_, by_group=None, by_user=None,
return 0
def _checker_forward_to_staging(self, opts, id_):
return self._checker_add_review(opts, id_, by_group='factory-staging', msg="Pick Staging Project")
def _checker_add_review_team(self, opts, id_):
return self._checker_add_review(opts, id_, by_group='opensuse-review-team', msg="Please review sources")
@ -141,8 +137,6 @@ def _checker_accept_request(self, opts, id_, msg, diff=10000):
self._checker_add_review(opts, id_, by_user='factory-repo-checker', msg='Please review build success')
self._checker_forward_to_staging(opts, id_)
self._checker_change_review_state(opts, id_, 'accepted', by_group='factory-auto', message=msg)
print("accepted " + msg)
@ -302,7 +296,6 @@ def _checker_one_request(self, rq, opts):
continue
else:
self._checker_forward_to_staging(opts, id_)
self._checker_change_review_state(opts, id_, 'accepted',
by_group='factory-auto',
message="Unchecked request type %s" % _type)