mirror of
https://github.com/virt-manager/virt-manager.git
synced 2025-01-27 14:03:57 +03:00
urlfetcher: Make fetcher cleanup idempotent
This commit is contained in:
parent
faa0ef5e55
commit
050d0fb16e
@ -84,7 +84,7 @@ class _ImageFetcher(object):
|
||||
return fn
|
||||
|
||||
def prepareLocation(self):
|
||||
return True
|
||||
pass
|
||||
|
||||
def cleanupLocation(self):
|
||||
pass
|
||||
@ -145,12 +145,12 @@ class _HTTPImageFetcher(_URIImageFetcher):
|
||||
|
||||
|
||||
class _FTPImageFetcher(_URIImageFetcher):
|
||||
def __init__(self, *args, **kwargs):
|
||||
_URIImageFetcher.__init__(self, *args, **kwargs)
|
||||
|
||||
self.ftp = None
|
||||
ftp = None
|
||||
|
||||
def prepareLocation(self):
|
||||
if self.ftp:
|
||||
return
|
||||
|
||||
try:
|
||||
url = urlparse.urlparse(self._make_path(""))
|
||||
if not url[1]:
|
||||
@ -161,6 +161,15 @@ class _FTPImageFetcher(_URIImageFetcher):
|
||||
raise ValueError(_("Opening URL %s failed: %s.") %
|
||||
(self.location, str(e)))
|
||||
|
||||
def cleanupLocation(self):
|
||||
if not self.ftp:
|
||||
return
|
||||
|
||||
try:
|
||||
self.ftp.quit()
|
||||
except:
|
||||
logging.debug("Error quitting ftp connection", exc_info=True)
|
||||
|
||||
|
||||
def hasFile(self, filename):
|
||||
path = self._make_path(filename)
|
||||
@ -197,9 +206,11 @@ class _MountedImageFetcher(_LocalImageFetcher):
|
||||
or loopback mounted file, or local CDROM device
|
||||
"""
|
||||
_in_test_suite = bool("VIRTINST_TEST_SUITE" in os.environ)
|
||||
_mounted = False
|
||||
|
||||
def prepareLocation(self):
|
||||
cmd = None
|
||||
if self._mounted:
|
||||
return
|
||||
|
||||
if self._in_test_suite:
|
||||
self.srcdir = os.environ["VIRTINST_TEST_URL_DIR"]
|
||||
@ -219,18 +230,21 @@ class _MountedImageFetcher(_LocalImageFetcher):
|
||||
cmd = [mountcmd, "-o", mountopt, self.location, self.srcdir]
|
||||
|
||||
logging.debug("mount cmd: %s", cmd)
|
||||
|
||||
if not self._in_test_suite:
|
||||
ret = subprocess.call(cmd)
|
||||
if ret != 0:
|
||||
self.cleanupLocation()
|
||||
raise ValueError(_("Mounting location '%s' failed") %
|
||||
(self.location))
|
||||
return True
|
||||
|
||||
self._mounted = True
|
||||
|
||||
def cleanupLocation(self):
|
||||
logging.debug("Cleaning up mount at " + self.srcdir)
|
||||
if not self._mounted:
|
||||
return
|
||||
|
||||
logging.debug("Cleaning up mount at " + self.srcdir)
|
||||
try:
|
||||
if not self._in_test_suite:
|
||||
cmd = ["/bin/umount", self.srcdir]
|
||||
subprocess.call(cmd)
|
||||
@ -238,6 +252,8 @@ class _MountedImageFetcher(_LocalImageFetcher):
|
||||
os.rmdir(self.srcdir)
|
||||
except:
|
||||
pass
|
||||
finally:
|
||||
self._mounted = False
|
||||
|
||||
|
||||
class _DirectImageFetcher(_LocalImageFetcher):
|
||||
|
Loading…
x
Reference in New Issue
Block a user