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

- added new function core.run_external which can be used to execute an external program

Basically it's just a wrapper around subprocess.call which raises an ExtRuntimeError
exception if subprocess.call raised an OSError with errno set to ENOENT (unfortunately
the OSError's filename attribute is set to None therefore we cannot print a meaningful
error message (that's why an ExtRuntimeError is raised)).
Replaced all occurrences of subprocess.call with a corresponding run_external call.
This commit is contained in:
Marcus Huewe 2013-03-08 00:56:57 +01:00
parent ec595d361b
commit 93df866787
4 changed files with 48 additions and 28 deletions

View File

@ -149,7 +149,7 @@ def run(prg):
print >>sys.stderr, e print >>sys.stderr, e
return 2 return 2
except oscerr.ExtRuntimeError, e: except oscerr.ExtRuntimeError, e:
print >>sys.stderr, e.msg print >>sys.stderr, e.file + ':', e.msg
return 1 return 1
except oscerr.WorkingCopyOutdated, e: except oscerr.WorkingCopyOutdated, e:
print >>sys.stderr, e print >>sys.stderr, e

View File

@ -13,7 +13,7 @@ import urlparse
from tempfile import NamedTemporaryFile, mkdtemp from tempfile import NamedTemporaryFile, mkdtemp
from osc.fetch import * from osc.fetch import *
from osc.core import get_buildinfo, store_read_apiurl, store_read_project, store_read_package, meta_exists, quote_plus, get_buildconfig, is_package_dir from osc.core import get_buildinfo, store_read_apiurl, store_read_project, store_read_package, meta_exists, quote_plus, get_buildconfig, is_package_dir
from osc.core import get_binarylist, get_binary_file from osc.core import get_binarylist, get_binary_file, run_external
from osc.util import rpmquery, debquery, archquery from osc.util import rpmquery, debquery, archquery
import osc.conf import osc.conf
import oscerr import oscerr
@ -913,14 +913,15 @@ def main(apiurl, opts, argv):
cmd = [ change_personality[bi.buildarch] ] + cmd; cmd = [ change_personality[bi.buildarch] ] + cmd;
try: try:
rc = subprocess.call(cmd) rc = run_external(cmd[0], *cmd[1:])
if rc: if rc:
print print
print 'The buildroot was:', build_root print 'The buildroot was:', build_root
sys.exit(rc) sys.exit(rc)
except KeyboardInterrupt, i: except KeyboardInterrupt, i:
print "keyboard interrupt, killing build ..." print "keyboard interrupt, killing build ..."
subprocess.call(cmd + ["--kill"]) cmd.append('--kill')
run_external(cmd[0], *cmd[1:])
raise i raise i
pacdir = os.path.join(build_root, '.build.packages') pacdir = os.path.join(build_root, '.build.packages')

View File

@ -5416,7 +5416,7 @@ Please submit there instead, or use --nodevelproject to force direct submission.
pdir, pdir,
"%s:%s" % (hostname, os.path.dirname(hostprefer))] "%s:%s" % (hostname, os.path.dirname(hostprefer))]
print 'Run: %s' % " ".join(rsync_prefer_cmd) print 'Run: %s' % " ".join(rsync_prefer_cmd)
ret = subprocess.call(rsync_prefer_cmd) ret = run_external(rsync_prefer_cmd[0], *rsync_prefer_cmd[1:])
if ret != 0: if ret != 0:
return ret return ret
@ -5466,7 +5466,7 @@ Please submit there instead, or use --nodevelproject to force direct submission.
# 1.) rsync sources # 1.) rsync sources
rsync_source_cmd = ['rsync', '-az', '-delete', '-e', 'ssh', cwd, "%s:%s" % (hostname, hostpath)] rsync_source_cmd = ['rsync', '-az', '-delete', '-e', 'ssh', cwd, "%s:%s" % (hostname, hostpath)]
print 'Run: %s' % " ".join(rsync_source_cmd) print 'Run: %s' % " ".join(rsync_source_cmd)
ret = subprocess.call(rsync_source_cmd) ret = run_external(rsync_source_cmd[0], *rsync_source_cmd[1:])
if ret != 0: if ret != 0:
return ret return ret
@ -5497,7 +5497,7 @@ Please submit there instead, or use --nodevelproject to force direct submission.
local_args = " ".join(hostargs)) local_args = " ".join(hostargs))
] ]
print 'Run: %s' % " ".join(ssh_cmd) print 'Run: %s' % " ".join(ssh_cmd)
build_ret = subprocess.call(ssh_cmd) build_ret = run_external(ssh_cmd[0], *ssh_cmd[1:])
if build_ret != 0: if build_ret != 0:
return build_ret return build_ret
@ -5505,7 +5505,7 @@ Please submit there instead, or use --nodevelproject to force direct submission.
if opts.keep_pkgs: if opts.keep_pkgs:
ret = rsync_keep_cmd = ['rsync', '-az', '-e', 'ssh', "%s:%s" % (hostname, hostkeep), opts.keep_pkgs] ret = rsync_keep_cmd = ['rsync', '-az', '-e', 'ssh', "%s:%s" % (hostname, hostkeep), opts.keep_pkgs]
print 'Run: %s' % " ".join(rsync_keep_cmd) print 'Run: %s' % " ".join(rsync_keep_cmd)
ret = subprocess.call(rsync_keep_cmd) ret = run_external(rsync_keep_cmd[0], *rsync_keep_cmd[1:])
if ret != 0: if ret != 0:
return ret return ret
@ -7308,14 +7308,14 @@ Please submit there instead, or use --nodevelproject to force direct submission.
continue continue
o = open(os.path.join(destdir, name), 'wb') o = open(os.path.join(destdir, name), 'wb')
code = subprocess.call(['diff3', '-m', '-E', code = run_external('diff3', '-m', '-E',
'-L', '.mine', '-L', '.mine',
os.path.join(destdir, name + '.mine'), os.path.join(destdir, name + '.mine'),
'-L', '.old', '-L', '.old',
os.path.join(destdir, name + '.old'), os.path.join(destdir, name + '.old'),
'-L', '.new', '-L', '.new',
os.path.join(destdir, name + '.new'), os.path.join(destdir, name + '.new'),
], stdout=o) stdout=o)
if code == 0: if code == 0:
print statfrmt('G', name) print statfrmt('G', name)
os.unlink(os.path.join(destdir, name + '.mine')) os.unlink(os.path.join(destdir, name + '.mine'))
@ -7436,11 +7436,11 @@ Please submit there instead, or use --nodevelproject to force direct submission.
continue continue
o = open(name, 'wb') o = open(name, 'wb')
code = subprocess.call(['diff3', '-m', '-E', code = run_external('diff3', '-m', '-E',
'-L', '.mine', name + '.mine', '-L', '.mine', name + '.mine',
'-L', '.old', name + '.old', '-L', '.old', name + '.old',
'-L', '.new', name + '.new', '-L', '.new', name + '.new',
], stdout=o) stdout=o)
if code == 0: if code == 0:
print statfrmt('G', name) print statfrmt('G', name)
os.unlink(name + '.mine') os.unlink(name + '.mine')

