Add 'openstack server create --use-config-drive'
Despite what the help text for this options says, the nova API only accepts boolean values for this value and has done so since at least the introduction of the 2.1 microversioned API. While it would be nice to convert '--config-drive' to a boolean flag, we'd need to be able to retain temporary support for people passing arguments. 'nargs=?' [1] looks promising but it has an annoying tendency to swallow a positional argument following it [2]. Since that is not an option, we have to live with a new config option, '--use-config-drive' and a '--no-config-drive' counterpart. [1] https://docs.python.org/3/library/argparse.html#nargs [2] https://bugs.python.org/issue9338 Change-Id: If9cce0ad4094cc9cef1c9136b80c3b0f35a82c7a Signed-off-by: Stephen Finucane <sfinucan@redhat.com> Story: #2005468 Task: #30547
This commit is contained in:
parent
82ebddca00
commit
12f1e56ebf
@ -693,12 +693,30 @@ class CreateServer(command.ShowOne):
|
|||||||
default={},
|
default={},
|
||||||
help=_('Hints for the scheduler (optional extension)'),
|
help=_('Hints for the scheduler (optional extension)'),
|
||||||
)
|
)
|
||||||
parser.add_argument(
|
config_drive_group = parser.add_mutually_exclusive_group()
|
||||||
|
config_drive_group.add_argument(
|
||||||
|
'--use-config-drive',
|
||||||
|
action='store_true',
|
||||||
|
dest='config_drive',
|
||||||
|
help=_("Enable config drive."),
|
||||||
|
)
|
||||||
|
config_drive_group.add_argument(
|
||||||
|
'--no-config-drive',
|
||||||
|
action='store_false',
|
||||||
|
dest='config_drive',
|
||||||
|
help=_("Disable config drive."),
|
||||||
|
)
|
||||||
|
# TODO(stephenfin): Drop support in the next major version bump after
|
||||||
|
# Victoria
|
||||||
|
config_drive_group.add_argument(
|
||||||
'--config-drive',
|
'--config-drive',
|
||||||
metavar='<config-drive-volume>|True',
|
metavar='<config-drive-volume>|True',
|
||||||
default=False,
|
default=False,
|
||||||
help=_('Use specified volume as the config drive, '
|
help=_(
|
||||||
'or \'True\' to use an ephemeral drive'),
|
"**Deprecated** Use specified volume as the config drive, "
|
||||||
|
"or 'True' to use an ephemeral drive. Replaced by "
|
||||||
|
"'--use-config-drive'."
|
||||||
|
),
|
||||||
)
|
)
|
||||||
parser.add_argument(
|
parser.add_argument(
|
||||||
'--min',
|
'--min',
|
||||||
@ -991,16 +1009,19 @@ class CreateServer(command.ShowOne):
|
|||||||
else:
|
else:
|
||||||
hints[key] = values
|
hints[key] = values
|
||||||
|
|
||||||
# What does a non-boolean value for config-drive do?
|
if isinstance(parsed_args.config_drive, bool):
|
||||||
# --config-drive argument is either a volume id or
|
# NOTE(stephenfin): The API doesn't accept False as a value :'(
|
||||||
# 'True' (or '1') to use an ephemeral volume
|
config_drive = parsed_args.config_drive or None
|
||||||
if str(parsed_args.config_drive).lower() in ("true", "1"):
|
|
||||||
config_drive = True
|
|
||||||
elif str(parsed_args.config_drive).lower() in ("false", "0",
|
|
||||||
"", "none"):
|
|
||||||
config_drive = None
|
|
||||||
else:
|
else:
|
||||||
config_drive = parsed_args.config_drive
|
# TODO(stephenfin): Remove when we drop support for
|
||||||
|
# '--config-drive'
|
||||||
|
if str(parsed_args.config_drive).lower() in ("true", "1"):
|
||||||
|
config_drive = True
|
||||||
|
elif str(parsed_args.config_drive).lower() in ("false", "0",
|
||||||
|
"", "none"):
|
||||||
|
config_drive = None
|
||||||
|
else:
|
||||||
|
config_drive = parsed_args.config_drive
|
||||||
|
|
||||||
boot_kwargs = dict(
|
boot_kwargs = dict(
|
||||||
meta=parsed_args.property,
|
meta=parsed_args.property,
|
||||||
|
@ -857,6 +857,7 @@ class TestServerCreate(TestServer):
|
|||||||
'--key-name', 'keyname',
|
'--key-name', 'keyname',
|
||||||
'--property', 'Beta=b',
|
'--property', 'Beta=b',
|
||||||
'--security-group', 'securitygroup',
|
'--security-group', 'securitygroup',
|
||||||
|
'--use-config-drive',
|
||||||
'--hint', 'a=b',
|
'--hint', 'a=b',
|
||||||
'--hint', 'a=c',
|
'--hint', 'a=c',
|
||||||
self.new_server.name,
|
self.new_server.name,
|
||||||
@ -868,7 +869,7 @@ class TestServerCreate(TestServer):
|
|||||||
('property', {'Beta': 'b'}),
|
('property', {'Beta': 'b'}),
|
||||||
('security_group', ['securitygroup']),
|
('security_group', ['securitygroup']),
|
||||||
('hint', {'a': ['b', 'c']}),
|
('hint', {'a': ['b', 'c']}),
|
||||||
('config_drive', False),
|
('config_drive', True),
|
||||||
('server_name', self.new_server.name),
|
('server_name', self.new_server.name),
|
||||||
]
|
]
|
||||||
parsed_args = self.check_parser(self.cmd, arglist, verifylist)
|
parsed_args = self.check_parser(self.cmd, arglist, verifylist)
|
||||||
@ -900,7 +901,7 @@ class TestServerCreate(TestServer):
|
|||||||
block_device_mapping_v2=[],
|
block_device_mapping_v2=[],
|
||||||
nics=[],
|
nics=[],
|
||||||
scheduler_hints={'a': ['b', 'c']},
|
scheduler_hints={'a': ['b', 'c']},
|
||||||
config_drive=None,
|
config_drive=True,
|
||||||
)
|
)
|
||||||
# ServerManager.create(name, image, flavor, **kwargs)
|
# ServerManager.create(name, image, flavor, **kwargs)
|
||||||
self.servers_mock.create.assert_called_with(
|
self.servers_mock.create.assert_called_with(
|
||||||
|
@ -0,0 +1,8 @@
|
|||||||
|
---
|
||||||
|
deprecations:
|
||||||
|
- |
|
||||||
|
The ``--config-drive`` option on the ``openstack server create`` command
|
||||||
|
has been deprecated in favour of the ``--use-config-drive`` and
|
||||||
|
``--no-config-drive`` arguments. The ``--config-drive`` option expected
|
||||||
|
either a string or bool-like argument, but the nova API has only supported
|
||||||
|
boolean values since API v2.1 was introduced.
|
Loading…
Reference in New Issue
Block a user