Support re-using existing destdirs better, with a --force option.

This commit is contained in:
Jesse Keating 2007-12-02 14:31:26 -05:00 committed by Jesse Keating
parent aef1db89aa
commit 6748133646
6 changed files with 49 additions and 11 deletions

View File

@ -1,3 +1,7 @@
* Sun Dec 02 Jesse Keating <jkeating@redhat.com>
- Add a --force option to reuse an existing destdir
- Only overwrite dirs if --force is offered, clean out some specific dirs
* Fri Nov 30 2007 Jesse Keating <jkeating@redhat.com> * Fri Nov 30 2007 Jesse Keating <jkeating@redhat.com>
- Only check for root if you're doing root level tasks (buildinstall) - Only check for root if you're doing root level tasks (buildinstall)

View File

@ -18,7 +18,7 @@ Display program's version number and then quit\&.
.IP "\fB\-\-name=string\fP" .IP "\fB\-\-name=string\fP"
Set the name for your distribution (defaults to "Fedora")\&. Set the name for your distribution (defaults to "Fedora")\&.
.IP "\fB\-\-ver=string\fP" .IP "\fB\-\-ver=string\fP"
Set the version for your distribution (defaults to datestamp)\&. Set the version for your distribution (defaults to datestamp, used for $releasever in yum)\&.
.IP "\fB\-\-flavor=string\fP" .IP "\fB\-\-flavor=string\fP"
Set the flavor of your spin (optional)\&. Set the flavor of your spin (optional)\&.
.IP "\fB\-\-destdir=pathspec\fP" .IP "\fB\-\-destdir=pathspec\fP"
@ -34,6 +34,8 @@ Disable gathering of source packages (optional)\&.
.IP "\fB\-\-nosplitmedia\fP" .IP "\fB\-\-nosplitmedia\fP"
Disable creation of split media (optional)\&. Disable creation of split media (optional)\&.
.IP "\fB\-\-sourceisos\fP" .IP "\fB\-\-sourceisos\fP"
Force reuse of an existing destination directory (will overwrite files)\&.
.IP "\fB\-\-force\fP"
Create the source media images (other arch runs must be done)\&. Create the source media images (other arch runs must be done)\&.
.IP "\fB\-c ksfile, \-\-config=ksfile\fP" .IP "\fB\-c ksfile, \-\-config=ksfile\fP"
Path to kickstart configuration file\&. Path to kickstart configuration file\&.

6
pungi
View File

@ -41,6 +41,8 @@ def main():
for part in ksparser.handler.partition.partitions: for part in ksparser.handler.partition.partitions:
if part.mountpoint == 'iso': if part.mountpoint == 'iso':
config.set('default', 'cdsize', str(part.size)) config.set('default', 'cdsize', str(part.size))
config.set('default', 'force', opts.force)
# Set up our directories # Set up our directories
if not os.path.exists(config.get('default', 'destdir')): if not os.path.exists(config.get('default', 'destdir')):
@ -49,6 +51,8 @@ def main():
except OSError, e: except OSError, e:
print >> sys.stderr, "Error: Cannot create destination dir %s" % config.get('default', 'destdir') print >> sys.stderr, "Error: Cannot create destination dir %s" % config.get('default', 'destdir')
sys.exit(1) sys.exit(1)
else:
print >> sys.stdout, "Warning: Reusing existing destination directory."
cachedir = config.get('default', 'cachedir') cachedir = config.get('default', 'cachedir')
@ -138,6 +142,8 @@ if __name__ == '__main__':
help='disable creation of split media (optional)') help='disable creation of split media (optional)')
parser.add_option("--sourceisos", default=False, action="store_true", dest="sourceisos", parser.add_option("--sourceisos", default=False, action="store_true", dest="sourceisos",
help='Create the source isos (other arch runs must be done)') help='Create the source isos (other arch runs must be done)')
parser.add_option("--force", default=False, action="store_true",
help='Force reuse of an existing destination directory (will overwrite files)')
parser.add_option("-c", "--config", dest="config", parser.add_option("-c", "--config", dest="config",
help='Path to kickstart config file') help='Path to kickstart config file')

View File

