Block Device Driver: report pools in volume stats

Block Device Driver doesn't support pools so it will
report only one pool like LVM implementation.

Change-Id: I7be456c8076c672586a9b9b6aa5425d3a1476b19
Closes-Bug: #1592980
This commit is contained in:
Ivan Kolodyazhny 2016-06-16 00:02:57 +03:00
parent caee4d0459
commit 948ac4ab45
3 changed files with 37 additions and 23 deletions

View File

@ -153,16 +153,18 @@ class TestBlockDeviceDriver(cinder.test.TestCase):
gud_mocked: gud_mocked:
self.drv._update_volume_stats() self.drv._update_volume_stats()
self.assertEqual({'total_capacity_gb': 2, reserved_percentage = self.configuration.reserved_percentage
'free_capacity_gb': 2, self.assertEqual({
'reserved_percentage': 'vendor_name': "Open Source",
self.configuration.reserved_percentage, 'driver_version': self.drv.VERSION,
'QoS_support': False, 'volume_backend_name': 'BlockDev',
'vendor_name': "Open Source", 'storage_protocol': 'unknown',
'driver_version': self.drv.VERSION, 'pools': [{
'storage_protocol': 'unknown', 'QoS_support': False,
'volume_backend_name': 'BlockDeviceDriver', 'total_capacity_gb': 2,
}, self.drv._stats) 'free_capacity_gb': 2,
'reserved_percentage': reserved_percentage,
'pool_name': 'BlockDev'}]}, self.drv._stats)
gud_mocked.assert_called_once_with() gud_mocked.assert_called_once_with()
ds_mocked.assert_called_once_with() ds_mocked.assert_called_once_with()

View File

@ -44,7 +44,7 @@ CONF.register_opts(volume_opts)
class BlockDeviceDriver(driver.BaseVD, driver.LocalVD, class BlockDeviceDriver(driver.BaseVD, driver.LocalVD,
driver.CloneableImageVD, driver.TransferVD): driver.CloneableImageVD, driver.TransferVD):
VERSION = '2.2.0' VERSION = '2.3.0'
def __init__(self, *args, **kwargs): def __init__(self, *args, **kwargs):
super(BlockDeviceDriver, self).__init__(*args, **kwargs) super(BlockDeviceDriver, self).__init__(*args, **kwargs)
@ -62,12 +62,13 @@ class BlockDeviceDriver(driver.BaseVD, driver.LocalVD,
def check_for_setup_error(self): def check_for_setup_error(self):
pass pass
def _update_provider_location(self, object, device): def _update_provider_location(self, obj, device):
# We update provider_location and host to mark device as used to # We update provider_location and host to mark device as used to
# avoid race with other threads. # avoid race with other threads.
# TODO(ynesenenko): need to remove DB access from driver # TODO(ynesenenko): need to remove DB access from driver
object.update({'provider_location': device, 'host': self.host}) host = '{host}#{pool}'.format(host=self.host, pool=self.get_pool(obj))
object.save() obj.update({'provider_location': device, 'host': host})
obj.save()
@utils.synchronized('block_device', external=True) @utils.synchronized('block_device', external=True)
def create_volume(self, volume): def create_volume(self, volume):
@ -153,18 +154,26 @@ class BlockDeviceDriver(driver.BaseVD, driver.LocalVD,
total_size += size total_size += size
LOG.debug("Updating volume stats.") LOG.debug("Updating volume stats.")
backend_name = self.configuration.safe_get('volume_backend_name') data = {
data = {'total_capacity_gb': total_size / units.Ki, 'volume_backend_name': self.backend_name,
'free_capacity_gb': free_size / units.Ki, 'vendor_name': "Open Source",
'reserved_percentage': self.configuration.reserved_percentage, 'driver_version': self.VERSION,
'QoS_support': False, 'storage_protocol': 'unknown',
'volume_backend_name': backend_name or self.__class__.__name__, 'pools': []}
'vendor_name': "Open Source",
'driver_version': self.VERSION,
'storage_protocol': 'unknown'}
single_pool = {
'pool_name': data['volume_backend_name'],
'total_capacity_gb': total_size / units.Ki,
'free_capacity_gb': free_size / units.Ki,
'reserved_percentage': self.configuration.reserved_percentage,
'QoS_support': False}
data['pools'].append(single_pool)
self._stats = data self._stats = data
def get_pool(self, volume):
return self.backend_name
def _get_used_paths(self, lst): def _get_used_paths(self, lst):
used_dev = set() used_dev = set()
for item in lst: for item in lst:

View File

@ -0,0 +1,3 @@
---
features:
- Report pools in volume stats for Block Device Driver.