1
0
mirror of https://github.com/openSUSE/osc.git synced 2025-01-12 08:56:13 +01:00

run pre_checkin.sh on build and commit

The pre_checkin.sh is script run after each checkin of package into
SUSE. Osc build and commit commands now runs it automatically too,
unless --no-precheckin is specified.
This commit is contained in:
Michal Vyskocil 2011-01-05 16:12:25 +01:00
parent ae13273045
commit 8ea5bc7f04
3 changed files with 36 additions and 1 deletions

1
NEWS
View File

@ -1,4 +1,5 @@
0.131 0.131
- call pre_checkin.sh on build and commit (can be suppressed with --no-precheckin)
0.130 0.130
- new "revert" command to restore the original working copy file (without - new "revert" command to restore the original working copy file (without

View File

@ -3084,6 +3084,8 @@ Please submit there instead, or use --nodevelproject to force direct submission.
help='Skip the source validation') help='Skip the source validation')
@cmdln.option('--verbose-validation', default=False, action="store_true", @cmdln.option('--verbose-validation', default=False, action="store_true",
help='Run the source validation with verbose information') help='Run the source validation with verbose information')
@cmdln.option('--no-precheckin', action='store_true', default=False,
help="don't run pre_checkin.sh, if exists")
def do_commit(self, subcmd, opts, *args): def do_commit(self, subcmd, opts, *args):
"""${cmd_name}: Upload content to the repository server """${cmd_name}: Upload content to the repository server
@ -3133,6 +3135,8 @@ Please submit there instead, or use --nodevelproject to force direct submission.
if conf.config['do_package_tracking'] and is_project_dir(arg): if conf.config['do_package_tracking'] and is_project_dir(arg):
try: try:
prj = Project(arg) prj = Project(arg)
if not opts.no_precheckin:
run_precheckin(prj.pacs_have)
prj.validate_pacs(validators, opts.verbose_validation) prj.validate_pacs(validators, opts.verbose_validation)
if not msg: if not msg:
msg = edit_message() msg = edit_message()
@ -3166,6 +3170,8 @@ Please submit there instead, or use --nodevelproject to force direct submission.
single_paths.append(pac.dir) single_paths.append(pac.dir)
for prj_path, packages in prj_paths.iteritems(): for prj_path, packages in prj_paths.iteritems():
prj = Project(prj_path) prj = Project(prj_path)
if not opts.no_precheckin:
run_precheckin((os.path.join(prj_path, p) for p in packages))
prj.validate_pacs(validators, opts.verbose_validation, *packages) prj.validate_pacs(validators, opts.verbose_validation, *packages)
if not msg: if not msg:
msg = get_commit_msg(prj.absdir, pac_objs[prj_path]) msg = get_commit_msg(prj.absdir, pac_objs[prj_path])
@ -3173,6 +3179,8 @@ Please submit there instead, or use --nodevelproject to force direct submission.
store_unlink_file(prj.absdir, '_commit_msg') store_unlink_file(prj.absdir, '_commit_msg')
for pac in single_paths: for pac in single_paths:
p = Package(pac) p = Package(pac)
if not opts.no_precheckin:
run_precheckin()
p.validate(validators, opts.verbose_validation) p.validate(validators, opts.verbose_validation)
if not msg: if not msg:
msg = get_commit_msg(p.absdir, [p]) msg = get_commit_msg(p.absdir, [p])
@ -3181,6 +3189,8 @@ Please submit there instead, or use --nodevelproject to force direct submission.
else: else:
for p in pacs: for p in pacs:
p = Package(pac) p = Package(pac)
if not opts.no_precheckin:
run_precheckin()
p.validate(validators, opts.verbose_validation) p.validate(validators, opts.verbose_validation)
if not msg: if not msg:
msg = get_commit_msg(p.absdir, [p]) msg = get_commit_msg(p.absdir, [p])
@ -4092,7 +4102,7 @@ Please submit there instead, or use --nodevelproject to force direct submission.
repositories = [] repositories = []
# store list of repos for potential offline use # store list of repos for potential offline use
repolistfile = os.path.join(os.getcwd(), osc.core.store, "_build_repositories") repolistfile = os.path.join(os.getcwd(), store, "_build_repositories")
if noinit: if noinit:
if os.path.exists(repolistfile): if os.path.exists(repolistfile):
f = open(repolistfile, 'r') f = open(repolistfile, 'r')
@ -4234,6 +4244,8 @@ Please submit there instead, or use --nodevelproject to force direct submission.
help='take previous build from DIR (special values: _self, _link)') help='take previous build from DIR (special values: _self, _link)')
@cmdln.option('--shell', action='store_true', @cmdln.option('--shell', action='store_true',
help=SUPPRESS_HELP) help=SUPPRESS_HELP)
@cmdln.option('--no-precheckin', action='store_true', default=False,
help="don't run pre_checkin.sh, if exists")
def do_build(self, subcmd, opts, *args): def do_build(self, subcmd, opts, *args):
"""${cmd_name}: Build a package on your local machine """${cmd_name}: Build a package on your local machine
@ -4316,6 +4328,9 @@ Please submit there instead, or use --nodevelproject to force direct submission.
if opts.offline and opts.preload: if opts.offline and opts.preload:
raise oscerr.WrongOptions('--offline and --preload are mutually exclusive') raise oscerr.WrongOptions('--offline and --preload are mutually exclusive')
if not opts.no_precheckin:
run_precheckin()
print 'Building %s for %s/%s' % (args[2], args[0], args[1]) print 'Building %s for %s/%s' % (args[2], args[0], args[1])
return osc.build.main(self.get_api_url(), opts, args) return osc.build.main(self.get_api_url(), opts, args)

View File

@ -5954,4 +5954,23 @@ def filter_role(meta, user, role):
for node in delete: for node in delete:
root.remove(node) root.remove(node)
# run the pre_checkin.sh if exists
def run_precheckin(packages=('.', )):
oldpwd = os.getcwd()
for dir in packages:
if os.path.isdir(dir):
os.chdir(dir)
if os.path.isfile('pre_checkin.sh'):
ret = subprocess.call(["/bin/sh", "pre_checkin.sh"])
if ret != 0:
script_name = 'pre_checkin.sh'
if dir != '.':
script_name = "%s/%s" % (dir, script_name)
#XXX: an ugly hack to prevent ../package - to me it seems, there's a bug in do_commit
if script_name[:3] == '../':
script_name = script_name[3:]
raise oscerr.ExtRuntimeError("sh %s has failed with exit code %d, fix it or ignore using --no-precheckin" % (script_name, ret), script_name)
os.chdir(oldpwd)
return True
# vim: sw=4 et # vim: sw=4 et