force_config_drive: StrOpt -> BoolOpt

The 'force_config_drive' option provides a way to force injection of
configuration drives on instances. Previously, this option supported
three values: 'always', 'True' and 'False'. However, the 'always'
value was deprecated in Liberty and can now be removed.

Remove this value and replace the existing 'StrOpt' with a 'BoolOpt'.
This also requires changing some unit tests to reflect the new value
for this parameter.

UpgradeImpact: This change removes support for the 'always' option.
    Configuration files providing this value will need to be updated
    accordingly.
DocImpact: This option is now a BoolOpt and documentation will need to
    be updated accordingly.
Change-Id: I0b4030ec1336fb1f2e721570c99a27a979e2847c
This commit is contained in:
Stephen Finucane 2015-10-20 19:41:30 +00:00
parent 73f6f11446
commit 296479e1ab
2 changed files with 20 additions and 40 deletions

View File

@ -12,36 +12,14 @@
# License for the specific language governing permissions and limitations # License for the specific language governing permissions and limitations
# under the License. # under the License.
from oslo_utils import strutils
from nova import objects from nova import objects
from nova import test from nova import test
from nova.virt import configdrive from nova.virt import configdrive
class ConfigDriveTestCase(test.NoDBTestCase): class ConfigDriveTestCase(test.NoDBTestCase):
def test_valid_string_values(self):
instance = objects.Instance(
config_drive=None,
system_metadata={}
)
for value in (strutils.TRUE_STRINGS + ('always',)):
self.flags(force_config_drive=value)
self.assertTrue(configdrive.required_by(instance))
def test_invalid_string_values(self):
instance = objects.Instance(
config_drive=None,
system_metadata={}
)
for value in (strutils.FALSE_STRINGS + ('foo',)):
self.flags(force_config_drive=value)
self.assertFalse(configdrive.required_by(instance))
def test_instance_force(self): def test_instance_force(self):
self.flags(force_config_drive="no") self.flags(force_config_drive=False)
instance = objects.Instance( instance = objects.Instance(
config_drive="yes", config_drive="yes",
@ -53,7 +31,7 @@ class ConfigDriveTestCase(test.NoDBTestCase):
self.assertTrue(configdrive.required_by(instance)) self.assertTrue(configdrive.required_by(instance))
def test_image_meta_force(self): def test_image_meta_force(self):
self.flags(force_config_drive="no") self.flags(force_config_drive=False)
instance = objects.Instance( instance = objects.Instance(
config_drive=None, config_drive=None,
@ -64,8 +42,20 @@ class ConfigDriveTestCase(test.NoDBTestCase):
self.assertTrue(configdrive.required_by(instance)) self.assertTrue(configdrive.required_by(instance))
def test_image_meta_opt(self): def test_config_flag_force(self):
self.flags(force_config_drive="no") self.flags(force_config_drive=True)
instance = objects.Instance(
config_drive=None,
system_metadata={
"image_img_config_drive": "optional",
}
)
self.assertTrue(configdrive.required_by(instance))
def test_no_config_drive(self):
self.flags(force_config_drive=False)
instance = objects.Instance( instance = objects.Instance(
config_drive=None, config_drive=None,

View File

@ -21,11 +21,9 @@ import shutil
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 fileutils from oslo_utils import fileutils
from oslo_utils import strutils
from oslo_utils import units from oslo_utils import units
from nova import exception from nova import exception
from nova.i18n import _LW
from nova import objects from nova import objects
from nova.objects import fields from nova.objects import fields
from nova import utils from nova import utils
@ -38,13 +36,9 @@ configdrive_opts = [
default='iso9660', default='iso9660',
choices=('iso9660', 'vfat'), choices=('iso9660', 'vfat'),
help='Config drive format.'), help='Config drive format.'),
# force_config_drive is a string option, to allow for future behaviors cfg.BoolOpt('force_config_drive',
# (e.g. use config_drive based on image properties) help='Force injection to take place on a config drive',
cfg.StrOpt('force_config_drive', default=False),
choices=('always', 'True', 'False'),
help='Set to "always" to force injection to take place on a '
'config drive. NOTE: The "always" will be deprecated in '
'the Liberty release cycle.'),
cfg.StrOpt('mkisofs_cmd', cfg.StrOpt('mkisofs_cmd',
default='genisoimage', default='genisoimage',
help='Name and optionally path of the tool used for ' help='Name and optionally path of the tool used for '
@ -62,9 +56,6 @@ class ConfigDriveBuilder(object):
"""Build config drives, optionally as a context manager.""" """Build config drives, optionally as a context manager."""
def __init__(self, instance_md=None): def __init__(self, instance_md=None):
if CONF.force_config_drive == 'always':
LOG.warning(_LW('The setting "always" will be deprecated in the '
'Liberty version. Please use "True" instead'))
self.imagefile = None self.imagefile = None
self.mdfiles = [] self.mdfiles = []
@ -186,8 +177,7 @@ def required_by(instance):
fields.ConfigDrivePolicy.OPTIONAL) fields.ConfigDrivePolicy.OPTIONAL)
return (instance.config_drive or return (instance.config_drive or
'always' == CONF.force_config_drive or CONF.force_config_drive or
strutils.bool_from_string(CONF.force_config_drive) or
image_prop == fields.ConfigDrivePolicy.MANDATORY image_prop == fields.ConfigDrivePolicy.MANDATORY
) )