Merge "Add clean step in iLO drivers to activate iLO license"

This commit is contained in:
Jenkins 2016-03-04 01:33:25 +00:00 committed by Gerrit Code Review
commit c4a24947ef
5 changed files with 138 additions and 15 deletions

View File

@ -71,6 +71,9 @@ cleaning steps.
See `How do I change the priority of a cleaning step?`_ for more information. See `How do I change the priority of a cleaning step?`_ for more information.
.. _manual_cleaning:
Manual cleaning Manual cleaning
=============== ===============

View File

@ -714,16 +714,18 @@ The following iLO drivers support node cleaning -
* ``iscsi_ilo`` * ``iscsi_ilo``
* ``agent_ilo`` * ``agent_ilo``
Supported Cleaning Operations For more information on node cleaning, see :ref:`cleaning`
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
* The cleaning operations supported are: Supported **Automated** Cleaning Operations
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
* The automated cleaning operations supported are:
-``reset_ilo``: -``reset_ilo``:
Resets the iLO. By default, enabled with priority 1. Resets the iLO. By default, enabled with priority 1.
-``reset_bios_to_default``: -``reset_bios_to_default``:
Resets system ROM sttings to default. By default, enabled with priority 10. Resets system ROM settings to default. By default, enabled with priority
This clean step is supported only on Gen9 and above servers. 10. This clean step is supported only on Gen9 and above servers.
-``reset_secure_boot_keys_to_default``: -``reset_secure_boot_keys_to_default``:
Resets secure boot keys to manufacturer's defaults. This step is supported Resets secure boot keys to manufacturer's defaults. This step is supported
only on Gen9 and above servers. By default, enabled with priority 20 . only on Gen9 and above servers. By default, enabled with priority 20 .
@ -737,15 +739,16 @@ Supported Cleaning Operations
* For in-band cleaning operations supported by ``agent_ilo`` driver, see * For in-band cleaning operations supported by ``agent_ilo`` driver, see
:ref:`InbandvsOutOfBandCleaning`. :ref:`InbandvsOutOfBandCleaning`.
* All the cleaning steps have an explicit configuration option for priority. * All the automated cleaning steps have an explicit configuration option for
In order to disable or change the priority of the clean steps, respective priority. In order to disable or change the priority of the automated clean
configuration option for priority should be updated in ironic.conf. steps, respective configuration option for priority should be updated in
ironic.conf.
* Updating clean step priority to 0, will disable that particular clean step * Updating clean step priority to 0, will disable that particular clean step
and will not run during cleaning. and will not run during automated cleaning.
* Configuration Options for the clean steps are listed under ``[ilo]`` section in * Configuration Options for the automated clean steps are listed under
ironic.conf :: ``[ilo]`` section in ironic.conf ::
- clean_priority_reset_ilo=1 - clean_priority_reset_ilo=1
- clean_priority_reset_bios_to_default=10 - clean_priority_reset_bios_to_default=10
@ -754,7 +757,31 @@ Supported Cleaning Operations
- clean_priority_reset_ilo_credential=30 - clean_priority_reset_ilo_credential=30
- clean_priority_erase_devices=10 - clean_priority_erase_devices=10
For more information on node cleaning, see :ref:`cleaning` For more information on node automated cleaning, see :ref:`automated_cleaning`
Supported **Manual** Cleaning Operations
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
* The manual cleaning operations supported are:
-``activate_license``:
Activates the iLO Advanced license. This is an out-of-band manual cleaning
step associated with ``management`` interface. See
`Activating iLO Advanced license as manual clean step`_ for user guidance
on usage. Please note that this operation cannot be performed using virtual
media based drivers like ``iscsi_ilo`` and ``agent_ilo`` as they need this
type of advanced license already active to use virtual media to boot into
to start cleaning operation. Virtual media is an advanced feature. If an
advanced license is already active and the user wants to overwrite the
current license key, for example in case of a multi-server activation key
delivered with a flexible-quantity kit or after completing an Activation
Key Agreement (AKA), then these drivers can still be used for executing
this cleaning step.
* iLO with firmware version 1.5 is minimally required to support all the
operations.
For more information on node manual cleaning, see :ref:`manual_cleaning`
Hardware Inspection Support Hardware Inspection Support
^^^^^^^^^^^^^^^^^^^^^^^^^^^ ^^^^^^^^^^^^^^^^^^^^^^^^^^^
@ -1213,3 +1240,33 @@ Localboot in standalone ironic
Conductor -> Baremetal [label = "Power on the node"]; Conductor -> Baremetal [label = "Power on the node"];
Baremetal -> Baremetal [label = "Boot user image from disk"]; Baremetal -> Baremetal [label = "Boot user image from disk"];
} }
Activating iLO Advanced license as manual clean step
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
iLO drivers can activate the iLO Advanced license key as a manual cleaning
step. Any manual cleaning step can only be initiated when a node is in the
``manageable`` state. Once the manual cleaning is finished, the node will be
put in the ``manageable`` state again. User can follow steps from
:ref:`manual_cleaning` to initiate manual cleaning operation on a node.
An example of a manual clean step to activate license as the only clean step
could be::
'clean_steps': [{
'interface': 'management',
'step': 'activate_license',
'args': {
'ilo_license_key': 'ABC12-XXXXX-XXXXX-XXXXX-YZ345'
}
}]
The different attributes of ``activate_license`` clean step are as follows:
.. csv-table::
:header: "Attribute", "Description"
:widths: 30, 120
"``interface``", "Interface of clean step, here ``management``"
"``step``", "Name of clean step, here ``activate_license``"
"``args``", "Keyword-argument entry (<name>: <value>) being passed to clean step"
"``args.ilo_license_key``", "The HPE iLO Advanced license key to activate enterprise features. This is mandatory."

