mirror of
https://github.com/openSUSE/osc.git
synced 2025-01-12 00:46:14 +01:00
- add request and review "supersede" command, to supersede by an existsing request
This commit is contained in:
parent
36007fb538
commit
0bf76163ed
1
NEWS
1
NEWS
@ -9,6 +9,7 @@
|
|||||||
- support viewing the commit history of deleted packages
|
- support viewing the commit history of deleted packages
|
||||||
- show review states on "review list"
|
- show review states on "review list"
|
||||||
- new source service commands "localrun" and "disabledrun" to generate files without _service: prefix
|
- new source service commands "localrun" and "disabledrun" to generate files without _service: prefix
|
||||||
|
- add "request supersede" and "review supersede" to supersede with existing request
|
||||||
#
|
#
|
||||||
# Features which requires OBS 2.2
|
# Features which requires OBS 2.2
|
||||||
#
|
#
|
||||||
|
@ -1658,7 +1658,7 @@ Please submit there instead, or use --nodevelproject to force direct submission.
|
|||||||
|
|
||||||
"reopen" will set the request back to new or review.
|
"reopen" will set the request back to new or review.
|
||||||
|
|
||||||
"wipe" will permanently delete a request
|
"supersede" will supersede one request with another existing one.
|
||||||
|
|
||||||
"revoke" will set the request state to "revoked"
|
"revoke" will set the request state to "revoked"
|
||||||
|
|
||||||
@ -1688,8 +1688,8 @@ Please submit there instead, or use --nodevelproject to force direct submission.
|
|||||||
osc request accept [-m TEXT] ID
|
osc request accept [-m TEXT] ID
|
||||||
osc request decline [-m TEXT] ID
|
osc request decline [-m TEXT] ID
|
||||||
osc request revoke [-m TEXT] ID
|
osc request revoke [-m TEXT] ID
|
||||||
osc request wipe ID
|
|
||||||
osc request reopen [-m TEXT] ID
|
osc request reopen [-m TEXT] ID
|
||||||
|
osc request supersede [-m TEXT] ID SUPERSEDE_ID
|
||||||
osc request approvenew [-m TEXT] PROJECT
|
osc request approvenew [-m TEXT] PROJECT
|
||||||
|
|
||||||
osc request checkout/co ID
|
osc request checkout/co ID
|
||||||
@ -1700,6 +1700,7 @@ Please submit there instead, or use --nodevelproject to force direct submission.
|
|||||||
osc review accept [-m TEXT] ID
|
osc review accept [-m TEXT] ID
|
||||||
osc review decline [-m TEXT] ID
|
osc review decline [-m TEXT] ID
|
||||||
osc review reopen [-m TEXT] ID
|
osc review reopen [-m TEXT] ID
|
||||||
|
osc review supersede [-m TEXT] ID SUPERSEDE_ID
|
||||||
|
|
||||||
${cmd_option_list}
|
${cmd_option_list}
|
||||||
"""
|
"""
|
||||||
@ -1728,11 +1729,11 @@ Please submit there instead, or use --nodevelproject to force direct submission.
|
|||||||
if args[0] == 'help':
|
if args[0] == 'help':
|
||||||
return self.do_help(['help', 'request'])
|
return self.do_help(['help', 'request'])
|
||||||
|
|
||||||
cmds = [ 'list', 'log', 'show', 'decline', 'reopen', 'clone', 'accept', 'approvenew', 'wipe', 'revoke', 'checkout', 'co' ]
|
cmds = [ 'list', 'log', 'show', 'decline', 'reopen', 'clone', 'accept', 'approvenew', 'wipe', 'supersede', 'revoke', 'checkout', 'co' ]
|
||||||
if subcmd != 'review' and args[0] not in cmds:
|
if subcmd != 'review' and args[0] not in cmds:
|
||||||
raise oscerr.WrongArgs('Unknown request action %s. Choose one of %s.' \
|
raise oscerr.WrongArgs('Unknown request action %s. Choose one of %s.' \
|
||||||
% (args[0],', '.join(cmds)))
|
% (args[0],', '.join(cmds)))
|
||||||
cmds = [ 'list', 'add', 'decline', 'accept', 'reopen' ]
|
cmds = [ 'list', 'add', 'decline', 'accept', 'reopen', 'supersede' ]
|
||||||
if subcmd == 'review' and args[0] not in cmds:
|
if subcmd == 'review' and args[0] not in cmds:
|
||||||
raise oscerr.WrongArgs('Unknown review action %s. Choose one of %s.' \
|
raise oscerr.WrongArgs('Unknown review action %s. Choose one of %s.' \
|
||||||
% (args[0],', '.join(cmds)))
|
% (args[0],', '.join(cmds)))
|
||||||
@ -1744,6 +1745,8 @@ Please submit there instead, or use --nodevelproject to force direct submission.
|
|||||||
|
|
||||||
if cmd in ['list']:
|
if cmd in ['list']:
|
||||||
min_args, max_args = 0, 2
|
min_args, max_args = 0, 2
|
||||||
|
elif cmd in ['supersede']:
|
||||||
|
min_args, max_args = 2, 2
|
||||||
else:
|
else:
|
||||||
min_args, max_args = 1, 1
|
min_args, max_args = 1, 1
|
||||||
if len(args) < min_args:
|
if len(args) < min_args:
|
||||||
@ -1753,6 +1756,8 @@ Please submit there instead, or use --nodevelproject to force direct submission.
|
|||||||
if cmd in ['add'] and not opts.user and not opts.group:
|
if cmd in ['add'] and not opts.user and not opts.group:
|
||||||
opts.user = conf.get_apiurl_usr(apiurl)
|
opts.user = conf.get_apiurl_usr(apiurl)
|
||||||
|
|
||||||
|
reqid = None
|
||||||
|
supersedid = None
|
||||||
if cmd == 'list' or cmd == 'approvenew':
|
if cmd == 'list' or cmd == 'approvenew':
|
||||||
package = None
|
package = None
|
||||||
project = None
|
project = None
|
||||||
@ -1767,6 +1772,9 @@ Please submit there instead, or use --nodevelproject to force direct submission.
|
|||||||
|
|
||||||
if len(args) > 1:
|
if len(args) > 1:
|
||||||
package = args[1]
|
package = args[1]
|
||||||
|
elif cmd == 'supersede':
|
||||||
|
reqid = args[0]
|
||||||
|
supersedid = args[1]
|
||||||
elif cmd in ['log', 'add', 'show', 'decline', 'reopen', 'clone', 'accept', 'wipe', 'revoke', 'checkout', 'co']:
|
elif cmd in ['log', 'add', 'show', 'decline', 'reopen', 'clone', 'accept', 'wipe', 'revoke', 'checkout', 'co']:
|
||||||
reqid = args[0]
|
reqid = args[0]
|
||||||
|
|
||||||
@ -1932,17 +1940,17 @@ Please submit there instead, or use --nodevelproject to force direct submission.
|
|||||||
action.src_rev, expand_link=True, prj_dir=action.src_project)
|
action.src_rev, expand_link=True, prj_dir=action.src_project)
|
||||||
|
|
||||||
else:
|
else:
|
||||||
state_map = {'reopen' : 'new', 'accept' : 'accepted', 'decline' : 'declined', 'wipe' : 'deleted', 'revoke' : 'revoked'}
|
state_map = {'reopen' : 'new', 'accept' : 'accepted', 'decline' : 'declined', 'wipe' : 'deleted', 'revoke' : 'revoked', 'supersede' : 'superseded'}
|
||||||
# Change review state only
|
# Change review state only
|
||||||
if subcmd == 'review':
|
if subcmd == 'review':
|
||||||
if not opts.message:
|
if not opts.message:
|
||||||
opts.message = edit_message()
|
opts.message = edit_message()
|
||||||
if cmd in ['accept', 'decline', 'reopen']:
|
if cmd in ['accept', 'decline', 'reopen', 'supersede']:
|
||||||
r = change_review_state(apiurl,
|
r = change_review_state(apiurl,
|
||||||
reqid, state_map[cmd], conf.get_apiurl_usr(apiurl), opts.group, opts.project, opts.package, opts.message or '')
|
reqid, state_map[cmd], conf.get_apiurl_usr(apiurl), opts.group, opts.project, opts.package, opts.message or '', supersed=supersedid)
|
||||||
print r
|
print r
|
||||||
# Change state of entire request
|
# Change state of entire request
|
||||||
elif cmd in ['reopen', 'accept', 'decline', 'wipe', 'revoke']:
|
elif cmd in ['reopen', 'accept', 'decline', 'wipe', 'revoke', 'supersede']:
|
||||||
rq = get_request(apiurl, reqid)
|
rq = get_request(apiurl, reqid)
|
||||||
if rq.state.name == state_map[cmd]:
|
if rq.state.name == state_map[cmd]:
|
||||||
repl = raw_input("\n *** The state of the request (#%s) is already '%s'. Change state anyway? [y/n] *** " % (reqid, rq.state.name))
|
repl = raw_input("\n *** The state of the request (#%s) is already '%s'. Change state anyway? [y/n] *** " % (reqid, rq.state.name))
|
||||||
@ -1954,7 +1962,7 @@ Please submit there instead, or use --nodevelproject to force direct submission.
|
|||||||
tmpl = change_request_state_template(rq, state_map[cmd])
|
tmpl = change_request_state_template(rq, state_map[cmd])
|
||||||
opts.message = edit_message(template=tmpl)
|
opts.message = edit_message(template=tmpl)
|
||||||
r = change_request_state(apiurl,
|
r = change_request_state(apiurl,
|
||||||
reqid, state_map[cmd], opts.message or '', force=opts.force)
|
reqid, state_map[cmd], opts.message or '', supersed=supersedid, force=opts.force)
|
||||||
print 'Result of change request state: %s' % r
|
print 'Result of change request state: %s' % r
|
||||||
|
|
||||||
# editmeta and its aliases are all depracated
|
# editmeta and its aliases are all depracated
|
||||||
|
Loading…
Reference in New Issue
Block a user