2014-03-05 15:12:45 +01:00
|
|
|
from xml.etree import cElementTree as ET
|
|
|
|
|
2014-03-04 15:30:49 +01:00
|
|
|
from osc import oscerr
|
2014-03-05 15:12:45 +01:00
|
|
|
from osc.core import http_GET
|
|
|
|
|
2014-03-04 09:39:14 +01:00
|
|
|
from osclib.request_finder import RequestFinder
|
|
|
|
|
2014-03-04 15:30:49 +01:00
|
|
|
|
|
|
|
class SelectCommand(object):
|
|
|
|
|
2014-03-04 09:39:14 +01:00
|
|
|
def __init__(self, api):
|
|
|
|
self.api = api
|
|
|
|
|
2014-03-05 15:12:45 +01:00
|
|
|
def _package(self, request):
|
|
|
|
"""Get the package name from the submit request XML."""
|
|
|
|
f = http_GET(self.api.makeurl(['request', str(request)]))
|
|
|
|
root = ET.parse(f).getroot()
|
|
|
|
package = str(root.find('action').find('target').attrib['package'])
|
|
|
|
return package
|
|
|
|
|
|
|
|
def _is_supersede(self, request):
|
|
|
|
"""
|
|
|
|
Check if the request supersede a different request from a
|
|
|
|
staging project.
|
|
|
|
"""
|
|
|
|
package = self._package(request)
|
|
|
|
|
|
|
|
for staging in self.api.get_staging_projects():
|
|
|
|
for rq in self.api.get_prj_pseudometa(staging)['requests']:
|
|
|
|
if rq['id'] != request and rq['package'] == package:
|
|
|
|
return (rq['id'], package, staging)
|
|
|
|
|
2014-03-04 15:30:49 +01:00
|
|
|
def select_request(self, rq, rq_prj, move, from_):
|
2014-03-05 15:12:45 +01:00
|
|
|
supersede = self._is_supersede(rq)
|
|
|
|
|
|
|
|
if 'staging' not in rq_prj and not supersede:
|
2014-03-04 09:39:14 +01:00
|
|
|
# Normal 'select' command
|
2014-03-04 15:00:25 +01:00
|
|
|
return self.api.rq_to_prj(rq, self.tprj)
|
2014-03-05 15:12:45 +01:00
|
|
|
elif 'staging' in rq_prj and (move or supersede):
|
2014-03-04 09:39:14 +01:00
|
|
|
# 'select' command becomes a 'move'
|
|
|
|
fprj = None
|
2014-03-04 15:30:49 +01:00
|
|
|
if from_:
|
|
|
|
fprj = self.api.prj_from_letter(from_)
|
2014-03-04 09:39:14 +01:00
|
|
|
else:
|
2014-03-05 15:12:45 +01:00
|
|
|
# supersede = (new_rq, package, project)
|
|
|
|
fprj = rq_prj['staging'] if not supersede else supersede[2]
|
|
|
|
if supersede:
|
|
|
|
print('"{} ({}) is superseded by {}'.format(rq, supersede[1], supersede[0]))
|
2014-03-04 09:39:14 +01:00
|
|
|
print('Moving "{}" from "{}" to "{}"'.format(rq, fprj, self.tprj))
|
2014-03-04 15:00:25 +01:00
|
|
|
return self.api.move_between_project(fprj, rq, self.tprj)
|
2014-03-04 15:30:49 +01:00
|
|
|
elif 'staging' in rq_prj and not move:
|
2014-03-04 09:39:14 +01:00
|
|
|
# Previously selected, but not explicit move
|
|
|
|
msg = 'Request {} is actually in "{}".\n'
|
|
|
|
msg = msg.format(rq, rq_prj['staging'])
|
2014-03-05 15:12:45 +01:00
|
|
|
if rq_prj['staging'] != self.tprj:
|
|
|
|
msg += 'Use --move modifier to move the request from "{}" to "{}"'
|
|
|
|
msg = msg.format(rq_prj['staging'], self.tprj)
|
2014-03-04 09:39:14 +01:00
|
|
|
print(msg)
|
2014-03-04 15:00:25 +01:00
|
|
|
return False
|
2014-03-04 09:39:14 +01:00
|
|
|
else:
|
|
|
|
raise oscerr.WrongArgs('Arguments for select are not correct.')
|
|
|
|
|
2014-03-04 15:30:49 +01:00
|
|
|
def perform(self, tprj, requests, move=False, from_=None):
|
2014-03-04 09:39:14 +01:00
|
|
|
if not self.api.prj_frozen_enough(tprj):
|
|
|
|
print('Freeze the prj first')
|
|
|
|
return False
|
|
|
|
self.tprj = tprj
|
|
|
|
|
|
|
|
for rq, rq_prj in RequestFinder.find_sr(requests, self.api.apiurl).items():
|
2014-03-04 15:00:25 +01:00
|
|
|
if not self.select_request(rq, rq_prj, move, from_):
|
|
|
|
return False
|
|
|
|
|
|
|
|
# now make sure we enable the prj
|
|
|
|
self.api.build_switch_prj(tprj, 'enable')
|
|
|
|
return True
|