Update from upstream #11
@ -15,6 +15,7 @@ CreateIsoOpts = namedtuple(
|
|||||||
"CreateIsoOpts",
|
"CreateIsoOpts",
|
||||||
[
|
[
|
||||||
"buildinstall_method",
|
"buildinstall_method",
|
||||||
|
"boot_iso",
|
||||||
"arch",
|
"arch",
|
||||||
"output_dir",
|
"output_dir",
|
||||||
"jigdo_dir",
|
"jigdo_dir",
|
||||||
@ -26,6 +27,7 @@ CreateIsoOpts = namedtuple(
|
|||||||
"hfs_compat",
|
"hfs_compat",
|
||||||
"use_xorrisofs",
|
"use_xorrisofs",
|
||||||
"iso_level",
|
"iso_level",
|
||||||
|
"script_dir",
|
||||||
],
|
],
|
||||||
)
|
)
|
||||||
CreateIsoOpts.__new__.__defaults__ = (None,) * len(CreateIsoOpts._fields)
|
CreateIsoOpts.__new__.__defaults__ = (None,) * len(CreateIsoOpts._fields)
|
||||||
@ -116,6 +118,27 @@ def make_jigdo(f, opts):
|
|||||||
emit(f, cmd)
|
emit(f, cmd)
|
||||||
|
|
||||||
|
|
||||||
|
def write_xorriso_commands(opts):
|
||||||
|
script = os.path.join(opts.script_dir, "xorriso-%s.txt" % id(opts))
|
||||||
|
with open(script, "w") as f:
|
||||||
|
emit(f, "-indev %s" % opts.boot_iso)
|
||||||
|
emit(f, "-outdev %s" % os.path.join(opts.output_dir, opts.iso_name))
|
||||||
|
emit(f, "-boot_image any replay")
|
||||||
|
emit(f, "-volid %s" % opts.volid)
|
||||||
|
|
||||||
|
with open(opts.graft_points) as gp:
|
||||||
|
for line in gp:
|
||||||
|
iso_path, fs_path = line.strip().split("=", 1)
|
||||||
|
emit(f, "-map %s %s" % (fs_path, iso_path))
|
||||||
|
|
||||||
|
if opts.arch == "ppc64le":
|
||||||
|
# This is needed for the image to be bootable.
|
||||||
|
emit(f, "-as mkisofs -U --")
|
||||||
|
|
||||||
|
emit(f, "-end")
|
||||||
|
return script
|
||||||
|
|
||||||
|
|
||||||
def write_script(opts, f):
|
def write_script(opts, f):
|
||||||
if bool(opts.jigdo_dir) != bool(opts.os_tree):
|
if bool(opts.jigdo_dir) != bool(opts.os_tree):
|
||||||
raise RuntimeError("jigdo_dir must be used together with os_tree")
|
raise RuntimeError("jigdo_dir must be used together with os_tree")
|
||||||
@ -123,8 +146,14 @@ def write_script(opts, f):
|
|||||||
emit(f, "#!/bin/bash")
|
emit(f, "#!/bin/bash")
|
||||||
emit(f, "set -ex")
|
emit(f, "set -ex")
|
||||||
emit(f, "cd %s" % opts.output_dir)
|
emit(f, "cd %s" % opts.output_dir)
|
||||||
|
|
||||||
|
if opts.use_xorrisofs and opts.buildinstall_method:
|
||||||
|
script = write_xorriso_commands(opts)
|
||||||
|
emit(f, "xorriso -dialog on <%s" % script)
|
||||||
|
else:
|
||||||
make_image(f, opts)
|
make_image(f, opts)
|
||||||
run_isohybrid(f, opts)
|
run_isohybrid(f, opts)
|
||||||
|
|
||||||
implant_md5(f, opts)
|
implant_md5(f, opts)
|
||||||
make_manifest(f, opts)
|
make_manifest(f, opts)
|
||||||
if opts.jigdo_dir:
|
if opts.jigdo_dir:
|
||||||
|
@ -343,7 +343,10 @@ class CreateisoPhase(PhaseLoggerMixin, PhaseBase):
|
|||||||
|
|
||||||
if bootable:
|
if bootable:
|
||||||
opts = opts._replace(
|
opts = opts._replace(
|
||||||
buildinstall_method=self.compose.conf["buildinstall_method"]
|
buildinstall_method=self.compose.conf[
|
||||||
|
"buildinstall_method"
|
||||||
|
],
|
||||||
|
boot_iso=os.path.join(os_tree, "images", "boot.iso"),
|
||||||
)
|
)
|
||||||
|
|
||||||
if self.compose.conf["create_jigdo"]:
|
if self.compose.conf["create_jigdo"]:
|
||||||
@ -355,10 +358,9 @@ class CreateisoPhase(PhaseLoggerMixin, PhaseBase):
|
|||||||
# Reuse was successful, go to next ISO
|
# Reuse was successful, go to next ISO
|
||||||
continue
|
continue
|
||||||
|
|
||||||
script_file = os.path.join(
|
script_dir = self.compose.paths.work.tmp_dir(arch, variant)
|
||||||
self.compose.paths.work.tmp_dir(arch, variant),
|
opts = opts._replace(script_dir=script_dir)
|
||||||
"createiso-%s.sh" % filename,
|
script_file = os.path.join(script_dir, "createiso-%s.sh" % filename)
|
||||||
)
|
|
||||||
with open(script_file, "w") as f:
|
with open(script_file, "w") as f:
|
||||||
createiso.write_script(opts, f)
|
createiso.write_script(opts, f)
|
||||||
cmd["cmd"] = ["bash", script_file]
|
cmd["cmd"] = ["bash", script_file]
|
||||||
|
@ -132,14 +132,15 @@ class ExtraIsosThread(WorkerThread):
|
|||||||
use_xorrisofs=compose.conf.get("createiso_use_xorrisofs"),
|
use_xorrisofs=compose.conf.get("createiso_use_xorrisofs"),
|
||||||
iso_level=compose.conf.get("iso_level"),
|
iso_level=compose.conf.get("iso_level"),
|
||||||
)
|
)
|
||||||
|
os_tree = compose.paths.compose.os_tree(arch, variant)
|
||||||
if compose.conf["create_jigdo"]:
|
if compose.conf["create_jigdo"]:
|
||||||
jigdo_dir = compose.paths.compose.jigdo_dir(arch, variant)
|
jigdo_dir = compose.paths.compose.jigdo_dir(arch, variant)
|
||||||
os_tree = compose.paths.compose.os_tree(arch, variant)
|
|
||||||
opts = opts._replace(jigdo_dir=jigdo_dir, os_tree=os_tree)
|
opts = opts._replace(jigdo_dir=jigdo_dir, os_tree=os_tree)
|
||||||
|
|
||||||
if bootable:
|
if bootable:
|
||||||
opts = opts._replace(
|
opts = opts._replace(
|
||||||
buildinstall_method=compose.conf["buildinstall_method"]
|
buildinstall_method=compose.conf["buildinstall_method"],
|
||||||
|
boot_iso=os.path.join(os_tree, "images", "boot.iso"),
|
||||||
)
|
)
|
||||||
|
|
||||||
# Check if it can be reused.
|
# Check if it can be reused.
|
||||||
@ -148,9 +149,9 @@ class ExtraIsosThread(WorkerThread):
|
|||||||
config_hash = hash.hexdigest()
|
config_hash = hash.hexdigest()
|
||||||
|
|
||||||
if not self.try_reuse(compose, variant, arch, config_hash, opts):
|
if not self.try_reuse(compose, variant, arch, config_hash, opts):
|
||||||
script_file = os.path.join(
|
script_dir = compose.paths.work.tmp_dir(arch, variant)
|
||||||
compose.paths.work.tmp_dir(arch, variant), "extraiso-%s.sh" % filename
|
opts = opts._replace(script_dir=script_dir)
|
||||||
)
|
script_file = os.path.join(script_dir, "extraiso-%s.sh" % filename)
|
||||||
with open(script_file, "w") as f:
|
with open(script_file, "w") as f:
|
||||||
createiso.write_script(opts, f)
|
createiso.write_script(opts, f)
|
||||||
|
|
||||||
|
@ -124,6 +124,7 @@ class CreateisoPhaseTest(helpers.PungiTestCase):
|
|||||||
os_tree=None,
|
os_tree=None,
|
||||||
hfs_compat=True,
|
hfs_compat=True,
|
||||||
use_xorrisofs=False,
|
use_xorrisofs=False,
|
||||||
|
script_dir="%s/work/x86_64/tmp-Server" % self.topdir,
|
||||||
)
|
)
|
||||||
],
|
],
|
||||||
)
|
)
|
||||||
@ -240,6 +241,9 @@ class CreateisoPhaseTest(helpers.PungiTestCase):
|
|||||||
[
|
[
|
||||||
CreateIsoOpts(
|
CreateIsoOpts(
|
||||||
output_dir="%s/compose/Server/x86_64/iso" % self.topdir,
|
output_dir="%s/compose/Server/x86_64/iso" % self.topdir,
|
||||||
|
boot_iso=(
|
||||||
|
"%s/compose/Server/x86_64/os/images/boot.iso" % self.topdir
|
||||||
|
),
|
||||||
iso_name="image-name",
|
iso_name="image-name",
|
||||||
volid="test-1.0 Server.x86_64",
|
volid="test-1.0 Server.x86_64",
|
||||||
graft_points="dummy-graft-points",
|
graft_points="dummy-graft-points",
|
||||||
@ -250,6 +254,7 @@ class CreateisoPhaseTest(helpers.PungiTestCase):
|
|||||||
os_tree=None,
|
os_tree=None,
|
||||||
hfs_compat=True,
|
hfs_compat=True,
|
||||||
use_xorrisofs=False,
|
use_xorrisofs=False,
|
||||||
|
script_dir="%s/work/x86_64/tmp-Server" % self.topdir,
|
||||||
),
|
),
|
||||||
CreateIsoOpts(
|
CreateIsoOpts(
|
||||||
output_dir="%s/compose/Server/source/iso" % self.topdir,
|
output_dir="%s/compose/Server/source/iso" % self.topdir,
|
||||||
@ -262,6 +267,7 @@ class CreateisoPhaseTest(helpers.PungiTestCase):
|
|||||||
os_tree=None,
|
os_tree=None,
|
||||||
hfs_compat=True,
|
hfs_compat=True,
|
||||||
use_xorrisofs=False,
|
use_xorrisofs=False,
|
||||||
|
script_dir="%s/work/src/tmp-Server" % self.topdir,
|
||||||
),
|
),
|
||||||
],
|
],
|
||||||
)
|
)
|
||||||
@ -394,6 +400,7 @@ class CreateisoPhaseTest(helpers.PungiTestCase):
|
|||||||
os_tree=None,
|
os_tree=None,
|
||||||
hfs_compat=True,
|
hfs_compat=True,
|
||||||
use_xorrisofs=False,
|
use_xorrisofs=False,
|
||||||
|
script_dir="%s/work/src/tmp-Server" % self.topdir,
|
||||||
)
|
)
|
||||||
],
|
],
|
||||||
)
|
)
|
||||||
@ -501,6 +508,7 @@ class CreateisoPhaseTest(helpers.PungiTestCase):
|
|||||||
os_tree=None,
|
os_tree=None,
|
||||||
hfs_compat=False,
|
hfs_compat=False,
|
||||||
use_xorrisofs=False,
|
use_xorrisofs=False,
|
||||||
|
script_dir="%s/work/x86_64/tmp-Server" % self.topdir,
|
||||||
)
|
)
|
||||||
],
|
],
|
||||||
)
|
)
|
||||||
|
Loading…
Reference in New Issue
Block a user