Merge "volume: Add 'volume type set --private/--public'"

This commit is contained in:
Zuul 2023-08-25 12:08:10 +00:00 committed by Gerrit Code Review
commit 356bc2566e
3 changed files with 156 additions and 138 deletions

View File

@ -29,18 +29,18 @@ class TestType(volume_fakes.TestVolume):
def setUp(self): def setUp(self):
super().setUp() super().setUp()
self.types_mock = self.app.client_manager.volume.volume_types self.volume_types_mock = self.app.client_manager.volume.volume_types
self.types_mock.reset_mock() self.volume_types_mock.reset_mock()
self.types_access_mock = ( self.volume_type_access_mock = (
self.app.client_manager.volume.volume_type_access self.app.client_manager.volume.volume_type_access
) )
self.types_access_mock.reset_mock() self.volume_type_access_mock.reset_mock()
self.encryption_types_mock = ( self.volume_encryption_types_mock = (
self.app.client_manager.volume.volume_encryption_types self.app.client_manager.volume.volume_encryption_types
) )
self.encryption_types_mock.reset_mock() self.volume_encryption_types_mock.reset_mock()
self.projects_mock = self.app.client_manager.identity.projects self.projects_mock = self.app.client_manager.identity.projects
self.projects_mock.reset_mock() self.projects_mock.reset_mock()
@ -66,7 +66,7 @@ class TestTypeCreate(TestType):
self.new_volume_type.name, self.new_volume_type.name,
) )
self.types_mock.create.return_value = self.new_volume_type self.volume_types_mock.create.return_value = self.new_volume_type
self.projects_mock.get.return_value = self.project self.projects_mock.get.return_value = self.project
# Get the command object to test # Get the command object to test
self.cmd = volume_type.CreateVolumeType(self.app, None) self.cmd = volume_type.CreateVolumeType(self.app, None)
@ -87,7 +87,7 @@ class TestTypeCreate(TestType):
parsed_args = self.check_parser(self.cmd, arglist, verifylist) parsed_args = self.check_parser(self.cmd, arglist, verifylist)
columns, data = self.cmd.take_action(parsed_args) columns, data = self.cmd.take_action(parsed_args)
self.types_mock.create.assert_called_with( self.volume_types_mock.create.assert_called_with(
self.new_volume_type.name, self.new_volume_type.name,
description=self.new_volume_type.description, description=self.new_volume_type.description,
is_public=True, is_public=True,
@ -115,7 +115,7 @@ class TestTypeCreate(TestType):
parsed_args = self.check_parser(self.cmd, arglist, verifylist) parsed_args = self.check_parser(self.cmd, arglist, verifylist)
columns, data = self.cmd.take_action(parsed_args) columns, data = self.cmd.take_action(parsed_args)
self.types_mock.create.assert_called_with( self.volume_types_mock.create.assert_called_with(
self.new_volume_type.name, self.new_volume_type.name,
description=self.new_volume_type.description, description=self.new_volume_type.description,
is_public=False, is_public=False,
@ -153,8 +153,8 @@ class TestTypeCreate(TestType):
self.new_volume_type = volume_fakes.create_one_volume_type( self.new_volume_type = volume_fakes.create_one_volume_type(
attrs={'encryption': encryption_info}, attrs={'encryption': encryption_info},
) )
self.types_mock.create.return_value = self.new_volume_type self.volume_types_mock.create.return_value = self.new_volume_type
self.encryption_types_mock.create.return_value = encryption_type self.volume_encryption_types_mock.create.return_value = encryption_type
encryption_columns = ( encryption_columns = (
'description', 'description',
'encryption', 'encryption',
@ -190,7 +190,7 @@ class TestTypeCreate(TestType):
parsed_args = self.check_parser(self.cmd, arglist, verifylist) parsed_args = self.check_parser(self.cmd, arglist, verifylist)
columns, data = self.cmd.take_action(parsed_args) columns, data = self.cmd.take_action(parsed_args)
self.types_mock.create.assert_called_with( self.volume_types_mock.create.assert_called_with(
self.new_volume_type.name, self.new_volume_type.name,
description=None, description=None,
) )
@ -200,7 +200,7 @@ class TestTypeCreate(TestType):
'key_size': 128, 'key_size': 128,
'control_location': 'front-end', 'control_location': 'front-end',
} }
self.encryption_types_mock.create.assert_called_with( self.volume_encryption_types_mock.create.assert_called_with(
self.new_volume_type, self.new_volume_type,
body, body,
) )
@ -214,10 +214,10 @@ class TestTypeDelete(TestType):
def setUp(self): def setUp(self):
super().setUp() super().setUp()
self.types_mock.get = volume_fakes.get_volume_types( self.volume_types_mock.get = volume_fakes.get_volume_types(
self.volume_types, self.volume_types,
) )
self.types_mock.delete.return_value = None self.volume_types_mock.delete.return_value = None
# Get the command object to mock # Get the command object to mock
self.cmd = volume_type.DeleteVolumeType(self.app, None) self.cmd = volume_type.DeleteVolumeType(self.app, None)
@ -229,7 +229,7 @@ class TestTypeDelete(TestType):
result = self.cmd.take_action(parsed_args) result = self.cmd.take_action(parsed_args)
self.types_mock.delete.assert_called_with(self.volume_types[0]) self.volume_types_mock.delete.assert_called_with(self.volume_types[0])
self.assertIsNone(result) self.assertIsNone(result)
def test_delete_multiple_types(self): def test_delete_multiple_types(self):
@ -246,7 +246,7 @@ class TestTypeDelete(TestType):
calls = [] calls = []
for t in self.volume_types: for t in self.volume_types:
calls.append(call(t)) calls.append(call(t))
self.types_mock.delete.assert_has_calls(calls) self.volume_types_mock.delete.assert_has_calls(calls)
self.assertIsNone(result) self.assertIsNone(result)
def test_delete_multiple_types_with_exception(self): def test_delete_multiple_types_with_exception(self):
@ -271,11 +271,13 @@ class TestTypeDelete(TestType):
self.assertEqual( self.assertEqual(
'1 of 2 volume types failed to delete.', str(e) '1 of 2 volume types failed to delete.', str(e)
) )
find_mock.assert_any_call(self.types_mock, self.volume_types[0].id) find_mock.assert_any_call(
find_mock.assert_any_call(self.types_mock, 'unexist_type') self.volume_types_mock, self.volume_types[0].id
)
find_mock.assert_any_call(self.volume_types_mock, 'unexist_type')
self.assertEqual(2, find_mock.call_count) self.assertEqual(2, find_mock.call_count)
self.types_mock.delete.assert_called_once_with( self.volume_types_mock.delete.assert_called_once_with(
self.volume_types[0] self.volume_types[0]
) )
@ -314,8 +316,8 @@ class TestTypeList(TestType):
def setUp(self): def setUp(self):
super().setUp() super().setUp()
self.types_mock.list.return_value = self.volume_types self.volume_types_mock.list.return_value = self.volume_types
self.types_mock.default.return_value = self.volume_types[0] self.volume_types_mock.default.return_value = self.volume_types[0]
# get the command to test # get the command to test
self.cmd = volume_type.ListVolumeType(self.app, None) self.cmd = volume_type.ListVolumeType(self.app, None)
@ -330,7 +332,7 @@ class TestTypeList(TestType):
parsed_args = self.check_parser(self.cmd, arglist, verifylist) parsed_args = self.check_parser(self.cmd, arglist, verifylist)
columns, data = self.cmd.take_action(parsed_args) columns, data = self.cmd.take_action(parsed_args)
self.types_mock.list.assert_called_once_with(is_public=None) self.volume_types_mock.list.assert_called_once_with(is_public=None)
self.assertEqual(self.columns, columns) self.assertEqual(self.columns, columns)
self.assertCountEqual(self.data, list(data)) self.assertCountEqual(self.data, list(data))
@ -348,7 +350,7 @@ class TestTypeList(TestType):
parsed_args = self.check_parser(self.cmd, arglist, verifylist) parsed_args = self.check_parser(self.cmd, arglist, verifylist)
columns, data = self.cmd.take_action(parsed_args) columns, data = self.cmd.take_action(parsed_args)
self.types_mock.list.assert_called_once_with(is_public=True) self.volume_types_mock.list.assert_called_once_with(is_public=True)
self.assertEqual(self.columns_long, columns) self.assertEqual(self.columns_long, columns)
self.assertCountEqual(self.data_long, list(data)) self.assertCountEqual(self.data_long, list(data))
@ -365,7 +367,7 @@ class TestTypeList(TestType):
parsed_args = self.check_parser(self.cmd, arglist, verifylist) parsed_args = self.check_parser(self.cmd, arglist, verifylist)
columns, data = self.cmd.take_action(parsed_args) columns, data = self.cmd.take_action(parsed_args)
self.types_mock.list.assert_called_once_with(is_public=False) self.volume_types_mock.list.assert_called_once_with(is_public=False)
self.assertEqual(self.columns, columns) self.assertEqual(self.columns, columns)
self.assertCountEqual(self.data, list(data)) self.assertCountEqual(self.data, list(data))
@ -383,7 +385,7 @@ class TestTypeList(TestType):
parsed_args = self.check_parser(self.cmd, arglist, verifylist) parsed_args = self.check_parser(self.cmd, arglist, verifylist)
columns, data = self.cmd.take_action(parsed_args) columns, data = self.cmd.take_action(parsed_args)
self.types_mock.default.assert_called_once_with() self.volume_types_mock.default.assert_called_once_with()
self.assertEqual(self.columns, columns) self.assertEqual(self.columns, columns)
self.assertCountEqual(self.data_with_default_type, list(data)) self.assertCountEqual(self.data_with_default_type, list(data))
@ -421,7 +423,7 @@ class TestTypeList(TestType):
) )
) )
self.encryption_types_mock.list.return_value = [encryption_type] self.volume_encryption_types_mock.list.return_value = [encryption_type]
arglist = [ arglist = [
"--encryption-type", "--encryption-type",
] ]
@ -431,66 +433,40 @@ class TestTypeList(TestType):
parsed_args = self.check_parser(self.cmd, arglist, verifylist) parsed_args = self.check_parser(self.cmd, arglist, verifylist)
columns, data = self.cmd.take_action(parsed_args) columns, data = self.cmd.take_action(parsed_args)
self.encryption_types_mock.list.assert_called_once_with() self.volume_encryption_types_mock.list.assert_called_once_with()
self.types_mock.list.assert_called_once_with(is_public=None) self.volume_types_mock.list.assert_called_once_with(is_public=None)
self.assertEqual(encryption_columns, columns) self.assertEqual(encryption_columns, columns)
self.assertCountEqual(encryption_data, list(data)) self.assertCountEqual(encryption_data, list(data))
class TestTypeSet(TestType): class TestTypeSet(TestType):
project = identity_fakes.FakeProject.create_one_project()
volume_type = volume_fakes.create_one_volume_type(
methods={'set_keys': None},
)
def setUp(self): def setUp(self):
super().setUp() super().setUp()
self.types_mock.get.return_value = self.volume_type self.project = identity_fakes.FakeProject.create_one_project()
# Return a project
self.projects_mock.get.return_value = self.project self.projects_mock.get.return_value = self.project
self.encryption_types_mock.create.return_value = None
self.encryption_types_mock.update.return_value = None self.volume_type = volume_fakes.create_one_volume_type(
# Get the command object to test methods={'set_keys': None},
)
self.volume_types_mock.get.return_value = self.volume_type
self.volume_encryption_types_mock.create.return_value = None
self.volume_encryption_types_mock.update.return_value = None
self.cmd = volume_type.SetVolumeType(self.app, None) self.cmd = volume_type.SetVolumeType(self.app, None)
def test_type_set_name(self): def test_type_set(self):
new_name = 'new_name'
arglist = [ arglist = [
'--name', '--name',
new_name, 'new_name',
self.volume_type.id,
]
verifylist = [
('name', new_name),
('description', None),
('property', None),
('volume_type', self.volume_type.id),
]
parsed_args = self.check_parser(self.cmd, arglist, verifylist)
result = self.cmd.take_action(parsed_args)
# Set expected values
kwargs = {
'name': new_name,
}
self.types_mock.update.assert_called_with(
self.volume_type.id, **kwargs
)
self.assertIsNone(result)
def test_type_set_description(self):
new_desc = 'new_desc'
arglist = [
'--description', '--description',
new_desc, 'new_description',
'--private',
self.volume_type.id, self.volume_type.id,
] ]
verifylist = [ verifylist = [
('name', None), ('name', 'new_name'),
('description', new_desc), ('description', 'new_description'),
('property', None), ('property', None),
('volume_type', self.volume_type.id), ('volume_type', self.volume_type.id),
] ]
@ -498,15 +474,20 @@ class TestTypeSet(TestType):
result = self.cmd.take_action(parsed_args) result = self.cmd.take_action(parsed_args)
# Set expected values
kwargs = { kwargs = {
'description': new_desc, 'name': 'new_name',
'description': 'new_description',
'is_public': False,
} }
self.types_mock.update.assert_called_with( self.volume_types_mock.update.assert_called_with(
self.volume_type.id, **kwargs self.volume_type.id, **kwargs
) )
self.assertIsNone(result) self.assertIsNone(result)
self.volume_type_access_mock.add_project_access.assert_not_called()
self.volume_encryption_types_mock.update.assert_not_called()
self.volume_encryption_types_mock.create.assert_not_called()
def test_type_set_property(self): def test_type_set_property(self):
arglist = [ arglist = [
'--property', '--property',
@ -522,12 +503,16 @@ class TestTypeSet(TestType):
parsed_args = self.check_parser(self.cmd, arglist, verifylist) parsed_args = self.check_parser(self.cmd, arglist, verifylist)
result = self.cmd.take_action(parsed_args) result = self.cmd.take_action(parsed_args)
self.assertIsNone(result)
self.volume_type.set_keys.assert_called_once_with( self.volume_type.set_keys.assert_called_once_with(
{'myprop': 'myvalue'} {'myprop': 'myvalue'}
) )
self.assertIsNone(result) self.volume_type_access_mock.add_project_access.assert_not_called()
self.volume_encryption_types_mock.update.assert_not_called()
self.volume_encryption_types_mock.create.assert_not_called()
def test_type_set_not_called_without_project_argument(self): def test_type_set_with_empty_project(self):
arglist = [ arglist = [
'--project', '--project',
'', '',
@ -543,26 +528,12 @@ class TestTypeSet(TestType):
result = self.cmd.take_action(parsed_args) result = self.cmd.take_action(parsed_args)
self.assertIsNone(result) self.assertIsNone(result)
self.assertFalse(self.types_access_mock.add_project_access.called) self.volume_type.set_keys.assert_not_called()
self.volume_type_access_mock.add_project_access.assert_not_called()
self.volume_encryption_types_mock.update.assert_not_called()
self.volume_encryption_types_mock.create.assert_not_called()
def test_type_set_failed_with_missing_volume_type_argument(self): def test_type_set_with_project(self):
arglist = [
'--project',
'identity_fakes.project_id',
]
verifylist = [
('project', 'identity_fakes.project_id'),
]
self.assertRaises(
tests_utils.ParserException,
self.check_parser,
self.cmd,
arglist,
verifylist,
)
def test_type_set_project_access(self):
arglist = [ arglist = [
'--project', '--project',
self.project.id, self.project.id,
@ -577,14 +548,17 @@ class TestTypeSet(TestType):
result = self.cmd.take_action(parsed_args) result = self.cmd.take_action(parsed_args)
self.assertIsNone(result) self.assertIsNone(result)
self.types_access_mock.add_project_access.assert_called_with( self.volume_type.set_keys.assert_not_called()
self.volume_type_access_mock.add_project_access.assert_called_with(
self.volume_type.id, self.volume_type.id,
self.project.id, self.project.id,
) )
self.volume_encryption_types_mock.update.assert_not_called()
self.volume_encryption_types_mock.create.assert_not_called()
def test_type_set_new_encryption(self): def test_type_set_with_new_encryption(self):
self.encryption_types_mock.update.side_effect = exceptions.NotFound( self.volume_encryption_types_mock.update.side_effect = (
'NotFound' exceptions.NotFound('NotFound')
) )
arglist = [ arglist = [
'--encryption-provider', '--encryption-provider',
@ -607,24 +581,25 @@ class TestTypeSet(TestType):
parsed_args = self.check_parser(self.cmd, arglist, verifylist) parsed_args = self.check_parser(self.cmd, arglist, verifylist)
result = self.cmd.take_action(parsed_args) result = self.cmd.take_action(parsed_args)
self.assertIsNone(result)
body = { body = {
'provider': 'LuksEncryptor', 'provider': 'LuksEncryptor',
'cipher': 'aes-xts-plain64', 'cipher': 'aes-xts-plain64',
'key_size': 128, 'key_size': 128,
'control_location': 'front-end', 'control_location': 'front-end',
} }
self.encryption_types_mock.update.assert_called_with( self.volume_encryption_types_mock.update.assert_called_with(
self.volume_type, self.volume_type,
body, body,
) )
self.encryption_types_mock.create.assert_called_with( self.volume_encryption_types_mock.create.assert_called_with(
self.volume_type, self.volume_type,
body, body,
) )
self.assertIsNone(result)
@mock.patch.object(utils, 'find_resource') @mock.patch.object(utils, 'find_resource')
def test_type_set_existing_encryption(self, mock_find): def test_type_set_with_existing_encryption(self, mock_find):
mock_find.side_effect = [self.volume_type, "existing_encryption_type"] mock_find.side_effect = [self.volume_type, "existing_encryption_type"]
arglist = [ arglist = [
'--encryption-provider', '--encryption-provider',
@ -644,21 +619,24 @@ class TestTypeSet(TestType):
parsed_args = self.check_parser(self.cmd, arglist, verifylist) parsed_args = self.check_parser(self.cmd, arglist, verifylist)
result = self.cmd.take_action(parsed_args) result = self.cmd.take_action(parsed_args)
self.assertIsNone(result)
self.volume_type.set_keys.assert_not_called()
self.volume_type_access_mock.add_project_access.assert_not_called()
body = { body = {
'provider': 'LuksEncryptor', 'provider': 'LuksEncryptor',
'cipher': 'aes-xts-plain64', 'cipher': 'aes-xts-plain64',
'control_location': 'front-end', 'control_location': 'front-end',
} }
self.encryption_types_mock.update.assert_called_with( self.volume_encryption_types_mock.update.assert_called_with(
self.volume_type, self.volume_type,
body, body,
) )
self.encryption_types_mock.create.assert_not_called() self.volume_encryption_types_mock.create.assert_not_called()
self.assertIsNone(result)
def test_type_set_new_encryption_without_provider(self): def test_type_set_new_encryption_without_provider(self):
self.encryption_types_mock.update.side_effect = exceptions.NotFound( self.volume_encryption_types_mock.update.side_effect = (
'NotFound' exceptions.NotFound('NotFound')
) )
arglist = [ arglist = [
'--encryption-cipher', '--encryption-cipher',
@ -676,24 +654,29 @@ class TestTypeSet(TestType):
('volume_type', self.volume_type.id), ('volume_type', self.volume_type.id),
] ]
parsed_args = self.check_parser(self.cmd, arglist, verifylist) parsed_args = self.check_parser(self.cmd, arglist, verifylist)
try:
self.cmd.take_action(parsed_args) exc = self.assertRaises(
self.fail('CommandError should be raised.') exceptions.CommandError,
except exceptions.CommandError as e: self.cmd.take_action,
self.assertEqual( parsed_args,
"Command Failed: One or more of" " the operations failed", )
str(e), self.assertEqual(
) "Command Failed: One or more of the operations failed",
str(exc),
)
self.volume_type.set_keys.assert_not_called()
self.volume_type_access_mock.add_project_access.assert_not_called()
body = { body = {
'cipher': 'aes-xts-plain64', 'cipher': 'aes-xts-plain64',
'key_size': 128, 'key_size': 128,
'control_location': 'front-end', 'control_location': 'front-end',
} }
self.encryption_types_mock.update.assert_called_with( self.volume_encryption_types_mock.update.assert_called_with(
self.volume_type, self.volume_type,
body, body,
) )
self.encryption_types_mock.create.assert_not_called() self.volume_encryption_types_mock.create.assert_not_called()
class TestTypeShow(TestType): class TestTypeShow(TestType):
@ -719,7 +702,7 @@ class TestTypeShow(TestType):
format_columns.DictColumn(self.volume_type.extra_specs), format_columns.DictColumn(self.volume_type.extra_specs),
) )
self.types_mock.get.return_value = self.volume_type self.volume_types_mock.get.return_value = self.volume_type
# Get the command object to test # Get the command object to test
self.cmd = volume_type.ShowVolumeType(self.app, None) self.cmd = volume_type.ShowVolumeType(self.app, None)
@ -733,7 +716,7 @@ class TestTypeShow(TestType):
parsed_args = self.check_parser(self.cmd, arglist, verifylist) parsed_args = self.check_parser(self.cmd, arglist, verifylist)
columns, data = self.cmd.take_action(parsed_args) columns, data = self.cmd.take_action(parsed_args)
self.types_mock.get.assert_called_with(self.volume_type.id) self.volume_types_mock.get.assert_called_with(self.volume_type.id)
self.assertEqual(self.columns, columns) self.assertEqual(self.columns, columns)
self.assertCountEqual(self.data, data) self.assertCountEqual(self.data, data)
@ -748,20 +731,20 @@ class TestTypeShow(TestType):
) )
type_access_list = volume_fakes.create_one_type_access() type_access_list = volume_fakes.create_one_type_access()
with mock.patch.object( with mock.patch.object(
self.types_mock, self.volume_types_mock,
'get', 'get',
return_value=private_type, return_value=private_type,
): ):
with mock.patch.object( with mock.patch.object(
self.types_access_mock, self.volume_type_access_mock,
'list', 'list',
return_value=[type_access_list], return_value=[type_access_list],
): ):
columns, data = self.cmd.take_action(parsed_args) columns, data = self.cmd.take_action(parsed_args)
self.types_mock.get.assert_called_once_with( self.volume_types_mock.get.assert_called_once_with(
self.volume_type.id self.volume_type.id
) )
self.types_access_mock.list.assert_called_once_with( self.volume_type_access_mock.list.assert_called_once_with(
private_type.id private_type.id
) )
@ -785,16 +768,16 @@ class TestTypeShow(TestType):
attrs={'is_public': False}, attrs={'is_public': False},
) )
with mock.patch.object( with mock.patch.object(
self.types_mock, 'get', return_value=private_type self.volume_types_mock, 'get', return_value=private_type
): ):
with mock.patch.object( with mock.patch.object(
self.types_access_mock, 'list', side_effect=Exception() self.volume_type_access_mock, 'list', side_effect=Exception()
): ):
columns, data = self.cmd.take_action(parsed_args) columns, data = self.cmd.take_action(parsed_args)
self.types_mock.get.assert_called_once_with( self.volume_types_mock.get.assert_called_once_with(
self.volume_type.id self.volume_type.id
) )
self.types_access_mock.list.assert_called_once_with( self.volume_type_access_mock.list.assert_called_once_with(
private_type.id private_type.id
) )
@ -820,8 +803,8 @@ class TestTypeShow(TestType):
self.volume_type = volume_fakes.create_one_volume_type( self.volume_type = volume_fakes.create_one_volume_type(
attrs={'encryption': encryption_info}, attrs={'encryption': encryption_info},
) )
self.types_mock.get.return_value = self.volume_type self.volume_types_mock.get.return_value = self.volume_type
self.encryption_types_mock.get.return_value = encryption_type self.volume_encryption_types_mock.get.return_value = encryption_type
encryption_columns = ( encryption_columns = (
'access_project_ids', 'access_project_ids',
'description', 'description',
@ -848,8 +831,10 @@ class TestTypeShow(TestType):
parsed_args = self.check_parser(self.cmd, arglist, verifylist) parsed_args = self.check_parser(self.cmd, arglist, verifylist)
columns, data = self.cmd.take_action(parsed_args) columns, data = self.cmd.take_action(parsed_args)
self.types_mock.get.assert_called_with(self.volume_type.id) self.volume_types_mock.get.assert_called_with(self.volume_type.id)
self.encryption_types_mock.get.assert_called_with(self.volume_type.id) self.volume_encryption_types_mock.get.assert_called_with(
self.volume_type.id
)
self.assertEqual(encryption_columns, columns) self.assertEqual(encryption_columns, columns)
self.assertCountEqual(encryption_data, data) self.assertCountEqual(encryption_data, data)
@ -863,7 +848,7 @@ class TestTypeUnset(TestType):
def setUp(self): def setUp(self):
super().setUp() super().setUp()
self.types_mock.get.return_value = self.volume_type self.volume_types_mock.get.return_value = self.volume_type
# Return a project # Return a project
self.projects_mock.get.return_value = self.project self.projects_mock.get.return_value = self.project
@ -907,7 +892,7 @@ class TestTypeUnset(TestType):
result = self.cmd.take_action(parsed_args) result = self.cmd.take_action(parsed_args)
self.assertIsNone(result) self.assertIsNone(result)
self.types_access_mock.remove_project_access.assert_called_with( self.volume_type_access_mock.remove_project_access.assert_called_with(
self.volume_type.id, self.volume_type.id,
self.project.id, self.project.id,
) )
@ -928,8 +913,10 @@ class TestTypeUnset(TestType):
result = self.cmd.take_action(parsed_args) result = self.cmd.take_action(parsed_args)
self.assertIsNone(result) self.assertIsNone(result)
self.encryption_types_mock.delete.assert_not_called() self.volume_encryption_types_mock.delete.assert_not_called()
self.assertFalse(self.types_access_mock.remove_project_access.called) self.assertFalse(
self.volume_type_access_mock.remove_project_access.called
)
def test_type_unset_failed_with_missing_volume_type_argument(self): def test_type_unset_failed_with_missing_volume_type_argument(self):
arglist = [ arglist = [
@ -960,7 +947,9 @@ class TestTypeUnset(TestType):
parsed_args = self.check_parser(self.cmd, arglist, verifylist) parsed_args = self.check_parser(self.cmd, arglist, verifylist)
result = self.cmd.take_action(parsed_args) result = self.cmd.take_action(parsed_args)
self.encryption_types_mock.delete.assert_called_with(self.volume_type) self.volume_encryption_types_mock.delete.assert_called_with(
self.volume_type
)
self.assertIsNone(result) self.assertIsNone(result)

View File

@ -327,7 +327,9 @@ class ListVolumeType(command.Lister):
help=_('List the default volume type'), help=_('List the default volume type'),
) )
public_group.add_argument( public_group.add_argument(
"--public", action="store_true", help=_("List only public types") "--public",
action="store_true",
help=_("List only public types"),
) )
public_group.add_argument( public_group.add_argument(
"--private", "--private",
@ -447,6 +449,21 @@ class SetVolumeType(command.Command):
'(admin only)' '(admin only)'
), ),
) )
public_group = parser.add_mutually_exclusive_group()
public_group.add_argument(
'--public',
action='store_true',
dest='is_public',
default=None,
help=_('Volume type is accessible to the public'),
)
public_group.add_argument(
'--private',
action='store_false',
dest='is_public',
default=None,
help=_("Volume type is not accessible to the public"),
)
identity_common.add_project_domain_option_to_parser(parser) identity_common.add_project_domain_option_to_parser(parser)
# TODO(Huanxuan Ao): Add choices for each "--encryption-*" option. # TODO(Huanxuan Ao): Add choices for each "--encryption-*" option.
parser.add_argument( parser.add_argument(
@ -500,15 +517,22 @@ class SetVolumeType(command.Command):
identity_client = self.app.client_manager.identity identity_client = self.app.client_manager.identity
volume_type = utils.find_resource( volume_type = utils.find_resource(
volume_client.volume_types, parsed_args.volume_type volume_client.volume_types,
parsed_args.volume_type,
) )
result = 0 result = 0
kwargs = {} kwargs = {}
if parsed_args.name: if parsed_args.name:
kwargs['name'] = parsed_args.name kwargs['name'] = parsed_args.name
if parsed_args.description: if parsed_args.description:
kwargs['description'] = parsed_args.description kwargs['description'] = parsed_args.description
if parsed_args.is_public is not None:
kwargs['is_public'] = parsed_args.is_public
if kwargs: if kwargs:
try: try:
volume_client.volume_types.update(volume_type.id, **kwargs) volume_client.volume_types.update(volume_type.id, **kwargs)

View File

@ -0,0 +1,5 @@
---
features:
- |
The ``volume type set`` command now supports ``--public`` and ``--private``
options.