Call clean_up_instance() during node teardown for Agent deploy
Agent based deploy do not call boot.clean_up_instance() during node teardown. This is required so that instance clean up can happen as part of node teardown. Change-Id: I6077b69f17ce462b6aae1b16fdb40158cf111c5e Closes-Bug: #1676321
This commit is contained in:
parent
8aec5fb6a5
commit
ef9300cb59
@ -459,6 +459,7 @@ class AgentDeploy(AgentDeployMixin, base.DeployInterface):
|
|||||||
"""
|
"""
|
||||||
if CONF.agent.manage_agent_boot:
|
if CONF.agent.manage_agent_boot:
|
||||||
task.driver.boot.clean_up_ramdisk(task)
|
task.driver.boot.clean_up_ramdisk(task)
|
||||||
|
task.driver.boot.clean_up_instance(task)
|
||||||
provider = dhcp_factory.DHCPFactory()
|
provider = dhcp_factory.DHCPFactory()
|
||||||
provider.clean_dhcp(task)
|
provider.clean_dhcp(task)
|
||||||
|
|
||||||
|
@ -374,20 +374,25 @@ class TestAgentDeploy(db_base.DbTestCase):
|
|||||||
|
|
||||||
@mock.patch('ironic.common.dhcp_factory.DHCPFactory._set_dhcp_provider')
|
@mock.patch('ironic.common.dhcp_factory.DHCPFactory._set_dhcp_provider')
|
||||||
@mock.patch('ironic.common.dhcp_factory.DHCPFactory.clean_dhcp')
|
@mock.patch('ironic.common.dhcp_factory.DHCPFactory.clean_dhcp')
|
||||||
|
@mock.patch.object(pxe.PXEBoot, 'clean_up_instance')
|
||||||
@mock.patch.object(pxe.PXEBoot, 'clean_up_ramdisk')
|
@mock.patch.object(pxe.PXEBoot, 'clean_up_ramdisk')
|
||||||
def test_clean_up(self, pxe_clean_up_ramdisk_mock, clean_dhcp_mock,
|
def test_clean_up(self, pxe_clean_up_ramdisk_mock,
|
||||||
|
pxe_clean_up_instance_mock, clean_dhcp_mock,
|
||||||
set_dhcp_provider_mock):
|
set_dhcp_provider_mock):
|
||||||
with task_manager.acquire(
|
with task_manager.acquire(
|
||||||
self.context, self.node['uuid'], shared=False) as task:
|
self.context, self.node['uuid'], shared=False) as task:
|
||||||
self.driver.clean_up(task)
|
self.driver.clean_up(task)
|
||||||
pxe_clean_up_ramdisk_mock.assert_called_once_with(task)
|
pxe_clean_up_ramdisk_mock.assert_called_once_with(task)
|
||||||
|
pxe_clean_up_instance_mock.assert_called_once_with(task)
|
||||||
set_dhcp_provider_mock.assert_called_once_with()
|
set_dhcp_provider_mock.assert_called_once_with()
|
||||||
clean_dhcp_mock.assert_called_once_with(task)
|
clean_dhcp_mock.assert_called_once_with(task)
|
||||||
|
|
||||||
@mock.patch('ironic.common.dhcp_factory.DHCPFactory._set_dhcp_provider')
|
@mock.patch('ironic.common.dhcp_factory.DHCPFactory._set_dhcp_provider')
|
||||||
@mock.patch('ironic.common.dhcp_factory.DHCPFactory.clean_dhcp')
|
@mock.patch('ironic.common.dhcp_factory.DHCPFactory.clean_dhcp')
|
||||||
|
@mock.patch.object(pxe.PXEBoot, 'clean_up_instance')
|
||||||
@mock.patch.object(pxe.PXEBoot, 'clean_up_ramdisk')
|
@mock.patch.object(pxe.PXEBoot, 'clean_up_ramdisk')
|
||||||
def test_clean_up_manage_agent_boot_false(self, pxe_clean_up_ramdisk_mock,
|
def test_clean_up_manage_agent_boot_false(self, pxe_clean_up_ramdisk_mock,
|
||||||
|
pxe_clean_up_instance_mock,
|
||||||
clean_dhcp_mock,
|
clean_dhcp_mock,
|
||||||
set_dhcp_provider_mock):
|
set_dhcp_provider_mock):
|
||||||
with task_manager.acquire(
|
with task_manager.acquire(
|
||||||
@ -395,6 +400,7 @@ class TestAgentDeploy(db_base.DbTestCase):
|
|||||||
self.config(group='agent', manage_agent_boot=False)
|
self.config(group='agent', manage_agent_boot=False)
|
||||||
self.driver.clean_up(task)
|
self.driver.clean_up(task)
|
||||||
self.assertFalse(pxe_clean_up_ramdisk_mock.called)
|
self.assertFalse(pxe_clean_up_ramdisk_mock.called)
|
||||||
|
pxe_clean_up_instance_mock.assert_called_once_with(task)
|
||||||
set_dhcp_provider_mock.assert_called_once_with()
|
set_dhcp_provider_mock.assert_called_once_with()
|
||||||
clean_dhcp_mock.assert_called_once_with(task)
|
clean_dhcp_mock.assert_called_once_with(task)
|
||||||
|
|
||||||
|
@ -0,0 +1,6 @@
|
|||||||
|
---
|
||||||
|
fixes:
|
||||||
|
- |
|
||||||
|
Fixes an issue wherein agent based deploy do not call
|
||||||
|
clean up the instance related configurations done on
|
||||||
|
the Ironic node.
|
Loading…
x
Reference in New Issue
Block a user