summaryrefslogtreecommitdiff
path: root/openstackclient
diff options
context:
space:
mode:
authorJenkins <jenkins@review.openstack.org>2016-04-15 21:01:10 +0000
committerGerrit Code Review <review@openstack.org>2016-04-15 21:01:10 +0000
commite80048de09044adad3ad7bd8d323b025856bf94e (patch)
treee4aab852cb7014d4da4edbda4e1a8dd2ab40f4df /openstackclient
parentf66f989d83cdd067acb811e9c9a3f9923483ba35 (diff)
parente12837067698062ce3fea89dd543f1cab39866c1 (diff)
downloadpython-openstackclient-e80048de09044adad3ad7bd8d323b025856bf94e.tar.gz
Merge "Fix wrong attribute name and add functional test for --snapshot"
Diffstat (limited to 'openstackclient')
-rw-r--r--openstackclient/tests/volume/v2/test_volume.py43
1 files changed, 43 insertions, 0 deletions
diff --git a/openstackclient/tests/volume/v2/test_volume.py b/openstackclient/tests/volume/v2/test_volume.py
index 12253806..e4ac7c10 100644
--- a/openstackclient/tests/volume/v2/test_volume.py
+++ b/openstackclient/tests/volume/v2/test_volume.py
@@ -14,6 +14,7 @@
import copy
+import mock
from mock import call
from openstackclient.common import utils
@@ -40,6 +41,9 @@ class TestVolume(volume_fakes.TestVolume):
self.images_mock = self.app.client_manager.image.images
self.images_mock.reset_mock()
+ self.snapshots_mock = self.app.client_manager.volume.volume_snapshots
+ self.snapshots_mock.reset_mock()
+
def setup_volumes_mock(self, count):
volumes = volume_fakes.FakeVolume.create_volumes(count=count)
@@ -376,6 +380,45 @@ class TestVolumeCreate(TestVolume):
self.assertEqual(self.columns, columns)
self.assertEqual(self.datalist, data)
+ def test_volume_create_with_snapshot(self):
+ arglist = [
+ '--size', str(self.new_volume.size),
+ '--snapshot', volume_fakes.snapshot_id,
+ self.new_volume.name,
+ ]
+ verifylist = [
+ ('size', self.new_volume.size),
+ ('snapshot', volume_fakes.snapshot_id),
+ ('name', self.new_volume.name),
+ ]
+ parsed_args = self.check_parser(self.cmd, arglist, verifylist)
+
+ fake_snapshot = mock.Mock()
+ fake_snapshot.id = volume_fakes.snapshot_id
+ self.snapshots_mock.get.return_value = fake_snapshot
+
+ # In base command class ShowOne in cliff, abstract method take_action()
+ # returns a two-part tuple with a tuple of column names and a tuple of
+ # data to be shown.
+ columns, data = self.cmd.take_action(parsed_args)
+
+ self.volumes_mock.create.assert_called_once_with(
+ size=self.new_volume.size,
+ snapshot_id=fake_snapshot.id,
+ name=self.new_volume.name,
+ description=None,
+ volume_type=None,
+ user_id=None,
+ project_id=None,
+ availability_zone=None,
+ metadata=None,
+ imageRef=None,
+ source_volid=None
+ )
+
+ self.assertEqual(self.columns, columns)
+ self.assertEqual(self.datalist, data)
+
class TestVolumeDelete(TestVolume):