Deal with iPXE boot interface incompatibility in Train
In Train cycle, iPXE boot with [pxe]ipxe_enabled option in ironic.conf file will be removed. And ipxe boot interface will be the only boot interface to deploy Ironic node with iPXE. Till Train, iRMC driver has supported iPXE boot with [pxe]ipxe_enabled option. This commit copes with this incompatibility and supports ipxe boot interface by adding ipxe.iPXEBoot to supported_boot_interface. Change-Id: Iec2284c2d101aebadd9d1b531c44794e2d4efacf Related-Bug: #1628069
This commit is contained in:
parent
1beb8068f9
commit
66b0739831
@ -20,6 +20,7 @@ from ironic.drivers import generic
|
|||||||
from ironic.drivers.modules import agent
|
from ironic.drivers.modules import agent
|
||||||
from ironic.drivers.modules import inspector
|
from ironic.drivers.modules import inspector
|
||||||
from ironic.drivers.modules import ipmitool
|
from ironic.drivers.modules import ipmitool
|
||||||
|
from ironic.drivers.modules import ipxe
|
||||||
from ironic.drivers.modules.irmc import bios
|
from ironic.drivers.modules.irmc import bios
|
||||||
from ironic.drivers.modules.irmc import boot
|
from ironic.drivers.modules.irmc import boot
|
||||||
from ironic.drivers.modules.irmc import inspect
|
from ironic.drivers.modules.irmc import inspect
|
||||||
@ -48,7 +49,7 @@ class IRMCHardware(generic.GenericHardware):
|
|||||||
# NOTE: Support for pxe boot is deprecated, and will be
|
# NOTE: Support for pxe boot is deprecated, and will be
|
||||||
# removed from the list in the future.
|
# removed from the list in the future.
|
||||||
return [boot.IRMCVirtualMediaBoot, boot.IRMCPXEBoot,
|
return [boot.IRMCVirtualMediaBoot, boot.IRMCPXEBoot,
|
||||||
pxe.PXEBoot]
|
ipxe.iPXEBoot, pxe.PXEBoot]
|
||||||
|
|
||||||
@property
|
@property
|
||||||
def supported_console_interfaces(self):
|
def supported_console_interfaces(self):
|
||||||
|
@ -21,6 +21,7 @@ from ironic.drivers import irmc
|
|||||||
from ironic.drivers.modules import agent
|
from ironic.drivers.modules import agent
|
||||||
from ironic.drivers.modules import inspector
|
from ironic.drivers.modules import inspector
|
||||||
from ironic.drivers.modules import ipmitool
|
from ironic.drivers.modules import ipmitool
|
||||||
|
from ironic.drivers.modules import ipxe
|
||||||
from ironic.drivers.modules.irmc import bios as irmc_bios
|
from ironic.drivers.modules.irmc import bios as irmc_bios
|
||||||
from ironic.drivers.modules.irmc import raid
|
from ironic.drivers.modules.irmc import raid
|
||||||
from ironic.drivers.modules import iscsi_deploy
|
from ironic.drivers.modules import iscsi_deploy
|
||||||
@ -35,8 +36,9 @@ class IRMCHardwareTestCase(db_base.DbTestCase):
|
|||||||
irmc.boot.check_share_fs_mounted_patcher.start()
|
irmc.boot.check_share_fs_mounted_patcher.start()
|
||||||
self.addCleanup(irmc.boot.check_share_fs_mounted_patcher.stop)
|
self.addCleanup(irmc.boot.check_share_fs_mounted_patcher.stop)
|
||||||
super(IRMCHardwareTestCase, self).setUp()
|
super(IRMCHardwareTestCase, self).setUp()
|
||||||
|
self.config_temp_dir('http_root', group='deploy')
|
||||||
self.config(enabled_hardware_types=['irmc'],
|
self.config(enabled_hardware_types=['irmc'],
|
||||||
enabled_boot_interfaces=['irmc-virtual-media'],
|
enabled_boot_interfaces=['irmc-virtual-media', 'ipxe'],
|
||||||
enabled_console_interfaces=['ipmitool-socat'],
|
enabled_console_interfaces=['ipmitool-socat'],
|
||||||
enabled_deploy_interfaces=['iscsi', 'direct'],
|
enabled_deploy_interfaces=['iscsi', 'direct'],
|
||||||
enabled_inspect_interfaces=['irmc'],
|
enabled_inspect_interfaces=['irmc'],
|
||||||
@ -185,3 +187,10 @@ class IRMCHardwareTestCase(db_base.DbTestCase):
|
|||||||
noop.NoBIOS)
|
noop.NoBIOS)
|
||||||
self.assertIsInstance(task.driver.rescue,
|
self.assertIsInstance(task.driver.rescue,
|
||||||
agent.AgentRescue)
|
agent.AgentRescue)
|
||||||
|
|
||||||
|
def test_override_with_boot_configuration(self):
|
||||||
|
node = obj_utils.create_test_node(
|
||||||
|
self.context, driver='irmc',
|
||||||
|
boot_interface='ipxe')
|
||||||
|
with task_manager.acquire(self.context, node.id) as task:
|
||||||
|
self.assertIsInstance(task.driver.boot, ipxe.iPXEBoot)
|
||||||
|
@ -0,0 +1,17 @@
|
|||||||
|
---
|
||||||
|
upgrade:
|
||||||
|
- |
|
||||||
|
iRMC hardware type deals with iPXE boot interface incompatibility.
|
||||||
|
To iPXE boot with ``ipxe`` boot interface, *(1)* add ``ipxe`` to
|
||||||
|
``enabled_boot_interfaces`` in ``ironic.conf``, *(2)* set up tftp &
|
||||||
|
http server following `Ironic document on iPXE boot configuration
|
||||||
|
<https://docs.openstack.org/ironic/latest/install/configure-pxe.html>`,
|
||||||
|
then *(3)* create/set baremetal node with ``--boot-interface ipxe``.
|
||||||
|
fixes:
|
||||||
|
- |
|
||||||
|
iRMC hardware type deals with iPXE boot interface incompatibility.
|
||||||
|
From Stein, ``[pxe]ipxe_enabled`` option has been deprecated and will be
|
||||||
|
removed in preference to ``ipxe`` boot interface in Train cycle. Till then,
|
||||||
|
iRMC hardware type supports iPXE boot through ``[pxe]ipxe_enabled`` option.
|
||||||
|
To cope with this incompatibility, iRMC hardware type supports ``ipxe``
|
||||||
|
boot interface.
|
Loading…
x
Reference in New Issue
Block a user