View File

@ -24,6 +24,7 @@ import conf
import subprocess import subprocess
import re import re
import socket import socket
import errno
try: try:
from xml.etree import cElementTree as ET from xml.etree import cElementTree as ET
except ImportError: except ImportError:
@ -361,10 +362,10 @@ class Serviceinfo:
name = call.split(None, 1)[0] name = call.split(None, 1)[0]
if not os.path.exists("/usr/lib/obs/service/"+name): if not os.path.exists("/usr/lib/obs/service/"+name):
raise oscerr.PackageNotInstalled("obs-service-"+name) raise oscerr.PackageNotInstalled("obs-service-"+name)
c = "/usr/lib/obs/service/" + call + " --outdir " + temp_dir cmd = "/usr/lib/obs/service/" + call + " --outdir " + temp_dir
if conf.config['verbose'] > 1 or verbose: if conf.config['verbose'] > 1 or verbose:
print "Run source service:", c print "Run source service:", cmd
r = subprocess.call(c, shell=True) r = run_external(cmd, shell=True)
if r != 0: if r != 0:
print "Aborting: service call failed: " + c print "Aborting: service call failed: " + c
@ -1458,8 +1459,7 @@ class Package:
# try merging # try merging
# diff3 OPTIONS... MINE OLDER YOURS # diff3 OPTIONS... MINE OLDER YOURS
merge_cmd = 'diff3 -m -E %s %s %s > %s' % (myfilename, storefilename, upfilename, filename) merge_cmd = 'diff3 -m -E %s %s %s > %s' % (myfilename, storefilename, upfilename, filename)
# we would rather use the subprocess module, but it is not availablebefore 2.4 ret = run_external(merge_cmd, shell=True)
ret = subprocess.call(merge_cmd, shell=True)
# "An exit status of 0 means `diff3' was successful, 1 means some # "An exit status of 0 means `diff3' was successful, 1 means some
# conflicts were found, and 2 means trouble." # conflicts were found, and 2 means trouble."
@ -3443,10 +3443,7 @@ def run_pager(message, tmp_suffix=''):
tmpfile.flush() tmpfile.flush()
pager = os.getenv('PAGER', default=get_default_pager()) pager = os.getenv('PAGER', default=get_default_pager())
try: try:
try: run_external(pager, tmpfile.name)
subprocess.call('%s %s' % (pager, tmpfile.name), shell=True)
except OSError, e:
raise oscerr.ExtRuntimeError('cannot run pager \'%s\': %s' % (pager, e.strerror), pager)
finally: finally:
tmpfile.close() tmpfile.close()
@ -3454,10 +3451,7 @@ def run_editor(filename):
editor = os.getenv('EDITOR', default=get_default_editor()) editor = os.getenv('EDITOR', default=get_default_editor())
cmd = editor.split(' ') cmd = editor.split(' ')
cmd.append(filename) cmd.append(filename)
try: return run_external(cmd[0], *cmd[1:])
return subprocess.call(cmd)
except OSError, e:
raise oscerr.ExtRuntimeError('cannot run editor \'%s\': %s' % (editor, e.strerror), editor)
def edit_message(footer='', template='', templatelen=30): def edit_message(footer='', template='', templatelen=30):
delim = '--This line, and those below, will be ignored--\n' delim = '--This line, and those below, will be ignored--\n'
@ -5836,7 +5830,7 @@ def unpack_srcrpm(srpm, dir, *files):
if os.path.isdir(dir): if os.path.isdir(dir):
os.chdir(dir) os.chdir(dir)
cmd = 'rpm2cpio %s | cpio -i %s &> /dev/null' % (srpm, ' '.join(files)) cmd = 'rpm2cpio %s | cpio -i %s &> /dev/null' % (srpm, ' '.join(files))
ret = subprocess.call(cmd, shell=True) ret = run_external(cmd, shell=True)
if ret != 0: if ret != 0:
print >>sys.stderr, 'error \'%s\' - cannot extract \'%s\'' % (ret, srpm) print >>sys.stderr, 'error \'%s\' - cannot extract \'%s\'' % (ret, srpm)
sys.exit(1) sys.exit(1)
@ -6413,7 +6407,7 @@ def request_interactive_review(apiurl, request, initial_cmd='', group=None, igno
def edit_submitrequest(apiurl, project, orequest, new_request=None): def edit_submitrequest(apiurl, project, orequest, new_request=None):
"""edit a submit action from orequest/new_request""" """edit a submit action from orequest/new_request"""
import tempfile, shutil, subprocess import tempfile, shutil
actions = orequest.get_actions('submit') actions = orequest.get_actions('submit')
oactions = actions oactions = actions
if not orequest is None: if not orequest is None:
@ -6446,7 +6440,7 @@ def edit_submitrequest(apiurl, project, orequest, new_request=None):
os.chdir(tmpdir) os.chdir(tmpdir)
print 'Checked out package \'%s\' to %s. Started a new shell (%s).\n' \ print 'Checked out package \'%s\' to %s. Started a new shell (%s).\n' \
'Please fix the package and close the shell afterwards.' % (package, tmpdir, shell) 'Please fix the package and close the shell afterwards.' % (package, tmpdir, shell)
subprocess.call(shell) run_external(shell)
# the pkg might have uncommitted changes... # the pkg might have uncommitted changes...
cleanup = False cleanup = False
os.chdir(olddir) os.chdir(olddir)
@ -6529,6 +6523,31 @@ def raw_input(*args):
# interpret ctrl-d as user abort # interpret ctrl-d as user abort
raise oscerr.UserAbort() raise oscerr.UserAbort()
def run_external(filename, *args, **kwargs):
"""Executes the program filename via subprocess.call.
*args are additional arguments which are passed to the
program filename. **kwargs specify additional arguments for
the subprocess.call function.
if no args are specified the plain filename is passed
to subprocess.call (this can be used to execute a shell
command). Otherwise [filename] + list(args) is passed
to the subprocess.call function.
"""
# unless explicitly specified use shell=False
kwargs.setdefault('shell', False)
if args:
cmd = [filename] + list(args)
else:
cmd = filename
try:
return subprocess.call(cmd, **kwargs)
except OSError, e:
if e.errno != errno.ENOENT:
raise
raise oscerr.ExtRuntimeError(e.strerror, filename)
# backward compatibility: local role filtering # backward compatibility: local role filtering
def filter_role(meta, user, role): def filter_role(meta, user, role):
""" """