View File

@ -18,12 +18,11 @@ iLO Management Interface
from oslo_config import cfg from oslo_config import cfg
from oslo_log import log as logging from oslo_log import log as logging
from oslo_utils import importutils from oslo_utils import importutils
import six
from ironic.common import boot_devices from ironic.common import boot_devices
from ironic.common import exception from ironic.common import exception
from ironic.common.i18n import _ from ironic.common.i18n import _, _LI, _LW
from ironic.common.i18n import _LI
from ironic.common.i18n import _LW
from ironic.conductor import task_manager from ironic.conductor import task_manager
from ironic.drivers import base from ironic.drivers import base
from ironic.drivers.modules.ilo import common as ilo_common from ironic.drivers.modules.ilo import common as ilo_common
@ -301,3 +300,36 @@ class IloManagement(base.ManagementInterface):
:raises: NodeCleaningFailure, on failure to execute step. :raises: NodeCleaningFailure, on failure to execute step.
""" """
return _execute_ilo_clean_step(task.node, 'clear_secure_boot_keys') return _execute_ilo_clean_step(task.node, 'clear_secure_boot_keys')
@base.clean_step(priority=0, abortable=False, argsinfo={
'ilo_license_key': {
'description': (
'The HPE iLO Advanced license key to activate enterprise '
'features.'
),
'required': True
}
})
def activate_license(self, task, **kwargs):
"""Activates iLO Advanced license.
:param task: a TaskManager object.
:raises: InvalidParameterValue, if any of the arguments are invalid.
:raises: NodeCleaningFailure, on failure to execute clean step.
"""
ilo_license_key = kwargs.get('ilo_license_key')
node = task.node
if not isinstance(ilo_license_key, six.string_types):
msg = (_("Value of 'ilo_license_key' must be a string instead of "
"'%(value)s'. Step 'activate_license' is not executed "
"for %(node)s.")
% {'value': ilo_license_key, 'node': node.uuid})
LOG.error(msg)
raise exception.InvalidParameterValue(msg)
LOG.debug("Activating iLO license for node %(node)s ...",
{'node': node.uuid})
_execute_ilo_clean_step(node, 'activate_license', ilo_license_key)
LOG.info(_LI("iLO license activated for node %(node)s."),
{'node': node.uuid})

View File

@ -296,3 +296,30 @@ class IloManagementTestCase(db_base.DbTestCase):
task.driver.management.clear_secure_boot_keys(task) task.driver.management.clear_secure_boot_keys(task)
clean_step_mock.assert_called_once_with(task.node, clean_step_mock.assert_called_once_with(task.node,
'clear_secure_boot_keys') 'clear_secure_boot_keys')
@mock.patch.object(ilo_management, '_execute_ilo_clean_step',
spec_set=True, autospec=True)
def test_activate_license(self, clean_step_mock):
with task_manager.acquire(self.context, self.node.uuid,
shared=False) as task:
activate_license_args = {
'ilo_license_key': 'XXXXX-YYYYY-ZZZZZ-XYZZZ-XXYYZ'}
task.driver.management.activate_license(task,
**activate_license_args)
clean_step_mock.assert_called_once_with(
task.node, 'activate_license', 'XXXXX-YYYYY-ZZZZZ-XYZZZ-XXYYZ')
@mock.patch.object(ilo_management, 'LOG', spec_set=True, autospec=True)
@mock.patch.object(ilo_management, '_execute_ilo_clean_step',
spec_set=True, autospec=True)
def test_activate_license_no_or_invalid_format_license_key(
self, clean_step_mock, log_mock):
with task_manager.acquire(self.context, self.node.uuid,
shared=False) as task:
for license_key_value in (None, [], {}):
activate_license_args = {'ilo_license_key': license_key_value}
self.assertRaises(exception.InvalidParameterValue,
task.driver.management.activate_license,
task,
**activate_license_args)
self.assertFalse(clean_step_mock.called)

View File

@ -0,0 +1,4 @@
---
features:
- Support for activation of iLO Advanced license as a
manual cleaning step in iLO drivers.