Merge "Fix creating volume by snapshot for GPFS driver"

This commit is contained in:
Jenkins 2015-12-31 20:06:47 +00:00 committed by Gerrit Code Review
commit 0e38f5c78a
2 changed files with 11 additions and 6 deletions

View File

@ -855,6 +855,9 @@ class GPFSDriverTestCase(test.TestCase):
mock_resize_volume_file.return_value = 5 * units.Gi mock_resize_volume_file.return_value = 5 * units.Gi
volume = self._fake_volume() volume = self._fake_volume()
volume['consistencygroup_id'] = None volume['consistencygroup_id'] = None
self.driver.db = mock.Mock()
self.driver.db.volume_get = mock.Mock()
self.driver.db.volume_get.return_value = volume
snapshot = self._fake_snapshot() snapshot = self._fake_snapshot()
mock_snapshot_path.return_value = "/tmp/fakepath" mock_snapshot_path.return_value = "/tmp/fakepath"
self.assertEqual({'size': 5.0}, self.assertEqual({'size': 5.0},
@ -885,6 +888,9 @@ class GPFSDriverTestCase(test.TestCase):
mock_resize_volume_file.return_value = 5 * units.Gi mock_resize_volume_file.return_value = 5 * units.Gi
volume = self._fake_volume() volume = self._fake_volume()
volume['consistencygroup_id'] = None volume['consistencygroup_id'] = None
self.driver.db = mock.Mock()
self.driver.db.volume_get = mock.Mock()
self.driver.db.volume_get.return_value = volume
snapshot = self._fake_snapshot() snapshot = self._fake_snapshot()
mock_snapshot_path.return_value = "/tmp/fakepath" mock_snapshot_path.return_value = "/tmp/fakepath"
mock_set_volume_attributes.return_value = True mock_set_volume_attributes.return_value = True

View File

@ -542,7 +542,6 @@ class GPFSDriver(driver.ConsistencyGroupVD, driver.ExtendVD,
# check if the snapshot lies in the same CG as the volume to be created # check if the snapshot lies in the same CG as the volume to be created
# if yes, clone the volume from the snapshot, else perform full copy # if yes, clone the volume from the snapshot, else perform full copy
clone = False clone = False
if volume['consistencygroup_id'] is not None:
ctxt = context.get_admin_context() ctxt = context.get_admin_context()
snap_parent_vol = self.db.volume_get(ctxt, snapshot['volume_id']) snap_parent_vol = self.db.volume_get(ctxt, snapshot['volume_id'])
if (volume['consistencygroup_id'] == if (volume['consistencygroup_id'] ==