Add --installpkgs argument (#1272222)
Recently, Fedora has been trying to do a 3 product split. As part of
that, lorax was changed to do "installpkg lorax-product-*" via
provides.
I think that approach is awkward; a much simpler approach is to simply
specify the product package as input to lorax on the command line, via
external rel-eng scripts.
This patch therefore adds --installpkgs (and we should probably add an
option to remove the implicit lorax-product-* glob).
(cherry picked from commit 52d962d613
)
Resolves: rhbz#1272222
This commit is contained in:
parent
5da9f5c179
commit
7c4d7b0c42
@ -143,6 +143,7 @@ class Lorax(BaseLoraxClass):
|
|||||||
def run(self, ybo, product, version, release, variant="", bugurl="",
|
def run(self, ybo, product, version, release, variant="", bugurl="",
|
||||||
isfinal=False, workdir=None, outputdir=None, buildarch=None, volid=None,
|
isfinal=False, workdir=None, outputdir=None, buildarch=None, volid=None,
|
||||||
domacboot=False, doupgrade=True, remove_temp=False,
|
domacboot=False, doupgrade=True, remove_temp=False,
|
||||||
|
installpkgs=None,
|
||||||
size=2,
|
size=2,
|
||||||
add_templates=None,
|
add_templates=None,
|
||||||
add_template_vars=None,
|
add_template_vars=None,
|
||||||
@ -152,6 +153,8 @@ class Lorax(BaseLoraxClass):
|
|||||||
|
|
||||||
assert self._configured
|
assert self._configured
|
||||||
|
|
||||||
|
installpkgs = installpkgs or []
|
||||||
|
|
||||||
# get lorax version
|
# get lorax version
|
||||||
try:
|
try:
|
||||||
import pylorax.version
|
import pylorax.version
|
||||||
@ -247,6 +250,7 @@ class Lorax(BaseLoraxClass):
|
|||||||
# NOTE: rb.root = ybo.conf.installroot (== self.inroot)
|
# NOTE: rb.root = ybo.conf.installroot (== self.inroot)
|
||||||
rb = RuntimeBuilder(product=self.product, arch=self.arch,
|
rb = RuntimeBuilder(product=self.product, arch=self.arch,
|
||||||
yum=ybo, templatedir=templatedir,
|
yum=ybo, templatedir=templatedir,
|
||||||
|
installpkgs=installpkgs,
|
||||||
add_templates=add_templates,
|
add_templates=add_templates,
|
||||||
add_template_vars=add_template_vars)
|
add_template_vars=add_template_vars)
|
||||||
|
|
||||||
|
@ -68,6 +68,7 @@ def generate_module_info(moddir, outfile=None):
|
|||||||
class RuntimeBuilder(object):
|
class RuntimeBuilder(object):
|
||||||
'''Builds the anaconda runtime image.'''
|
'''Builds the anaconda runtime image.'''
|
||||||
def __init__(self, product, arch, yum, templatedir=None,
|
def __init__(self, product, arch, yum, templatedir=None,
|
||||||
|
installpkgs=None,
|
||||||
add_templates=None,
|
add_templates=None,
|
||||||
add_template_vars=None):
|
add_template_vars=None):
|
||||||
root = yum.conf.installroot
|
root = yum.conf.installroot
|
||||||
@ -81,6 +82,7 @@ class RuntimeBuilder(object):
|
|||||||
yum=yum, templatedir=templatedir)
|
yum=yum, templatedir=templatedir)
|
||||||
self.add_templates = add_templates or []
|
self.add_templates = add_templates or []
|
||||||
self.add_template_vars = add_template_vars or {}
|
self.add_template_vars = add_template_vars or {}
|
||||||
|
self._installpkgs = installpkgs or []
|
||||||
self._runner.defaults = self.vars
|
self._runner.defaults = self.vars
|
||||||
|
|
||||||
def _install_branding(self):
|
def _install_branding(self):
|
||||||
@ -107,6 +109,8 @@ class RuntimeBuilder(object):
|
|||||||
def install(self):
|
def install(self):
|
||||||
'''Install packages and do initial setup with runtime-install.tmpl'''
|
'''Install packages and do initial setup with runtime-install.tmpl'''
|
||||||
self._install_branding()
|
self._install_branding()
|
||||||
|
if len(self._installpkgs) > 0:
|
||||||
|
self._runner.installpkg(*self._installpkgs)
|
||||||
self._runner.run("runtime-install.tmpl")
|
self._runner.run("runtime-install.tmpl")
|
||||||
for tmpl in self.add_templates:
|
for tmpl in self.add_templates:
|
||||||
self._runner.run(tmpl, **self.add_template_vars)
|
self._runner.run(tmpl, **self.add_template_vars)
|
||||||
|
@ -119,6 +119,9 @@ def main(args):
|
|||||||
optional.add_option("-e", "--excludepkgs", default=[],
|
optional.add_option("-e", "--excludepkgs", default=[],
|
||||||
action="append", metavar="STRING",
|
action="append", metavar="STRING",
|
||||||
help="package glob to exclude (may be listed multiple times)")
|
help="package glob to exclude (may be listed multiple times)")
|
||||||
|
optional.add_option("-i", "--installpkgs", default=[],
|
||||||
|
action="append", metavar="STRING",
|
||||||
|
help="package glob to install before runtime-install.tmpl runs. (may be listed multiple times)")
|
||||||
optional.add_option("--buildarch", default=None,
|
optional.add_option("--buildarch", default=None,
|
||||||
help="build architecture", metavar="STRING")
|
help="build architecture", metavar="STRING")
|
||||||
optional.add_option("--volid", default=None,
|
optional.add_option("--volid", default=None,
|
||||||
@ -218,6 +221,7 @@ def main(args):
|
|||||||
opts.variant, opts.bugurl, opts.isfinal,
|
opts.variant, opts.bugurl, opts.isfinal,
|
||||||
workdir=tempdir, outputdir=outputdir, buildarch=opts.buildarch,
|
workdir=tempdir, outputdir=outputdir, buildarch=opts.buildarch,
|
||||||
volid=opts.volid, domacboot=opts.domacboot, doupgrade=opts.doupgrade,
|
volid=opts.volid, domacboot=opts.domacboot, doupgrade=opts.doupgrade,
|
||||||
|
installpkgs=opts.installpkgs,
|
||||||
add_templates=opts.add_templates,
|
add_templates=opts.add_templates,
|
||||||
add_template_vars=parsed_add_template_vars,
|
add_template_vars=parsed_add_template_vars,
|
||||||
add_arch_templates=opts.add_arch_templates,
|
add_arch_templates=opts.add_arch_templates,
|
||||||
|
Loading…
Reference in New Issue
Block a user