From db02ef5173c33af68d2ee9827b49b6f2ff7b2392 Mon Sep 17 00:00:00 2001 From: Anup Navare Date: Fri, 1 Apr 2016 00:34:31 +0000 Subject: [PATCH] In node_power_action() add node.UUID to log message In the node_power_action() function, add the node.uuid to the log warning message. This is only a partial fix for the referenced bug. Partial-Bug: #1567689 Change-Id: I8fb62dd341aba71062f47e82db2d0d85320827a4 --- ironic/conductor/utils.py | 7 ++++--- ironic/tests/unit/conductor/test_utils.py | 7 ++++++- 2 files changed, 10 insertions(+), 4 deletions(-) diff --git a/ironic/conductor/utils.py b/ironic/conductor/utils.py index b7a6b1d9c2..0aac967a09 100644 --- a/ironic/conductor/utils.py +++ b/ironic/conductor/utils.py @@ -101,9 +101,10 @@ def node_power_action(task, new_state): node['power_state'] = new_state node['target_power_state'] = states.NOSTATE node.save() - LOG.warning(_LW("Not going to change node power state because " - "current state = requested state = '%(state)s'."), - {'state': curr_state}) + LOG.warning(_LW("Not going to change node %(node)s power " + "state because current state = requested state " + "= '%(state)s'."), + {'node': node.uuid, 'state': curr_state}) return if curr_state == states.ERROR: diff --git a/ironic/tests/unit/conductor/test_utils.py b/ironic/tests/unit/conductor/test_utils.py index 81f4a5aa9c..5e99cb445d 100644 --- a/ironic/tests/unit/conductor/test_utils.py +++ b/ironic/tests/unit/conductor/test_utils.py @@ -178,7 +178,8 @@ class NodePowerActionTestCase(base.DbTestCase): self.assertEqual(states.NOSTATE, node['target_power_state']) self.assertIsNone(node['last_error']) - def test_node_power_action_in_same_state(self): + @mock.patch.object(conductor_utils, 'LOG', autospec=True) + def test_node_power_action_in_same_state(self, log_mock): """Test setting node state to its present state. Test that we don't try to set the power state if the requested @@ -206,6 +207,10 @@ class NodePowerActionTestCase(base.DbTestCase): self.assertEqual(states.POWER_ON, node['power_state']) self.assertIsNone(node['target_power_state']) self.assertIsNone(node['last_error']) + log_mock.warning.assert_called_once_with( + u"Not going to change node %(node)s power state because " + u"current state = requested state = '%(state)s'.", + {'state': states.POWER_ON, 'node': node.uuid}) def test_node_power_action_in_same_state_db_not_in_sync(self): """Test setting node state to its present state if DB is out of sync.