Add datastore-show to OSC
This change adds database support to the python-openstackclient project for the datastore-show command. The trove command datastore-show is now: openstack datastore show Change-Id: I126493627d6b7fdf60e5d605dd64cfb3fbead10e Partially-Implements: trove-support-in-python-openstackclient
This commit is contained in:
parent
7e14c4f2b0
commit
2db7bf24e4
|
@ -0,0 +1,4 @@
|
||||||
|
---
|
||||||
|
features:
|
||||||
|
- The command ``trove datastore-show`` is now available to use in
|
||||||
|
the python-openstackclient CLI as ``openstack datastore show``
|
|
@ -39,6 +39,7 @@ openstack.database.v1 =
|
||||||
database_list = troveclient.osc.v1.databases:ListDatabases
|
database_list = troveclient.osc.v1.databases:ListDatabases
|
||||||
database_user_list = troveclient.osc.v1.database_users:ListDatabaseUsers
|
database_user_list = troveclient.osc.v1.database_users:ListDatabaseUsers
|
||||||
datastore_list = troveclient.osc.v1.datastores:ListDatastores
|
datastore_list = troveclient.osc.v1.datastores:ListDatastores
|
||||||
|
datastore_show = troveclient.osc.v1.datastores:ShowDatastore
|
||||||
|
|
||||||
|
|
||||||
[build_sphinx]
|
[build_sphinx]
|
||||||
|
|
|
@ -14,10 +14,26 @@
|
||||||
|
|
||||||
from osc_lib.command import command
|
from osc_lib.command import command
|
||||||
from osc_lib import utils
|
from osc_lib import utils
|
||||||
|
import six
|
||||||
|
|
||||||
from troveclient.i18n import _
|
from troveclient.i18n import _
|
||||||
|
|
||||||
|
|
||||||
|
def set_attributes_for_print_detail(datastore):
|
||||||
|
info = datastore._info.copy()
|
||||||
|
versions = info.get('versions', [])
|
||||||
|
versions_str = "\n".join(
|
||||||
|
[ver['name'] + " (" + ver['id'] + ")" for ver in versions])
|
||||||
|
info['versions (id)'] = versions_str
|
||||||
|
info.pop('versions', None)
|
||||||
|
info.pop('links', None)
|
||||||
|
if hasattr(datastore, 'default_version'):
|
||||||
|
def_ver_id = getattr(datastore, 'default_version')
|
||||||
|
info['default_version'] = [
|
||||||
|
ver['name'] for ver in versions if ver['id'] == def_ver_id][0]
|
||||||
|
return info
|
||||||
|
|
||||||
|
|
||||||
class ListDatastores(command.Lister):
|
class ListDatastores(command.Lister):
|
||||||
|
|
||||||
_description = _("List available datastores")
|
_description = _("List available datastores")
|
||||||
|
@ -28,3 +44,23 @@ class ListDatastores(command.Lister):
|
||||||
datastores = datastore_client.list()
|
datastores = datastore_client.list()
|
||||||
ds = [utils.get_item_properties(d, self.columns) for d in datastores]
|
ds = [utils.get_item_properties(d, self.columns) for d in datastores]
|
||||||
return self.columns, ds
|
return self.columns, ds
|
||||||
|
|
||||||
|
|
||||||
|
class ShowDatastore(command.ShowOne):
|
||||||
|
_description = _("Shows details of a datastore")
|
||||||
|
|
||||||
|
def get_parser(self, prog_name):
|
||||||
|
parser = super(ShowDatastore, self).get_parser(prog_name)
|
||||||
|
parser.add_argument(
|
||||||
|
'datastore',
|
||||||
|
metavar='<datastore>',
|
||||||
|
help=_('ID of the datastore'),
|
||||||
|
)
|
||||||
|
return parser
|
||||||
|
|
||||||
|
def take_action(self, parsed_args):
|
||||||
|
datastore_client = self.app.client_manager.database.datastores
|
||||||
|
datastore = utils.find_resource(datastore_client,
|
||||||
|
parsed_args.datastore)
|
||||||
|
datastore = set_attributes_for_print_detail(datastore)
|
||||||
|
return zip(*sorted(six.iteritems(datastore)))
|
||||||
|
|
|
@ -39,3 +39,27 @@ class TestDatastoreList(TestDatastores):
|
||||||
self.datastore_client.list.assert_called_once_with()
|
self.datastore_client.list.assert_called_once_with()
|
||||||
self.assertEqual(self.columns, columns)
|
self.assertEqual(self.columns, columns)
|
||||||
self.assertEqual([self.values], data)
|
self.assertEqual([self.values], data)
|
||||||
|
|
||||||
|
|
||||||
|
class TestDatastoreShow(TestDatastores):
|
||||||
|
|
||||||
|
values = ('5.6', 'd-123', 'mysql', '5.6 (v-56)')
|
||||||
|
|
||||||
|
def setUp(self):
|
||||||
|
super(TestDatastoreShow, self).setUp()
|
||||||
|
self.cmd = datastores.ShowDatastore(self.app, None)
|
||||||
|
self.data = self.fake_datastores.get_datastores_d_123()
|
||||||
|
self.datastore_client.get.return_value = self.data
|
||||||
|
self.columns = (
|
||||||
|
'default_version',
|
||||||
|
'id',
|
||||||
|
'name',
|
||||||
|
'versions (id)',
|
||||||
|
)
|
||||||
|
|
||||||
|
def test_show(self):
|
||||||
|
args = ['mysql']
|
||||||
|
parsed_args = self.check_parser(self.cmd, args, [])
|
||||||
|
columns, data = self.cmd.take_action(parsed_args)
|
||||||
|
self.assertEqual(self.columns, columns)
|
||||||
|
self.assertEqual(self.values, data)
|
||||||
|
|
Loading…
Reference in New Issue