[scm-wrapper] Use context manager for managing temp dir
This is a sure way to have it removed, without having to duplicate the logic in all places where it is used. Signed-off-by: Lubomír Sedlář <lsedlar@redhat.com>
This commit is contained in:
parent
6daf43f72e
commit
3ac7148b38
@ -22,6 +22,7 @@ import shutil
|
|||||||
import pipes
|
import pipes
|
||||||
import glob
|
import glob
|
||||||
import time
|
import time
|
||||||
|
import contextlib
|
||||||
|
|
||||||
import kobo.log
|
import kobo.log
|
||||||
from kobo.shortcuts import run, force_list
|
from kobo.shortcuts import run, force_list
|
||||||
@ -32,17 +33,19 @@ class ScmBase(kobo.log.LoggingBase):
|
|||||||
def __init__(self, logger=None):
|
def __init__(self, logger=None):
|
||||||
kobo.log.LoggingBase.__init__(self, logger=logger)
|
kobo.log.LoggingBase.__init__(self, logger=logger)
|
||||||
|
|
||||||
def _create_temp_dir(self, tmp_dir=None):
|
@contextlib.contextmanager
|
||||||
|
def _temp_dir(self, tmp_dir=None):
|
||||||
if tmp_dir is not None:
|
if tmp_dir is not None:
|
||||||
makedirs(tmp_dir)
|
makedirs(tmp_dir)
|
||||||
return tempfile.mkdtemp(prefix="cvswrapper_", dir=tmp_dir)
|
path = tempfile.mkdtemp(prefix="cvswrapper_", dir=tmp_dir)
|
||||||
|
|
||||||
def _delete_temp_dir(self, tmp_dir):
|
yield path
|
||||||
self.log_debug("Removing %s" % tmp_dir)
|
|
||||||
|
self.log_debug("Removing %s" % path)
|
||||||
try:
|
try:
|
||||||
shutil.rmtree(tmp_dir)
|
shutil.rmtree(path)
|
||||||
except OSError as ex:
|
except OSError as ex:
|
||||||
self.log_warning("Error removing %s: %s" % (tmp_dir, ex))
|
self.log_warning("Error removing %s: %s" % (path, ex))
|
||||||
|
|
||||||
def export_file(self, scm_root, scm_file, target_dir, scm_branch=None, tmp_dir=None, log_file=None):
|
def export_file(self, scm_root, scm_file, target_dir, scm_branch=None, tmp_dir=None, log_file=None):
|
||||||
raise NotImplemented
|
raise NotImplemented
|
||||||
@ -89,68 +92,71 @@ class CvsWrapper(ScmBase):
|
|||||||
def export_dir(self, scm_root, scm_dir, target_dir, scm_branch=None, tmp_dir=None, log_file=None):
|
def export_dir(self, scm_root, scm_dir, target_dir, scm_branch=None, tmp_dir=None, log_file=None):
|
||||||
scm_dir = scm_dir.lstrip("/")
|
scm_dir = scm_dir.lstrip("/")
|
||||||
scm_branch = scm_branch or "HEAD"
|
scm_branch = scm_branch or "HEAD"
|
||||||
tmp_dir = self._create_temp_dir(tmp_dir=tmp_dir)
|
with self._temp_dir(tmp_dir=tmp_dir) as tmp_dir:
|
||||||
|
self.log_debug("Exporting directory %s from CVS %s (branch %s)..."
|
||||||
self.log_debug("Exporting directory %s from CVS %s (branch %s)..." % (scm_dir, scm_root, scm_branch))
|
% (scm_dir, scm_root, scm_branch))
|
||||||
self.retry_run(["/usr/bin/cvs", "-q", "-d", scm_root, "export", "-r", scm_branch, scm_dir], workdir=tmp_dir, show_cmd=True, logfile=log_file)
|
self.retry_run(["/usr/bin/cvs", "-q", "-d", scm_root, "export", "-r", scm_branch, scm_dir],
|
||||||
_copy_all(os.path.join(tmp_dir, scm_dir), target_dir)
|
workdir=tmp_dir, show_cmd=True, logfile=log_file)
|
||||||
self._delete_temp_dir(tmp_dir)
|
_copy_all(os.path.join(tmp_dir, scm_dir), target_dir)
|
||||||
|
|
||||||
def export_file(self, scm_root, scm_file, target_dir, scm_branch=None, tmp_dir=None, log_file=None):
|
def export_file(self, scm_root, scm_file, target_dir, scm_branch=None, tmp_dir=None, log_file=None):
|
||||||
scm_file = scm_file.lstrip("/")
|
scm_file = scm_file.lstrip("/")
|
||||||
scm_branch = scm_branch or "HEAD"
|
scm_branch = scm_branch or "HEAD"
|
||||||
tmp_dir = self._create_temp_dir(tmp_dir=tmp_dir)
|
with self._temp_dir(tmp_dir=tmp_dir) as tmp_dir:
|
||||||
|
target_path = os.path.join(target_dir, os.path.basename(scm_file))
|
||||||
|
self.log_debug("Exporting file %s from CVS %s (branch %s)..." % (scm_file, scm_root, scm_branch))
|
||||||
|
self.retry_run(["/usr/bin/cvs", "-q", "-d", scm_root, "export", "-r", scm_branch, scm_file],
|
||||||
|
workdir=tmp_dir, show_cmd=True, logfile=log_file)
|
||||||
|
|
||||||
target_path = os.path.join(target_dir, os.path.basename(scm_file))
|
makedirs(target_dir)
|
||||||
self.log_debug("Exporting file %s from CVS %s (branch %s)..." % (scm_file, scm_root, scm_branch))
|
shutil.copy2(os.path.join(tmp_dir, scm_file), target_path)
|
||||||
self.retry_run(["/usr/bin/cvs", "-q", "-d", scm_root, "export", "-r", scm_branch, scm_file], workdir=tmp_dir, show_cmd=True, logfile=log_file)
|
|
||||||
|
|
||||||
makedirs(target_dir)
|
|
||||||
shutil.copy2(os.path.join(tmp_dir, scm_file), target_path)
|
|
||||||
self._delete_temp_dir(tmp_dir)
|
|
||||||
|
|
||||||
|
|
||||||
class GitWrapper(ScmBase):
|
class GitWrapper(ScmBase):
|
||||||
def export_dir(self, scm_root, scm_dir, target_dir, scm_branch=None, tmp_dir=None, log_file=None):
|
def export_dir(self, scm_root, scm_dir, target_dir, scm_branch=None, tmp_dir=None, log_file=None):
|
||||||
scm_dir = scm_dir.lstrip("/")
|
scm_dir = scm_dir.lstrip("/")
|
||||||
scm_branch = scm_branch or "master"
|
scm_branch = scm_branch or "master"
|
||||||
tmp_dir = self._create_temp_dir(tmp_dir=tmp_dir)
|
|
||||||
|
|
||||||
if "://" not in scm_root:
|
with self._temp_dir(tmp_dir=tmp_dir) as tmp_dir:
|
||||||
scm_root = "file://%s" % scm_root
|
if "://" not in scm_root:
|
||||||
|
scm_root = "file://%s" % scm_root
|
||||||
|
|
||||||
self.log_debug("Exporting directory %s from git %s (branch %s)..." % (scm_dir, scm_root, scm_branch))
|
self.log_debug("Exporting directory %s from git %s (branch %s)..."
|
||||||
cmd = "/usr/bin/git archive --remote=%s %s %s | tar xf -" % (pipes.quote(scm_root), pipes.quote(scm_branch), pipes.quote(scm_dir))
|
% (scm_dir, scm_root, scm_branch))
|
||||||
# git archive is not supported by http/https
|
cmd = ("/usr/bin/git archive --remote=%s %s %s | tar xf -"
|
||||||
# or by smart http https://git-scm.com/book/en/v2/Git-on-the-Server-Smart-HTTP
|
% (pipes.quote(scm_root), pipes.quote(scm_branch), pipes.quote(scm_dir)))
|
||||||
if scm_root.startswith("http"):
|
# git archive is not supported by http/https
|
||||||
cmd = "/usr/bin/git clone --depth 1 --branch=%s %s %s" % (pipes.quote(scm_branch), pipes.quote(scm_root), pipes.quote(tmp_dir))
|
# or by smart http https://git-scm.com/book/en/v2/Git-on-the-Server-Smart-HTTP
|
||||||
self.retry_run(cmd, workdir=tmp_dir, show_cmd=True, logfile=log_file)
|
if scm_root.startswith("http"):
|
||||||
|
cmd = ("/usr/bin/git clone --depth 1 --branch=%s %s %s"
|
||||||
|
% (pipes.quote(scm_branch), pipes.quote(scm_root), pipes.quote(tmp_dir)))
|
||||||
|
self.retry_run(cmd, workdir=tmp_dir, show_cmd=True, logfile=log_file)
|
||||||
|
|
||||||
_copy_all(os.path.join(tmp_dir, scm_dir), target_dir)
|
_copy_all(os.path.join(tmp_dir, scm_dir), target_dir)
|
||||||
self._delete_temp_dir(tmp_dir)
|
|
||||||
|
|
||||||
def export_file(self, scm_root, scm_file, target_dir, scm_branch=None, tmp_dir=None, log_file=None):
|
def export_file(self, scm_root, scm_file, target_dir, scm_branch=None, tmp_dir=None, log_file=None):
|
||||||
scm_file = scm_file.lstrip("/")
|
scm_file = scm_file.lstrip("/")
|
||||||
scm_branch = scm_branch or "master"
|
scm_branch = scm_branch or "master"
|
||||||
tmp_dir = self._create_temp_dir(tmp_dir=tmp_dir)
|
|
||||||
|
|
||||||
target_path = os.path.join(target_dir, os.path.basename(scm_file))
|
with self._temp_dir(tmp_dir=tmp_dir) as tmp_dir:
|
||||||
|
target_path = os.path.join(target_dir, os.path.basename(scm_file))
|
||||||
|
|
||||||
if "://" not in scm_root:
|
if "://" not in scm_root:
|
||||||
scm_root = "file://%s" % scm_root
|
scm_root = "file://%s" % scm_root
|
||||||
|
|
||||||
self.log_debug("Exporting file %s from git %s (branch %s)..." % (scm_file, scm_root, scm_branch))
|
self.log_debug("Exporting file %s from git %s (branch %s)..."
|
||||||
cmd = "/usr/bin/git archive --remote=%s %s %s | tar xf -" % (pipes.quote(scm_root), pipes.quote(scm_branch), pipes.quote(scm_file))
|
% (scm_file, scm_root, scm_branch))
|
||||||
# git archive is not supported by http/https
|
cmd = ("/usr/bin/git archive --remote=%s %s %s | tar xf -"
|
||||||
# or by smart http https://git-scm.com/book/en/v2/Git-on-the-Server-Smart-HTTP
|
% (pipes.quote(scm_root), pipes.quote(scm_branch), pipes.quote(scm_file)))
|
||||||
if scm_root.startswith("http"):
|
# git archive is not supported by http/https
|
||||||
cmd = "/usr/bin/git clone --depth 1 --branch=%s %s %s" % (pipes.quote(scm_branch), pipes.quote(scm_root), pipes.quote(tmp_dir))
|
# or by smart http https://git-scm.com/book/en/v2/Git-on-the-Server-Smart-HTTP
|
||||||
self.retry_run(cmd, workdir=tmp_dir, show_cmd=True, logfile=log_file)
|
if scm_root.startswith("http"):
|
||||||
|
cmd = ("/usr/bin/git clone --depth 1 --branch=%s %s %s"
|
||||||
|
% (pipes.quote(scm_branch), pipes.quote(scm_root), pipes.quote(tmp_dir)))
|
||||||
|
self.retry_run(cmd, workdir=tmp_dir, show_cmd=True, logfile=log_file)
|
||||||
|
|
||||||
makedirs(target_dir)
|
makedirs(target_dir)
|
||||||
shutil.copy2(os.path.join(tmp_dir, scm_file), target_path)
|
shutil.copy2(os.path.join(tmp_dir, scm_file), target_path)
|
||||||
self._delete_temp_dir(tmp_dir)
|
|
||||||
|
|
||||||
|
|
||||||
class RpmScmWrapper(ScmBase):
|
class RpmScmWrapper(ScmBase):
|
||||||
@ -162,31 +168,29 @@ class RpmScmWrapper(ScmBase):
|
|||||||
def export_dir(self, scm_root, scm_dir, target_dir, scm_branch=None, tmp_dir=None, log_file=None):
|
def export_dir(self, scm_root, scm_dir, target_dir, scm_branch=None, tmp_dir=None, log_file=None):
|
||||||
for rpm in self._list_rpms(scm_root):
|
for rpm in self._list_rpms(scm_root):
|
||||||
scm_dir = scm_dir.lstrip("/")
|
scm_dir = scm_dir.lstrip("/")
|
||||||
tmp_dir = self._create_temp_dir(tmp_dir=tmp_dir)
|
with self._temp_dir(tmp_dir=tmp_dir) as tmp_dir:
|
||||||
self.log_debug("Extracting directory %s from RPM package %s..." % (scm_dir, rpm))
|
self.log_debug("Extracting directory %s from RPM package %s..." % (scm_dir, rpm))
|
||||||
explode_rpm_package(rpm, tmp_dir)
|
explode_rpm_package(rpm, tmp_dir)
|
||||||
|
|
||||||
makedirs(target_dir)
|
makedirs(target_dir)
|
||||||
# "dir" includes the whole directory while "dir/" includes it's content
|
# "dir" includes the whole directory while "dir/" includes it's content
|
||||||
if scm_dir.endswith("/"):
|
if scm_dir.endswith("/"):
|
||||||
_copy_all(os.path.join(tmp_dir, scm_dir), target_dir)
|
_copy_all(os.path.join(tmp_dir, scm_dir), target_dir)
|
||||||
else:
|
else:
|
||||||
run("cp -a %s %s/" % (pipes.quote(os.path.join(tmp_dir, scm_dir)), pipes.quote(target_dir)))
|
run("cp -a %s %s/" % (pipes.quote(os.path.join(tmp_dir, scm_dir)),
|
||||||
self._delete_temp_dir(tmp_dir)
|
pipes.quote(target_dir)))
|
||||||
|
|
||||||
def export_file(self, scm_root, scm_file, target_dir, scm_branch=None, tmp_dir=None, log_file=None):
|
def export_file(self, scm_root, scm_file, target_dir, scm_branch=None, tmp_dir=None, log_file=None):
|
||||||
for rpm in self._list_rpms(scm_root):
|
for rpm in self._list_rpms(scm_root):
|
||||||
scm_file = scm_file.lstrip("/")
|
scm_file = scm_file.lstrip("/")
|
||||||
tmp_dir = self._create_temp_dir(tmp_dir=tmp_dir)
|
with self._temp_dir(tmp_dir=tmp_dir) as tmp_dir:
|
||||||
|
self.log_debug("Exporting file %s from RPM file %s..." % (scm_file, rpm))
|
||||||
|
explode_rpm_package(rpm, tmp_dir)
|
||||||
|
|
||||||
self.log_debug("Exporting file %s from RPM file %s..." % (scm_file, rpm))
|
makedirs(target_dir)
|
||||||
explode_rpm_package(rpm, tmp_dir)
|
for src in glob.glob(os.path.join(tmp_dir, scm_file)):
|
||||||
|
dst = os.path.join(target_dir, os.path.basename(src))
|
||||||
makedirs(target_dir)
|
shutil.copy2(src, dst)
|
||||||
for src in glob.glob(os.path.join(tmp_dir, scm_file)):
|
|
||||||
dst = os.path.join(target_dir, os.path.basename(src))
|
|
||||||
shutil.copy2(src, dst)
|
|
||||||
self._delete_temp_dir(tmp_dir)
|
|
||||||
|
|
||||||
|
|
||||||
def _get_wrapper(scm_type, *args, **kwargs):
|
def _get_wrapper(scm_type, *args, **kwargs):
|
||||||
|
Loading…
Reference in New Issue
Block a user