[createiso] Add back running isohybrid on x86 disk images
rhbz#1331317 when we refactored how we make dvds in
df400002d8
we lost the ability to boot
the dvd as a disk image.
Signed-off-by: Dennis Gilmore <dennis@ausil.us>
This commit is contained in:
parent
b949bfd615
commit
5c4d3a5196
@ -45,6 +45,15 @@ def implant_md5(iso, opts):
|
|||||||
shortcuts.run(cmd, stdout=True, show_cmd=True, workdir=opts.output_dir)
|
shortcuts.run(cmd, stdout=True, show_cmd=True, workdir=opts.output_dir)
|
||||||
|
|
||||||
|
|
||||||
|
def run_isohybrid(iso, opts):
|
||||||
|
"""If the image is bootable, it needs to include an MBR or GPT so that it
|
||||||
|
can actually be booted. This is done by running isohybrid on the image.
|
||||||
|
"""
|
||||||
|
if opts.buildinstall_method and opts.arch in ["x86_64", "i386"]:
|
||||||
|
cmd = iso.get_isohybrid_cmd(opts.iso_name, opts.arch)
|
||||||
|
shortcuts.run(cmd, stdout=True, show_cmd=True, workdir=opts.output_dir)
|
||||||
|
|
||||||
|
|
||||||
def make_manifest(iso, opts):
|
def make_manifest(iso, opts):
|
||||||
shortcuts.run(iso.get_manifest_cmd(opts.iso_name), stdout=True,
|
shortcuts.run(iso.get_manifest_cmd(opts.iso_name), stdout=True,
|
||||||
show_cmd=True, workdir=opts.output_dir)
|
show_cmd=True, workdir=opts.output_dir)
|
||||||
@ -68,6 +77,7 @@ def make_jigdo(opts):
|
|||||||
def run(opts):
|
def run(opts):
|
||||||
iso = IsoWrapper()
|
iso = IsoWrapper()
|
||||||
make_image(iso, opts)
|
make_image(iso, opts)
|
||||||
|
run_isohybrid(iso, opts)
|
||||||
implant_md5(iso, opts)
|
implant_md5(iso, opts)
|
||||||
make_manifest(iso, opts)
|
make_manifest(iso, opts)
|
||||||
if opts.jigdo_dir:
|
if opts.jigdo_dir:
|
||||||
|
@ -205,6 +205,15 @@ class IsoWrapper(kobo.log.LoggingBase):
|
|||||||
result = line.rsplit(":")[-1].strip()
|
result = line.rsplit(":")[-1].strip()
|
||||||
return result
|
return result
|
||||||
|
|
||||||
|
def get_isohybrid_cmd(self, iso_path, arch):
|
||||||
|
# isohybrid is in syslinux which is x86 only
|
||||||
|
cmd = ["/usr/bin/isohybrid"]
|
||||||
|
# uefi is only supported on x86_64
|
||||||
|
if arch == "x86_64":
|
||||||
|
cmd.append("--uefi")
|
||||||
|
cmd.append(iso_path)
|
||||||
|
return cmd
|
||||||
|
|
||||||
def get_manifest_cmd(self, iso_name):
|
def get_manifest_cmd(self, iso_name):
|
||||||
return "isoinfo -R -f -i %s | grep -v '/TRANS.TBL$' | sort >> %s.manifest" % (pipes.quote(iso_name), pipes.quote(iso_name))
|
return "isoinfo -R -f -i %s | grep -v '/TRANS.TBL$' | sort >> %s.manifest" % (pipes.quote(iso_name), pipes.quote(iso_name))
|
||||||
|
|
||||||
|
@ -13,7 +13,7 @@ from tests import helpers
|
|||||||
from pungi import createiso
|
from pungi import createiso
|
||||||
|
|
||||||
|
|
||||||
class OstreeScriptTest(helpers.PungiTestCase):
|
class CreateIsoScriptTest(helpers.PungiTestCase):
|
||||||
|
|
||||||
def assertEqualCalls(self, actual, expected):
|
def assertEqualCalls(self, actual, expected):
|
||||||
self.assertEqual(len(actual), len(expected))
|
self.assertEqual(len(actual), len(expected))
|
||||||
@ -21,7 +21,7 @@ class OstreeScriptTest(helpers.PungiTestCase):
|
|||||||
self.assertEqual(x, y)
|
self.assertEqual(x, y)
|
||||||
|
|
||||||
def setUp(self):
|
def setUp(self):
|
||||||
super(OstreeScriptTest, self).setUp()
|
super(CreateIsoScriptTest, self).setUp()
|
||||||
self.outdir = os.path.join(self.topdir, 'isos')
|
self.outdir = os.path.join(self.topdir, 'isos')
|
||||||
|
|
||||||
@mock.patch('kobo.shortcuts.run')
|
@mock.patch('kobo.shortcuts.run')
|
||||||
@ -79,12 +79,51 @@ class OstreeScriptTest(helpers.PungiTestCase):
|
|||||||
show_cmd=True, stdout=True, workdir=self.outdir),
|
show_cmd=True, stdout=True, workdir=self.outdir),
|
||||||
mock.call(['pungi-pylorax-find-templates', '/usr/share/lorax'],
|
mock.call(['pungi-pylorax-find-templates', '/usr/share/lorax'],
|
||||||
show_cmd=True, stdout=True),
|
show_cmd=True, stdout=True),
|
||||||
|
mock.call(['/usr/bin/isohybrid', '--uefi', 'DP-1.0-20160405.t.3-x86_64.iso'],
|
||||||
|
show_cmd=True, stdout=True, workdir=self.outdir),
|
||||||
mock.call(['/usr/bin/implantisomd5', 'DP-1.0-20160405.t.3-x86_64.iso'],
|
mock.call(['/usr/bin/implantisomd5', 'DP-1.0-20160405.t.3-x86_64.iso'],
|
||||||
show_cmd=True, stdout=True, workdir=self.outdir),
|
show_cmd=True, stdout=True, workdir=self.outdir),
|
||||||
mock.call('isoinfo -R -f -i DP-1.0-20160405.t.3-x86_64.iso | grep -v \'/TRANS.TBL$\' | sort >> DP-1.0-20160405.t.3-x86_64.iso.manifest',
|
mock.call('isoinfo -R -f -i DP-1.0-20160405.t.3-x86_64.iso | grep -v \'/TRANS.TBL$\' | sort >> DP-1.0-20160405.t.3-x86_64.iso.manifest',
|
||||||
show_cmd=True, stdout=True, workdir=self.outdir)]
|
show_cmd=True, stdout=True, workdir=self.outdir)]
|
||||||
)
|
)
|
||||||
|
|
||||||
|
@mock.patch('kobo.shortcuts.run')
|
||||||
|
def test_bootable_run_on_i386(self, run):
|
||||||
|
# This will call isohybrid, but not with --uefi switch
|
||||||
|
run.return_value = (0, '/usr/share/lorax')
|
||||||
|
|
||||||
|
createiso.main([
|
||||||
|
'--output-dir={}'.format(self.outdir),
|
||||||
|
'--iso-name=DP-1.0-20160405.t.3-i386.iso',
|
||||||
|
'--volid=DP-1.0-20160405.t.3',
|
||||||
|
'--graft-points=graft-list',
|
||||||
|
'--arch=i386',
|
||||||
|
'--buildinstall-method=lorax',
|
||||||
|
])
|
||||||
|
|
||||||
|
self.maxDiff = None
|
||||||
|
self.assertItemsEqual(
|
||||||
|
run.call_args_list,
|
||||||
|
[mock.call(['/usr/bin/genisoimage', '-untranslated-filenames',
|
||||||
|
'-volid', 'DP-1.0-20160405.t.3', '-J', '-joliet-long',
|
||||||
|
'-rational-rock', '-translation-table',
|
||||||
|
'-input-charset', 'utf-8', '-x', './lost+found',
|
||||||
|
'-b', 'isolinux/isolinux.bin', '-c', 'isolinux/boot.cat',
|
||||||
|
'-no-emul-boot',
|
||||||
|
'-boot-load-size', '4', '-boot-info-table',
|
||||||
|
'-o', 'DP-1.0-20160405.t.3-i386.iso',
|
||||||
|
'-graft-points', '-path-list', 'graft-list'],
|
||||||
|
show_cmd=True, stdout=True, workdir=self.outdir),
|
||||||
|
mock.call(['pungi-pylorax-find-templates', '/usr/share/lorax'],
|
||||||
|
show_cmd=True, stdout=True),
|
||||||
|
mock.call(['/usr/bin/isohybrid', 'DP-1.0-20160405.t.3-i386.iso'],
|
||||||
|
show_cmd=True, stdout=True, workdir=self.outdir),
|
||||||
|
mock.call(['/usr/bin/implantisomd5', 'DP-1.0-20160405.t.3-i386.iso'],
|
||||||
|
show_cmd=True, stdout=True, workdir=self.outdir),
|
||||||
|
mock.call('isoinfo -R -f -i DP-1.0-20160405.t.3-i386.iso | grep -v \'/TRANS.TBL$\' | sort >> DP-1.0-20160405.t.3-i386.iso.manifest',
|
||||||
|
show_cmd=True, stdout=True, workdir=self.outdir)]
|
||||||
|
)
|
||||||
|
|
||||||
@mock.patch('kobo.shortcuts.run')
|
@mock.patch('kobo.shortcuts.run')
|
||||||
def test_bootable_run_ppc64(self, run):
|
def test_bootable_run_ppc64(self, run):
|
||||||
run.return_value = (0, '/usr/share/lorax')
|
run.return_value = (0, '/usr/share/lorax')
|
||||||
|
Loading…
Reference in New Issue
Block a user