@ -16,6 +16,7 @@ import logging
import os import os
import subprocess import subprocess
import shutil import shutil
import sys
class PungiBase(object): class PungiBase(object):
"""The base Pungi class. Set up config items and logging here""" """The base Pungi class. Set up config items and logging here"""
@ -37,8 +38,7 @@ class PungiBase(object):
logdir = os.path.join(self.config.get('default', 'destdir'), 'logs') logdir = os.path.join(self.config.get('default', 'destdir'), 'logs')
if not os.path.exists(logdir): _ensuredir(logdir, force=True) # Always allow logs to be written out
os.makedirs(logdir)
if self.config.get('default', 'flavor'): if self.config.get('default', 'flavor'):
logfile = os.path.join(logdir, '%s.%s.log' % (self.config.get('default', 'flavor'), logfile = os.path.join(logdir, '%s.%s.log' % (self.config.get('default', 'flavor'),
@ -85,3 +85,25 @@ def _link(local, target, force=False):
# Can't hardlink cross file systems # Can't hardlink cross file systems
shutil.copy2(local, target) shutil.copy2(local, target)
def _ensuredir(target, force=False, clean=False):
"""Ensure that a directory exists, if it already exists, only continue
if force is set."""
def whoops(func, path, exc_info):
self.logger.error('Could not remove %s' % path)
sys.exit(1)
if os.path.exists(target) and not os.path.isdir(target):
self.logger.error('%s exists but is not a directory.' % target)
sys.exit(1)
if not os.path.isdir(target):
os.makedirs(target)
elif force and clean:
shutil.rmtree(target, onerror=whoops)
os.makedirs(target)
elif force:
return
else:
self.logger.error('Directory %s already exists. Use --force to overwrite.' % target)
sys.exit(1)

View File

@ -46,6 +46,7 @@ class PungiYum(yum.YumBase):
logfile = os.path.join(logdir, '%s.log' % (self.pungiconfig.get('default', 'arch'))) logfile = os.path.join(logdir, '%s.log' % (self.pungiconfig.get('default', 'arch')))
yum.logging.basicConfig(level=yum.logging.DEBUG, filename=logfile) yum.logging.basicConfig(level=yum.logging.DEBUG, filename=logfile)
self.logger.error('foobar')
def doFileLogSetup(self, uid, logfile): def doFileLogSetup(self, uid, logfile):
# This function overrides a yum function, allowing pungi to control # This function overrides a yum function, allowing pungi to control
@ -320,8 +321,8 @@ class Gather(pypungi.PungiBase):
self.config.get('default', 'flavor'), self.config.get('default', 'flavor'),
relpkgdir) relpkgdir)
if not os.path.exists(pkgdir): # Ensure the pkgdir exists, force if requested, and make sure we clean it out
os.makedirs(pkgdir) pypungi._ensuredir(pkgdir, force=self.config.getbool('default', 'force'), clean=True)
probs = self.ayum.downloadPkgs(polist) probs = self.ayum.downloadPkgs(polist)

View File

@ -44,8 +44,7 @@ class Pungi(pypungi.PungiBase):
self.topdir = os.path.join(self.archdir, 'os') self.topdir = os.path.join(self.archdir, 'os')
self.isodir = os.path.join(self.archdir, self.config.get('default','isodir')) self.isodir = os.path.join(self.archdir, self.config.get('default','isodir'))
if not os.path.exists(self.workdir): pypungi._ensuredir(workdir, force=self.config.getbool('default', 'force'))
os.makedirs(self.workdir)
self.common_files = [] self.common_files = []
self.infofile = os.path.join(self.config.get('default', 'destdir'), self.infofile = os.path.join(self.config.get('default', 'destdir'),
@ -174,7 +173,7 @@ class Pungi(pypungi.PungiBase):
for pattern in self.config.get('default', 'relnotedirre').split(): for pattern in self.config.get('default', 'relnotedirre').split():
dirres.append(re.compile(pattern)) dirres.append(re.compile(pattern))
os.makedirs(docsdir) pypungi._ensuredir(docsdir, force=self.config.getbool('default', 'force'), clean=True)
# Expload the packages we list as relnote packages # Expload the packages we list as relnote packages
pkgs = os.listdir(os.path.join(self.topdir, self.config.get('default', 'product_path'))) pkgs = os.listdir(os.path.join(self.topdir, self.config.get('default', 'product_path')))
@ -269,7 +268,9 @@ class Pungi(pypungi.PungiBase):
# this is stolen from splittree.py in anaconda-runtime. Blame them if its ugly (: # this is stolen from splittree.py in anaconda-runtime. Blame them if its ugly (:
for i in range(timber.src_list[0], timber.src_list[-1] + 1): for i in range(timber.src_list[0], timber.src_list[-1] + 1):
os.makedirs("%s-disc%d/SRPMS" % (timber.dist_dir, i)) pypungi._ensuredir('%s-disc%d/SRPMS' % (timper.dist_dir, i),
force=self.config.getbool('default', 'force'),
clean=True)
timber.linkFiles(timber.dist_dir, timber.linkFiles(timber.dist_dir,
"%s-disc%d" %(timber.dist_dir, i), "%s-disc%d" %(timber.dist_dir, i),
timber.common_files) timber.common_files)
@ -303,7 +304,8 @@ class Pungi(pypungi.PungiBase):
createrepo.append('--outputdir') createrepo.append('--outputdir')
if self.config.getint('default', 'discs') == 1: if self.config.getint('default', 'discs') == 1:
os.makedirs('%s-disc1' % self.topdir) # rename this for single disc pypungi._ensuredir('%s-disc1', force=self.config.getbool('default', 'force'),
clean=True) # rename this for single disc
createrepo.append('%s-disc1' % self.topdir) createrepo.append('%s-disc1' % self.topdir)
createrepo.append('--basedir') createrepo.append('--basedir')
@ -344,7 +346,8 @@ cost=500
anaruntime = '/usr/lib/anaconda-runtime/boot' anaruntime = '/usr/lib/anaconda-runtime/boot'
discinfofile = os.path.join(self.topdir, '.discinfo') # we use this a fair amount discinfofile = os.path.join(self.topdir, '.discinfo') # we use this a fair amount
os.makedirs(self.isodir) pypungi._ensuredir(self.isodir, force=self.config.getbool('default', 'force'),
clean=True) # This is risky...
# setup the base command # setup the base command
mkisofs = ['/usr/bin/mkisofs'] mkisofs = ['/usr/bin/mkisofs']